[
    {
        "tags": [
            "json",
            "command-line",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1575227014,
                "creation_date": 1575227014,
                "answer_id": 59128911,
                "question_id": 59128837,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming `Resource` can either be of type `string` or `array`\r\n```\r\n.Statement[].Resource | if type == &quot;array&quot; then length else 1 end\r\n```\r\nwill output\r\n```\r\n1\r\n3\r\n```",
                "title": "I need a reliable method to count the nbr of Resources"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1575227374,
                "last_edit_date": 1575227374,
                "creation_date": 1575227297,
                "answer_id": 59128955,
                "question_id": 59128837,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can convert the `Resource` section to an array, flatten() it, then pipe it out to length() to get the correct number of elements.\r\n\r\n```\r\n$ cat api_return.json | jq &#39;[.Statement[0].Resource] | flatten | length&#39;\r\n1\r\n```",
                "title": "I need a reliable method to count the nbr of Resources"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1575255072,
                "creation_date": 1575255072,
                "answer_id": 59132050,
                "question_id": 59128837,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For the total count of resources, wherever they are specified, you might like to consider:\r\n```\r\ndef sigma(s): reduce s as $x (0; .+$x);\r\n\r\nsigma(.. | objects | select(.Resource).Resource\r\n      | if type == &quot;array&quot; then length else 1 end)\r\n```",
                "title": "I need a reliable method to count the nbr of Resources"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1575267900,
        "creation_date": 1575226435,
        "last_edit_date": 1575267900,
        "question_id": 59128837,
        "body_markdown": "I have the following JSON that comes back from an API:\r\n\r\n    {\r\n\t&quot;Statement&quot;: [{\r\n\t\t\t&quot;Sid&quot;: &quot;Group1&quot;,\r\n\t\t\t&quot;Resource&quot;: &quot;arn:aws:ecs:*:777744445555:task-rendition/${aws:PrincipalTag/Service}-*:*&quot;,\r\n\t\t\t&quot;Effect&quot;: &quot;Allow&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Sid&quot;: &quot;Group2&quot;,\r\n\t\t\t&quot;Resource&quot;: [\r\n\t\t\t\t&quot;arn:aws:ecs:*:777744445555:task-definition/${aws:PrincipalTag/Service}-*:*&quot;,\r\n\t\t\t\t&quot;arn:aws:ecs:*:777744445555:task-petition/${aws:PrincipalTag/Service}-*:*&quot;,\r\n\t\t\t\t&quot;arn:aws:ecs:*:777744445555:task-fruition/${aws:PrincipalTag/Service}-*:*&quot;\r\n\t\t\t],\r\n\t\t\t&quot;Effect&quot;: &quot;Allow&quot;\r\n\t\t}\r\n\r\n\t]}\r\n\r\nWhen I apply these commands I get unreliable results:\r\n\r\n.Statement[0].Resource | length   --&gt;  73 incorrect &lt;/br&gt;\r\n.Statement[1].Resource | length   --&gt;  3 correct &lt;/br&gt;\r\n\r\nThe first command produces the number equal to the number of characters in that string, which is not what I need.  How can I achieve the 1 and 3 in a more certain way?\r\n\r\nMy context is bash shell script on CentOS 7 and jq 1.5\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59128837/i-need-a-reliable-method-to-count-the-nbr-of-resources",
        "title": "I need a reliable method to count the nbr of Resources"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1575353842,
                "post_id": 59150845,
                "comment_id": 104527425,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1575389638,
                "last_edit_date": 1575389638,
                "creation_date": 1575354115,
                "answer_id": 59151219,
                "question_id": 59150845,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Note: The following assumes that the data shown in the Q have been corrected so that they are valid JSON.]\r\n\r\nThe merging you want can be achieved by object addition (`x + y`).  For example, given the two JSON objects as shown in the question (i.e., as a stream), you could write:\r\n\r\n    jq -s &#39;.[0] + .[1]&#39;\r\n\r\nHowever, since the question also indicates these objects are actually in an array, let&#39;s next consider the case of an array with two objects.  In that case, you could simply write:\r\n\r\n    jq add\r\n\r\nFinally, if you have an array of arrays each of which is an array of objects, you could use `map(add)`. Since you don&#39;t have a very large array, you could simply write:\r\n\r\n    group_by(.id) | map(add)\r\n\r\nPlease note that jq defines object addition in a non-commutative way.  Specifically, there is a bias towards the right-most key.\r\n ",
                "title": "Merge objects in same array on single key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1575389638,
        "creation_date": 1575351908,
        "last_edit_date": 1575386625,
        "question_id": 59150845,
        "body_markdown": "I have an array of JSON objects formatted as follows:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;names&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Bulbasaur&quot;,\r\n        &quot;language&quot;: {\r\n          &quot;name&quot;: &quot;en&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/language/9/&quot;\r\n        }\r\n      },\r\n    ],\r\n  },\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;types&quot;: [\r\n      {\r\n        &quot;slot&quot;: 1,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;grass&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/12/&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;slot&quot;: 2,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;poison&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/4/&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;names&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Ivysaur&quot;,\r\n        &quot;language&quot;: {\r\n          &quot;name&quot;: &quot;en&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/language/9/&quot;\r\n        }\r\n      },\r\n    ],\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;types&quot;: [\r\n      {\r\n        &quot;slot&quot;: 1,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;ice&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/10/&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;slot&quot;: 2,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;electric&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/8/&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;names&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Venusaur&quot;,\r\n        &quot;language&quot;: {\r\n          &quot;name&quot;: &quot;en&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/language/9/&quot;\r\n        }\r\n      },\r\n    ],\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;types&quot;: [\r\n      {\r\n        &quot;slot&quot;: 1,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;ground&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/2/&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;slot&quot;: 2,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;rock&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/3/&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nNote that these are pairs of separate objects that appear sequentially in a JSON array, with each pair sharing an `id` field. This pattern repeats several hundred times in the array. What I need to accomplish is to &quot;merge&quot; each `id`-sharing pair into one object. So, the resultant output would be\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;names&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Bulbasaur&quot;,\r\n        &quot;language&quot;: {\r\n          &quot;name&quot;: &quot;en&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/language/9/&quot;\r\n        }\r\n      },\r\n    ],\r\n    &quot;types&quot;: [\r\n      {\r\n        &quot;slot&quot;: 1,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;grass&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/12/&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;slot&quot;: 2,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;poison&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/4/&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;names&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Ivysaur&quot;,\r\n        &quot;language&quot;: {\r\n          &quot;name&quot;: &quot;en&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/language/9/&quot;\r\n        }\r\n      },\r\n    ],\r\n    &quot;types&quot;: [\r\n      {\r\n        &quot;slot&quot;: 1,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;ice&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/10/&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;slot&quot;: 2,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;electric&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/8/&quot;\r\n        }\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;names&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;Venusaur&quot;,\r\n        &quot;language&quot;: {\r\n          &quot;name&quot;: &quot;en&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/language/9/&quot;\r\n        }\r\n      },\r\n    ],\r\n    &quot;types&quot;: [\r\n      {\r\n        &quot;slot&quot;: 1,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;ground&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/2/&quot;\r\n        }\r\n      },\r\n      {\r\n        &quot;slot&quot;: 2,\r\n        &quot;type&quot;: {\r\n          &quot;name&quot;: &quot;rock&quot;,\r\n          &quot;url&quot;: &quot;http://myserver.com:8000/api/v2/type/3/&quot;\r\n        }\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI&#39;ve gotten these objects to appear next to each other via the `group_by(.id)` command, but I&#39;m at a loss as to how I should actually combine them. I&#39;m very much still a novice with `jq` so I&#39;m a bit overwhelmed with the amount of possible solutions.\r\n",
        "link": "https://stackoverflow.com/questions/59150845/merge-objects-in-same-array-on-single-key",
        "title": "Merge objects in same array on single key"
    },
    {
        "tags": [
            "json",
            "shell",
            "insert",
            "addition",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575359931,
                "post_id": 59152473,
                "comment_id": 104529690,
                "content_license": "CC BY-SA 4.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": 1575360026,
                "post_id": 59152473,
                "comment_id": 104529731,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17227199,
                    "reputation": 3,
                    "user_id": 12472553,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c600d82b338fb4ae207125409dcc67d0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Noctibia",
                    "link": "https://stackoverflow.com/users/12472553/noctibia"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575362487,
                "post_id": 59152473,
                "comment_id": 104530662,
                "content_license": "CC BY-SA 4.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": 1575363008,
                "post_id": 59152473,
                "comment_id": 104530927,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17227199,
                    "reputation": 3,
                    "user_id": 12472553,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c600d82b338fb4ae207125409dcc67d0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Noctibia",
                    "link": "https://stackoverflow.com/users/12472553/noctibia"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575364213,
                "post_id": 59152473,
                "comment_id": 104531563,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1575362965,
                "last_edit_date": 1575362965,
                "creation_date": 1575360321,
                "answer_id": 59152566,
                "question_id": 59152473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One approach (after ensuring the data is valid JSON) would be to specify the path to the empty array explicitly:\r\n```\r\njq --argfile insert devices_format.json &#39;\r\n  .drivers.lorawan.interfaces[0].devices |= [$insert]\r\n  &#39; test_3.json\r\n```\r\n\r\n## Equivalently ...\r\n```\r\njq -n &#39;input as $insert\r\n       | input \r\n       | .drivers.lorawan.interfaces[0].devices |= [$insert]\r\n  &#39; devices_format.json test_3.json\r\n```",
                "title": "insert, the json of a file, in the empty array of a json of another file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1575363200,
                "last_edit_date": 1575363200,
                "creation_date": 1575361880,
                "answer_id": 59152934,
                "question_id": 59152473,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want every .devices array that&#39;s empty to be replaced by the specified JSON, you could go with `walk/1`, e.g.:\r\n```\r\njq -n &#39;input as $insert\r\n       | input\r\n       | walk(if type==&quot;object&quot; and .devices == [] \r\n              then .devices = [$insert] \r\n              else . end)\r\n  &#39; devices_format.json test_3.json\r\n``` ",
                "title": "insert, the json of a file, in the empty array of a json of another file"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1575363200,
        "creation_date": 1575359838,
        "last_edit_date": 1575361597,
        "question_id": 59152473,
        "body_markdown": "I would like to insert this piece of code from the devices_format.json file\r\n\r\n```\r\n{\r\n  &quot;devices&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;new_elsys&quot;,\r\n      &quot;objects&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;ServerRoomTemp&quot;,\r\n          &quot;datapoint_type&quot;: &quot;measurement&quot;,\r\n          &quot;coder_field&quot;: &quot;temperature&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;old_elsys&quot;,\r\n      &quot;objects&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;ServerRoomTemp&quot;,\r\n          &quot;datapoint_type&quot;: &quot;measurement&quot;,\r\n          &quot;coder_field&quot;: &quot;temperature&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\nin the empty array of test_3.json\r\n\r\n```\r\n{\r\n  &quot;drivers&quot;: {\r\n    &quot;lorawan&quot;: {\r\n      &quot;interfaces&quot;: [\r\n        {\r\n          &quot;devices&quot;: []\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n\r\n```\r\n\r\n\r\nThe result should look like this\r\n\r\n\r\n```\r\n{\r\n  &quot;drivers&quot;: {\r\n    &quot;lorawan&quot;: {\r\n      &quot;interfaces&quot;: [\r\n        {\r\n          &quot;devices&quot;: [\r\n           {\r\n             &quot;devices&quot;: [\r\n               {\r\n                 &quot;name&quot;: &quot;new_elsys&quot;,\r\n                 &quot;objects&quot;: [\r\n                   {\r\n                     &quot;name&quot;: &quot;ServerRoomTemp&quot;,\r\n                     &quot;datapoint_type&quot;: &quot;measurement&quot;,\r\n                     &quot;coder_field&quot;: &quot;temperature&quot;\r\n                   }\r\n                 ]\r\n               },\r\n               {\r\n                 &quot;name&quot;: &quot;old_elsys&quot;,\r\n                 &quot;objects&quot;: [\r\n                   {\r\n                     &quot;name&quot;: &quot;ServerRoomTemp&quot;,\r\n                     &quot;datapoint_type&quot;: &quot;measurement&quot;,\r\n                     &quot;coder_field&quot;: &quot;temperature&quot;\r\n                   }\r\n                 ]\r\n               }\r\n             ]\r\n           }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\nI tried using jq but I wanted to know if it was possible also with jshn\r\n\r\nI modified the post to make it clearer, thank you guys in advance and have a good day :P\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59152473/insert-the-json-of-a-file-in-the-empty-array-of-a-json-of-another-file",
        "title": "insert, the json of a file, in the empty array of a json of another file"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1575388532,
                "last_edit_date": 1575388532,
                "creation_date": 1575363024,
                "answer_id": 59153224,
                "question_id": 59153051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like this, works with jq &lt; 1.6 too:\r\n\r\n    &lt; payload.json.tpl jq --arg a &quot;${array[*]}&quot; &#39;.x.y=($a|split(&quot; &quot;))&#39;\r\n\r\nNote the use of `${array[*]}` instead of `${array[@]}`. When using `*`, the elements of `${array}` will be passed as a single string instead of multiple strings.\r\n\r\nhttps://www.gnu.org/software/bash/manual/html_node/Arrays.html",
                "title": "replace a key with array in bash"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1575367142,
                "last_edit_date": 1575367142,
                "creation_date": 1575364503,
                "answer_id": 59153665,
                "question_id": 59153051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `$ARGS.positional` (requires jq 1.6)\r\n```\r\n$ array=(&quot;one&quot; &quot;two&quot; &quot;three&quot;)\r\n$ jq &#39;.x.y = $ARGS.positional&#39; payload.json.tpl --args &quot;${array[@]}&quot;\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;x&quot;: {\r\n    &quot;y&quot;: [\r\n      &quot;one&quot;,\r\n      &quot;two&quot;,\r\n      &quot;three&quot;\r\n    ]\r\n  }\r\n}\r\n```",
                "title": "replace a key with array in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1607583062,
        "creation_date": 1575362367,
        "last_edit_date": 1607583062,
        "question_id": 59153051,
        "body_markdown": "Sample json file `payload.json.tpl`: \r\n\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;x&quot;: {\r\n    &quot;y&quot;: &quot;${array}&quot;\r\n  }\r\n}\r\n```\r\n\r\nI have an array in bash\r\n\r\n```\r\narray=(&quot;one&quot; &quot;two&quot; &quot;three&quot;)\r\n```\r\n\r\nHow can I run the jq command to replace the key `.x.y` to `[&quot;one&quot;, &quot;two&quot;, &quot;three&quot;]`\r\n\r\nSo the final json will be: \r\n```\r\n{\r\n  &quot;foo&quot;: &quot;bar&quot;,\r\n  &quot;x&quot;: {\r\n    &quot;y&quot;: [&quot;one&quot;, &quot;two&quot;, &quot;three&quot;]\r\n  }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/59153051/replace-a-key-with-array-in-bash",
        "title": "replace a key with array in bash"
    },
    {
        "tags": [
            "json",
            "linux",
            "parsing",
            "ubuntu",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1575364627,
                "post_id": 59153661,
                "comment_id": 104531797,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1575364650,
                "post_id": 59153661,
                "comment_id": 104531809,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13283893,
                    "reputation": 961,
                    "user_id": 9590601,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ec844af76da2968c57ded21a62a25b41?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rishab Prasad",
                    "link": "https://stackoverflow.com/users/9590601/rishab-prasad"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1575364679,
                "post_id": 59153661,
                "comment_id": 104531825,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1575364723,
                "post_id": 59153661,
                "comment_id": 104531861,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575364768,
                "post_id": 59153661,
                "comment_id": 104531884,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1575364859,
                "post_id": 59153661,
                "comment_id": 104531939,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13283893,
                    "reputation": 961,
                    "user_id": 9590601,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/ec844af76da2968c57ded21a62a25b41?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Rishab Prasad",
                    "link": "https://stackoverflow.com/users/9590601/rishab-prasad"
                },
                "reply_to_user": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575364877,
                "post_id": 59153661,
                "comment_id": 104531955,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1575365098,
                "creation_date": 1575365098,
                "answer_id": 59153835,
                "question_id": 59153661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a regular expression with `sed` if you know the accesss token never contains quotes.\r\n\r\n```\r\necho &#39;{&quot;access_token&quot;:&quot;XXXX&quot;&quot;expires_in&quot;:300&quot;token_type&quot;:&quot;Bearer&quot;}&#39; |\r\n    sed &#39;s/&quot;access_token&quot;:&quot;\\([^&quot;]*\\)/\\1/&#39;\r\n```\r\n\r\nThe capture group between `\\(` and `\\)` captures the string between the quotes, and `\\1` in the replacement string extracts it.",
                "title": "Parsing JSON String without separator using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1575384733,
                "creation_date": 1575384733,
                "answer_id": 59159750,
                "question_id": 59153661,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here are two just-jq solutions, each with its own degree of brittleness. The first one attempts to convert each entire input line into valid JSON:\r\n\r\n## Using `fromjson`\r\n```\r\necho &#39;{&quot;access_token&quot;:&quot;XXXX&quot;&quot;expires_in&quot;:300&quot;token_type&quot;:&quot;Bearer&quot;}&#39; |\r\njq -rR &#39;gsub(&quot;(?&lt;k&gt;\\&quot;[^\\&quot;]*\\&quot;)&quot;; &quot;,&quot; + .k )\r\n    | gsub(&quot;{,\\&quot;&quot;;&quot;{\\&quot;&quot;) | gsub(&quot;:,\\&quot;&quot;; &quot;:\\&quot;&quot;) \r\n    | fromjson | .access_token&#39;\r\nXXXX\r\n```\r\n\r\n### Assume the value is a string on the same line\r\n```\r\njq -rR &#39;sub(&quot;.*\\&quot;access_token\\&quot; *: *\\&quot;(?&lt;v&gt;[^\\&quot;]*)\\&quot;.*&quot;; .v )&#39;\r\n```\r\n\r\n\r\n",
                "title": "Parsing JSON String without separator using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1575384733,
        "creation_date": 1575364495,
        "last_edit_date": 1575367215,
        "question_id": 59153661,
        "body_markdown": "I have a JSON string without the separator `,`. How do I parse it using `jq`?\r\n\r\n    $echo &#39;{&quot;access_token&quot;:&quot;XXXX&quot;&quot;expires_in&quot;:300&quot;token_type&quot;:&quot;Bearer&quot;}&#39; | jq -r .access_token\r\n\r\nThe above line gives me the below error:\r\n\r\n    parse error: Expected separator between values at line 1\r\n\r\nI understand that the issue is because the JSON string provided is not comma-separated. But this is what I am getting as a response from the server. How do I parse such a string? I want to retrive the value for key `&quot;access_token&quot;`.\r\n",
        "link": "https://stackoverflow.com/questions/59153661/parsing-json-string-without-separator-using-jq",
        "title": "Parsing JSON String without separator using jq"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575395282,
                "post_id": 59162608,
                "comment_id": 104549676,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1575395937,
                "last_edit_date": 1575395937,
                "creation_date": 1575395406,
                "answer_id": 59162754,
                "question_id": 59162608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In your specific case I think you have a small bash quoting error causing `${branch}` to be treated as a constant. I think you want to quote it like this:\r\n\r\n```\r\n     &#39;.&quot;&#39;      &quot;${branch}&quot;         &#39;&quot; | .auth&#39;\r\n     ------    ------------------  -----------\r\n     single    double quote so     single\r\n     quote     shell expands the   quote\r\n     constant  branch variable     constant\r\n```\r\n\r\nSample Run\r\n```\r\n$ echo &#39;.&quot;&#39;&quot;${branch}&quot;&#39;&quot; | .auth&#39;\r\n.&quot;feature/EBS_DDS_SC-27428&quot; | .auth\r\n\r\n$ cat input.json | jq --raw-output &#39;.&quot;&#39;&quot;${branch}&quot;&#39;&quot; | .auth&#39;\r\nhttp://ab123:8080/service.jsp\r\n```\r\n\r\nThe variable substitution section of the [Advanced Bash Scripting Guide](http://tldp.org/LDP/abs/html/varsubn.html) is your friend.",
                "title": "jq select dynamic item where key is an environmental variable and not a bash variable"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1575414279,
                "creation_date": 1575414279,
                "answer_id": 59166712,
                "question_id": 59162608,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; I have an environmental variable called branch\r\n\r\nEnvironment variables (as opposed to shell variables) can be dereferenced in jq programs using the `env` object. In your case, you&#39;d write `env.branch`.\r\n\r\nIf you wanted to make the value of a variable accessible as `$branch` in the shell, it is best to use the --arg command-line option, along the lines of:\r\n\r\n    jq --arg branch &quot;$branch&quot;\r\n\r\nThat way, you can reference the value as `$branch` in the jq program. In the specific case of the Q, you could (for example) write:\r\n\r\n    jq -r &#39;.[$branch].auth&#39;\r\n",
                "title": "jq select dynamic item where key is an environmental variable and not a bash variable"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1575430244,
        "creation_date": 1575394862,
        "last_edit_date": 1575430244,
        "question_id": 59162608,
        "body_markdown": "I have the following json:\r\n\r\n```\r\n{\r\n\t&quot;feature/EBS_DDS_SC-27428&quot;: {\r\n\t\t&quot;auth&quot;: &quot;http://test123:8080/service.jsp&quot;,\r\n\t\t&quot;publish&quot;: &quot;http://test234:8080/service.jsp&quot;,\r\n\t\t&quot;general_name&quot;: &quot;PG&quot;\r\n\t},\r\n\t&quot;feature/EBS_DDS_SC-27428&quot;: {\r\n\t\t&quot;auth&quot;: &quot;http://ab123:8080/service.jsp&quot;,\r\n\t\t&quot;publish&quot;: &quot;http://ab234:8080/service.jsp&quot;,\r\n\t\t&quot;general_name&quot;: &quot;PG1&quot;\r\n\t}\r\n\r\n}\r\n```\r\nwhen I do the following I get the expected result\r\n```\r\njq --raw-output &#39;.&quot;feature/EBS_DDS_SC-27428&quot; | .auth&#39;\r\n```\r\n\r\nBut the following is not working,\r\n```\r\nexport branch=feature/EBS_DDS_SC-27428\r\ncat input.json | jq --raw-output &#39;.&quot;${branch}&quot; | .auth&#39;\r\n```\r\n\r\nI get the following compilation error:\r\n\r\n```\r\njq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.${branch} | .auth\r\njq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n.${branch} | .auth\r\njq: 2 compile errors\r\n```\r\n\r\n\r\n\r\n\r\nNow I have an environmental variable called `branch` in my Linux machine\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59162608/jq-select-dynamic-item-where-key-is-an-environmental-variable-and-not-a-bash-var",
        "title": "jq select dynamic item where key is an environmental variable and not a bash variable"
    },
    {
        "tags": [
            "jenkins",
            "jenkins-pipeline",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575409810,
                "post_id": 59164392,
                "comment_id": 104555579,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1575410477,
                "creation_date": 1575410477,
                "answer_id": 59166030,
                "question_id": 59164392,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `jq` command runs fine against the sample input - see [here][1] (if someone is trying it on their own, do not paste the single quotes `&#39;` in the Filter input line).\r\n\r\nThe whole external command is executed with `bat`, so it is on Windows...could you remove the `\\` characters and try? On Linux, `\\` continues the command on a new line (was it `^` on Windows?)...\r\n\r\n\r\n  [1]: https://jqplay.org/s/_YFZSU7wxQ",
                "title": "jq: select is not recognized as an internal or external command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1575410477,
        "creation_date": 1575402739,
        "last_edit_date": 1575409449,
        "question_id": 59164392,
        "body_markdown": "I am trying to using `jq` within Jenkins pipeline code, but it gives,\r\n\r\n    \r\n\r\n    stage(&#39;sad&#39;) {   \r\n        steps { \r\n          bat &quot;&quot;&quot;oc new-app abc/openshift-mysql:22 --output=json --dry-run=true | \\ jq &#39;.items[] | select(.kind == &quot;DeploymentConfig&quot;) | .spec.template.spec.containers[0].env +=\r\n             [{&quot;name&quot;:&quot;db_name&quot;,&quot;valueFrom&quot;:{&quot;secretKeyRef&quot;:{&quot;key&quot;:&quot;database-name&quot;,&quot;name&quot;:&quot;mysql&quot;}}},{&quot;name&quot;:&quot;db_username&quot;,&quot;valueFrom&quot;:{&quot;secretKeyRef&quot;:{&quot;key&quot;:&quot;database-user&quot;,&quot;name&quot;:&quot;mysql&quot;}}},{&quot;name&quot;:&quot;db_password&quot;,&quot;valueFrom&quot;:{&quot;secretKeyRef&quot;:{&quot;key&quot;:&quot;database-password&quot;,&quot;name&quot;:&quot;mysql&quot;}}}]&#39;\r\n           | \\ oc apply --filename -&quot;&quot;&quot;   \r\n         }   \r\n     }\r\n\r\n    &#39;select&#39; is not recognized as an internal or external command,\r\n\r\nSample JSON,\r\n\r\n    {\r\n      &quot;kind&quot;: &quot;List&quot;,\r\n      &quot;apiVersion&quot;: &quot;v1&quot;,\r\n      &quot;metadata&quot;: {\r\n        \r\n      },\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;kind&quot;: &quot;DeploymentConfig&quot;,\r\n          &quot;apiVersion&quot;: &quot;v1&quot;,\r\n          &quot;metadata&quot;: {\r\n            &quot;name&quot;: &quot;openshift-mysql&quot;,\r\n            &quot;creationTimestamp&quot;: null,\r\n            &quot;labels&quot;: {\r\n              &quot;app&quot;: &quot;openshift-mysql&quot;\r\n            },\r\n            &quot;annotations&quot;: {\r\n              &quot;openshift.io/generated-by&quot;: &quot;OpenShiftNewApp&quot;\r\n            }\r\n          },\r\n          &quot;spec&quot;: {\r\n            &quot;strategy&quot;: {\r\n              &quot;resources&quot;: {\r\n                \r\n              }\r\n            },\r\n            &quot;triggers&quot;: [\r\n              {\r\n                &quot;type&quot;: &quot;ConfigChange&quot;\r\n              },\r\n              {\r\n                &quot;type&quot;: &quot;ImageChange&quot;,\r\n                &quot;imageChangeParams&quot;: {\r\n                  &quot;automatic&quot;: true,\r\n                  &quot;containerNames&quot;: [\r\n                    &quot;openshift-mysql&quot;\r\n                  ],\r\n                  &quot;from&quot;: {\r\n                    &quot;kind&quot;: &quot;ImageStreamTag&quot;,\r\n                    &quot;namespace&quot;: &quot;abc&quot;,\r\n                    &quot;name&quot;: &quot;openshift-mysql:22&quot;\r\n                  }\r\n                }\r\n              }\r\n            ],\r\n            &quot;replicas&quot;: 1,\r\n            &quot;test&quot;: false,\r\n            &quot;selector&quot;: {\r\n              &quot;app&quot;: &quot;openshift-mysql&quot;,\r\n              &quot;deploymentconfig&quot;: &quot;openshift-mysql&quot;\r\n            },\r\n            &quot;template&quot;: {\r\n              &quot;metadata&quot;: {\r\n                &quot;creationTimestamp&quot;: null,\r\n                &quot;labels&quot;: {\r\n                  &quot;app&quot;: &quot;openshift-mysql&quot;,\r\n                  &quot;deploymentconfig&quot;: &quot;openshift-mysql&quot;\r\n                },\r\n                &quot;annotations&quot;: {\r\n                  &quot;openshift.io/generated-by&quot;: &quot;OpenShiftNewApp&quot;\r\n                }\r\n              },\r\n              &quot;spec&quot;: {\r\n                &quot;containers&quot;: [\r\n                  {\r\n                    &quot;name&quot;: &quot;openshift-mysql&quot;,\r\n                    &quot;image&quot;: &quot;172.30.1.1:5000/abc/openshift-mysql:22&quot;,\r\n                    &quot;ports&quot;: [\r\n                      {\r\n                        &quot;containerPort&quot;: 8080,\r\n                        &quot;protocol&quot;: &quot;TCP&quot;\r\n                      }\r\n                    ],\r\n                    &quot;resources&quot;: {\r\n                      \r\n                    }\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nDo we need to escape the JSON?",
        "link": "https://stackoverflow.com/questions/59164392/jq-select-is-not-recognized-as-an-internal-or-external-command",
        "title": "jq: select is not recognized as an internal or external command"
    },
    {
        "tags": [
            "json",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575475538,
                "post_id": 59180063,
                "comment_id": 104581269,
                "content_license": "CC BY-SA 4.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": 1575475574,
                "post_id": 59180063,
                "comment_id": 104581288,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1224790,
                    "reputation": 5600,
                    "user_id": 1190586,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/fab048d6c3f7059f681e8e9595f05127?s=256&d=identicon&r=PG",
                    "display_name": "fraxture",
                    "link": "https://stackoverflow.com/users/1190586/fraxture"
                },
                "reply_to_user": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575476959,
                "post_id": 59180063,
                "comment_id": 104582140,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "reply_to_user": {
                    "account_id": 262968,
                    "reputation": 789094,
                    "user_id": 548225,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/dab08478b226280d4a30894c9a7ed719?s=256&d=identicon&r=PG",
                    "display_name": "anubhava",
                    "link": "https://stackoverflow.com/users/548225/anubhava"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1575479348,
                "post_id": 59180063,
                "comment_id": 104583534,
                "content_license": "CC BY-SA 4.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": 1575573421,
                "post_id": 59180063,
                "comment_id": 104621556,
                "content_license": "CC BY-SA 4.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": 1575573567,
                "post_id": 59180063,
                "comment_id": 104621644,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1575478055,
                "creation_date": 1575478055,
                "answer_id": 59180944,
                "question_id": 59180063,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may use this as shell function:\r\n\r\n    pparselogs() {\r\n       while read data; do\r\n          echo &quot;$data&quot; | jq -rR &#39;. as $line | try fromjson catch $line&#39;\r\n       done\r\n    }\r\n\r\nThen use it with invalid `json`:\r\n\r\n    echo &#39;Hello World&#39; | pparselogs\r\n&lt;p/&gt;\r\n\r\n    Hello World\r\n\r\nand with valid `json`:\r\n\r\n    echo &#39;{&quot;id&quot;:1, &quot;message&quot;:&quot;Hello World&quot;}&#39; | pparselogs\r\n\r\n&lt;p/&gt;\r\n\r\n    {\r\n      &quot;id&quot;: 1,\r\n      &quot;message&quot;: &quot;Hello World&quot;\r\n    }\r\n\r\n",
                "title": "Shell quoting problem when trying to use jq with --arg option"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1575478055,
        "creation_date": 1575475211,
        "last_edit_date": 1575477691,
        "question_id": 59180063,
        "body_markdown": "I am having a problem getting jq to work with the `-r` and `--arg` options to reference a variable and avoid &quot;shell quoting&quot; problems.\r\n\r\nAn existing topic [here](https://stackoverflow.com/questions/40027395/passing-bash-variable-to-jq-select), suggests using `--arg` to define a command. I&#39;ve tried that in this shell function that is designed to take log input and parse it as json if it is parseable as json. If it isn&#39;t it just dumps it out as a string.\r\n\r\n```\r\nfunction pparselogs () {\r\n    while read data\r\n    do\r\n        jq --arg line &quot;$data&quot; -R -r &#39;. as $line | try fromjson catch $line&#39;\r\n    done\r\n}\r\n```\r\nThe error that I keep running into is the following:\r\n```\r\n&gt; echo &quot;Hello World&quot; | pparselogs .   \r\njq: error: syntax error, unexpected &#39;|&#39;, expecting &#39;$&#39; or &#39;[&#39; or &#39;{&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n. as  | try fromjson catch\r\njq: 1 compile error\r\n```\r\nGiven that the error is complaining about the `|`, it seems as though the `&quot;$data&quot;` arg value is not being picked up. But given the answer referenced above, this should be the way to do this. I can&#39;t see where I&#39;m making a mistake.\r\n\r\nDoes anyone see the problem here?",
        "link": "https://stackoverflow.com/questions/59180063/shell-quoting-problem-when-trying-to-use-jq-with-arg-option",
        "title": "Shell quoting problem when trying to use jq with --arg option"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1575581675,
                "creation_date": 1575581675,
                "answer_id": 59203596,
                "question_id": 59203157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "By having a pipe between filters, you&#39;re changing the input context to the value(s) produced from the previous filters. By the time you reach the `select/1` call, the input is the codename values. You need to keep the context to the device first, select based on the model, then get the codename.\r\n\r\n    $ ... | jq --arg model &quot;$model&quot; &#39;.devices[] | select(.model == $model).codename&#39;",
                "title": "Get android codename from model with the jq tool"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1575990389,
        "creation_date": 1575579460,
        "last_edit_date": 1575990389,
        "question_id": 59203157,
        "body_markdown": "Trying to get the codename of a specific android device having its model and brand from https://github.com/jaredrummler/AndroidDeviceNames :\r\n&lt;!-- language-all: lang-bash --&gt;\r\n\r\n    $ brand=ACER\r\n    $ model=B3-A20B\r\n    $ \\curl -Ls https://github.com/jaredrummler/AndroidDeviceNames/raw/master/json/manufacturers/$brand.json | \\\r\n    jq &quot;.devices[].codename | select( .devices[].model == \\&quot;$model\\&quot; )&quot; \r\n    jq: error (at &lt;stdin&gt;:1114): Cannot index string with string &quot;devices&quot;\r\n    $ echo $?\r\n    5\r\n\r\nEDIT 1 : For those who could be interested, I&#39;ve written this little bash function in my `.bash_functions` thanks to @jeff-mercado :\r\n\r\n    getCodeName () {\r\n    \tif [ $# != 2 ]; then\r\n    \t\techo &quot;=&gt; Usage: $FUNCNAME brand model&quot; &gt;&amp;2\r\n    \t\treturn 1\r\n    \tfi\r\n\r\n    \tlocal brand=$1\r\n    \tlocal model=$2\r\n    \tlocal codeNameJSONDataBaseURL=https://github.com/jaredrummler/AndroidDeviceNames/raw/master/json/manufacturers\r\n    \tlocal curl=&quot;$(which curl) -sL&quot;\r\n\r\n    \t$curl $codeNameJSONDataBaseURL/$brand.json | jq -r --arg model $model &#39;.devices[] | select( .model | match($model;&quot;i&quot;) ).codename&#39;\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59203157/get-android-codename-from-model-with-the-jq-tool",
        "title": "Get android codename from model with the jq tool"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1575640893,
                "post_id": 59212769,
                "comment_id": 104645150,
                "content_license": "CC BY-SA 4.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": 2,
                "creation_date": 1575647219,
                "post_id": 59212769,
                "comment_id": 104648496,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1575902113,
                "last_edit_date": 1575902113,
                "creation_date": 1575634980,
                "answer_id": 59213085,
                "question_id": 59212769,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "try\r\n\r\n    VARIABLE=&#39;[{&quot;id&quot;: 2, &quot;name&quot;: &quot;job&quot;, &quot;description&quot;: &quot;job&quot;, &quot;token&quot;: &quot;toknetokentokentoken/token=&quot;}]&#39;\r\n    TOKEN=$(echo &quot;$VARIABLE&quot;|jq &#39;.[] | select(.name == &quot;job&quot;).token&#39;)\r\n    echo &quot;$TOKEN&quot;\r\n\r\n**Edit:** as suggested a few clarifications:\r\n\r\nthe OP did not clariy on the *it erturns nothing part* but as @chepner pointed out in the comments: assingments don&#39;t procude output\r\n\r\nbackticks and `$()` are interchangeable, you should use `$()` since backticks are obsolete and don&#39;t support nesting",
                "title": "Get value from JSON using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1575902113,
        "creation_date": 1575633646,
        "question_id": 59212769,
        "body_markdown": "I am trying to export json as a variable:\r\n\r\n`$ export VARIABLE=&#39;[{&quot;id&quot;: 2, &quot;name&quot;: &quot;job&quot;, &quot;description&quot;: &quot;job&quot;, &quot;token&quot;: &quot;toknetokentokentoken/token=&quot;}]&#39;`\r\n\r\n`$ echo $VARIABLE | jq .`\r\n    \r\n    [\r\n      {\r\n        &quot;id&quot;: 2,\r\n        &quot;name&quot;: &quot;job&quot;,\r\n        &quot;description&quot;: &quot;job&quot;,\r\n        &quot;token&quot;: &quot;toknetokentokentoken/token=&quot;\r\n      }\r\n    ]\r\n\r\nand then I am trying to get the value from token:\r\n\r\n`TOKEN=$(echo &quot;$VARIABLE&quot; | jq -r &#39;.[] | select (.name == &quot;job&quot;).token&#39;)`\r\n\r\nbut it returns nothing. I am looking on to that but I can&#39;t find the problem.",
        "link": "https://stackoverflow.com/questions/59212769/get-value-from-json-using-jq",
        "title": "Get value from JSON using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1628754524,
                "last_edit_date": 1628754524,
                "creation_date": 1575809166,
                "answer_id": 59235514,
                "question_id": 59235418,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Just slurp them. `-n` is for null input, and is overkill for this trivial task.\r\n```\r\njq -s &#39;transpose | map(add)&#39; a.json b.json\r\n```",
                "title": "How to combine two arrays by merging each object with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1628754524,
        "creation_date": 1575808386,
        "last_edit_date": 1575809316,
        "question_id": 59235418,
        "body_markdown": "How can I use jq to combine the two files above, into a single array, by merging each object?\r\n\r\nI&#39;ve found https://stackoverflow.com/questions/54925675/combine-array-of-objects-from-two-files-with-jq-under-specific-key-1-4 but this is for a specific key.\r\n\r\nI&#39;ve tried:\r\n```\r\njq -n &#39;{ combined: (transpose | map(add)) }&#39; a.json b.json  \r\njq: error (at &lt;unknown&gt;): Cannot iterate over null (null)\r\n```\r\n\r\nInput: \r\n```\r\n    ==&gt; a.json &lt;==\r\n    [\r\n      {\r\n        &quot;datetime&quot;: &quot;2019-12-08 11:34&quot;\r\n      },\r\n      {\r\n        &quot;datetime&quot;: &quot;2019-12-08 11:35&quot;\r\n      },\r\n      {\r\n        &quot;datetime&quot;: &quot;2019-12-08 12:03&quot;\r\n      }\r\n    ]\r\n    \r\n    ==&gt; b.json &lt;==\r\n    [\r\n      {\r\n        &quot;command&quot;: &quot;cat test.txt&quot;\r\n      },\r\n      {\r\n        &quot;command&quot;: &quot;cat test2.txt&quot;\r\n      },\r\n      {\r\n        &quot;command&quot;: &quot;cat test3.txt&quot;\r\n      }\r\n    ]\r\n```\r\n\r\nDesired output:\r\n```\r\n    [\r\n      {\r\n        &quot;command&quot;: &quot;cat test.txt&quot;,\r\n        &quot;datetime&quot;: &quot;2019-12-08 11:34&quot;\r\n      },\r\n      {\r\n        &quot;command&quot;: &quot;cat test2.txt&quot;,\r\n        &quot;datetime&quot;: &quot;2019-12-08 11:35&quot;\r\n      },\r\n      {\r\n        &quot;command&quot;: &quot;cat test3.txt&quot;,\r\n        &quot;datetime&quot;: &quot;2019-12-08 12:03&quot;\r\n      }\r\n    ]\r\n```",
        "link": "https://stackoverflow.com/questions/59235418/how-to-combine-two-arrays-by-merging-each-object-with-jq",
        "title": "How to combine two arrays by merging each object with jq?"
    },
    {
        "tags": [
            "json",
            "date",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1575909508,
                "last_edit_date": 1575909508,
                "creation_date": 1575858243,
                "answer_id": 59241780,
                "question_id": 59241552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is valid JSON, with &quot;items&quot; as the top-level key, then the value of &quot;items&quot; can be updated relative to `now` as follows:\r\n```\r\n(now - 30*24*60*60 | strflocaltime(&quot;%Y-%m-%dT%H:%M:%S&quot;)) as $recent\r\n| .items |= map( select((.accessDate\r\n                         | sub(&quot;-(?&lt;d&gt;[0-9]-)&quot;;&quot;-0\\(.d)&quot;)) &gt;= $recent) )\r\n```\r\n\r\n(The invocation of `sub` is needed to handle months given as `-d-`.)",
                "title": "Get only data that are 30 days old using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1575909508,
        "creation_date": 1575855804,
        "last_edit_date": 1575880527,
        "question_id": 59241552,
        "body_markdown": "i have a json file with user access data similar to this. I am trying to filter out user (name and accessDate fields) who has not accessed system for last 30 days. Does anyone know if this can be done using jq operation?\r\n\r\n    &quot;items&quot;: [\r\n    {\r\n    \t&quot;id&quot;: &quot;1&quot;,\r\n    \t&quot;accessDate&quot;: &quot;2019-11-13T11:35:39.1097956&quot;,\r\n    \t&quot;user&quot;:{\r\n    \t\t&quot;name&quot;: &quot;john doe&quot;\r\n    \t}\r\n    }\r\n    {\r\n    \t&quot;id&quot;: &quot;2&quot;,\r\n    \t&quot;accessDate&quot;: &quot;2019-10-13T11:35:39.1097956&quot;,\r\n    \t&quot;user&quot;:{\r\n    \t\t&quot;name&quot;: &quot;scott doe&quot;\r\n    \t}\r\n    }\r\n    {\r\n    \t&quot;id&quot;: &quot;3&quot;,\r\n    \t&quot;accessDate&quot;: &quot;2019-9-13T11:35:39.1097956&quot;,\r\n    \t&quot;user&quot;:{\r\n    \t\t&quot;name&quot;: &quot;matt doe&quot;\r\n    \t}\r\n    }",
        "link": "https://stackoverflow.com/questions/59241552/get-only-data-that-are-30-days-old-using-jq",
        "title": "Get only data that are 30 days old using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 55050,
                    "reputation": 196179,
                    "user_id": 164835,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/ayYoh.jpg?s=256",
                    "display_name": "Kent",
                    "link": "https://stackoverflow.com/users/164835/kent"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575971523,
                "post_id": 59264302,
                "comment_id": 104736849,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14750453,
                    "reputation": 59,
                    "user_id": 10652693,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-okU_5WnYGxY/AAAAAAAAAAI/AAAAAAAADnc/sZOzO_y2fiM/s256-rj/photo.jpg",
                    "display_name": "Vorbisset",
                    "link": "https://stackoverflow.com/users/10652693/vorbisset"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575972525,
                "post_id": 59264302,
                "comment_id": 104737399,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14750453,
                    "reputation": 59,
                    "user_id": 10652693,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-okU_5WnYGxY/AAAAAAAAAAI/AAAAAAAADnc/sZOzO_y2fiM/s256-rj/photo.jpg",
                    "display_name": "Vorbisset",
                    "link": "https://stackoverflow.com/users/10652693/vorbisset"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1575972590,
                "post_id": 59264302,
                "comment_id": 104737431,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1575972882,
                "creation_date": 1575972882,
                "answer_id": 59264856,
                "question_id": 59264302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [tag:jq] for parsing JSON, for example:\r\n```\r\n$ jq -r &#39;.data.result[] | &quot;\\(.metric.project_site) : \\(.value[1]) seconds&quot;&#39; file\r\nAUB : 0.3889104875437488 seconds\r\nVDR : 0.2267407994117705 seconds\r\n```",
                "title": "Extract numeric values from awk return"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1575974486,
                "creation_date": 1575974486,
                "answer_id": 59265366,
                "question_id": 59264302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I have upvoted the answer by @oguzismail, and will repeat their suggestion to use `jq` instead if at all feasible.\r\n\r\nIf your input is not valid JSON, there are several things wrong with your approach, several of them related more to efficiency and common practice than outright erroneous.\r\n\r\n1. Your regex is wrong. See below.\r\n1. Avoid the [useless `cat`.](/questions/11710552/useless-use-of-cat)\r\n1. If you are using Awk anyway, you don&#39;t need `grep`.  See [useless use of `grep`.](http://www.iki.fi/era/unix/award.html#grep)\r\n1. [Quote your variable.](/questions/10067266/when-to-wrap-quotes-around-a-shell-variable/27701642)\r\n1. Only in this case, you want to remove the useless `echo` entirely. Capturing standard output so that you can `echo` it to standard output is simply a waste of processes (unless you specifically wanted to break the quoting, as a special case of the previous item; but that is not the case here).\r\n1. It is unclear what you hope for the empty string `&quot;&quot;` to accomplish. After the shell is done with quote removal, `&quot;&quot;cat` is simply `cat`.\r\n\r\nIn some more detail, `[0.0001-9999.9]` matches a single character which is `0` or `.` or `0` (oh we mentioned that already, didn&#39;t we?) or `0` (ditto) or between `1` and `9` or `9` (etc etc).  In short, `grep` is not at all the right tool for searching for number ranges; fortunately, Awk can do that easily too.\r\n\r\nHere, then, is an attempt to refactor to remove these problems.\r\n```\r\nawk -F &#39;,&#39; &#39;{ split(&quot;5:&quot; NF, a, &quot;:&quot;); split(&quot;AUB:VDR&quot;, l, &quot;:&quot;)\r\n  for (i=1; i&lt;=2; i++) {\r\n    n = $a[i]; gsub(/[]}&quot;]+/, &quot;&quot;, n);\r\n    if (n &gt;= 0.0001 &amp;&amp; n &lt;= 9999.9)\r\n      print l[i] &quot;: &quot; n &quot; seconds&quot;} }&#39; test.txt\r\n```\r\nThis is extremely brittle because it hard-codes the locations of the strings within the surface structure of the (not?) JSON data, which could change without warning.\r\n\r\nThe `split` is a hack to get the numbers 5 and NF into an array `a`. We create a second array with the same length for the corresponding labels. We then loop over the first array and use the numbers as indices into the current record&#39;s fields. We trim off any quoting and brackets, and then perform the numeric comparison on the thus extracted field. At the end, we add the corresponding label from the other array in front of the printed text.",
                "title": "Extract numeric values from awk return"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1666590559,
        "creation_date": 1575971123,
        "last_edit_date": 1666590559,
        "question_id": 59264302,
        "body_markdown": "For supervision system, I need to return 2 values about latency to my supervisor server thru nrpe.\r\n\r\nHere the values that I&#39;m working on (I put this in a file : test.txt) : \r\n\r\n    {&quot;status&quot;:&quot;success&quot;,&quot;data&quot;:{&quot;resultType&quot;:&quot;vector&quot;,&quot;result&quot;:[{&quot;metric&quot;:{&quot;project_site&quot;:&quot;AUB&quot;},&quot;value&quot;:[1575277537.052,&quot;0.3889104875437488&quot;]},{&quot;metric&quot;:{&quot;project_site&quot;:&quot;VDR&quot;},&quot;value&quot;:[1575277537.052,&quot;0.2267407994117705&quot;]}]}}\r\n\r\nI need to extract `0.3889104875437488` and `0.2267407994117705`\r\n\r\nI&#39;m using this :\r\n\r\n    for i in $(&quot;&quot;cat test.txt | awk -F &#39;,&#39; &#39;{print $5 $NF}&#39; | grep -o &#39;[0.0001-9999.9]\\+&#39;&quot;&quot;); do echo $i; done\r\n\r\nI&#39;m not sure that&#39;s the best method, especially since I have to add this : &quot;AUB&quot; for row 1 and &quot;VDR&quot; for row 2 before each line. Like :\r\n\r\n    AUB : 0.3889104875437488 seconds\r\n    VDR : 0.2267407994117705 seconds\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59264302/extract-numeric-values-from-awk-return",
        "title": "Extract numeric values from awk return"
    },
    {
        "tags": [
            "python",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 13970176,
                    "reputation": 14586,
                    "user_id": 12366110,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/2f3973f67bacd20d5304f913dcfa5e3b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "CDJB",
                    "link": "https://stackoverflow.com/users/12366110/cdjb"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1575983637,
                "post_id": 59264692,
                "comment_id": 104743452,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1575988854,
                "creation_date": 1575988854,
                "answer_id": 59269711,
                "question_id": 59264692,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your jq query does not even mention `keysstoremove`.  One possibility would be to use a jq query such as the following:\r\n\r\n```\r\ndef keysstoremove:\r\n  [&quot;KLLIE2D&quot;, &quot;FLLIE2D&quot;, &quot;SLLIE2D&quot;, &quot;ELLIE2D&quot;];\r\n\r\n.configurations[]\r\n| .en_key as $k\r\n| select( keysstoremove | index($k) | not)\r\n| {www, en_key}\r\n```\r\n\r\n## General hint\r\n\r\nWhen experiencing difficulty while using a wrapper such as pyjq, it is often simplest to check that your jq query is correct by using the jq command-line interpreter, which is generally available for the major operating systems.",
                "title": "Pyjq - Remove set of strings defined in a variable"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1575988854,
        "creation_date": 1575972379,
        "last_edit_date": 1575976155,
        "question_id": 59264692,
        "body_markdown": "I need to filter some JSON such that only objects with a `www` key that is NOT in the `keysstoremove` array are kept in the final output.\r\n\r\nMy code:\r\n\r\n    import pyjq, json\r\n    \r\n    keysstoremove = [&quot;KLLIE2D&quot;, &quot;FLLIE2D&quot;, &quot;SLLIE2D&quot;, &quot;ELLIE2D&quot;]\r\n    infile = json.load(open(&#39;./test.json&#39;))\r\n    json_object = pyjq.all(&#39;.configurations[] | {www, en_key} | select(.en_key != null)&#39;, infile)\r\n\r\n**Example Output (incorrect):**\r\n\r\n    [{\r\n        &quot;www&quot;: &quot;BLLIE2D&quot;,\r\n        &quot;en_key&quot;: &quot;hashAAAAB3NzaC1y&quot;\r\n    },\r\n    {\r\n        &quot;www&quot;: &quot;KLLIE2D&quot;,\r\n        &quot;en_key&quot;: &quot;hashAAAAB3NwCXr57&quot;\r\n    },\r\n    {\r\n        &quot;www&quot;: &quot;JLLIE2D&quot;,\r\n        &quot;en_key&quot;: &quot;hashnAAAt8zlnwg1Pj&quot;\r\n    },\r\n    {\r\n        &quot;www&quot;: &quot;FLLIE2D&quot;,\r\n        &quot;en_key&quot;: &quot;hashAAAAB3NzaC1ycA&quot;\r\n    {\r\n        &quot;www&quot;: &quot;ELLIE2D&quot;,\r\n        &quot;en_key&quot;: &quot;hashAAAAB3Nz0Md9sdvs&quot;\r\n    },\r\n    {\r\n        &quot;www&quot;: &quot;SLLIE2D&quot;,\r\n        &quot;en_key&quot;: &quot;hashAAAAB3NzaC1yc2EAJ&quot;\r\n    }]\r\n\r\n**Expected output:**\r\n\r\n    [{\r\n        &quot;www&quot;: &quot;BLLIE2D&quot;,\r\n        &quot;en_key&quot;: &quot;hashAAAAB3NzaC1y&quot;\r\n    },\r\n    {\r\n        &quot;www&quot;: &quot;JLLIE2D&quot;,\r\n        &quot;en_key&quot;: &quot;hashnAAAt8zlnwg1Pj&quot;\r\n    }]",
        "link": "https://stackoverflow.com/questions/59264692/pyjq-remove-set-of-strings-defined-in-a-variable",
        "title": "Pyjq - Remove set of strings defined in a variable"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1576009836,
                "creation_date": 1576009836,
                "answer_id": 59274913,
                "question_id": 59274735,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For this specific case, you can simply add `Statement` fields of two objects like this:\r\n```\r\njq &#39;.Statement += input.Statement&#39; file1 file2\r\n```",
                "title": "How to merge those two JSON files using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1576009836,
        "creation_date": 1576009059,
        "question_id": 59274735,
        "body_markdown": "I&#39;m using jq 1.5 for this.   I have two json files: 1.json and 2.json below.  Files both contain Statement[] array of objects that I want to combine into one file (result.json). \r\n\r\n1.json:\r\n```\r\n{\r\n\t&quot;Statement&quot;: [{\r\n\t\t\t&quot;Resource&quot;: [\r\n\t\t\t\t&quot;arn:aws:autoscaling:*:55555555:autoScalingGroup:*:autoScalingGroupName/${aws:PrincipalTag/Service}-*&quot;\r\n\t\t\t],\r\n\t\t\t&quot;Effect&quot;: &quot;Allow&quot;,\r\n\t\t\t&quot;Action&quot;: [\r\n\t\t\t\t&quot;autoscaling:ExitStandby&quot;,\r\n\t\t\t\t&quot;autoscaling:RecordLifecycleActionHeartbeat&quot;\r\n\t\t\t],\r\n\t\t\t&quot;Sid&quot;: &quot;ascIBP0&quot;\r\n\t\t}\r\n\t],\r\n\t&quot;Version&quot;: &quot;2012-10-17&quot;\r\n}\r\n```\r\n\r\nand 2.json, which has identical structure: Statement[...]\r\n```\r\n{\r\n    &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n    &quot;Statement&quot;: [\r\n        {\r\n            &quot;Action&quot;: [\r\n                &quot;lambda:UpdateEventSourceMapping&quot;,\r\n                &quot;lambda:CreateEventSourceMapping&quot;,\r\n                &quot;lambda:DeleteEventSourceMapping&quot;\r\n            ],\r\n            &quot;Effect&quot;: &quot;Allow&quot;,\r\n            &quot;Condition&quot;: {\r\n                &quot;ArnLike&quot;: {\r\n                    &quot;lambda:FunctionArn&quot;: &quot;arn:aws:lambda:*:*:function:${aws:PrincipalTag/Service}-*&quot;\r\n                }\r\n            },\r\n            &quot;Resource&quot;: &quot;*&quot;,\r\n            &quot;Sid&quot;: &quot;lmbIBP0&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nresults.json\r\n```\r\n{\r\n    &quot;Version&quot;: &quot;2012-10-17&quot;,\r\n    &quot;Statement&quot;: [\r\n\t\t{\r\n\t\t\t&quot;Resource&quot;: [\r\n\t\t\t\t&quot;arn:aws:autoscaling:*:55555555:autoScalingGroup:*:autoScalingGroupName/${aws:PrincipalTag/Service}-*&quot;\r\n\t\t\t],\r\n\t\t\t&quot;Effect&quot;: &quot;Allow&quot;,\r\n\t\t\t&quot;Action&quot;: [\r\n\t\t\t\t&quot;autoscaling:ExitStandby&quot;,\r\n\t\t\t\t&quot;autoscaling:RecordLifecycleActionHeartbeat&quot;\r\n\t\t\t],\r\n\t\t\t&quot;Sid&quot;: &quot;ascIBP0&quot;\r\n\t\t},\t\r\n        {\r\n            &quot;Action&quot;: [\r\n                &quot;lambda:UpdateEventSourceMapping&quot;,\r\n                &quot;lambda:CreateEventSourceMapping&quot;,\r\n                &quot;lambda:DeleteEventSourceMapping&quot;\r\n            ],\r\n            &quot;Effect&quot;: &quot;Allow&quot;,\r\n            &quot;Condition&quot;: {\r\n                &quot;ArnLike&quot;: {\r\n                    &quot;lambda:FunctionArn&quot;: &quot;arn:aws:lambda:*:*:function:${aws:PrincipalTag/Service}-*&quot;\r\n                }\r\n            },\r\n            &quot;Resource&quot;: &quot;*&quot;,\r\n            &quot;Sid&quot;: &quot;lmbIBP0&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n\r\nI&#39;ve come close, but I can&#39;t get it right.   Been trying these combinations:\r\n```\r\njq -s &#39;.[0] * .[1]&#39; 1.json 2.json\r\njq -s &#39;.[1] * .[0]&#39; 1.json 2.json\r\njq -s &#39;.[] * .[]&#39; 1.json 2.json\r\n```\r\nStill no luck",
        "link": "https://stackoverflow.com/questions/59274735/how-to-merge-those-two-json-files-using-jq",
        "title": "How to merge those two JSON files using jq"
    },
    {
        "tags": [
            "shell",
            "command-line-interface",
            "jq",
            "az"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 7523087,
                    "reputation": 149,
                    "user_id": 6587877,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/be75f80eb3a59af5e27e6b10e13dc44c?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Flow",
                    "link": "https://stackoverflow.com/users/6587877/flow"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576243066,
                "post_id": 59281120,
                "comment_id": 104846302,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1580393479,
                "creation_date": 1580393479,
                "answer_id": 59987915,
                "question_id": 59281120,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Azure Support has been contacted, they recommended using dictionaries to pass arguments, since after all, az cli runs py in backend:\r\n\r\n```\r\naz vm run-command invoke -g $RGROUP -n $RGROUP-00 --command-id RunShellScript  --scripts &#39;echo &quot;$1&quot; &quot;$2&quot;&#39; --parameters &quot;hello&quot; &quot;&#39;this is just a test&#39;&quot;\r\n{\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;code&quot;: &quot;ProvisioningState/succeeded&quot;,\r\n      &quot;displayStatus&quot;: &quot;Provisioning succeeded&quot;,\r\n      &quot;level&quot;: &quot;Info&quot;,\r\n      &quot;message&quot;: &quot;Enable succeeded: \\n[stdout]\\nhello this is just a test\\n\\n[stderr]\\n&quot;,\r\n      &quot;time&quot;: null\r\n    }\r\n  ]\r\n}\r\n\r\n",
                "title": "AZ CLI (az vm run-command invoke) losing variable data when executed with parameters"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1580393479,
        "creation_date": 1576050972,
        "question_id": 59281120,
        "body_markdown": "Scenario:\r\n\r\n- multiple servers with 1 json file that must have a token replaced\r\n- using jq for json replace\r\n- az vm run-command for running it for all machines\r\n- azuregateways.txt is the list of Azure VMs\r\n- newtokens.csv is the list of new tokens for each gw\r\n\r\nThe command:\r\n\r\n    for i in `cat azuregateways.txt | awk -F &quot;-00&quot; {&#39;print $1&#39;}`; do newtoken=$(grep $i newtokens.csv | cut -d : -f2); az vm run-command invoke -g $i -n $i-00 --command-id RunShellScript --scripts &quot;&quot;&quot;cp /home/ops/data/registrationticket.json /home/ops/data/registrationticket.json_old; sudo apt install -y jq; q --arg httpsas &quot;$newtoken&quot; &#39;.OutboxAccessTicket.HttpSas=$httpsas&#39; registrationticket.json_old &gt; registrationticket.json; docker restart mygateway&quot;&quot;&quot;;done\r\n\r\nThe variable which is being lost is **$newtoken**. The command when executed with --debug:\r\n\r\n    Command arguments: [&#39;vm&#39;, &#39;run-command&#39;, &#39;invoke&#39;, &#39;-g&#39;, &#39;ANDROIDGW&#39;, &#39;-n&#39;, &#39;ANDROIDGW-00&#39;, &#39;--command-id&#39;, &#39;RunShellScript&#39;, &#39;--scripts&#39;, &quot;cp /home/ops/data/registrationticket.json /home/ops/data/registrationticket.json_old; jq --arg httpsas &#39;ASDASD ASD ASD ASD ASD&#39; &#39;.OutboxAccessTicket.HttpSas=&#39; /home/ops/data/registrationticket.json_old &gt; /home/ops/data/registrationticket.json&quot;, &#39;--debug&#39;]\r\n\r\nSo if we can look over the Comnmand arguments section, we notice that AZ CLI is losing the jq variable:\r\n\r\n**jq --arg httpsas &#39;ASDASD ASD ASD ASD ASD&#39; &#39;.OutboxAccessTicket.HttpSas=&#39;** \r\n\r\nI have tried exporting the variables as global variables, quoting in every possible way, doing a script and running that instead but all behaves the same when I introduce the token as being a variable.",
        "link": "https://stackoverflow.com/questions/59281120/az-cli-az-vm-run-command-invoke-losing-variable-data-when-executed-with-parame",
        "title": "AZ CLI (az vm run-command invoke) losing variable data when executed with parameters"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576068039,
                "post_id": 59285870,
                "comment_id": 104777312,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5180018,
                    "reputation": 4579,
                    "user_id": 4146004,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/x5FIZ.jpg?s=256",
                    "display_name": "nullPointer",
                    "link": "https://stackoverflow.com/users/4146004/nullpointer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576068772,
                "post_id": 59285870,
                "comment_id": 104777682,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1704632,
                    "reputation": 4370,
                    "user_id": 1563960,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/in6vi.png?s=256",
                    "display_name": "webb",
                    "link": "https://stackoverflow.com/users/1563960/webb"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1576069280,
                "post_id": 59285870,
                "comment_id": 104777969,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 26377,
                    "reputation": 363501,
                    "user_id": 68587,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://www.gravatar.com/avatar/7d9fd158e03cbde94f7e0b33b78222af?s=256&d=identicon&r=PG",
                    "display_name": "John Kugelman",
                    "link": "https://stackoverflow.com/users/68587/john-kugelman"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1576070210,
                "post_id": 59285870,
                "comment_id": 104778531,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576076026,
                "post_id": 59285870,
                "comment_id": 104781887,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1576075182,
                "last_edit_date": 1576075182,
                "creation_date": 1576070232,
                "answer_id": 59286692,
                "question_id": 59285870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This can get you started. It uses `jq`, but I&#39;m not yet familiar enough with it, so there could be easier way to achieve your goal.\r\n\r\n    #!/bin/bash\r\n    \r\n    v1=&#39;k1 v1 k2 v2 double &quot;&#39;\r\n    \r\n    jq -n &quot;$(while : ; do\r\n        k=${v1%% *}\r\n        v1=${v1#* }\r\n        v=${v1%% *}\r\n        v1=${v1#* }\r\n        jq --arg k &quot;$k&quot; --arg v &quot;$v&quot; -n &#39;{($k): $v}&#39;\r\n        [[ $v1 == *&#39; &#39;* ]] || break\r\n        printf +\r\n    done)&quot;\r\n\r\nAs shown, it works even if the variable contains double quotes.\r\n\r\nUsing a higher-level language with JSON support seems much easier:\r\n\r\n    perl -MJSON -le &#39;print encode_json({@ARGV})&#39; $v1\r\n\r\nFor more variables, it gets a bit more hairy:\r\n\r\n    perl -MJSON -le &#39;print encode_json(\r\n        {map +(&quot;t&quot; . ++$i, {split}), @ARGV}\r\n    )&#39; -- &quot;$v1&quot; &quot;$v2&quot;\r\n\r\ni.e. it splits each variable on whitespace and prepends a key to a hash created from it.",
                "title": "Create nested json file using shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1576077184,
                "last_edit_date": 1576077184,
                "creation_date": 1576076827,
                "answer_id": 59288710,
                "question_id": 59285870,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an only-jq solution.  Notice that all the iteration can be done within the jq program itself:\r\n\r\n```\r\njq -n --arg var1 &quot;$var1&quot; --arg var2 &quot;$var2&quot; &#39;\r\n  [$var2|splits(&quot;  *&quot;)] as $v2\r\n  | (reduce range(0; $v2|length) as $i ({};\r\n       . + { ($v2[$i]): &quot;v\\($i + 1)&quot; })) as $o\r\n  | reduce ($var1|splits(&quot;  *&quot;)) as $v1 ({};\r\n      setpath([$v1]; $o) )\r\n&#39;\r\n```\r\n## Example\r\nWith:\r\n```\r\nvar1=&quot;t1 t2&quot;\r\nvar2=&quot;k1 k2&quot;\r\n```\r\nthe output would be as shown in the Q, i.e.:\r\n```\r\n{\r\n  &quot;t1&quot;: {\r\n    &quot;k1&quot;: &quot;v1&quot;,\r\n    &quot;k2&quot;: &quot;v2&quot;\r\n  },\r\n  &quot;t2&quot;: {\r\n    &quot;k1&quot;: &quot;v1&quot;,\r\n    &quot;k2&quot;: &quot;v2&quot;\r\n  }\r\n}\r\n```\r\n\r\n",
                "title": "Create nested json file using shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1576077184,
        "creation_date": 1576067402,
        "last_edit_date": 1576074433,
        "question_id": 59285870,
        "body_markdown": "Is there any way to create nested json in bash. \r\n\r\n    {\r\n      &quot;t1&quot;: {\r\n            &quot;k1&quot;: &quot;v1&quot;,\r\n            &quot;k2&quot;: &quot;v2&quot;\r\n      },\r\n      &quot;t2&quot;: {\r\n            &quot;k1&quot;: &quot;v1&quot;,\r\n            &quot;k2&quot;: &quot;v2&quot;\r\n      }\r\n    }\r\n\r\nI have 2 variable having space separated values. \r\n\r\n    var1=&quot;aa bb cc dd&quot; -- which gives t1,t2 etc in the sample json\r\n    var2=&quot;ee ff gg hh&quot; -- which gives k1,k2 etc in the sample json\r\n\r\nUpon iterating the variables i should derive the values of t&#39;s, k&#39;s and v&#39;s in the json. Below is the loop which i&#39;m thinking to have. However can be changed based on the suggestion.\r\n\r\n    for i in var1;\r\n    do\r\n       -----\r\n       -----\r\n       for j in var2;\r\n       do\r\n         -----\r\n         &#39;json creation&#39;\r\n       done\r\n     done\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59285870/create-nested-json-file-using-shell-script",
        "title": "Create nested json file using shell script"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1576072484,
                "creation_date": 1576072484,
                "answer_id": 59287341,
                "question_id": 59287280,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "JQ accepts a stream of JSON. You don&#39;t have to do anything special to get it to read the data.\r\n\r\n```\r\n$ jq &#39;.&#39; test.json\r\n{\r\n  &quot;thing&quot;: 1,\r\n  &quot;other&quot;: &quot;foo&quot;\r\n}\r\n{\r\n  &quot;thing&quot;: 2,\r\n  &quot;other&quot;: &quot;baz&quot;\r\n}\r\n$ jq -r &#39;.other&#39; test.json\r\nfoo\r\nbaz\r\n```\r\n\r\nUse `-s` if you want JQ to *slurp* the input into one big array.\r\n\r\n```\r\n$ jq -s &#39;.&#39; test.json\r\n[\r\n  {\r\n    &quot;thing&quot;: 1,\r\n    &quot;other&quot;: &quot;foo&quot;\r\n  },\r\n  {\r\n    &quot;thing&quot;: 2,\r\n    &quot;other&quot;: &quot;baz&quot;\r\n  }\r\n]\r\n```",
                "title": "How to join multi URL output in curl to pass to jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1576072682,
        "creation_date": 1576072271,
        "last_edit_date": 1576072682,
        "question_id": 59287280,
        "body_markdown": "I am using a multi-url curl command like this:\r\n\r\n`curl -snL http://url1 http://url2`\r\n\r\nEach produces json as such:\r\n\r\n    {\r\n       &quot;thing&quot;: 1,\r\n       &quot;other&quot;: &quot;foo&quot;\r\n    }\r\n    \r\n    {\r\n       &quot;thing&quot;: 2,\r\n       &quot;other&quot;: &quot;baz&quot;\r\n    }\r\n\r\nwhat I want to know is if there is a simple way to combine these so they can effectively be passed to jq (or maybe jq can just do this) such that I get:\r\n\r\n\r\n    [{\r\n       &quot;thing&quot;: 1,\r\n       &quot;other&quot;: &quot;foo&quot;\r\n    },\r\n    {\r\n       &quot;thing&quot;: 2,\r\n       &quot;other&quot;: &quot;baz&quot;\r\n    }]\r\n\r\nand thus can do, ultimately: `curl -snL http://url1 http://url2 | jq -re .[].other`",
        "link": "https://stackoverflow.com/questions/59287280/how-to-join-multi-url-output-in-curl-to-pass-to-jq",
        "title": "How to join multi URL output in curl to pass to jq"
    },
    {
        "tags": [
            "jenkins",
            "jenkins-plugins",
            "jq",
            "jenkins-api"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1578419779,
                "last_edit_date": 1592644375,
                "creation_date": 1576109311,
                "answer_id": 59295931,
                "question_id": 59295890,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;m making this way more difficult than it needs to be. I can just get the names of the plugins from the API:\n\n    curl -u $USERNAME:$TOKEN --globoff -H &quot;${JENKINS_CRUMB}&quot; &quot;${JENKINS_URL}/pluginManager/api/json?tree=plugins[shortName]&quot; | jq &#39;.plugins[] | .shortName&#39;\n\nand then [install them and their dependencies with `jenkins-cli`][1]:\n\n    java -jar jenkins-cli.jar -s $JENKINS_URL install-plugin $PLUGIN\n\n\n  [1]: https://stackoverflow.com/a/34773752/1183256\n\n---\n\n### Update\n\nI ended up opting for the SSH option to interact with Jenkins&#39; API, it&#39;s cleaner and easier to use:\n\n    ssh.exe -l &quot;${USER}&quot; -p 53801 &quot;${HOST}&quot; list-plugins | awk &#39;{print $1}&#39; &gt; plugins.txt\n\n    for line in $(cat plugins.txt)\n    do\n        echo &quot;Installing ${line} plugin&quot;\n        ssh.exe -l &quot;${USER}&quot; -p 53801 &quot;${HOST}&quot; install-plugin $line\n    done",
                "title": "Generating comprehensive Jenkins plugin manifest using Plugin Manager&#39;s REST API and JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1578419779,
        "creation_date": 1576108969,
        "question_id": 59295890,
        "body_markdown": "I&#39;m trying to get a Set of installed Jenkins plugins through the API using `curl` and `jq` but can&#39;t seem to flatten nested arrays correctly. An example of the output JSON I&#39;m fetching:\r\n\r\n    {\r\n        &quot;plugins&quot;: [\r\n            {\r\n                &quot;shortName&quot;: &quot;foo&quot;,\r\n                &quot;version&quot;: &quot;6.9&quot;,\r\n                &quot;dependencies&quot;: [\r\n                    {\r\n                        &quot;shortName&quot;: &quot;bar&quot;,\r\n                        &quot;version&quot;: &quot;4.2.0&quot;\r\n                    },\r\n                    {\r\n                        &quot;shortName&quot;: &quot;baz&quot;,\r\n                        &quot;version&quot;: &quot;6.6.6&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;shortName&quot;: &quot;fah&quot;,\r\n                &quot;version&quot;: &quot;4.2&quot;,\r\n                &quot;dependencies&quot;: [\r\n                    {\r\n                        &quot;shortName&quot;: &quot;bah&quot;,\r\n                        &quot;version&quot;: &quot;1.3&quot;\r\n                    },\r\n                    {\r\n                        &quot;shortName&quot;: &quot;bar&quot;,\r\n                        &quot;version&quot;: &quot;2.1.0&quot;\r\n                    },\r\n                    {\r\n                        &quot;shortName&quot;: &quot;baz&quot;,\r\n                        &quot;version&quot;: &quot;6.6.6&quot;\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nAnd here&#39;s the result that I&#39;d like to get:\r\n\r\n    [\r\n        {\r\n            &quot;shortName&quot;: &quot;bah&quot;,\r\n            &quot;version&quot;: &quot;1.3&quot;\r\n        },\r\n        {\r\n            &quot;shortName&quot;: &quot;bar&quot;,\r\n            &quot;version&quot;: &quot;2.1.0&quot;\r\n        },\r\n        {\r\n            &quot;shortName&quot;: &quot;bar&quot;,\r\n            &quot;version&quot;: &quot;4.2.0&quot;\r\n        },\r\n        {\r\n            &quot;shortName&quot;: &quot;baz&quot;,\r\n            &quot;version&quot;: &quot;6.6.6&quot;\r\n        },\r\n        {\r\n            &quot;shortName&quot;: &quot;fah&quot;,\r\n            &quot;version&quot;: &quot;4.2&quot;\r\n        },\r\n        {\r\n            &quot;shortName&quot;: &quot;foo&quot;,\r\n            &quot;version&quot;: &quot;6.9&quot;\r\n        },\r\n    ]\r\n\r\nI&#39;ve made various attempts at using `map` and `flatten` but can&#39;t seem to preserve the parent&#39;s keys, let alone getting a comprehensive array of each plugin and its version. The payload is easy enough to get with `curl`:\r\n\r\n    curl -u username:token --globoff -H &quot;${JENKINS_CRUMB}&quot; &quot;${JENKINS_URL}/pluginManager/api/json?tree=plugins[shortName,version,dependencies[shortName,version]]&quot;\r\n\r\nI&#39;d like to just pipe that output straight into `jq` to transform it into the desired results. Am I able to do this within `jq` or would I need to have some sort of wrapper for these transformations like Python?",
        "link": "https://stackoverflow.com/questions/59295890/generating-comprehensive-jenkins-plugin-manifest-using-plugin-managers-rest-api",
        "title": "Generating comprehensive Jenkins plugin manifest using Plugin Manager&#39;s REST API and JQ"
    },
    {
        "tags": [
            "json",
            "select",
            "command-line-arguments",
            "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": 1576123119,
                "post_id": 59297265,
                "comment_id": 104798868,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4738630,
                    "reputation": 297,
                    "user_id": 3832212,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://i.sstatic.net/B8eLI.jpg?s=256",
                    "display_name": "Iris Louis",
                    "link": "https://stackoverflow.com/users/3832212/iris-louis"
                },
                "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": 1576123457,
                "post_id": 59297265,
                "comment_id": 104798948,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1576123401,
                "creation_date": 1576123401,
                "answer_id": 59297529,
                "question_id": 59297265,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; ... I want to ignore attributes if that is empty or null\r\n\r\nTo remove unwanted keys from an object, you could  pass it to a filter such as:\r\n```\r\nwith_entries(select(.value | (. != &quot;&quot; and . != {} and . != null)))\r\n```\r\n",
                "title": "Jq select condition"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1576134703,
                "creation_date": 1576134703,
                "answer_id": 59299419,
                "question_id": 59297265,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To check whether a value, say $value, is `null` or `&quot;&quot;`, one could write: \r\n\r\n    $value == null or $value == &quot;&quot;\r\n\r\nSo you could achieve what you want by using this jq program:\r\n\r\n    def agrees(value): \r\n      value == null or value == &quot;&quot; or . == value;\r\n\r\n    select( (.city | agrees($city)) and\r\n            (.person.name | agrees($name)) )\r\n",
                "title": "Jq select condition"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1576134780,
        "creation_date": 1576120974,
        "last_edit_date": 1576134780,
        "question_id": 59297265,
        "body_markdown": "I have a log file and want to grep data from it, so I use Jq to filter some data by parameters.\r\n\r\nAs I said above, I will filter data based on the argument passed to Jq\r\n\r\nFor details:\r\n\r\nThe structure of my log file:\r\n\r\n     {\r\n     \tcity: &quot;&quot;,\r\n     \tphone_number: &quot;&quot;,\r\n     \taddress: &quot;&quot;,\r\n     \tzip_code: &quot;&quot;,\r\n     \tperson : {\r\n     \t\tname: &quot;&quot;,\r\n     \t\tsex: &quot;&quot;,\r\n     \t\t...\r\n     \t}\r\n     }\r\n\r\nMy expected is I want to ignore attributes use to filter if that is `empty` or `null`.\r\n\r\nFor example:\r\n\r\n    cat my_log_file.log | jq -r --arg city ${city} --arg name ${name}  &#39;select(.city == $city and .person.name == $name)&#39;\r\n\r\nWith the command above if `${city}` argument I passed is `empty` or `null` then I want to remove the filter with **city** and just filter with **name**\r\n\r\nI have tried but still doesn&#39;t work\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59297265/jq-select-condition",
        "title": "Jq select condition"
    },
    {
        "tags": [
            "bash",
            "curl",
            "jq",
            "slack",
            "slack-api"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1576138189,
                "post_id": 59299383,
                "comment_id": 104803416,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5513612,
                    "reputation": 33143,
                    "user_id": 4379151,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/kOLJQ.jpg?s=256",
                    "display_name": "Erik Kalkoken",
                    "link": "https://stackoverflow.com/users/4379151/erik-kalkoken"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576144362,
                "post_id": 59299383,
                "comment_id": 104806474,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "user_type": "does_not_exist",
                    "display_name": "user12377430"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576207238,
                "post_id": 59299383,
                "comment_id": 104832723,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1576207208,
        "creation_date": 1576134524,
        "last_edit_date": 1576207208,
        "question_id": 59299383,
        "body_markdown": "### Ideal\r\nI can send Slack API to post just like share, and ideal is to show pictures on it.\r\n\r\n### What I tried\r\n\r\n```javascript\r\n\tconst attachments = {\r\n        &quot;fallback&quot;: somePostData.text,\r\n\t\t&quot;ts&quot;: pickedMessage.ts,\r\n\t\t&quot;author_id&quot;: somePostData.user_id,\r\n\t\t&quot;author_subname&quot;: somePostData.user_name,\r\n\t\t&quot;channel_id&quot;: &quot;---&quot;,\r\n\t\t&quot;channel_name&quot;: &quot;---&quot;,\r\n\t\t&quot;is_msg_unfurl&quot;: true,\r\n\t\t&quot;text&quot;: somePostData.text,\r\n\t\t&quot;author_name&quot;: somePostData.user_name,\r\n\t\t&quot;author_link&quot;: &quot;---&quot;,\r\n\t\t&quot;author_icon&quot;: somePostData.user_icon,\r\n\t\t&quot;mrkdwn_in&quot;: [&quot;text&quot;],\r\n\t\t&quot;color&quot;: &quot;D0D0D0&quot;,\r\n\t\t// &quot;files&quot;: somePostData.files,\r\n\t\t&quot;from_url&quot;: somePostData.url,\r\n\t\t&quot;is_share&quot;: true,\r\n\t\t&quot;footer&quot;: &quot;Posted in ----&quot;\r\n\t}\r\n\r\n\tvar param = {\r\n\t\t&quot;response_type&quot;: &quot;in_channel&quot;,\r\n\t\t&quot;text&quot;: somePostData.url,\r\n\t\t&quot;files&quot;: somePostData.files,\r\n\t\t&quot;attachments&quot;: [ attachments ],\r\n        &quot;display_as_bot&quot;: false,\r\n        &quot;upload&quot;: true,\r\n\t}\r\n\tres.status(200).send(param);\r\n```\r\n\r\n\r\nI could post like share,  but it doesn&#39;t show pictures.\r\nI made sure the response has valid format like\r\n\r\n\r\n```json\r\n                    &quot;files&quot;: [\r\n                        {\r\n                            &quot;id&quot;: &quot;---&quot;,\r\n                            &quot;created&quot;: 1576130341,\r\n                            &quot;timestamp&quot;: 1576130341,\r\n                            &quot;name&quot;: &quot;---&quot;,\r\n                            &quot;title&quot;: &quot;---&quot;,\r\n                            &quot;mimetype&quot;: &quot;image\\/jpeg&quot;,\r\n                            &quot;filetype&quot;: &quot;jpg&quot;,\r\n                            &quot;pretty_type&quot;: &quot;JPEG&quot;,\r\n                            &quot;user&quot;: &quot;---&quot;,\r\n                            &quot;editable&quot;: false,\r\n                            &quot;size&quot;: 233329,\r\n                            &quot;mode&quot;: &quot;hosted&quot;,\r\n                            &quot;is_external&quot;: false,\r\n                            &quot;external_type&quot;: &quot;&quot;,\r\n                            &quot;is_public&quot;: true,\r\n                            &quot;public_url_shared&quot;: false,\r\n                            &quot;display_as_bot&quot;: false,\r\n                            &quot;username&quot;: &quot;&quot;,\r\n                            &quot;url_private&quot;: &quot;---&quot;,\r\n                            &quot;url_private_download&quot;: &quot;---&quot;,\r\n                            &quot;thumb_64&quot;: &quot;---&quot;,\r\n                            &quot;thumb_80&quot;: &quot;---&quot;,\r\n                            &quot;thumb_360&quot;: &quot;---&quot;,\r\n                            &quot;thumb_360_w&quot;: 360,\r\n                            &quot;thumb_360_h&quot;: 270,\r\n                            &quot;thumb_480&quot;: &quot;---&quot;,\r\n                            &quot;thumb_480_w&quot;: 480,\r\n                            &quot;thumb_480_h&quot;: 360,\r\n                            &quot;thumb_160&quot;: &quot;---&quot;,\r\n                            &quot;thumb_720&quot;: &quot;---&quot;,\r\n                            &quot;thumb_720_w&quot;: 720,\r\n                            &quot;thumb_720_h&quot;: 540,\r\n                            &quot;thumb_800&quot;: &quot;---&quot;,\r\n                            &quot;thumb_800_w&quot;: 800,\r\n                            &quot;thumb_800_h&quot;: 600,\r\n                            &quot;thumb_960&quot;: &quot;---&quot;,\r\n                            &quot;thumb_960_w&quot;: 960,\r\n                            &quot;thumb_960_h&quot;: 720,\r\n                            &quot;thumb_1024&quot;: &quot;---&quot;,\r\n                            &quot;thumb_1024_w&quot;: 1024,\r\n                            &quot;thumb_1024_h&quot;: 768,\r\n                            &quot;image_exif_rotation&quot;: 1,\r\n                            &quot;original_w&quot;: 1200,\r\n                            &quot;original_h&quot;: 900,\r\n                            &quot;thumb_tiny&quot;: &quot;---&quot;,\r\n                            &quot;permalink&quot;: &quot;---&quot;,\r\n                            &quot;permalink_public&quot;: &quot;---&quot;,\r\n                            &quot;is_starred&quot;: false,\r\n                            &quot;has_rich_preview&quot;: false\r\n                        }\r\n                    ],\r\n\r\n```\r\n\r\nI put this to attachment block and top level.\r\nbut it never worked.\r\n\r\n### Conclusion\r\nAny information is appreciated.",
        "link": "https://stackoverflow.com/questions/59299383/i-can-send-slack-api-to-post-just-like-share-but-its-not-working-to-show-pictu",
        "title": "I can send Slack API to post just like share, but it&#39;s not working to show Pictures"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 366852,
                    "reputation": 177148,
                    "user_id": 712649,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/tP0yV.jpg?s=256",
                    "display_name": "Mathias R. Jessen",
                    "link": "https://stackoverflow.com/users/712649/mathias-r-jessen"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576154174,
                "post_id": 59302509,
                "comment_id": 104811851,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576156492,
                "post_id": 59302509,
                "comment_id": 104813111,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7277951,
                    "reputation": 557,
                    "user_id": 5548735,
                    "user_type": "registered",
                    "profile_image": "https://lh5.googleusercontent.com/-I6D0ikqfSsA/AAAAAAAAAAI/AAAAAAAAApQ/4bpbVx3nWBQ/s256-rj/photo.jpg",
                    "display_name": "Pramod Yadav",
                    "link": "https://stackoverflow.com/users/5548735/pramod-yadav"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576164739,
                "post_id": 59302509,
                "comment_id": 104818123,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4601261,
                    "reputation": 28010,
                    "user_id": 6654942,
                    "user_type": "registered",
                    "accept_rate": 25,
                    "profile_image": "https://www.gravatar.com/avatar/ec4296025717927f341dc51d4000bbd9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "js2010",
                    "link": "https://stackoverflow.com/users/6654942/js2010"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576170024,
                "post_id": 59302509,
                "comment_id": 104821174,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1576164604,
                "creation_date": 1576164604,
                "answer_id": 59307976,
                "question_id": 59302509,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Although still dont know how to do it with jq, here is another way of achieving what I wanted using Powershell.\r\n\r\n    $inputJson = &#39;[{&quot;name&quot;:&quot;JSON&quot;, &quot;good&quot;:true}, {&quot;name&quot;:&quot;XML&quot;, &quot;good&quot;:false}]&#39; | ConvertFrom-Json\r\n    write-host &quot;`nNr of jsonObjects:&quot;\r\n    write-host $inputJson.Length\r\n    \r\n    write-host &quot;`nfirst jsonObject:&quot;\r\n    Write-Host $inputJson[0]\r\n\r\n    write-host &quot;`njsonObjects value:&quot;\r\n    $value = $inputJson[0] | ConvertTo-Json\r\n    Write-Host $value\r\n\r\nResult is:\r\nNr of jsonObjects:\r\n2\r\n\r\nfirst jsonObject:\r\n@{name=JSON; good=True}\r\n\r\njsonObjects value:\r\n{\r\n    &quot;name&quot;:  &quot;JSON&quot;,\r\n    &quot;good&quot;:  true\r\n}",
                "title": "jq &#39;.[]&#39; doesnt give jsonObjects but rather give psobjects in powershell. How to solve this?"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1576179242,
                "last_edit_date": 1576179242,
                "creation_date": 1576170383,
                "answer_id": 59309557,
                "question_id": 59302509,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The question is confusing.  All jq does is output strings.  Powershell will make each line a new string array element.  The only way I see it doing what you want, is with jq&#39;s `--compact-output` option, which outputs one object (to jq) per line.  That seems to be the way that online example was run, anyway.  But to powershell, these are two *strings*.  They would be objects to powershell only after using `convertfrom-json`.  \r\n\r\n    $items = $inputJson | jq &#39;.[]&#39; --compact-output\r\n    $items\r\n\r\n    {&quot;name&quot;:&quot;JSON&quot;,&quot;good&quot;:true}\r\n    {&quot;name&quot;:&quot;XML&quot;,&quot;good&quot;:false}\r\n",
                "title": "jq &#39;.[]&#39; doesnt give jsonObjects but rather give psobjects in powershell. How to solve this?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1576179242,
        "creation_date": 1576146501,
        "question_id": 59302509,
        "body_markdown": "Taking an example from JQs official site, I am trying to parse the jsonArray in below example screenshot. \r\n\r\n[![Parsing Json Array using jq ][2]][2]\r\n\r\nI am trying to get both jsonObjects, so that I can do something with them for my problem statement. However, when I try to do this in PowerShell using below code: \r\n\r\n$inputJson = &#39;[{&quot;name&quot;:&quot;JSON&quot;, &quot;good&quot;:true}, {&quot;name&quot;:&quot;XML&quot;, &quot;good&quot;:false}]&#39;\r\n\r\n$items = $inputJson | \tjq &#39;.[]&#39;\r\n\r\nI get not two $items objects but 8 $items psobjects. As seen in the second screenshot. \r\n[![enter image description here][1]][1]\r\n\r\nAny pointers, on what changes I can make to get only two jsonObjects here?\r\n\r\n\r\n\r\n\r\n  [1]: https://i.sstatic.net/mlNLZ.png\r\n  [2]: https://i.sstatic.net/a8B2q.png",
        "link": "https://stackoverflow.com/questions/59302509/jq-doesnt-give-jsonobjects-but-rather-give-psobjects-in-powershell-how-to",
        "title": "jq &#39;.[]&#39; doesnt give jsonObjects but rather give psobjects in powershell. How to solve this?"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1576170225,
                "post_id": 59309499,
                "comment_id": 104821267,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17295660,
                    "reputation": 31,
                    "user_id": 12526393,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AAuE7mD7HLwai-5v7XJSvSKShq8Ju237mDRPnvMVEO_rhA=k-s256",
                    "display_name": "Kris",
                    "link": "https://stackoverflow.com/users/12526393/kris"
                },
                "reply_to_user": {
                    "account_id": 1852014,
                    "reputation": 24882,
                    "user_id": 1678362,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ba023d18099cde022b9e4394d5714c0?s=256&d=identicon&r=PG",
                    "display_name": "Aaron",
                    "link": "https://stackoverflow.com/users/1678362/aaron"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576172392,
                "post_id": 59309499,
                "comment_id": 104822288,
                "content_license": "CC BY-SA 4.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": 1576174497,
                "post_id": 59309499,
                "comment_id": 104823199,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1576175645,
                "post_id": 59309499,
                "comment_id": 104823742,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1576176115,
                "last_edit_date": 1576176115,
                "creation_date": 1576170980,
                "answer_id": 59309738,
                "question_id": 59309499,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I believe you&#39;re looking for the following command :\r\n\r\n    jq --raw-output &#39;map( select(.filters | any(.attributeName == &quot;serverName&quot; and .value == &quot;Sever101&quot;)) |.sGName) | join(&quot;\\n&quot;)&#39;\r\n\r\nYou can [try it here](https://jqplay.org/s/UJiKKUvWQk).\r\n\r\nWith the serverName criteria extracted as a parameter :\r\n\r\n    jq --raw-output --arg serverName &quot;Sever101&quot; &#39;map( select(.filters | any(.attributeName == &quot;serverName&quot; and .value == $serverName)) |.sGName) | join(&quot;\\n&quot;)&#39;\r\n\r\n[oguz ismail](https://stackoverflow.com/users/10248678/) proposes a more streamlined solution :\r\n\r\n    jq --raw-output --arg serverName &quot;Sever101&quot; &#39;.[] | select(any(.filters[]; .attributeName==&quot;serverName&quot; and .value==$serverName)).sGName&#39;",
                "title": "Retrieve data from JSON where list items have specific/known values using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1576181695,
        "creation_date": 1576170113,
        "last_edit_date": 1576181695,
        "question_id": 59309499,
        "body_markdown": "I have a JSON file with block like below\r\n\r\n```json\r\n  {\r\n    &quot;id&quot;: 0000,\r\n    &quot;sGName&quot;: &quot;SG1&quot;,\r\n\r\n    &quot;customProperties&quot;: [\r\n      {\r\n        &quot;id&quot;: 100000,\r\n        &quot;name&quot;: &quot;clustersIP&quot;,\r\n        &quot;value&quot;: &quot;ABC&quot;\r\n      }\r\n    ],\r\n\r\n    &quot;filters&quot;: [\r\n      {\r\n        &quot;id&quot;: 74616,\r\n        &quot;attributeName&quot;: &quot;serverName&quot;,\r\n        &quot;value&quot;: &quot;Sever101&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 74617,\r\n        &quot;attributeName&quot;: &quot;bigIPPool&quot;,\r\n        &quot;value&quot;: &quot;server101v1&quot;\r\n      }\r\n    ],\r\n\r\n  },\r\n```\r\n\r\nI am looking for JQ in bash to retrieve\r\nsGName, where &quot;attributeName&quot;=&quot;serverName&quot;, and  &quot;value&quot;=&quot;Sever101&quot; Can some one please help on that?\r\n\r\nI might have multiple &quot;sGName&quot;",
        "link": "https://stackoverflow.com/questions/59309499/retrieve-data-from-json-where-list-items-have-specific-known-values-using-jq",
        "title": "Retrieve data from JSON where list items have specific/known values using JQ"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 103585,
                    "reputation": 346,
                    "user_id": 277363,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/8ff7f3980a944d3cdef0234c0da234a7?s=256&d=identicon&r=PG",
                    "display_name": "Lukasz Siemiradzki",
                    "link": "https://stackoverflow.com/users/277363/lukasz-siemiradzki"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1578360390,
                "post_id": 59323232,
                "comment_id": 105405494,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1576243248,
                "last_edit_date": 1576243248,
                "creation_date": 1576242859,
                "answer_id": 59323338,
                "question_id": 59323232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were almost there. Just add the objects in those arrays to objects you created out of keys.\r\n```\r\n.results | keys_unsorted[] as $k | { timestamp: $k } + .[$k][]\r\n```\r\n[Online demo with your sample](https://jqplay.org/s/1BeMW9tCtM)  \r\n[Online demo with a slightly different input to show what `+ .[$k][]` does clearly](https://jqplay.org/s/4v3Q6lVtyU)",
                "title": "jq: split one resultset to multiple json objects"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1576250831,
                "creation_date": 1576250831,
                "answer_id": 59325472,
                "question_id": 59323232,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or using `to_entries`:\r\n```\r\n.results\r\n| to_entries[]\r\n| { timestamp: .key } + .value[]\r\n```",
                "title": "jq: split one resultset to multiple json objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1576250831,
        "creation_date": 1576242398,
        "last_edit_date": 1576244660,
        "question_id": 59323232,
        "body_markdown": "I&#39;m trying to transform one big json resultset to multiple objects.\r\n\r\nInput:\r\n\r\n    {\r\n      &quot;results&quot;: {\r\n        &quot;2019-11-27 00:00:00&quot;: [\r\n          {\r\n            &quot;e&quot;: &quot;10814&quot;,\r\n            &quot;s&quot;: &quot;153330&quot;,\r\n            &quot;t&quot;: &quot;164144&quot;\r\n          }\r\n        ],\r\n        &quot;2019-11-27 00:15:00&quot;: [\r\n          {\r\n            &quot;e&quot;: &quot;11052&quot;,\r\n            &quot;s&quot;: &quot;148692&quot;,\r\n            &quot;t&quot;: &quot;159744&quot;\r\n          }\r\n        ],\r\n        &quot;2019-11-27 00:30:00&quot;: [\r\n          {\r\n            &quot;e&quot;: &quot;11550&quot;,\r\n            &quot;s&quot;: &quot;152379&quot;,\r\n            &quot;t&quot;: &quot;163929&quot;\r\n          }\r\n        ],\r\n        &quot;2019-11-27 00:45:00&quot;: [\r\n          {\r\n            &quot;e&quot;: &quot;12640&quot;,\r\n            &quot;s&quot;: &quot;154984&quot;,\r\n            &quot;t&quot;: &quot;167624&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\nThis is the output I&#39;m trying to reach:\r\n\r\n    {&quot;timestamp&quot;:&quot;2019-11-27 00:00:00&quot;,&quot;e&quot;:&quot;10814&quot;,&quot;s&quot;:&quot;153330&quot;,&quot;t&quot;:&quot;164144&quot;}\r\n    {&quot;timestamp&quot;:&quot;2019-11-27 00:15:00&quot;,&quot;e&quot;:&quot;11052&quot;,&quot;s&quot;:&quot;148692&quot;,&quot;t&quot;:&quot;159744&quot;}\r\n    {&quot;timestamp&quot;:&quot;2019-11-27 00:30:00&quot;,&quot;e&quot;:&quot;11550&quot;,&quot;s&quot;:&quot;152379&quot;,&quot;t&quot;:&quot;163929&quot;}\r\n    {&quot;timestamp&quot;:&quot;2019-11-27 00:45:00&quot;,&quot;e&quot;:&quot;12640&quot;,&quot;s&quot;:&quot;154984&quot;,&quot;t&quot;:&quot;167624&quot;}\r\n\r\nI tried so far:\r\n\r\n    $ cat input.json | jq -cr &#39;.[] | keys[] as $k | { &quot;timestamp&quot;: &quot;\\($k)&quot;}&#39;\r\n    {&quot;timestamp&quot;:&quot;2019-11-27 00:00:00&quot;}\r\n    {&quot;timestamp&quot;:&quot;2019-11-27 00:15:00&quot;}\r\n    {&quot;timestamp&quot;:&quot;2019-11-27 00:30:00&quot;}\r\n    {&quot;timestamp&quot;:&quot;2019-11-27 00:45:00&quot;}\r\n\r\n\r\nand\r\n\r\n    $ cat input.json | jq -c &#39;.[] | .[]  | .[]&#39;\r\n    {&quot;e&quot;:&quot;10814&quot;,&quot;s&quot;:&quot;153330&quot;,&quot;t&quot;:&quot;164144&quot;}\r\n    {&quot;e&quot;:&quot;11052&quot;,&quot;s&quot;:&quot;148692&quot;,&quot;t&quot;:&quot;159744&quot;}\r\n    {&quot;e&quot;:&quot;11550&quot;,&quot;s&quot;:&quot;152379&quot;,&quot;t&quot;:&quot;163929&quot;}\r\n    {&quot;e&quot;:&quot;12640&quot;,&quot;s&quot;:&quot;154984&quot;,&quot;t&quot;:&quot;167624&quot;}\r\n\r\nI just need a hint to combine these two filters to obtain the result as described above. I&#39;m not sure how to do it. Any ideas?\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59323232/jq-split-one-resultset-to-multiple-json-objects",
        "title": "jq: split one resultset to multiple json objects"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq",
            "json-path-expression"
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1576249471,
                "last_edit_date": 1576249471,
                "creation_date": 1576247999,
                "answer_id": 59324719,
                "question_id": 59324676,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your attempt failed because of following :\r\n\r\n&gt; Note that the LHS of assignment operators refers to a value in `.`. Thus\r\n&gt; `$var.foo = 1` won’t work as expected (`$var.foo` is not a valid or useful\r\n&gt; path expression in `.`); use `$var | .foo = 1` instead.\r\n\r\nFrom the [Assignment section of the jq manual](https://stedolan.github.io/jq/manual/#Assignment).\r\n\r\nIt likely only worked in your first `jq` command because `$list` and `.` were equal.\r\n\r\nFollowing that you could have used the following :\r\n\r\n    split(&quot;,&quot;) | map(tonumber) as $list | $list | .[0] = 30\r\n\r\nOr more simply in your case :\r\n\r\n    split(&quot;,&quot;) | map(tonumber) | .[0]=30",
                "title": "Invalid path expression near attempt to access element"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 7,
        "last_activity_date": 1576297805,
        "creation_date": 1576247821,
        "last_edit_date": 1576297805,
        "question_id": 59324676,
        "body_markdown": "When trying to change a single element in an array, I get `Invalid path expression near attempt to access element` - but only when the array is captured from `--rawInput`.\r\n\r\nExample:\r\n\r\n```\r\n# input: [ 1, 0 ]\r\n. as $list | $list[0] = 30\r\n# output: [ 30, 0 ]\r\n```\r\n\r\nBut this doesn&#39;t work:\r\n\r\n```\r\n# input: 1,0\r\nsplit(&quot;,&quot;) | map(tonumber) as $list | $list[0] = 30\r\n# Invalid path expression near attempt to access element 0 of [1,0]\r\n```\r\n\r\n- [Working example](https://jqterm.com/bbee16b98d741cc079a137c69dbd2c20?query=.%20as%20%24list%20%7C%20%24list%5B0%5D%20%3D%2030)\r\n- [Not working example](https://jqterm.com/5cac96271e2d235f2554543d852f5973?query=split%28%22%2C%22%29%20%7C%20map%28tonumber%29%20as%20%24list%20%7C%20%24list%5B0%5D%20%3D%2030&amp;raw-input=true)\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/59324676/invalid-path-expression-near-attempt-to-access-element",
        "title": "Invalid path expression near attempt to access element"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "curl",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1576345547,
                "last_edit_date": 1576345547,
                "creation_date": 1576344698,
                "answer_id": 59337520,
                "question_id": 59337414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you use `curl -sS` to retrieve the file, the &#39;//&#39;-style comments are skipped:\r\n```\r\ncurl -Ss &#39;https://jobs.github.com/positions.json?description=python&amp;location=new+york&#39; | jq &#39;.[] | .company&#39; \r\n&quot;BentoBox&quot;\r\n&quot;Aon Cyber Solutions&quot;\r\n&quot;Sesame&quot;\r\n&quot;New York University&quot;\r\n```\r\n\r\nSo presumably your JB.json contains the &quot;//&quot;-style comments.  The simplest workaround would probably be to filter out those first two lines (e.g. using `sed` (or jq!)) first.\r\n\r\nHere&#39;s a jq-only solution:\r\n```\r\n&lt; JB.json jq -Rr &#39;select( test(&quot;^//&quot;)|not)&#39; |\r\n   jq &#39;.[] | .company&#39; \r\n```\r\n",
                "title": "Jq parse error: Invalid numeric literal at line 1, column 9"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1576345547,
        "creation_date": 1576343885,
        "question_id": 59337414,
        "body_markdown": "I am trying to get values from a json file from a url using curl and then printing specific keys with jq command (e.g. company). Unfortunately when I use:\r\n```jq &#39;.[] | .company&#39; JB.json```\r\nI get the error: \r\n```parse error: Invalid numeric literal at line 1, column 9```. I have checked the downloaded file with less and it looks exactly like in the url. \r\n\r\nSome people suggested to use the -R option but it prints:\r\n```jq: error: Cannot iterate over string```\r\n\r\n\r\nThe url of the file is: https://jobs.github.com/positions.json?description=python&amp;location=new+york",
        "link": "https://stackoverflow.com/questions/59337414/jq-parse-error-invalid-numeric-literal-at-line-1-column-9",
        "title": "Jq parse error: Invalid numeric literal at line 1, column 9"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1576376994,
                "creation_date": 1576376994,
                "answer_id": 59340782,
                "question_id": 59340401,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d take a completely different approach and do this instead.\r\n\r\n    (now | todate) as $_processDate | [\r\n        .[].changes[]\r\n        | (.change\r\n            | scan(&quot;\\\\b(submitted|rejected)=true\\\\b&quot;)[]\r\n            | {submitted:&quot;submission&quot;,rejected:&quot;rejection&quot;}[.]) as $type\r\n        | {id, date, $type, user, $_processDate}\r\n    ]\r\n\r\nFirst take note of the current date at the beginning. Then determine what type of change it is. Assuming that &quot;submitted&quot; and &quot;rejected&quot; (or other &quot;types&quot;) are mutually exclusive, easier to match on the key name. Then build up the result. This will keep the results in an array.\r\n\r\nhttps://jqplay.org/s/S65ySzbF30\r\n",
                "title": "jq not getting expected output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1576376994,
        "creation_date": 1576371232,
        "last_edit_date": 1576374639,
        "question_id": 59340401,
        "body_markdown": "**My JSON looks like this.**\r\n```\r\n&quot;[{\r\n   changes&quot;: [\r\n    {\r\n      &quot;change&quot;: &quot;{users=[7], submitted=true}&quot;,\r\n      &quot;date&quot;: &quot;2016-11-13T14:34:27.353Z&quot;,\r\n      &quot;user&quot;: &quot;abcd&quot;\r\n    }\r\n   ]\r\n}]\r\n```\r\n**Expected Output:**\r\n```\r\n{\r\n      id: null,\r\n      date: &quot;2016-11-13T14:34:27.353Z&quot;,\r\n      type: &quot;submission&quot;,\r\n      user: abcd,\r\n      _processDate: todaysDate\r\n    }\r\n```\r\n**JQ I tried**\r\n```\r\n[.[][] as $source |\r\n$source.changes[] as $log |\r\n$log.change |\r\n{\r\n  submitted: .| (scan(&quot;submitted=(?&lt;submitted&gt;[^,}]+)&quot;) // [&quot;&quot;] ) | .[0],\r\n  rejected: .| (scan(&quot;rejected=(?&lt;rejected&gt;[^,}]+)&quot;) // [&quot;&quot;] ) | .[0]\r\n\r\n} as $change |\r\n[\r\n  (\r\n    select($change.submitted == &quot;true&quot;) |\r\n    {\r\n      id: $source.id,\r\n      date: $log.date,\r\n      type: &quot;submission&quot;,\r\n      user: $log.user,\r\n      _processDate: now | todate\r\n    }),\r\n    (select($change.rejected == &quot;true&quot;) |\r\n    {\r\n      id: $source.id,\r\n      date: $log.date,\r\n      type: &quot;rejection&quot;,\r\n      user: $log.user,\r\n      _processDate: now | todate\r\n    }\r\n  )\r\n] |\r\n.[]]\r\n```\r\n\r\nThere could &#39;rejections&#39; in the json and the output should display the rejections .\r\nMy JQ is not yielding expected output. \r\nAny pointers on how to fix this query.\r\nThank you for your help.\r\nAppreciate it.",
        "link": "https://stackoverflow.com/questions/59340401/jq-not-getting-expected-output",
        "title": "jq not getting expected output"
    },
    {
        "tags": [
            "arrays",
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1576400249,
                "post_id": 59342412,
                "comment_id": 104882222,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1576400593,
                "creation_date": 1576400593,
                "answer_id": 59342503,
                "question_id": 59342412,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need reduce here, `group_by` should suffice. E.g:\r\n```\r\n.remote | group_by(.name) | map({(.[0].name): map(.id)}) | add\r\n```\r\nhttps://jqplay.org/s/_0CFADWu2G",
                "title": "filter specific entries in an array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1576400593,
        "creation_date": 1576399637,
        "question_id": 59342412,
        "body_markdown": "i&#39;ll make this short.\r\nThis is what im dealin with. I&#39;ve got a link using curl to pipe a json format output to filter specific entries using jq.\r\nThis is the json file\r\n\r\n```\r\n{\r\n    &quot;remote&quot;:  [\r\n        {&quot;name&quot;: &quot;cast-1&quot;,\r\n         &quot;id&quot;: 1212\r\n        },\r\n        {&quot;name&quot;: &quot;cast-1&quot;,\r\n         &quot;id&quot;: 1214\r\n        },\r\n        {&quot;name&quot;: &quot;home-11&quot;,\r\n         &quot;id&quot;: 3212\r\n        },\r\n        {&quot;name&quot;: &quot;cast-3&quot;,\r\n         &quot;id&quot;: 3212\r\n        },\r\n        {&quot;name&quot;: &quot;cast-3&quot;,\r\n         &quot;id&quot;: 3213\r\n        },\r\n        {&quot;name&quot;: &quot;cast-4&quot;,\r\n         &quot;id&quot;: 4211\r\n        }\r\n\r\n    ]\r\n}\r\n```\r\nmy desired output is\r\n```\r\n &quot;cast-1&quot;: 1212 , 1214,\r\n &quot;cast-3&quot;: 3212 , 3213,\r\n &quot;cast-4&quot;: 4211,\r\n```\r\n\r\nwith my attempt, i only am able to output this\r\n\r\n```\r\n &quot;cast-1&quot;: 1214,\r\n &quot;cast-3&quot;: 3213, \r\n &quot;cast-4&quot;: 4211,\r\n```\r\n\r\nmy code so far\r\n```\r\ncurl ... | jq  &#39;reduce .remote[] as $v ({}; . + {&quot;\\($v.name)&quot;:$v.id})&#39;  \r\n\r\n```\r\n\r\nCant figure out to add the second id from cast-1 and cast-3.\r\nIs there a method to format the output, to get a valid JSON output format?\r\nmaybe python or perl method? Im not familiar with awk, sed to let you know.",
        "link": "https://stackoverflow.com/questions/59342412/filter-specific-entries-in-an-array-using-jq",
        "title": "filter specific entries in an array using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1576515913,
                "last_edit_date": 1576515913,
                "creation_date": 1576491448,
                "answer_id": 59354557,
                "question_id": 59354507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`sort_by` assumes its input is iterable, and expands it by applying `.[]` before sorting its members. You&#39;re providing a stream of objects to it, and each object expands to a stream of non-indexable values (`&quot;XX&quot;, 1` etc.) in this case, thus `.guid` fails.\r\n\r\nSlurp them to make it work, e.g:\r\n```\r\njq -s &#39;sort_by(.guid)[]&#39; conn.json\r\n```\r\n\r\n---\r\nTo extract the object with the largest GUID, you wouldn&#39;t sort the slurped input manually; for such tasks, jq has `max_by`, e.g:\r\n```\r\njq -s &#39;max_by(.guid)&#39; conn.json\r\n```\r\nand `reduce`, which is a more convenient construct for large inputs and eliminates the need for slurping.\r\n```\r\njq &#39;reduce inputs as $in (input; if $in.guid &gt; .guid then $in else . end)&#39; conn.json",
                "title": "jq - order by value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1576515913,
        "creation_date": 1576491277,
        "last_edit_date": 1576492928,
        "question_id": 59354507,
        "body_markdown": "I have the following structure:\r\n\r\n    {&quot;ID&quot;:&quot;XX&quot;,&quot;guid&quot;:1}\r\n    {&quot;ID&quot;:&quot;YY&quot;,&quot;guid&quot;:2}\r\n    ...\r\n\r\nI have tried running:\r\n\r\n    jq &#39;sort_by(.guid)&#39; conn.json\r\n\r\nI however get an error:\r\n\r\n    Cannot index string with string &quot;guid&quot;\r\n\r\nPlease can you advise how I&#39;d sort the file by guid and/or find the record where guid is the largest?\r\n\r\n**UPDATE**\r\n\r\nWhat I am actually looking for is the record where the GUID is the largest in the dataset. Thought sorting it would help me but it&#39;s proving to be very slow\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/59354507/jq-order-by-value",
        "title": "jq - order by value"
    },
    {
        "tags": [
            "json",
            "csv",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1576524433,
                "last_edit_date": 1576524433,
                "creation_date": 1576509215,
                "answer_id": 59359390,
                "question_id": 59358517,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Found it:\r\n\r\n```\r\njq &#39;keys[] as $host \r\n  | .[]\r\n  | keys[] as $fs\r\n  | .[$fs][&quot;available&quot;] as $val \r\n  | .[$fs][&quot;total&quot;] as $tot\r\n  | {host:$host, fs: $fs, val: $val, tot: $tot }\r\n  | select(.tot&gt;0)\r\n  | (($val/$tot)*100) as $perc\r\n  | select($perc&lt;5) \r\n  | [$host,$fs,$perc]\r\n  | @csv\r\n```",
                "title": "jq obtain parent and child key perform calculation on grandchild values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1576527893,
                "last_edit_date": 1576527893,
                "creation_date": 1576524349,
                "answer_id": 59363085,
                "question_id": 59358517,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your approach can be simplified, robustified and made more efficient:\r\n```\r\nkeys_unsorted[] as $host\r\n| .[$host]\r\n| keys_unsorted[] as $fs\r\n| .[$fs]\r\n| select(.total &gt; 0)\r\n| ((.available/.total)*100) as $perc\r\n| select($perc &lt; 5)\r\n| [$host, $fs, $perc]\r\n| @csv\r\n```\r\n\r\nThis assumes the original ordering of keys should be preserved.  If you want the keys to be sorted, then by all means use `keys` instead of `keys_unsorted` as appropriate.\r\n\r\n",
                "title": "jq obtain parent and child key perform calculation on grandchild values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1576537472,
        "creation_date": 1576506000,
        "last_edit_date": 1576537472,
        "question_id": 59358517,
        "body_markdown": "Been trying everything I can think of for days on this, I just want to do following, from this JSON:\r\n\r\n```\r\n{\r\n    &quot;kube-prod-worker-0&quot;: {\r\n        &quot;/var/lib/docker/aufs&quot;: {\r\n            &quot;available&quot;: 222222733312, \r\n            &quot;total&quot;: 312202997760\r\n        },\r\n        &quot;/var/lib/docker/aufs/mnt/0000000000000007ffb4e1xxxx5&quot;: {\r\n            &quot;available&quot;: 222222733399, \r\n            &quot;total&quot;: 1634054144\r\n        }\r\n    }\r\n}\r\n{\r\n    &quot;kube-prod-worker-7&quot;: {\r\n        &quot;/var/lib/docker/aufs&quot;: {\r\n            &quot;available&quot;: 253056245760, \r\n            &quot;total&quot;: 3122029977600\r\n        }, \r\n        &quot;/var/lib/docker/aufs/mnt/000000000dc1150f1xxxxdd3e4e4d3&quot;: {\r\n            &quot;available&quot;: 253056245760, \r\n            &quot;total&quot;: 3122029977605\r\n        } \r\n    }\r\n}\r\n```\r\n\r\nFor each top-level key, $host (e.g. kube-prod-worker-0), and for each key, $fs, at the next level (e.g. &quot;/var/lib/docker/aufs&quot;), compute the percentage available, $pc; if the percentage is less than 5% then output as CSV:\r\n\r\n    $host, $fs, $pc \r\n\r\nThis is what I&#39;ve got so far, which appears to repeats for every grandchild for each parent and child:\r\n\r\n```\r\n$ cat diskusage.json | jq -r &#39; keys[] as $host | .[] | keys[] as $fs | $host,$fs, values[].available,values[].total&#39;\r\nkube-prod-worker-0\r\n/var/lib/docker/aufs\r\n222222733312\r\n222222733399\r\n312202997760\r\n1634054144\r\nkube-prod-worker-0\r\n/var/lib/docker/aufs/mnt/0000000000000007ffb4e1xxxx5\r\n222222733312\r\n222222733399\r\n312202997760\r\n1634054144\r\nkube-prod-worker-7\r\n/var/lib/docker/aufs\r\n253056245760\r\n253056245760\r\n3122029977600\r\n3122029977605\r\nkube-prod-worker-7\r\n/var/lib/docker/aufs/mnt/000000000dc1150f1xxxxdd3e4e4d3\r\n253056245760\r\n253056245760\r\n3122029977600\r\n3122029977605\r\n```\r\n\r\nAnd produce percentages:\r\n\r\n```\r\n$ cat diskusage.json | jq -r &#39; keys[] as $host | .[] | keys[] as $fs | $host,$fs, (values[].available/values[].total)*100 &#39;\r\nkube-prod-worker-0\r\n/var/lib/docker/aufs\r\n71.17892361905808\r\n71.17892364692456\r\n13599.471849079682\r\n13599.471854403864\r\nkube-prod-worker-0\r\n/var/lib/docker/aufs/mnt/0000000000000007ffb4e1xxxx5\r\n71.17892361905808\r\n71.17892364692456\r\n13599.471849079682\r\n13599.471854403864\r\nkube-prod-worker-7\r\n/var/lib/docker/aufs\r\n8.105503392844808\r\n8.105503392844808\r\n8.105503392831826\r\n8.105503392831826\r\nkube-prod-worker-7\r\n/var/lib/docker/aufs/mnt/000000000dc1150f1xxxxdd3e4e4d3\r\n8.105503392844808\r\n8.105503392844808\r\n8.105503392831826\r\n8.105503392831826\r\n```",
        "link": "https://stackoverflow.com/questions/59358517/jq-obtain-parent-and-child-key-perform-calculation-on-grandchild-values",
        "title": "jq obtain parent and child key perform calculation on grandchild values"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1576509709,
                "creation_date": 1576509709,
                "answer_id": 59359532,
                "question_id": 59358553,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not to diminish your efforts at all, but that&#39;s not how we use jq. You can do this in a single call, e.g:\r\n```\r\njq --arg originResponse ZZZ --arg viewerRequest YYY --arg originRequest XXX &#39;\r\n.DistributionConfig.DefaultCacheBehavior.LambdaFunctionAssociations.Items |= map(\r\n  .EventType as $t | .LambdaFunctionARN =\r\n    if $t == &quot;origin-response&quot; then $originResponse\r\n    elif $t == &quot;viewer-request&quot; then $viewerRequest\r\n    elif $t == &quot;origin-request&quot; then $originRequest\r\n    else . end\r\n)&#39; file\r\n```",
                "title": "how to replace entire array using jq in shell script?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1576509785,
        "creation_date": 1576506146,
        "last_edit_date": 1576509785,
        "question_id": 59358553,
        "body_markdown": "Having the following structure:\r\n```\r\n{\r\n  &quot;DistributionConfig&quot;: {\r\n    &quot;DefaultCacheBehavior&quot;: {\r\n      &quot;LambdaFunctionAssociations&quot;: {\r\n        &quot;Quantity&quot;: 3,\r\n        &quot;Items&quot;: [\r\n          {\r\n            &quot;LambdaFunctionARN&quot;: &quot;3&quot;,\r\n            &quot;EventType&quot;: &quot;origin-response&quot;,\r\n            &quot;IncludeBody&quot;: false\r\n          },\r\n          {\r\n            &quot;LambdaFunctionARN&quot;: &quot;2&quot;,\r\n            &quot;EventType&quot;: &quot;viewer-request&quot;,\r\n            &quot;IncludeBody&quot;: false\r\n          },\r\n          {\r\n            &quot;LambdaFunctionARN&quot;: &quot;1&quot;,\r\n            &quot;EventType&quot;: &quot;origin-request&quot;,\r\n            &quot;IncludeBody&quot;: false\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\nI extracted the items and modified them using the following:\r\n\r\n    export lambdaFunctionAssociations=$(echo $json |  jq &#39;.DistributionConfig.DefaultCacheBehavior.LambdaFunctionAssociations.Items&#39; |\r\n     jq &#39;map(if .EventType == &quot;origin-response&quot;\r\n              then . + {&quot;LambdaFunctionARN&quot;:&#39;$originResponse&#39;}\r\n              else .\r\n              end\r\n             )&#39;  |\r\n    jq &#39;map(if .EventType == &quot;viewer-request&quot;\r\n              then . + {&quot;LambdaFunctionARN&quot;:&#39;$viewerRequest&#39;}\r\n              else .\r\n              end\r\n             )&#39; |\r\n    jq &#39;map(if .EventType == &quot;origin-request&quot;\r\n              then . + {&quot;LambdaFunctionARN&quot;:&#39;$originRequest&#39;}\r\n              else .\r\n              end\r\n             )&#39;)\r\n\r\n\r\nNow I have the following stored in lambdaFunctionAssociations:\r\n\r\n    [\r\n      {\r\n        &quot;LambdaFunctionARN&quot;: &quot;ZZZ&quot;,\r\n        &quot;EventType&quot;: &quot;origin-response&quot;,\r\n        &quot;IncludeBody&quot;: false\r\n      },\r\n      {\r\n        &quot;LambdaFunctionARN&quot;: &quot;YYY&quot;,\r\n        &quot;EventType&quot;: &quot;viewer-request&quot;,\r\n        &quot;IncludeBody&quot;: false\r\n      },\r\n      {\r\n        &quot;LambdaFunctionARN&quot;: &quot;XXX&quot;,\r\n        &quot;EventType&quot;: &quot;origin-request&quot;,\r\n        &quot;IncludeBody&quot;: false\r\n      }\r\n    ]\r\n\r\nI want to replace the &quot;Items&quot;: in the org json trying this:\r\n\r\n    export updatedCloudFrontConf=$(echo $json | jq &#39;.DistributionConfig.DefaultCacheBehavior.LambdaFunctionAssociations.Items=&#39;$lambdaFunctionAssociations&#39;&#39;)\r\n\r\n\r\nwith thefollowing error: \r\n\r\n    jq: error: syntax error, unexpected $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .DistributionConfig.DefaultCacheBehavior.LambdaFunctionAssociations.Items=[\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59358553/how-to-replace-entire-array-using-jq-in-shell-script",
        "title": "how to replace entire array using jq in shell script?"
    },
    {
        "tags": [
            "sql",
            "json",
            "database",
            "jq",
            "druid"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1576607583,
                "creation_date": 1576607583,
                "answer_id": 59380161,
                "question_id": 59379953,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you have enough RAM, the simplest would be to use:\r\n\r\n    jq -sc &#39;.[]&#39;\r\n\r\nIf you don&#39;t have enough RAM, then use:\r\n\r\n    jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39;",
                "title": "Newline based resultFormat for Druid native queries"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1579365268,
        "creation_date": 1576606589,
        "question_id": 59379953,
        "body_markdown": "I have a usecase wherein a Druid query results in millions of rows which makes it obvious to consume the response as a stream of rows with a new line for each.\r\n\r\nThe [Druid SQL over HTTP][1] has very good support for this with a `resultFormat` config supporting `objectLines`, `arrayLines`, &amp; `csv` enabling stream-based response consumption.\r\n\r\nHowever, I&#39;m using Druid&#39;s native queries which don’t seem to consider `resultFormat` config. The response is a JSONArray just like -\r\n```\r\n[\r\n  {\r\n    &quot;version&quot; : &quot;v1&quot;,\r\n    &quot;timestamp&quot; : &quot;2012-01-01T00:00:00.000Z&quot;,\r\n    &quot;event&quot; : {\r\n      &quot;country&quot; : &lt;some_dim_value_one&gt;,\r\n      &quot;device&quot; : &lt;some_dim_value_two&gt;,\r\n      &quot;total_usage&quot; : &lt;some_value_one&gt;,\r\n      &quot;data_transfer&quot; :&lt;some_value_two&gt;,\r\n      &quot;avg_usage&quot; : &lt;some_avg_usage_value&gt;\r\n    }\r\n  },\r\n  {\r\n    &quot;version&quot; : &quot;v1&quot;,\r\n    &quot;timestamp&quot; : &quot;2012-01-01T00:00:12.000Z&quot;,\r\n    &quot;event&quot; : {\r\n      &quot;dim1&quot; : &lt;some_other_dim_value_one&gt;,\r\n      &quot;dim2&quot; : &lt;some_other_dim_value_two&gt;,\r\n      &quot;sample_name1&quot; : &lt;some_other_value_one&gt;,\r\n      &quot;sample_name2&quot; :&lt;some_other_value_two&gt;,\r\n      &quot;avg_usage&quot; : &lt;some_other_avg_usage_value&gt;\r\n    }\r\n  },\r\n...\r\n]\r\n```\r\n\r\nThis response doesn’t contain newline and is difficult to process as a stream. It needs to download entire resultset and then parse using tools like `jq` to extract row per line.\r\n\r\nP.S I&#39;ve tested `jd --stream` which is again not very fast. Hence want to know if there is anything to get native query results as newline-separated rows.\r\n\r\n  [1]: https://druid.apache.org/docs/latest/querying/sql.html#responses",
        "link": "https://stackoverflow.com/questions/59379953/newline-based-resultformat-for-druid-native-queries",
        "title": "Newline based resultFormat for Druid native queries"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576610949,
                "post_id": 59380424,
                "comment_id": 104953702,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1325431,
                    "reputation": 846,
                    "user_id": 2088767,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/816ad35fd29cb6e8adfc747d36caec7f?s=256&d=identicon&r=PG",
                    "display_name": "Matt",
                    "link": "https://stackoverflow.com/users/2088767/matt"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576700593,
                "post_id": 59380424,
                "comment_id": 104988090,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576700726,
                "post_id": 59380424,
                "comment_id": 104988143,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1325431,
                    "reputation": 846,
                    "user_id": 2088767,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/816ad35fd29cb6e8adfc747d36caec7f?s=256&d=identicon&r=PG",
                    "display_name": "Matt",
                    "link": "https://stackoverflow.com/users/2088767/matt"
                },
                "reply_to_user": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576794698,
                "post_id": 59380424,
                "comment_id": 105022725,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1576611455,
                "creation_date": 1576611455,
                "answer_id": 59381015,
                "question_id": 59380424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    .thing[0] as $tofind | .other[$tofind]",
                "title": "use jq variable (from &quot;as&quot;) to look up a key"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1576622686,
                "creation_date": 1576622686,
                "answer_id": 59383175,
                "question_id": 59380424,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could simply write:\r\n\r\n    jq &#39;.other[.thing[0]]&#39;\r\n\r\n",
                "title": "use jq variable (from &quot;as&quot;) to look up a key"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1576622686,
        "creation_date": 1576608821,
        "question_id": 59380424,
        "body_markdown": "Given JSON like:\r\n```\r\n{&quot;thing&quot;: [&quot;hello&quot;, &quot;bye&quot;], &quot;other&quot;: {&quot;hello&quot;: &quot;myval&quot;}}\r\n```\r\nI want a jq expression which takes the first element of the array under &quot;thing&quot; and looks it up in &quot;other&quot;. So I did:\r\n```\r\njq &#39;.thing[0] as $tofind | .other.$tofind&#39;\r\n```\r\nbut I get\r\n```\r\njq: error: syntax error, unexpected &#39;$&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.thing[0] as $tofind | .other.$tofind\r\njq: 1 compile error\r\n```\r\nI&#39;ve tried a variety of other approaches:\r\n```\r\necho &#39;{&quot;thing&quot;: [&quot;hello&quot;, &quot;bye&quot;], &quot;other&quot;: {&quot;hello&quot;: &quot;myval&quot;}}&#39; | jq &#39;.thing[0] as $tofind | .other.($tofind)&#39;\r\njq: error: syntax error, unexpected &#39;(&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.thing[0] as $tofind | .other.($tofind)\r\njq: 1 compile error\r\necho &#39;{&quot;thing&quot;: [&quot;hello&quot;, &quot;bye&quot;], &quot;other&quot;: {&quot;hello&quot;: &quot;myval&quot;}}&#39; | jq &#39;.thing[0] as $tofind | .other.[($tofind)]&#39;\r\njq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.thing[0] as $tofind | .other.[($tofind)]\r\njq: 1 compile error\r\necho &#39;{&quot;thing&quot;: [&quot;hello&quot;, &quot;bye&quot;], &quot;other&quot;: {&quot;hello&quot;: &quot;myval&quot;}}&#39; | jq &#39;.thing[0] as $tofind | .other.[$tofind]&#39;\r\njq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.thing[0] as $tofind | .other.[$tofind]\r\njq: 1 compile error\r\necho &#39;{&quot;thing&quot;: [&quot;hello&quot;, &quot;bye&quot;], &quot;other&quot;: {&quot;hello&quot;: &quot;myval&quot;}}&#39; | jq &#39;.thing[0] as $tofind | .other.[&quot;$tofind&quot;]&#39;\r\njq: error: syntax error, unexpected &#39;[&#39;, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.thing[0] as $tofind | .other.[&quot;$tofind&quot;]\r\njq: 1 compile error\r\necho &#39;{&quot;thing&quot;: [&quot;hello&quot;, &quot;bye&quot;], &quot;other&quot;: {&quot;hello&quot;: &quot;myval&quot;}}&#39; | jq &#39;.thing[0] as $tofind | .other.&quot;$tofind&quot;&#39;\r\nnull\r\necho &#39;{&quot;thing&quot;: [&quot;hello&quot;, &quot;bye&quot;], &quot;other&quot;: {&quot;hello&quot;: &quot;myval&quot;}}&#39; | jq &#39;.thing[0] as $tofind | .other.&quot;($tofind)&quot;&#39;\r\nnull\r\n```\r\n\r\nI found a hacky workaround with `select` and `to_entries`, but I feel like there&#39;s got to be a decent way to do this that I&#39;m missing.",
        "link": "https://stackoverflow.com/questions/59380424/use-jq-variable-from-as-to-look-up-a-key",
        "title": "use jq variable (from &quot;as&quot;) to look up a key"
    },
    {
        "tags": [
            "json",
            "csv",
            "export-to-csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1576615816,
                "creation_date": 1576615816,
                "answer_id": 59381887,
                "question_id": 59381620,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You should add the -r command-line option when invoking jq.\r\n\r\nExample:\r\n\r\n```\r\n$ curl -Ss &#39;https://uinames.com/api/?amount=3&#39; |\r\n   jq -r &#39;.[] | [.name, .surname] | @csv&#39; \r\n&quot;Γόργασος&quot;,&quot;Θεοδωρίδης&quot;\r\n&quot;Marta&quot;,&quot;Brediceanu&quot;\r\n&quot;Iulian&quot;,&quot;B&#226;rcă&quot;\r\n```",
                "title": "jq - json list of dicts to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1576657367,
        "creation_date": 1576614370,
        "last_edit_date": 1576657367,
        "question_id": 59381620,
        "body_markdown": "Input JSON example:\r\n```json\r\n[\r\n  {&quot;name&quot;:&quot;Θεμιστοκλής&quot;,&quot;surname&quot;:&quot;Παπαϊωάννου&quot;,&quot;gender&quot;:&quot;male&quot;,&quot;region&quot;:&quot;Greece&quot;}, \r\n  {&quot;name&quot;:&quot;Casian&quot;,&quot;surname&quot;:&quot;Cusin&quot;,&quot;gender&quot;:&quot;male&quot;,&quot;region&quot;:&quot;Romania&quot;}\r\n]\r\n```\r\nNow with my code I have output as strings:\r\n```\r\n$ curl -s https://uinames.com/api/?amount=3 | jq &#39;.[] | [.name, .surname] | @csv&#39;\r\n&quot;\\&quot;Anamaria\\&quot;,\\&quot;Tămaș\\&quot;&quot;\r\n&quot;\\&quot;Aurora\\&quot;,\\&quot;Coronado\\&quot;&quot;\r\n&quot;\\&quot;Εύηνος\\&quot;,\\&quot;Ελευθερόπουλος\\&quot;&quot;\r\n```\r\nWhat I need:\r\n```\r\n&quot;Anamaria&quot;,&quot;Tămaș&quot;\r\n&quot;Aurora&quot;,&quot;Coronado&quot;\r\n&quot;Εύηνος&quot;,&quot;Ελευθερόπουλος&quot;\r\n```\r\nCan anybody explain please what I do wrong?",
        "link": "https://stackoverflow.com/questions/59381620/jq-json-list-of-dicts-to-csv",
        "title": "jq - json list of dicts to csv"
    },
    {
        "tags": [
            "shell",
            "awk",
            "command",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1576614650,
                "creation_date": 1576614650,
                "answer_id": 59381668,
                "question_id": 59381644,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Like this, using a proper [tag:json] parser: [tag:jq] :\r\n\r\n    curl -s &#39;https://bch-chain.api.btc.com/v3/block/latest&#39; | jq &#39;.data.height&#39;\r\n\r\n\r\n##&#160;output\r\n\r\n    613777\r\n",
                "title": "AWK command print number only"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1576631342,
        "creation_date": 1576614472,
        "last_edit_date": 1576631342,
        "question_id": 59381644,
        "body_markdown": "I am trying to print just the number with this code, although I get the &quot;XXX,version&quot;. Any ideas how I could fix it?\r\n\r\n```sh\r\nwget -O - https://bch-chain.api.btc.com/v3/block/latest 2&gt;/dev/null | awk -F &#39;:&#39; &#39;{print $3}&#39;\r\n````\r\n\r\n&gt; 613777,&quot;version&quot;\r\n\r\nAny help is greatly appreciated.",
        "link": "https://stackoverflow.com/questions/59381644/awk-command-print-number-only",
        "title": "AWK command print number only"
    },
    {
        "tags": [
            "json",
            "nested",
            "jq",
            "data-manipulation"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1576703168,
                "last_edit_date": 1576703168,
                "creation_date": 1576628257,
                "answer_id": 59383901,
                "question_id": 59383329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following filter produces the &quot;Option 2&quot; output:\r\n```\r\n.Marketplace |= map(\r\n  {Level1Name} as $Level1Name\r\n  | .Level1Array[]\r\n  | {Level2Name} as $Level2Name\r\n  | .Level2Contents[]?\r\n  | select(.Level3Name == &quot;ALL&quot;)\r\n  | $Level1Name + $Level2Name + . )\r\n\r\n```\r\n\r\n## Breaking it down ...\r\nOne way to understand this is to consider:\r\n```\r\n.Marketplace[]\r\n| {Level1Name} as $Level1Name\r\n| .Level1Array[]\r\n| {Level2Name} as $Level2Name\r\n| .Level2Contents[]?             # in case .Level2Contents is missing\r\n| if (.Level3Name == &quot;ALL&quot;)\r\n  then $Level1Name + $Level2Name + .\r\n  else empty\r\n  end\r\n```\r\n\r\n## Addendum: &quot;Name&quot;\r\nThe OP subsequently asked what can be done if the three levels of &quot;Name&quot; keys are all named &quot;Name&quot;.  An answer can easily be obtained by tweaking the above, to yield:\r\n```\r\n.Marketplace |= map(\r\n  {Level1Name: .Name} as $Level1Name\r\n  | .Level1Array[]\r\n  | {Level2Name: .Name} as $Level2Name\r\n  | .Level2Contents[]?\r\n  | select(.Name == &quot;ALL&quot;)\r\n  | $Level1Name + $Level2Name + . )\r\n```\r\n\r\n### Output\r\nIn this case, the output would be as follows:\r\n\r\n```\r\n{\r\n  &quot;Marketplace&quot;: [\r\n    {\r\n      &quot;Level1Name&quot;: &quot;Company A Products&quot;,\r\n      &quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n      &quot;Name&quot;: &quot;ALL&quot;,\r\n      &quot;Level3URL&quot;: &quot;https://a.com/products&quot;\r\n    },\r\n    {\r\n      &quot;Level1Name&quot;: &quot;Company B Products&quot;,\r\n      &quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n      &quot;Name&quot;: &quot;ALL&quot;,\r\n      &quot;Level3URL&quot;: &quot;https://b.com/products&quot;\r\n    },\r\n    {\r\n      &quot;Level1Name&quot;: &quot;Company B Products&quot;,\r\n      &quot;Level2Name&quot;: &quot;EU Products List&quot;,\r\n      &quot;Name&quot;: &quot;ALL&quot;,\r\n      &quot;Level3URL&quot;: &quot;https://b.eu/products&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Use JQ to parse JSON nested objects, using select to match key-value in nested object while showing existing structure"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1576649119,
                "last_edit_date": 1576649119,
                "creation_date": 1576647854,
                "answer_id": 59386116,
                "question_id": 59383329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a different approach you could take for this problem. As I understand it, you want a way to search your recursive tree of objects for some value, and remove any objects that do not have a property with that value.\r\n\r\nWhat you could do is search for the paths of all values you wish to keep (has the value you&#39;re searching for), then remove all other objects that are not on the paths of any of the paths to keep.\r\n\r\n    def is_subpath($paths): [., length] as [$path, $length] |\r\n        any($paths[]; $length &lt;= length and $path == .[:$length]);\r\n    [paths(strings == &quot;ALL&quot;)[:-1]] as $keepers\r\n    | delpaths([paths(objects) | select(is_subpath($keepers) | not)])\r\n\r\n&lt;!-- --&gt;\r\n\r\n    {\r\n      &quot;Marketplace&quot;: [\r\n        {\r\n          &quot;Level1Name&quot;: &quot;Company A Products&quot;,\r\n          &quot;Level1Array&quot;: [\r\n            {\r\n              &quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n              &quot;Level2Contents&quot;: [\r\n                {\r\n                  &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n                  &quot;Level3URL&quot;: &quot;https://a.com/products&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;Level1Name&quot;: &quot;Company B Products&quot;,\r\n          &quot;Level1Array&quot;: [\r\n            {\r\n              &quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n              &quot;Level2Contents&quot;: [\r\n                {\r\n                  &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n                  &quot;Level3URL&quot;: &quot;https://b.com/products&quot;\r\n                }\r\n              ]\r\n            },\r\n            {\r\n              &quot;Level2Name&quot;: &quot;EU Products List&quot;,\r\n              &quot;Level2Contents&quot;: [\r\n                {\r\n                  &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n                  &quot;Level3URL&quot;: &quot;https://b.eu/products&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n",
                "title": "Use JQ to parse JSON nested objects, using select to match key-value in nested object while showing existing structure"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1675081578,
        "creation_date": 1576623824,
        "last_edit_date": 1675081578,
        "question_id": 59383329,
        "body_markdown": "Use JQ to parse JSON nested objects, using select to match key-value in nested object while showing existing structure\r\n\r\nI am trying to take a complex JSON file of 20,000+ lines and extract a specific key while retaining the surrounding metadata which adds necessary human-understandable context.\r\n\r\n---\r\n\r\n**Data source (complex structure):**\r\n```\r\n{\r\n  &quot;Marketplace&quot;: [\r\n    {\r\n      &quot;Level1Name&quot;: &quot;Company A Products&quot;,\r\n      &quot;Level1Array&quot;: [\r\n        {\r\n          &quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n          &quot;Level2Contents&quot;: [\r\n            {\r\n              &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n              &quot;Level3URL&quot;: &quot;https://a.com/products&quot;\r\n            },\r\n            {\r\n              &quot;Level3Name&quot;: &quot;Subset1001&quot;,\r\n              &quot;Level3URL&quot;: &quot;https://a.com/products/subset1001&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Level1Name&quot;: &quot;Company B Products&quot;,\r\n      &quot;Level1Array&quot;: [\r\n        {\r\n          &quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n          &quot;Level2Contents&quot;: [\r\n            {\r\n              &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n              &quot;Level3URL&quot;: &quot;https://b.com/products&quot;\r\n            },\r\n            {\r\n              &quot;Level3Name&quot;: &quot;Subset500&quot;,\r\n              &quot;Level3URL&quot;: &quot;https://b.com/products/subset500&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;Level2Name&quot;: &quot;EU Products List&quot;,\r\n          &quot;Level2Contents&quot;: [\r\n            {\r\n              &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n              &quot;Level3URL&quot;: &quot;https://b.eu/products&quot;\r\n            },\r\n            {\r\n              &quot;Level3Name&quot;: &quot;Subset200&quot;,\r\n              &quot;Level3URL&quot;: &quot;https://b.eu/products/subset200&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;Level1Name&quot;: &quot;Company X Products&quot;,\r\n      &quot;Level1Array&quot;: [\r\n        {\r\n          &quot;Level2Name&quot;: &quot;Deleted Products&quot;,\r\n          &quot;Level2URL&quot;: &quot;https://internal.x.com/products&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n**JQ command currently used to extract removes all other contextual metadata...**\r\n\r\n```\r\njq -r &#39;(\r\n         .Marketplace[].Level1Array[].Level2Contents[]\r\n         | select (.Level3Name | index(&quot;ALL&quot;))\r\n         | [.]\r\n         )&#39;\r\n```\r\n\r\n**Output given...**\r\n```\r\n[\r\n  {\r\n    &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n    &quot;Level3URL&quot;: &quot;https://a.com/products&quot;\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n    &quot;Level3URL&quot;: &quot;https://b.com/products&quot;\r\n  }\r\n]\r\n[\r\n  {\r\n    &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n    &quot;Level3URL&quot;: &quot;https://b.eu/products&quot;\r\n  }\r\n]\r\n```\r\n\r\n---\r\n\r\n**Option 1 output desired, same JSON structure with removing all other objects which does not match select filter &quot;ALL&quot; string criteria**\r\n```\r\n{\r\n\t&quot;Marketplace&quot;:\r\n  [\r\n\t\t{\r\n\t\t\t&quot;Level1Name&quot;: &quot;Company A Products&quot;,\r\n\t\t\t&quot;Level1Array&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n\t\t\t\t\t&quot;Level2Contents&quot;: [\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t&quot;Level3Name&quot;: &quot;ALL&quot;,\r\n\t\t\t\t\t\t\t&quot;Level3URL&quot;: &quot;https://a.com/products&quot;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t]\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Level1Name&quot;: &quot;Company B Products&quot;,\r\n\t\t\t&quot;Level1Array&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n\t\t\t\t\t&quot;Level2Contents&quot;: [\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t&quot;Level3Name&quot;: &quot;ALL&quot;,\r\n\t\t\t\t\t\t\t&quot;Level3URL&quot;: &quot;https://b.com/products&quot;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t]\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t\t&quot;Level2Name&quot;: &quot;EU Products List&quot;,\r\n\t\t\t\t\t&quot;Level2Contents&quot;: [\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\t&quot;Level3Name&quot;: &quot;ALL&quot;,\r\n\t\t\t\t\t\t\t&quot;Level3URL&quot;: &quot;https://b.eu/products&quot;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t]\r\n\t\t\t\t}\r\n\t\t\t]\r\n\t\t}\r\n\t]\r\n}\r\n```\r\n\r\n**Option 2 output desired, any similar format which can be iterated with loop such as:**\r\n```\r\n{\r\n  &quot;Marketplace&quot;:\r\n  [\r\n\t{\r\n      &quot;Level1Name&quot;: &quot;Company A Products&quot;,\r\n      &quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n      &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n      &quot;Level3URL&quot;: &quot;https://a.com/products&quot;\r\n    },\r\n    {\r\n      &quot;Level1Name&quot;: &quot;Company B Products&quot;,\r\n      &quot;Level2Name&quot;: &quot;USA Products List&quot;,\r\n      &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n      &quot;Level3URL&quot;: &quot;https://b.com/products&quot;\r\n    },\r\n    {\r\n      &quot;Level1Name&quot;: &quot;Company B Products&quot;,\r\n      &quot;Level2Name&quot;: &quot;EU Products List&quot;,\r\n      &quot;Level3Name&quot;: &quot;ALL&quot;,\r\n      &quot;Level3URL&quot;: &quot;https://b.eu/products&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/59383329/use-jq-to-parse-json-nested-objects-using-select-to-match-key-value-in-nested-o",
        "title": "Use JQ to parse JSON nested objects, using select to match key-value in nested object while showing existing structure"
    },
    {
        "tags": [
            "json",
            "powershell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 285798,
                    "reputation": 21818,
                    "user_id": 584676,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/CbAoj.png?s=256",
                    "display_name": "codewario",
                    "link": "https://stackoverflow.com/users/584676/codewario"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576731376,
                "post_id": 59403294,
                "comment_id": 104995531,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1098812,
                    "reputation": 449,
                    "user_id": 1091765,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/288a52277776c139713155a956930b3c?s=256&d=identicon&r=PG",
                    "display_name": "NewRK",
                    "link": "https://stackoverflow.com/users/1091765/newrk"
                },
                "reply_to_user": {
                    "account_id": 285798,
                    "reputation": 21818,
                    "user_id": 584676,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/CbAoj.png?s=256",
                    "display_name": "codewario",
                    "link": "https://stackoverflow.com/users/584676/codewario"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576731616,
                "post_id": 59403294,
                "comment_id": 104995583,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 285798,
                    "reputation": 21818,
                    "user_id": 584676,
                    "user_type": "registered",
                    "accept_rate": 94,
                    "profile_image": "https://i.sstatic.net/CbAoj.png?s=256",
                    "display_name": "codewario",
                    "link": "https://stackoverflow.com/users/584676/codewario"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576732848,
                "post_id": 59403294,
                "comment_id": 104995861,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2174203,
                    "reputation": 1827,
                    "user_id": 1925327,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/9c6527cb9ecdbba51bff2792d93ce4b2?s=256&d=identicon&r=PG",
                    "display_name": "moritz.vieli",
                    "link": "https://stackoverflow.com/users/1925327/moritz-vieli"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577326301,
                "post_id": 59403294,
                "comment_id": 105142508,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1620142027,
                "last_edit_date": 1620142027,
                "creation_date": 1576865981,
                "answer_id": 59429757,
                "question_id": 59403294,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As far as I know, convertfrom-json doesn&#39;t have a streaming mode, but jq does:  https://stackoverflow.com/questions/32182087/processing-huge-json-array-files-with-jq.  This code will turn a giant array into just the contents of the array, that can be output piece by piece.  Otherwise a 6mb, 400000 line json file can use 1 gig of memory after conversion (400 megs in powershell 7).\r\n\r\n    get-content file.json | \r\n      jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39; | \r\n      % { $_ | convertfrom-json }\r\n\r\nSo for example this:\r\n\r\n    [\r\n      {&quot;name&quot;:&quot;joe&quot;},\r\n      {&quot;name&quot;:&quot;john&quot;}\r\n    ]\r\n\r\nbecomes this:\r\n\r\n    {&quot;name&quot;:&quot;joe&quot;}\r\n    {&quot;name&quot;:&quot;john&quot;}\r\n\r\nThe streaming format of jq looks very different from json.  For example, the array looks like this, with paths to each value and object or array end-markers.\r\n\r\n```\r\n&#39;[{&quot;name&quot;:&quot;joe&quot;},{&quot;name&quot;:&quot;john&quot;}]&#39; | jq --stream -c\r\n\r\n[[0,&quot;name&quot;],&quot;joe&quot;]\r\n[[0,&quot;name&quot;]]        # end object\r\n[[1,&quot;name&quot;],&quot;john&quot;]\r\n[[1,&quot;name&quot;]]        # end object\r\n[[1]]               # end array\r\n```\r\nAnd then after truncating &quot;1&quot; &quot;parent folder&quot; in the path of the two values:\r\n\r\n```\r\n&#39;[{&quot;name&quot;:&quot;joe&quot;},{&quot;name&quot;:&quot;john&quot;}]&#39; | jq -cn --stream &#39;1|truncate_stream(inputs)&#39;     \r\n\r\n[[&quot;name&quot;],&quot;joe&quot;]\r\n[[&quot;name&quot;]]           # end object\r\n[[&quot;name&quot;],&quot;john&quot;]\r\n[[&quot;name&quot;]]           # end object\r\n                     # no more end array\r\n```\r\n\r\n&quot;fromstream()&quot; turns it back into json...\r\n\r\n```\r\n&#39;[{&quot;name&quot;:&quot;joe&quot;},{&quot;name&quot;:&quot;john&quot;}]&#39; | jq -cn --stream &#39;fromstream(1|truncate_stream(inputs))&#39;  \r\n\r\n{&quot;name&quot;:&quot;joe&quot;}\r\n{&quot;name&quot;:&quot;john&quot;}\r\n```\r\n",
                "title": "Iterate though huge JSON in powershell"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1620142027,
        "creation_date": 1576729572,
        "last_edit_date": 1577327674,
        "question_id": 59403294,
        "body_markdown": "I have a 19 gigs JSON file. A huge array of rather small objects. \r\n\r\n```\r\n[{\r\n  &quot;name&quot;:&quot;Joe Blow&quot;,\r\n  &quot;address&quot;:&quot;Gotham, CA&quot;\r\n  &quot;log&quot;: [{},{},{}]\r\n},\r\n...\r\n]\r\n```\r\n\r\nI want to iterate thru the root array of this JSON. Every object with the log takes no more than 2MB of memory. It is possible to load one object into a memory, work with it and throw it away. \r\n\r\nYet the file by itself is 19 gigs. It has millions of those objects. I found it is possible to iterate thru such an array by using C# and Newtonsoft.Json library. You just read a file in a stream and as soon as you see finished object, serialize it and spit it out. \r\n\r\nBut I want to see if the powershell can do the same? Not to read the whole thing as one chunk, but rather iterate what you have in the hopper right now.\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/59403294/iterate-though-huge-json-in-powershell",
        "title": "Iterate though huge JSON in powershell"
    },
    {
        "tags": [
            "json",
            "shell",
            "header",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1576786573,
                "last_edit_date": 1576786573,
                "creation_date": 1576784957,
                "answer_id": 59416082,
                "question_id": 59415968,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the &quot;,&quot; operator, e.g.:\r\n\r\n    jq &#39;&quot;name&quot;, .[].name&#39;\r\n\r\nThis will, however, result in `&quot;name&quot;`.\r\n\r\nIf you really want `name` to be unquoted but the names to be quoted, then consider:\r\n\r\n    jq -r &#39;&quot;name&quot;, (.[].name | &quot;\\&quot;\\(.)\\&quot;&quot;)&#39;\r\n\r\n# More than one field\r\nYou can use the same strategy with more than one column.  In the following, I&#39;ll assume you want TSV output (i.e. with fields separated by tabs):\r\n```\r\njq -r &#39;[&quot;name&quot;, &quot;id&quot;], (.[] | [.name, .id]) | @tsv&#39;\r\n```",
                "title": "Assign Column name to values extracted after using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1582238695,
        "creation_date": 1576784503,
        "last_edit_date": 1582238695,
        "question_id": 59415968,
        "body_markdown": "I&#39;m trying to extract values from JSON data using jq in shell once I get the value i would like to give column name to it. \r\n\r\n    ... | jq &#39;.[].name&#39;\r\n\r\noutput should be\r\n \r\n\r\n    name\r\n    &quot;tom&quot;\r\n    &quot;harry&quot;\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59415968/assign-column-name-to-values-extracted-after-using-jq",
        "title": "Assign Column name to values extracted after using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576788918,
                "post_id": 59416185,
                "comment_id": 105020895,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1576792981,
                "creation_date": 1576792981,
                "answer_id": 59417434,
                "question_id": 59416185,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you really want output that is not valid JSON, you will have to construct the output string, which can easily be done using string interpolation, e.g.:\r\n\r\n    jq -r &#39;.items[] | &quot;[\\&quot;\\(.node)\\&quot;,\\&quot;\\(.result.stdout)\\&quot;]&quot;&#39;",
                "title": "Parsing json output using jq -jr"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1576794708,
                "creation_date": 1576794708,
                "answer_id": 59417689,
                "question_id": 59416185,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@peak thank you.. that helped. Below is how it looks like\r\n\r\n```\r\n$ bolt command run &quot;cat /blah/blah&quot; -n @hname.txt -u UID --no-host-key-check --format json |jq -r &#39;.items[] | &quot;[\\&quot;\\(.node)\\&quot;,\\&quot;\\(.result.stdout)\\&quot;]&quot;&#39;\r\n[&quot;node name&quot;,&quot;stdout data\r\n&quot;]\r\n```\r\n\r\nI used a work around to get the data I needed by using the @csv flag to the command itself. Sharing with you below what worked.\r\n\r\n```\r\n$ bolt command run &quot;cat /blah/blah&quot; -n @hname.txt -u uid --no-host-key-check --format json |jq -jr &#39;.items[]|[.node],[.result.stdout]|@csv&#39;\r\n&quot;&quot;node-name&quot;&quot;stdout.data\r\n&quot;\r\n```",
                "title": "Parsing json output using jq -jr"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1576794708,
        "creation_date": 1576785520,
        "question_id": 59416185,
        "body_markdown": "I am running a puppet bolt command query certain information from a set of servers in json format. I am piping it to jq.. Below is what I get\r\n\r\n```\r\n$ bolt command run &quot;cat /blah/blah&quot; -n @hname.txt -u uid --no-host-key-check --format json |jq -jr &#39;.items[]|[.node],[.result.stdout]&#39;\r\n\r\n[\r\n  &quot;node-name&quot;\r\n][\r\n  &quot;stdout data\\n&quot;\r\n]\r\n```\r\nWhat do I need to do to make it appear like below\r\n\r\n```\r\n[&quot;nodename&quot;:&quot;stdout data&quot;]\r\n```",
        "link": "https://stackoverflow.com/questions/59416185/parsing-json-output-using-jq-jr",
        "title": "Parsing json output using jq -jr"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4487997,
                    "reputation": 1426,
                    "user_id": 3649977,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/554a3246cdbb1dbea0d1c07f89efd7ef?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Jeffrey Devloo",
                    "link": "https://stackoverflow.com/users/3649977/jeffrey-devloo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576787795,
                "post_id": 59416540,
                "comment_id": 105020536,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1609179049,
                "last_edit_date": 1609179049,
                "creation_date": 1576787881,
                "answer_id": 59416613,
                "question_id": 59416540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Reconstruct each object, and `add` them all to get a big, single one.\r\n```\r\nmap({(.k): .v}) | add\r\n```\r\nIf your input is a large dataset, `reduce` might be a better choice in terms of performance.\r\n```\r\nreduce .[] as {$k,$v} ({}; . + {($k): $v})\r\n```",
                "title": "accumulate an array of key-value pairs into a single object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1576868887,
                "creation_date": 1576868887,
                "answer_id": 59430243,
                "question_id": 59416540,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another option, since your objects are similar to how entries are structured, you could map them as those key/value pairs and convert to an object that way.\r\n\r\n    map({key: .k, value: .v}) | from_entries",
                "title": "accumulate an array of key-value pairs into a single object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1609179049,
        "creation_date": 1576787388,
        "last_edit_date": 1576826212,
        "question_id": 59416540,
        "body_markdown": "How can I use `jq` to transform this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;k&quot;: &quot;a&quot;,\r\n    &quot;v&quot;: 123\r\n  },\r\n  {\r\n    &quot;k&quot;: &quot;b&quot;,\r\n    &quot;v&quot;: 456\r\n  }\r\n]\r\n```\r\n\r\ninto this:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: 123,\r\n  &quot;b&quot;: 456\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/59416540/accumulate-an-array-of-key-value-pairs-into-a-single-object",
        "title": "accumulate an array of key-value pairs into a single object"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1576802338,
                "creation_date": 1576802338,
                "answer_id": 59418588,
                "question_id": 59418412,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The whole thing can be done in jq using the -r command-line option:\r\n\r\n```\r\n.[].stats.data[]\r\n| [.identifier.names, .identifier.values]\r\n| transpose[]\r\n| &quot;\\(.[0])=\\(.[1])&quot;\r\n```",
                "title": "Parse and Map 2 Arrays with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1576817329,
        "creation_date": 1576800574,
        "last_edit_date": 1576817329,
        "question_id": 59418412,
        "body_markdown": "I am working with a JSON file similar to the one below: \r\n\r\n    {   &quot;Response&quot; : {\r\n        &quot;TimeUnit&quot; : [ 1576126800000 ],\r\n        &quot;metaData&quot; : {\r\n          &quot;errors&quot; : [ ],\r\n          &quot;notices&quot; : [ &quot;query served by:1&quot;]\r\n        },\r\n        &quot;stats&quot; : {\r\n          &quot;data&quot; : [ {\r\n            &quot;identifier&quot; : {\r\n              &quot;names&quot; : [ &quot;apiproxy&quot;, &quot;response_status_code&quot;, &quot;target_response_code&quot;, &quot;target_ip&quot; ],\r\n              &quot;values&quot; : [ &quot;IO&quot;, &quot;502&quot;, &quot;502&quot;, &quot;7.1.143.6&quot; ]\r\n            },\r\n            &quot;metric&quot; : [ {\r\n              &quot;env&quot; : &quot;dev&quot;,\r\n              &quot;name&quot; : &quot;sum(message_count)&quot;,\r\n              &quot;values&quot; : [ 0.0]\r\n            } ]\r\n          } ]\r\n        }   } }\r\n\r\nMy object is to display a mapping of the identifier and values like : \r\n\r\n    apiproxy=IO\r\n    response_status_code=502\r\n    target_response_code=502 \r\n    target_ip=7.1.143.6\r\n\r\nI have been able to parse both names and values with \r\n\r\n`.[].stats.data[]  | (.identifier.names[])` and `.[].stats.data[]  | (.identifier.values[])`  \r\n\r\nbut I need help with the jq way to map the values. ",
        "link": "https://stackoverflow.com/questions/59418412/parse-and-map-2-arrays-with-jq",
        "title": "Parse and Map 2 Arrays with jq"
    },
    {
        "tags": [
            "ruby",
            "pipe",
            "stdout",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 283053,
                    "reputation": 23417,
                    "user_id": 580346,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/ba17945a06aac247b06548d5afe341e8?s=256&d=identicon&r=PG",
                    "display_name": "mrzasa",
                    "link": "https://stackoverflow.com/users/580346/mrzasa"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1576828079,
                "post_id": 59421549,
                "comment_id": 105029593,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 658903,
                    "reputation": 114823,
                    "user_id": 477037,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/dde78fe4cdc16eb855d68ff7a8cd017d?s=256&d=identicon&r=PG",
                    "display_name": "Stefan",
                    "link": "https://stackoverflow.com/users/477037/stefan"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1576829012,
                "post_id": 59421549,
                "comment_id": 105029903,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 658903,
                    "reputation": 114823,
                    "user_id": 477037,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/dde78fe4cdc16eb855d68ff7a8cd017d?s=256&d=identicon&r=PG",
                    "display_name": "Stefan",
                    "link": "https://stackoverflow.com/users/477037/stefan"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1576829230,
                "post_id": 59421549,
                "comment_id": 105029999,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 363391,
                    "reputation": 225890,
                    "user_id": 707111,
                    "user_type": "moderator",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/oXZkh.jpg?s=256",
                    "display_name": "Ry-",
                    "link": "https://stackoverflow.com/users/707111/ry"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1576829274,
                "post_id": 59421549,
                "comment_id": 105030013,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 363391,
                    "reputation": 225890,
                    "user_id": 707111,
                    "user_type": "moderator",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/oXZkh.jpg?s=256",
                    "display_name": "Ry-",
                    "link": "https://stackoverflow.com/users/707111/ry"
                },
                "reply_to_user": {
                    "account_id": 2318915,
                    "reputation": 121254,
                    "user_id": 2035262,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/pPtKA.jpg?s=256",
                    "display_name": "Aleksei Matiushkin",
                    "link": "https://stackoverflow.com/users/2035262/aleksei-matiushkin"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1576829438,
                "post_id": 59421549,
                "comment_id": 105030069,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2318915,
                    "reputation": 121254,
                    "user_id": 2035262,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/pPtKA.jpg?s=256",
                    "display_name": "Aleksei Matiushkin",
                    "link": "https://stackoverflow.com/users/2035262/aleksei-matiushkin"
                },
                "reply_to_user": {
                    "account_id": 363391,
                    "reputation": 225890,
                    "user_id": 707111,
                    "user_type": "moderator",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/oXZkh.jpg?s=256",
                    "display_name": "Ry-",
                    "link": "https://stackoverflow.com/users/707111/ry"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1576829708,
                "post_id": 59421549,
                "comment_id": 105030171,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1208118,
                    "reputation": 3123,
                    "user_id": 1177200,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/99ddd63eb79f04e76156db21c172c7f1?s=256&d=identicon&r=PG",
                    "display_name": "taylorthurlow",
                    "link": "https://stackoverflow.com/users/1177200/taylorthurlow"
                },
                "reply_to_user": {
                    "account_id": 283053,
                    "reputation": 23417,
                    "user_id": 580346,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/ba17945a06aac247b06548d5afe341e8?s=256&d=identicon&r=PG",
                    "display_name": "mrzasa",
                    "link": "https://stackoverflow.com/users/580346/mrzasa"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576862836,
                "post_id": 59421549,
                "comment_id": 105044302,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1208118,
                    "reputation": 3123,
                    "user_id": 1177200,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/99ddd63eb79f04e76156db21c172c7f1?s=256&d=identicon&r=PG",
                    "display_name": "taylorthurlow",
                    "link": "https://stackoverflow.com/users/1177200/taylorthurlow"
                },
                "reply_to_user": {
                    "account_id": 658903,
                    "reputation": 114823,
                    "user_id": 477037,
                    "user_type": "registered",
                    "accept_rate": 87,
                    "profile_image": "https://www.gravatar.com/avatar/dde78fe4cdc16eb855d68ff7a8cd017d?s=256&d=identicon&r=PG",
                    "display_name": "Stefan",
                    "link": "https://stackoverflow.com/users/477037/stefan"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576863049,
                "post_id": 59421549,
                "comment_id": 105044391,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1208118,
                    "reputation": 3123,
                    "user_id": 1177200,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/99ddd63eb79f04e76156db21c172c7f1?s=256&d=identicon&r=PG",
                    "display_name": "taylorthurlow",
                    "link": "https://stackoverflow.com/users/1177200/taylorthurlow"
                },
                "reply_to_user": {
                    "account_id": 2318915,
                    "reputation": 121254,
                    "user_id": 2035262,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/pPtKA.jpg?s=256",
                    "display_name": "Aleksei Matiushkin",
                    "link": "https://stackoverflow.com/users/2035262/aleksei-matiushkin"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1576863110,
                "post_id": 59421549,
                "comment_id": 105044413,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1577358392,
                "creation_date": 1577358392,
                "answer_id": 59487533,
                "question_id": 59421549,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @Ry points out [in the comments][1], `$stdout.sync` is `true` by default in IRB, but this is not necessarily the same for scripts.\n\nSo you should set `$stdout.sync = true` to be sure to prevent buffering.\n\n  [1]: https://stackoverflow.com/questions/59421549/why-is-ruby-stdout-buffering-when-i-dont-expect-it-to#comment105030013_59421549",
                "title": "Why is Ruby STDOUT buffering when I don&#39;t expect it to?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1577358392,
        "creation_date": 1576827858,
        "question_id": 59421549,
        "body_markdown": "The following code is a simplification of my current situation. I have a JSON log source which I continuously fetch and write to stdout with `puts`.\r\n\r\n```ruby\r\n#!/usr/bin/env ruby\r\n\r\nrequire &quot;json&quot;\r\n\r\nloop do\r\n  puts({ value: &quot;foobar&quot; }.to_json)\r\n  sleep 1\r\nend\r\n```\r\n\r\nI want to be able to pipe the output of this script into `jq` for further processing, but in a &#39;stream&#39;-friendly way, using unix pipes. Running the above code like so:\r\n\r\n```bash\r\n./my_script | jq\r\n```\r\n\r\nResults in an empty output. However, if I place an `exit` statement after the `sleep` call, the output is sent through the pipe to `jq` as expected. I was able to solve this problem by calling `$stdout.flush` following the `puts` call. While it&#39;s working now, I&#39;m not sure why. `$stdout.sync` is set to `true` by default (see [`IO#sync`](https://ruby-doc.org/core-2.6.5/IO.html#method-i-sync)). It seems to me that if sync was enabled, then Ruby should be doing no output buffering, and calling `$stdout.flush` should not be required - yet it is.\r\n\r\nMy follow-up question is about using `tail` instead of `jq`. It seems to me that I should be able to pipe a text stream into `tail` the same way I pipe it into `jq`, but neither method (with the `$stdout.flush` call or without it) works - the output is just empty.",
        "link": "https://stackoverflow.com/questions/59421549/why-is-ruby-stdout-buffering-when-i-dont-expect-it-to",
        "title": "Why is Ruby STDOUT buffering when I don&#39;t expect it to?"
    },
    {
        "tags": [
            "json",
            "linux",
            "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": 0,
                "creation_date": 1576858816,
                "post_id": 59426914,
                "comment_id": 105042736,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1576859429,
                "creation_date": 1576859429,
                "answer_id": 59428535,
                "question_id": 59426914,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` doesn&#39;t have the output capabilities to create the desired files after grouping the objects; you&#39;ll need to use another language with a JSON library. An example using Python:\r\n\r\n    import json\r\n    import fileinput\r\n\r\n    for line in fileinput.input():  # Read from standard input or filename arguments\r\n        d = json.loads(line)\r\n        with open(d[&#39;name&#39;], &quot;a&quot;) as f:\r\n            print(d[&#39;content&#39;], file=f)\r\n\r\nThis has the drawback of repeatedly opening and closing each file multiple times, but it&#39;s simple. A more complex, but more efficient, example would use an exit stack context manager.\r\n\r\n    import json\r\n    import fileinput\r\n    import contextlib\r\n\r\n    with contextlib.ExitStack() as es:\r\n        files = {}\r\n        for line in fileinput.input():\r\n            d = json.loads(line)\r\n            file_name = d[&#39;name&#39;]\r\n            if file_name not in files:\r\n                files[file_name] = es.enter_context(open(file_name, &quot;w&quot;))\r\n            print(d[&#39;content&#39;], file=files[file_name])\r\n\r\nPut briefly, files are opened and cached as they are discovered. Once the loop completes (or in the event of an exception), the exit stack ensures all files previously opened are properly closed.\r\n\r\nIf there&#39;s a chance that there will be too many files to have open simultaneously, you&#39;ll have to use the simple-but-inefficient code, though you could implement something even *more* complex that just keeps a small, fixed number of files open at any given time, reopening them in append mode as necessary. Implementing that is beyond the scope of this answer, though.\r\n        \r\n\r\n",
                "title": "How to split line delimited JSON into many files using linux shell script"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1576871495,
                "last_edit_date": 1576871495,
                "creation_date": 1576867693,
                "answer_id": 59430050,
                "question_id": 59426914,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to an efficient, jq-based solution is to pipe the output of jq (invoked with the -c option) to a program such as awk to perform the actual writing of the output files.\r\n```\r\njq -c &#39;.name, .content&#39; input.json | \r\n  awk &#39;fn {print &gt; fn; close(fn); fn=&quot;&quot;; next;}\r\n       {fn=$0; sub(/^&quot;/,&quot;&quot;,fn); sub(/&quot;$/,&quot;&quot;,fn);}&#39; \r\n```\r\n### Warnings\r\n\r\nBlindly relying on the JSON input for the file names has some risks,\r\ne.g.\r\n\r\n- what if the same &quot;name&quot; is specified more than once?\r\n- if a file already exists, the above program will simply append to it.  \r\n\r\nAlso, somewhere along the line, the validity of .name as a filename should be checked.\r\n\r\n### Related answers on SO\r\n\r\nThis question has been asked and answered on SO in slightly different forms before,\r\nsee e.g. https://stackoverflow.com/questions/28744361/split-a-json-file-into-separate-files\r\n",
                "title": "How to split line delimited JSON into many files using linux shell script"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1576872519,
                "creation_date": 1576872519,
                "answer_id": 59430828,
                "question_id": 59426914,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following jq-based solution ensures that the output in the JSON files is pretty-printed,\r\nbut ignores any input object with .content equal to the JSON string: &quot;IGNORE ME&quot;:\r\n```\r\njq &#39;if .content == &quot;IGNORE ME&quot; \r\n    then &quot;Skipping IGNORE ME&quot; | stderr | empty\r\n    else .name, .content, &quot;IGNORE ME&quot; end&#39; input.json |\r\n    awk &#39;/^&quot;IGNORE ME&quot;$/ {close(fn); fn=&quot;&quot;; next}\r\n         fn {print &gt;&gt; fn; next}\r\n         {fn=$0; sub(/^&quot;/,&quot;&quot;,fn); sub(/&quot;$/,&quot;&quot;,fn);}&#39;\r\n``` \r\n",
                "title": "How to split line delimited JSON into many files using linux shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1576872519,
        "creation_date": 1576852216,
        "question_id": 59426914,
        "body_markdown": "I have a huge newline delimited JSON file input.json which like this:\r\n```\r\n{ &quot;name&quot;:&quot;a.txt&quot;, &quot;content&quot;:&quot;...&quot;, &quot;other_keys&quot;:&quot;...&quot;}\r\n{ &quot;name&quot;:&quot;b.txt&quot;, &quot;content&quot;:&quot;...&quot;, &quot;something_else&quot;:&quot;...&quot;}\r\n{ &quot;name&quot;:&quot;c.txt&quot;, &quot;content&quot;:&quot;...&quot;, &quot;etc&quot;:&quot;...&quot;}\r\n...\r\n```\r\nHow can I split it into multiple text files, where file names are taken from &quot;name&quot; and file content is taken from &quot;content&quot;? Other keys can be ignored. Currently toying with `jq` tool without luck.",
        "link": "https://stackoverflow.com/questions/59426914/how-to-split-line-delimited-json-into-many-files-using-linux-shell-script",
        "title": "How to split line delimited JSON into many files using linux shell script"
    },
    {
        "tags": [
            "json",
            "jq",
            "json-ld"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 359162,
                    "reputation": 5389,
                    "user_id": 700391,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/OqZ7R.png?s=256",
                    "display_name": "hrdwdmrbl",
                    "link": "https://stackoverflow.com/users/700391/hrdwdmrbl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1674851432,
                "post_id": 59429051,
                "comment_id": 132809144,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1576866231,
                "creation_date": 1576866231,
                "answer_id": 59429793,
                "question_id": 59429051,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following solution first incrementally constructs both the dictionary and the array of objects with an id,\r\nand then produces the desired result using `map`:\r\n```\r\nreduce inputs as $x ({};\r\n  if $x|has(&quot;id&quot;) then .objects += [$x]\r\n  elif $x|has(&quot;__parentId&quot;) then .dict[$x.__parentId] += [$x.originalSrc]\r\n  else . # an error?\r\n  end)\r\n| .dict as $dict\r\n| .objects\r\n| map( . + {images: $dict[.id]})\r\n\r\n```\r\n### Invocation\r\nThe -n command-line ooption must be used, e.g.\r\n\r\n    jq -nf shopify.jq shopify.json\r\n",
                "title": "Transform Shopify JSONL file to JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1576875000,
        "creation_date": 1576861959,
        "last_edit_date": 1576875000,
        "question_id": 59429051,
        "body_markdown": "I have a Shopify jsonl file that I&#39;m trying to map to a different json structure.\r\n\r\nGiven this input:\r\n\r\n```\r\n{&quot;id&quot;:&quot;gid:\\/\\/shopify\\/Product\\/123456789&quot;,&quot;title&quot;:&quot;Gift Card&quot;}\r\n{&quot;originalSrc&quot;:&quot;https:\\/\\/cdn.shopify.com\\/s\\/files\\/1\\/1111\\/2222\\/products\\/gift-card-01.jpg&quot;,&quot;__parentId&quot;:&quot;gid:\\/\\/shopify\\/Product\\/123456789&quot;}\r\n{&quot;originalSrc&quot;:&quot;https:\\/\\/cdn.shopify.com\\/s\\/files\\/1\\/1111\\/2222\\/products\\/gift-card-02.jpg&quot;,&quot;__parentId&quot;:&quot;gid:\\/\\/shopify\\/Product\\/123456789&quot;}\r\n```\r\n\r\nI&#39;d like to have the images, mapped to the correct product id using __parentId.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;:&quot;gid:\\/\\/shopify\\/Product\\/123456789&quot;,\r\n    &quot;title&quot;:&quot;Gift Card&quot;,\r\n    &quot;images: [\r\n      &quot;https:\\/\\/cdn.shopify.com\\/s\\/files\\/1\\/1111\\/2222\\/products\\/gift-card-01.jpg&quot;,\r\n      &quot;https:\\/\\/cdn.shopify.com\\/s\\/files\\/1\\/1111\\/2222\\/products\\/gift-card-02.jpg&quot;\r\n    ]\r\n  },\r\n  ...\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/59429051/transform-shopify-jsonl-file-to-json",
        "title": "Transform Shopify JSONL file to JSON"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1576955071,
                "creation_date": 1576955071,
                "answer_id": 59439069,
                "question_id": 59438639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Both responses and textAnnotations are arrays, so as far as i remember, you have to either loop through them, or access the first response element&#39;s first textAnnotation like so: responses[0].textAnnotations[0].description\r\n\r\n I suggest looping if possible.",
                "title": "Parse JSON data using jq and curl from command line"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1576986151,
                "creation_date": 1576986151,
                "answer_id": 59441465,
                "question_id": 59438639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want all the descriptions under .responses[].textAnnotations you could write:\r\n\r\n    .responses[].textAnnotations[].description \r\n\r\nwhich is short for:\r\n\r\n    .responses[] | .textAnnotations[] |.description \r\n\r\nwhich is effectively a &quot;for&quot; loop within a &quot;for&quot; loop.",
                "title": "Parse JSON data using jq and curl from command line"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1576986151,
        "creation_date": 1576951701,
        "last_edit_date": 1576985895,
        "question_id": 59438639,
        "body_markdown": "I would like to parse JSON data using jq and curl from command line but I haven&#39;t been successful. In fact, I would like to get the value of response &gt; textAnnotations &gt; description but i&#39;m doing something wrong. Here is my command :\r\n\r\n\r\n    curl -X POST &gt; response.txt \\\r\n         -H &quot;Content-Type: application/json; charset=utf-8&quot; \\\r\n         --data &quot;{\r\n          &#39;requests&#39;: [\r\n            {\r\n              &#39;image&#39;: {\r\n                &#39;source&#39;: {\r\n                  &#39;imageUri&#39;: &#39;http://adn-cdn2.avadeo.net/articles/vignettes/grandes/146.jpg&#39;\r\n                }\r\n              },\r\n              &#39;features&#39;: [\r\n                {\r\n                  &#39;type&#39;: &#39;TEXT_DETECTION&#39;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        }&quot; &quot;https://vision.googleapis.com/v1/images:annotate?key=XXXXXXXXXXXXXXXXXXX&quot; | jq -r &#39;.responses.textAnnotations.description&#39;\r\n\r\n\r\nAnd here is the Curl answer if I do not filter with JQ :\r\n\r\n        {\r\n      &quot;responses&quot;: [\r\n        {\r\n          &quot;textAnnotations&quot;: [\r\n            {\r\n              &quot;locale&quot;: &quot;und&quot;,\r\n              &quot;description&quot;: &quot;24\\nmois\\n12\\nmois\\n&quot;,\r\n              &quot;boundingPoly&quot;: {\r\n                &quot;vertices&quot;: [\r\n                  {\r\n                    &quot;x&quot;: 12,\r\n                    &quot;y&quot;: 24\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 285,\r\n                    &quot;y&quot;: 24\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 285,\r\n                    &quot;y&quot;: 206\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 12,\r\n                    &quot;y&quot;: 206\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n              &quot;description&quot;: &quot;24&quot;,\r\n              &quot;boundingPoly&quot;: {\r\n                &quot;vertices&quot;: [\r\n                  {\r\n                    &quot;x&quot;: 216,\r\n                    &quot;y&quot;: 24\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 285,\r\n                    &quot;y&quot;: 24\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 285,\r\n                    &quot;y&quot;: 83\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 216,\r\n                    &quot;y&quot;: 83\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n              &quot;description&quot;: &quot;mois&quot;,\r\n              &quot;boundingPoly&quot;: {\r\n                &quot;vertices&quot;: [\r\n                  {\r\n                    &quot;x&quot;: 223,\r\n                    &quot;y&quot;: 83\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 280,\r\n                    &quot;y&quot;: 84\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 280,\r\n                    &quot;y&quot;: 110\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 223,\r\n                    &quot;y&quot;: 109\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n              &quot;description&quot;: &quot;12&quot;,\r\n              &quot;boundingPoly&quot;: {\r\n                &quot;vertices&quot;: [\r\n                  {\r\n                    &quot;x&quot;: 12,\r\n                    &quot;y&quot;: 122\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 81,\r\n                    &quot;y&quot;: 122\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 81,\r\n                    &quot;y&quot;: 179\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 12,\r\n                    &quot;y&quot;: 179\r\n                  }\r\n                ]\r\n              }\r\n            },\r\n            {\r\n              &quot;description&quot;: &quot;mois&quot;,\r\n              &quot;boundingPoly&quot;: {\r\n                &quot;vertices&quot;: [\r\n                  {\r\n                    &quot;x&quot;: 19,\r\n                    &quot;y&quot;: 177\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 76,\r\n                    &quot;y&quot;: 176\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 76,\r\n                    &quot;y&quot;: 205\r\n                  },\r\n                  {\r\n                    &quot;x&quot;: 19,\r\n                    &quot;y&quot;: 206\r\n                  }\r\n                ]\r\n              }\r\n            }\r\n          ],\r\n          &quot;fullTextAnnotation&quot;: {\r\n            &quot;pages&quot;: [\r\n              {\r\n                &quot;width&quot;: 300,\r\n                &quot;height&quot;: 225,\r\n                &quot;blocks&quot;: [\r\n                  {\r\n                    &quot;boundingBox&quot;: {\r\n                      &quot;vertices&quot;: [\r\n                        {\r\n                          &quot;x&quot;: 216,\r\n                          &quot;y&quot;: 24\r\n                        },\r\n                        {\r\n                          &quot;x&quot;: 285,\r\n                          &quot;y&quot;: 24\r\n                        },\r\n                        {\r\n                          &quot;x&quot;: 285,\r\n                          &quot;y&quot;: 83\r\n                        },\r\n                        {\r\n                          &quot;x&quot;: 216,\r\n                          &quot;y&quot;: 83\r\n                        }\r\n                      ]\r\n                    },\r\n                    &quot;paragraphs&quot;: [\r\n                      {\r\n                        &quot;boundingBox&quot;: {\r\n                          &quot;vertices&quot;: [\r\n                            {\r\n                              &quot;x&quot;: 216,\r\n                              &quot;y&quot;: 24\r\n                            },\r\n                            {\r\n                              &quot;x&quot;: 285,\r\n                              &quot;y&quot;: 24\r\n                            },\r\n                            {\r\n                              &quot;x&quot;: 285,\r\n                              &quot;y&quot;: 83\r\n                            },\r\n                            {\r\n                              &quot;x&quot;: 216,\r\n                              &quot;y&quot;: 83\r\n                            }\r\n                          ]\r\n                        },\r\n                        &quot;words&quot;: [\r\n                          {\r\n                            &quot;boundingBox&quot;: {\r\n                              &quot;vertices&quot;: [\r\n                                {\r\n                                  &quot;x&quot;: 216,\r\n                                  &quot;y&quot;: 24\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 285,\r\n                                  &quot;y&quot;: 24\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 285,\r\n                                  &quot;y&quot;: 83\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 216,\r\n                                  &quot;y&quot;: 83\r\n                                }\r\n                              ]\r\n                            },\r\n                            &quot;symbols&quot;: [\r\n                              {\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 216,\r\n                                      &quot;y&quot;: 25\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 248,\r\n                                      &quot;y&quot;: 25\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 248,\r\n                                      &quot;y&quot;: 76\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 216,\r\n                                      &quot;y&quot;: 76\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;2&quot;\r\n                              },\r\n                              {\r\n                                &quot;property&quot;: {\r\n                                  &quot;detectedBreak&quot;: {\r\n                                    &quot;type&quot;: &quot;EOL_SURE_SPACE&quot;\r\n                                  }\r\n                                },\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 255,\r\n                                      &quot;y&quot;: 24\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 285,\r\n                                      &quot;y&quot;: 24\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 285,\r\n                                      &quot;y&quot;: 83\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 255,\r\n                                      &quot;y&quot;: 83\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;4&quot;\r\n                              }\r\n                            ]\r\n                          }\r\n                        ]\r\n                      }\r\n                    ],\r\n                    &quot;blockType&quot;: &quot;TEXT&quot;\r\n                  },\r\n                  {\r\n                    &quot;boundingBox&quot;: {\r\n                      &quot;vertices&quot;: [\r\n                        {\r\n                          &quot;x&quot;: 223,\r\n                          &quot;y&quot;: 83\r\n                        },\r\n                        {\r\n                          &quot;x&quot;: 280,\r\n                          &quot;y&quot;: 84\r\n                        },\r\n                        {\r\n                          &quot;x&quot;: 280,\r\n                          &quot;y&quot;: 110\r\n                        },\r\n                        {\r\n                          &quot;x&quot;: 223,\r\n                          &quot;y&quot;: 109\r\n                        }\r\n                      ]\r\n                    },\r\n                    &quot;paragraphs&quot;: [\r\n                      {\r\n                        &quot;boundingBox&quot;: {\r\n                          &quot;vertices&quot;: [\r\n                            {\r\n                              &quot;x&quot;: 223,\r\n                              &quot;y&quot;: 83\r\n                            },\r\n                            {\r\n                              &quot;x&quot;: 280,\r\n                              &quot;y&quot;: 84\r\n                            },\r\n                            {\r\n                              &quot;x&quot;: 280,\r\n                              &quot;y&quot;: 110\r\n                            },\r\n                            {\r\n                              &quot;x&quot;: 223,\r\n                              &quot;y&quot;: 109\r\n                            }\r\n                          ]\r\n                        },\r\n                        &quot;words&quot;: [\r\n                          {\r\n                            &quot;boundingBox&quot;: {\r\n                              &quot;vertices&quot;: [\r\n                                {\r\n                                  &quot;x&quot;: 223,\r\n                                  &quot;y&quot;: 83\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 280,\r\n                                  &quot;y&quot;: 84\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 280,\r\n                                  &quot;y&quot;: 110\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 223,\r\n                                  &quot;y&quot;: 109\r\n                                }\r\n                              ]\r\n                            },\r\n                            &quot;symbols&quot;: [\r\n                              {\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 223,\r\n                                      &quot;y&quot;: 89\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 242,\r\n                                      &quot;y&quot;: 89\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 242,\r\n                                      &quot;y&quot;: 108\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 223,\r\n                                      &quot;y&quot;: 108\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;m&quot;\r\n                              },\r\n                              {\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 246,\r\n                                      &quot;y&quot;: 88\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 259,\r\n                                      &quot;y&quot;: 88\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 259,\r\n                                      &quot;y&quot;: 108\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 246,\r\n                                      &quot;y&quot;: 108\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;o&quot;\r\n                              },\r\n                              {\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 262,\r\n                                      &quot;y&quot;: 83\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 264,\r\n                                      &quot;y&quot;: 83\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 264,\r\n                                      &quot;y&quot;: 109\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 262,\r\n                                      &quot;y&quot;: 109\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;i&quot;\r\n                              },\r\n                              {\r\n                                &quot;property&quot;: {\r\n                                  &quot;detectedBreak&quot;: {\r\n                                    &quot;type&quot;: &quot;EOL_SURE_SPACE&quot;\r\n                                  }\r\n                                },\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 269,\r\n                                      &quot;y&quot;: 89\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 280,\r\n                                      &quot;y&quot;: 89\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 280,\r\n                                      &quot;y&quot;: 108\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 269,\r\n                                      &quot;y&quot;: 108\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;s&quot;\r\n                              }\r\n                            ]\r\n                          }\r\n                        ]\r\n                      }\r\n                    ],\r\n                    &quot;blockType&quot;: &quot;TEXT&quot;\r\n                  },\r\n                  {\r\n                    &quot;boundingBox&quot;: {\r\n                      &quot;vertices&quot;: [\r\n                        {\r\n                          &quot;x&quot;: 12,\r\n                          &quot;y&quot;: 122\r\n                        },\r\n                        {\r\n                          &quot;x&quot;: 81,\r\n                          &quot;y&quot;: 122\r\n                        },\r\n                        {\r\n                          &quot;x&quot;: 82,\r\n                          &quot;y&quot;: 206\r\n                        },\r\n                        {\r\n                          &quot;x&quot;: 13,\r\n                          &quot;y&quot;: 206\r\n                        }\r\n                      ]\r\n                    },\r\n                    &quot;paragraphs&quot;: [\r\n                      {\r\n                        &quot;boundingBox&quot;: {\r\n                          &quot;vertices&quot;: [\r\n                            {\r\n                              &quot;x&quot;: 12,\r\n                              &quot;y&quot;: 122\r\n                            },\r\n                            {\r\n                              &quot;x&quot;: 81,\r\n                              &quot;y&quot;: 122\r\n                            },\r\n                            {\r\n                              &quot;x&quot;: 82,\r\n                              &quot;y&quot;: 206\r\n                            },\r\n                            {\r\n                              &quot;x&quot;: 13,\r\n                              &quot;y&quot;: 206\r\n                            }\r\n                          ]\r\n                        },\r\n                        &quot;words&quot;: [\r\n                          {\r\n                            &quot;boundingBox&quot;: {\r\n                              &quot;vertices&quot;: [\r\n                                {\r\n                                  &quot;x&quot;: 12,\r\n                                  &quot;y&quot;: 122\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 81,\r\n                                  &quot;y&quot;: 122\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 81,\r\n                                  &quot;y&quot;: 179\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 12,\r\n                                  &quot;y&quot;: 179\r\n                                }\r\n                              ]\r\n                            },\r\n                            &quot;symbols&quot;: [\r\n                              {\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 12,\r\n                                      &quot;y&quot;: 122\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 43,\r\n                                      &quot;y&quot;: 122\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 43,\r\n                                      &quot;y&quot;: 175\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 12,\r\n                                      &quot;y&quot;: 175\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;1&quot;\r\n                              },\r\n                              {\r\n                                &quot;property&quot;: {\r\n                                  &quot;detectedBreak&quot;: {\r\n                                    &quot;type&quot;: &quot;EOL_SURE_SPACE&quot;\r\n                                  }\r\n                                },\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 50,\r\n                                      &quot;y&quot;: 122\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 81,\r\n                                      &quot;y&quot;: 122\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 81,\r\n                                      &quot;y&quot;: 179\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 50,\r\n                                      &quot;y&quot;: 179\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;2&quot;\r\n                              }\r\n                            ]\r\n                          },\r\n                          {\r\n                            &quot;boundingBox&quot;: {\r\n                              &quot;vertices&quot;: [\r\n                                {\r\n                                  &quot;x&quot;: 19,\r\n                                  &quot;y&quot;: 177\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 76,\r\n                                  &quot;y&quot;: 176\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 76,\r\n                                  &quot;y&quot;: 205\r\n                                },\r\n                                {\r\n                                  &quot;x&quot;: 19,\r\n                                  &quot;y&quot;: 206\r\n                                }\r\n                              ]\r\n                            },\r\n                            &quot;symbols&quot;: [\r\n                              {\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 19,\r\n                                      &quot;y&quot;: 186\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 38,\r\n                                      &quot;y&quot;: 186\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 38,\r\n                                      &quot;y&quot;: 205\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 19,\r\n                                      &quot;y&quot;: 205\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;m&quot;\r\n                              },\r\n                              {\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 42,\r\n                                      &quot;y&quot;: 186\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 55,\r\n                                      &quot;y&quot;: 186\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 55,\r\n                                      &quot;y&quot;: 206\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 42,\r\n                                      &quot;y&quot;: 206\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;o&quot;\r\n                              },\r\n                              {\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 58,\r\n                                      &quot;y&quot;: 177\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 60,\r\n                                      &quot;y&quot;: 177\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 60,\r\n                                      &quot;y&quot;: 205\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 58,\r\n                                      &quot;y&quot;: 205\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;i&quot;\r\n                              },\r\n                              {\r\n                                &quot;property&quot;: {\r\n                                  &quot;detectedBreak&quot;: {\r\n                                    &quot;type&quot;: &quot;EOL_SURE_SPACE&quot;\r\n                                  }\r\n                                },\r\n                                &quot;boundingBox&quot;: {\r\n                                  &quot;vertices&quot;: [\r\n                                    {\r\n                                      &quot;x&quot;: 65,\r\n                                      &quot;y&quot;: 186\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 76,\r\n                                      &quot;y&quot;: 186\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 76,\r\n                                      &quot;y&quot;: 205\r\n                                    },\r\n                                    {\r\n                                      &quot;x&quot;: 65,\r\n                                      &quot;y&quot;: 205\r\n                                    }\r\n                                  ]\r\n                                },\r\n                                &quot;text&quot;: &quot;s&quot;\r\n                              }\r\n                            ]\r\n                          }\r\n                        ]\r\n                      }\r\n                    ],\r\n                    &quot;blockType&quot;: &quot;TEXT&quot;\r\n                  }\r\n                ]\r\n              }\r\n            ],\r\n            &quot;text&quot;: &quot;24\\nmois\\n12\\nmois\\n&quot;\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nCan you please help me ?\r\n\r\nThank you all :)",
        "link": "https://stackoverflow.com/questions/59438639/parse-json-data-using-jq-and-curl-from-command-line",
        "title": "Parse JSON data using jq and curl from command line"
    },
    {
        "tags": [
            "bash",
            "sed",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1576962575,
                "creation_date": 1576962575,
                "answer_id": 59439862,
                "question_id": 59439487,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all; rather than iterating the JSON `node` array using Bash, you could as well offload it entirely to `jq` with:\r\n\r\n```sh\r\njq -r &#39;.node[]|.description&#39; file.json\r\n```\r\n\r\nAbout your issue with parsing the `$node` Bash variable with `jq` when it contains double quotes `&quot;`; is because the `read` command needs a `-r` option or it will un-escape the double-quotes (remove the backslash `\\`) from the JSON string, turning it into an invalid JSON string.\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\njq -c  &#39;.node[]&#39; file.json | while read -r node; do\r\necho &quot;$node&quot;\r\n    description=$(jq -r &#39;.description&#39; &lt;&lt;&lt; &quot;$node&quot;);\r\n    printf &#39;%s\\n&#39; &quot;$description&quot;;\r\ndone\r\n```\r\n\r\nAlso this Bash script will fail if the `.node[]` array is empty or non-existent, because `jq` is going to parse an empty input.",
                "title": "jq breaks reading encoded entities from valid JSON string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1576962575,
        "creation_date": 1576958861,
        "last_edit_date": 1576959465,
        "question_id": 59439487,
        "body_markdown": "I&#39;m using `jq` to iterate through a JSON file and am having issues with occurrences of `\\u0022` within the json values.\r\n\r\n    jq -c  &#39;.node[]&#39; file.json | while read node; do\r\n\r\n        description=$(jq -r &#39;.description&#39; &lt;&lt;&lt; &quot;$node&quot;);\r\n    \r\n        printf &#39;%s\\n&#39; &quot;$description&quot;;\r\n    \r\n\r\n    done\r\n\r\nThis works for all values except that `jq` decodes the values which causes an error when encountering `\\u0022` since it translates to a double quote.\r\n\r\nSo for a value of\r\n\r\n    {&quot;description&quot;:&quot;This is my \\u0022real\\u0022 name&quot;}\r\n\r\n`jq` will error with: `parse error: Invalid numeric literal`\r\n\r\nHow do I get `jq` to NOT decode the entities or ignore or remove them?\r\n",
        "link": "https://stackoverflow.com/questions/59439487/jq-breaks-reading-encoded-entities-from-valid-json-string",
        "title": "jq breaks reading encoded entities from valid JSON string"
    },
    {
        "tags": [
            "json",
            "types",
            "key",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1577039388,
                "last_edit_date": 1577039388,
                "creation_date": 1576979418,
                "answer_id": 59441134,
                "question_id": 59440452,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This gets very close to the requested output.\r\n\r\n    jq -c &#39;to_entries[] \r\n           | if .value|type == &quot;object&quot;\r\n             then .key as $k \r\n                | .value\r\n                | to_entries[]\r\n                | [&quot;\\($k).\\(.key)&quot;, (.value|type)]\r\n             else [.key, (.value|type)]\r\n             end&#39;\r\n\r\nOutput:\r\n\r\n    [&quot;parameter.colA&quot;,&quot;string&quot;]\r\n    [&quot;parameter.COLB&quot;,&quot;string&quot;]\r\n    [&quot;workRequired&quot;,&quot;number&quot;]\r\n    [&quot;work&quot;,&quot;number&quot;]\r\n    [&quot;updateType&quot;,&quot;string&quot;]\r\n\r\nThe main difference is in the first two lines. I don&#39;t think that `[&quot;parameter&quot;.&quot;colA&quot;,&quot;string&#39;]` is valid json.\r\n\r\nSome of the types are different as well.\r\n\r\n**Explanation**\r\n\r\nOne way of learning how this stuff works is to go step by step. So start with `jq -c &#39;to_entries[]&#39;` to see what comes out and then add each step in turn. The [manual](https://stedolan.github.io/jq/manual/v1.6/) is also quite good.\r\n\r\nHere, we start with an object. The first command is `to_entries[]`. To quote the manual, when &quot;to_entries is passed an object, then for each k: v entry in the input, the output array includes {&quot;key&quot;: k, &quot;value&quot;: v}.&quot; Adding `[]` at the end means the output will just be the objects in the array that `to_entries` produces. So this is the output after the first step:\r\n\r\n    {&quot;key&quot;:&quot;parameter&quot;,&quot;value&quot;:{&quot;colA&quot;:&quot;No&quot;,&quot;COLB&quot;:&quot;No&quot;}}\r\n    {&quot;key&quot;:&quot;workRequired&quot;,&quot;value&quot;:0}\r\n    {&quot;key&quot;:&quot;work&quot;,&quot;value&quot;:0}\r\n    {&quot;key&quot;:&quot;updateType&quot;,&quot;value&quot;:&quot;AUTO&quot;}\r\n\r\nNow we have four objects. One contains another object. The original question concerns the object that contains an object. The problem was to combine the key for the containing object with the key for the contained object in the final output.\r\n\r\nThe conditional `if .value|type == &quot;object&quot;` identifies the object that contains an object.\r\n\r\nWhen this condition is met, `.key as $k` saves the value of the containing object&#39;s &quot;key&quot; key as a variable named $k.\r\n\r\nThen we repeat `to_entries[]` with the contained object. The contained object is the value of the key &quot;value&quot; in the containing object. The code `.value | to_entries[]` filters the contained object through `to_entries[]`. That gives us these two objects.\r\n\r\n    {&quot;key&quot;:&quot;colA&quot;,&quot;value&quot;:&quot;No&quot;}\r\n    {&quot;key&quot;:&quot;COLB&quot;,&quot;value&quot;:&quot;No&quot;}\r\n\r\nTo create the desired output, we need to construct an array that combines the key of the containing object, which was saved as $k, with the elements of those two objects. Here is how we do that. (See &quot;String interpolation&quot; in the [manual](https://stedolan.github.io/jq/manual/v1.6/) for an explanation of how the part in quotes works.)\r\n\r\n    [&quot;\\($k).\\(.key)&quot;, (.value|type)]\r\n\r\nFor each object, the key we saved as the variable $k is combined with the value of the &quot;key&quot; key in the object. Then we output the type of the value of the &quot;value&quot; key in the object.\r\n\r\nThis yields the first two lines of the final output:\r\n\r\n    [&quot;parameter.colA&quot;,&quot;string&quot;]\r\n    [&quot;parameter.COLB&quot;,&quot;string&quot;]\r\n\r\nNow we move to the other branch of our conditional. This deals with the three objects from the first step that do not contain objects. Here we just repeat the original code from the question since that was satisfactory.\r\n\r\n    else [.key, (.value|type)]\r\n\r\nThat yields this:\r\n\r\n    [&quot;workRequired&quot;,&quot;number&quot;]\r\n    [&quot;work&quot;,&quot;number&quot;]\r\n    [&quot;updateType&quot;,&quot;string&quot;]\r\n\r\nThe command `end` ends the conditional.\r\n\r\nOne more thing. The flag `-c` at the very beginning tells jq we want compact output. Without it, the output would be logically the same, but spread over multiple lines.\r\n",
                "title": "How to get keys and key types of nested json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1577039388,
        "creation_date": 1576968857,
        "question_id": 59440452,
        "body_markdown": "I have a file data.json like below -\r\n\r\n         { \r\n           &quot;parameter&quot;: {\r\n            &quot;colA&quot;: &quot;No&quot;,\r\n            &quot;COLB&quot;: &quot;No&quot;\r\n          },\r\n          &quot;workRequired&quot;: 0,\r\n          &quot;work&quot;: 0,\r\n          &quot;updateType&quot;: &quot;AUTO&quot;\r\n    }\r\n\r\nI know how to get the key and key type of json -\r\n\r\n    jq -c &#39;to_entries[] | [.key, (.value|type)]&#39; data.json\r\n\r\nbut the above command returns me -\r\n\r\n    [&quot;parmeter&quot;,&quot;object&quot;]\r\n    [&quot;workRequired&quot;,&quot;string&quot;]\r\n    [&quot;work&quot;,&quot;null&quot;]\r\n    [&quot;updateType&quot;,&quot;number&quot;]\r\n\r\nbut I want the command to return like below, so that I get key type of nested json -\r\n\r\n    [&quot;parmeter&quot;.&quot;colA&quot;,&quot;string&quot;]\r\n    [&quot;parmeter&quot;.&quot;colB&quot;,&quot;string&quot;]\r\n    [&quot;workRequired&quot;,&quot;string&quot;]\r\n    [&quot;work&quot;,&quot;null&quot;]\r\n    [&quot;updateType&quot;,&quot;number&quot;]\r\n\r\n\r\nIs there any way to do using jq",
        "link": "https://stackoverflow.com/questions/59440452/how-to-get-keys-and-key-types-of-nested-json-using-jq",
        "title": "How to get keys and key types of nested json using jq"
    },
    {
        "tags": [
            "mysql",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1577046219,
                "last_edit_date": 1577046219,
                "creation_date": 1577044136,
                "answer_id": 59447563,
                "question_id": 59447428,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem arises because of the way you&#39;re reading in the SQL commands.\r\n\r\nTo illustrate, consider:\r\n```\r\n#!/bin/bash\r\nread -d &#39;&#39; SQL1 &lt;&lt; EOM\r\n    LINES TERMINATED BY &#39;\\n&#39;\r\nEOM\r\n\r\necho &quot;$SQL1&quot;\r\n```\r\nThis produces:\r\n\r\n```\r\nLINES TERMINATED BY &#39;n&#39;\r\n```\r\n\r\nSo if you&#39;re going to use the HEREDOC technique to specify the LINES TERMINATED BY value, you&#39;ll either need to write\r\n\r\n\r\n    LINES TERMINATED BY &#39;\\\\\\n&#39;\r\n\r\nor use the -r option of `read`.\r\n\r\nSince `\\n` is supposedly the default anyway (at least in MYSQL V8), you could try simply omitting the LINES TERMINATED BY specification.\r\n\r\n",
                "title": "MySQL unable to detect line breaks from jq generated CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1577046219,
        "creation_date": 1577043023,
        "question_id": 59447428,
        "body_markdown": "I have written a small Bash script to read a JSON file to CSV for import into MySQL. The below example is a boiled down version of what we have - the JSON is quite complex making it difficult to import directly into MySQL.\r\n\r\nA CSV will allow us to import to a temporary table and use the data in a number of different ways with validation etc.\r\n\r\nOur issue is, the line breaks in the generated CSV file are not recognized by MySQL using `&#39;\\n&#39;`. I have tried `&#39;\\r\\n&#39;` and validated with `file -k` the filetype `(ASCII text, with very long lines)`. I can successfully count the number of `&#39;\\n&#39;` in the command line, so I&#39;m confident the text file is correctly generated.\r\n\r\nRegardless, MySQL fails to recognize the line break for row termination with `ERROR 1262 (01000) at line 5: Row 1 was truncated; it contained more data than there were input columns`.\r\n\r\n**Editing the file down to a single row imports successfully**, so I know the fields in the CSV match up to the table.\r\n\r\nHere is my script:\r\n\r\n    #!/bin/bash\r\n    {\r\n    \r\n    # Define variables\r\n    source &quot;$_source/../_config.sh&quot;\r\n    \r\n    _today=$(date &#39;+%Y-%m-%d&#39;);\r\n    _source=&quot;$(dirname &quot;$0&quot;)&quot;\r\n    \r\n    jq -r &#39;.data | [.val1, .val2, .val3] | @csv&#39; &lt;$_source/raw/&quot;$_today&quot;.json &gt;raw/&quot;$_today&quot;.csv\r\n    \r\n    read -d &#39;&#39; SQL1 &lt;&lt; EOM\r\n        set unique_checks = 0;\r\n        set foreign_key_checks = 0;\r\n        set sql_log_bin=0;\r\n    \r\n    \tLOAD DATA LOCAL INFILE &#39;raw/&quot;$_today&quot;.csv&#39; \r\n    \tREPLACE INTO TABLE imports \r\n    \tCHARACTER SET utf8 \r\n    \r\n    \tFIELDS TERMINATED BY &#39;,&#39; \r\n    \tOPTIONALLY ENCLOSED BY &#39;&quot;&#39;\r\n    \tLINES TERMINATED BY &#39;\\n&#39;\r\n    \t\r\n    \t(@col1, @col2, @col3)\r\n    \tSET \r\n    \t\tval1 = TRIM(@col1),\r\n    \t\tval2 = TRIM(@col2),\r\n    \t\tval3 = TRIM(@col3)\r\n    \t;\r\n    EOM\r\n    \r\n    _result=$(echo &quot;$SQL1&quot; | mysql $_db -u$_user -p$_pass -s -N)\r\n    \r\n    }\r\n\r\nWith `jq`, I have tried the `-a` and the `-c` flag as well with no noticeable difference. Any ideas why MySQL doesn&#39;t see the newlines?\r\n",
        "link": "https://stackoverflow.com/questions/59447428/mysql-unable-to-detect-line-breaks-from-jq-generated-csv",
        "title": "MySQL unable to detect line breaks from jq generated CSV"
    },
    {
        "tags": [
            "json",
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6759085,
                    "reputation": 3560,
                    "user_id": 5223223,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-QFGa11QGfIg/AAAAAAAAAAI/AAAAAAAAAB0/1HgxEcgjlSg/s256-rj/photo.jpg",
                    "display_name": "dibery",
                    "link": "https://stackoverflow.com/users/5223223/dibery"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1577118157,
                "post_id": 59458409,
                "comment_id": 105097952,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 84370,
                    "reputation": 16191,
                    "user_id": 235908,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/rTstt.jpg?s=256",
                    "display_name": "sshine",
                    "link": "https://stackoverflow.com/users/235908/sshine"
                },
                "reply_to_user": {
                    "account_id": 6759085,
                    "reputation": 3560,
                    "user_id": 5223223,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-QFGa11QGfIg/AAAAAAAAAAI/AAAAAAAAAB0/1HgxEcgjlSg/s256-rj/photo.jpg",
                    "display_name": "dibery",
                    "link": "https://stackoverflow.com/users/5223223/dibery"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577118255,
                "post_id": 59458409,
                "comment_id": 105098000,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14111294,
                    "reputation": 1917,
                    "user_id": 10194070,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fWbkw.png?s=256",
                    "display_name": "Judy",
                    "link": "https://stackoverflow.com/users/10194070/judy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577118525,
                "post_id": 59458409,
                "comment_id": 105098138,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14111294,
                    "reputation": 1917,
                    "user_id": 10194070,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/fWbkw.png?s=256",
                    "display_name": "Judy",
                    "link": "https://stackoverflow.com/users/10194070/judy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577119091,
                "post_id": 59458409,
                "comment_id": 105098409,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1613587,
                    "reputation": 786618,
                    "user_id": 1491895,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://www.gravatar.com/avatar/82f9e178a16364bf561d0ed4da09a35d?s=256&d=identicon&r=PG",
                    "display_name": "Barmar",
                    "link": "https://stackoverflow.com/users/1491895/barmar"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1577119714,
                "post_id": 59458409,
                "comment_id": 105098686,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6014861,
                    "reputation": 20007,
                    "user_id": 7939871,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/1199ba5dde05e4083823a058c5ac6bed?s=256&d=identicon&r=PG",
                    "display_name": "L&#233;a Gris",
                    "link": "https://stackoverflow.com/users/7939871/l%c3%a9a-gris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577120671,
                "post_id": 59458409,
                "comment_id": 105099051,
                "content_license": "CC BY-SA 4.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": 1577121224,
                "post_id": 59458409,
                "comment_id": 105099253,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1577123552,
                "creation_date": 1577123552,
                "answer_id": 59459406,
                "question_id": 59458409,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can pretty print a json string using Python 3 if you cant install jq for some reason :\r\n\r\n    echo &#39;{ &quot;name&quot; : &quot;Matias&quot;, &quot;age&quot;: 32 }&#39; | python3 -c &#39;import sys\r\n    import json\r\n    print(json.dumps(json.load(sys.stdin), indent=&quot;  &quot;))\r\n    &#39;\r\n\r\nThis will print : \r\n\r\n    {\r\n      &quot;name&quot;: &quot;Matias&quot;,\r\n      &quot;age&quot;: 32\r\n    }\r\n\r\nHope it&#39;s useful.",
                "title": "convert long line of json file to readable file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1577123552,
        "creation_date": 1577118072,
        "last_edit_date": 1577118430,
        "question_id": 59458409,
        "body_markdown": "I need help about how to convert long line of json file to readable file\r\n\r\nthis is the json format \r\n\r\n\r\n    &quot;version&quot;: 1, &quot;partitions&quot;: [{&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 7, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [3, 0, 2]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 4, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [3, 0, 2]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 15, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [2, 3, 0]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 9, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [2, 3, 0]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 12, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [2, 3, 0]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 1, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [3, 2, 0]}, {&quot;topic&quot;: &quot;CatchAllTopic&quot;, &quot;partition&quot;: 0, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [0, 3, 2]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 17, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [0, 3, 2]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 6, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [2, 0, 3]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 3, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [2, 0, 3]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 14, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [0, 2, 3]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 0, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [2, 0, 3]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 11, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [0, 2, 3]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 16, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [3, 0, 2]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 8, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [0, 3, 2]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 2, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [0, 3, 2]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 13, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [3, 0, 2]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 5, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [0, 3, 2]}, {&quot;topic&quot;: &quot;Topic3&quot;, &quot;partition&quot;: 10, &quot;log_dirs&quot;: [&quot;any&quot;], &quot;replicas&quot;: [3, 0, 2]}]}\r\n\r\nor actually more like this:\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n\r\nwhile we want the file as the following format\r\n\r\nmore file.json\r\n\r\n    {&quot;partitions&quot;:\r\n           [{&quot;topic&quot;: &quot;foo&quot;,\r\n             &quot;partition&quot;: 1,\r\n              &quot;replicas&quot;: [1,2,3],\r\n              &quot;log_dirs&quot;: [&quot;any&quot;,&quot;any&quot;,&quot;any&quot;]\r\n           }],\r\n    .\r\n    .\r\n    .\r\n    .\r\n    .\r\n\r\n\r\n  [1]: https://i.sstatic.net/7RsQ7.png",
        "link": "https://stackoverflow.com/questions/59458409/convert-long-line-of-json-file-to-readable-file",
        "title": "convert long line of json file to readable file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1577203742,
                "last_edit_date": 1577203742,
                "creation_date": 1577195451,
                "answer_id": 59469802,
                "question_id": 59469594,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is a job of simple filter in `jq` to select the required object from the list of objects.\r\n\r\n    jq --arg part_id &quot;4&quot; &#39;.partitions[] | select(.partition == ($part_id|tonumber))&#39;\r\n\r\nor use the `map()` function\r\n\r\nYou can feed the required partition id as input and later use that in the `select(..)` expression. Since by default the args are evaluated as strings and the filter needing an integer value to be checked, we do a string to input conversion using `tonumber`, so that the `.partitition` is compared against an integer value.\r\n\r\nTo answer the follow up question to retain only the object needed and remove the other ones, use the `|=` operator and select\r\n\r\n    jq --arg part_id &quot;4&quot; &#39;.partitions |= map(select(.partition == ($part_id|tonumber)))&#39;",
                "title": "Filtering out one object from a list of objects based on a field using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1577203742,
        "creation_date": 1577194396,
        "last_edit_date": 1577196223,
        "question_id": 59469594,
        "body_markdown": "We have the following json file , that include partitions and partition id ) \r\n\r\nin the file we have 6 partitions , while topic name is the same on all partitions \r\n\r\n    more file.json\r\n    \r\n    {\r\n      &quot;version&quot;: 1,\r\n      &quot;partitions&quot;: [\r\n        {\r\n          &quot;topic&quot;: &quot;list_of_cars&quot;,\r\n          &quot;partition&quot;: 2,\r\n          &quot;replicas&quot;: [\r\n            1003,\r\n            1004,\r\n            1005\r\n          ],\r\n          &quot;log_dirs&quot;: [\r\n            &quot;any&quot;,\r\n            &quot;any&quot;,\r\n            &quot;any&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;topic&quot;: &quot;list_of_cars&quot;,\r\n          &quot;partition&quot;: 4,\r\n          &quot;replicas&quot;: [\r\n            1005,\r\n            1006,\r\n            1001\r\n          ],\r\n          &quot;log_dirs&quot;: [\r\n            &quot;any&quot;,\r\n            &quot;any&quot;,\r\n            &quot;any&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;topic&quot;: &quot;list_of_cars&quot;,\r\n          &quot;partition&quot;: 0,\r\n          &quot;replicas&quot;: [\r\n            1001,\r\n            1002,\r\n            1003\r\n          ],\r\n          &quot;log_dirs&quot;: [\r\n            &quot;any&quot;,\r\n            &quot;any&quot;,\r\n            &quot;any&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;topic&quot;: &quot;list_of_cars&quot;,\r\n          &quot;partition&quot;: 1,\r\n          &quot;replicas&quot;: [\r\n            1002,\r\n            1003,\r\n            1004\r\n          ],\r\n          &quot;log_dirs&quot;: [\r\n            &quot;any&quot;,\r\n            &quot;any&quot;,\r\n            &quot;any&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;topic&quot;: &quot;list_of_cars&quot;,\r\n          &quot;partition&quot;: 5,\r\n          &quot;replicas&quot;: [\r\n            1006,\r\n            1001,\r\n            1002\r\n          ],\r\n          &quot;log_dirs&quot;: [\r\n            &quot;any&quot;,\r\n            &quot;any&quot;,\r\n            &quot;any&quot;\r\n          ]\r\n        },\r\n        {\r\n          &quot;topic&quot;: &quot;list_of_cars&quot;,\r\n          &quot;partition&quot;: 3,\r\n          &quot;replicas&quot;: [\r\n            1004,\r\n            1005,\r\n            1006\r\n          ],\r\n          &quot;log_dirs&quot;: [\r\n            &quot;any&quot;,\r\n            &quot;any&quot;,\r\n            &quot;any&quot;\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nIs it possible to print the following according to partition id\r\n\r\nFor example\r\n\r\nLets say we want to print the json part for partition id – 4\r\n\r\nThen expected results should be like this\r\n\r\n    {\r\n               &quot;topic&quot;: &quot;list_of_cars&quot;,\r\n               &quot;partition&quot;: 4,\r\n               &quot;replicas&quot;: [\r\n                              1005,\r\n                              1006,\r\n                              1001\r\n               ],\r\n               &quot;log_dirs&quot;: [\r\n                              &quot;any&quot;,\r\n                              &quot;any&quot;,\r\n                              &quot;any&quot;\r\n               ]\r\n    }\r\n\r\n\r\n\r\n**the best case is to print the following valid format ( if it possible )**\r\n\r\n    {\r\n    \t&quot;version&quot;: 1,\r\n    \t&quot;partitions&quot;: [{\r\n    \t\t&quot;topic&quot;: &quot;list_of_cars&quot;,\r\n    \t\t&quot;partition&quot;: 4,\r\n    \t\t&quot;replicas&quot;: [\r\n    \t\t\t1005,\r\n    \t\t\t1006,\r\n    \t\t\t1001\r\n    \t\t],\r\n    \t\t&quot;log_dirs&quot;: [\r\n    \t\t\t&quot;any&quot;,\r\n    \t\t\t&quot;any&quot;,\r\n    \t\t\t&quot;any&quot;\r\n    \t\t]\r\n    \t}]\r\n    }",
        "link": "https://stackoverflow.com/questions/59469594/filtering-out-one-object-from-a-list-of-objects-based-on-a-field-using-jq",
        "title": "Filtering out one object from a list of objects based on a field using jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1577256774,
                "last_edit_date": 1577256774,
                "creation_date": 1577247923,
                "answer_id": 59475215,
                "question_id": 59475031,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the built-in function, `INDEX`, for creating a dictionary allows a straightforward solution as follows:\r\n\r\n```\r\n(.header.type\r\n | INDEX(to_entries[]; .key)\r\n | map_values(.value.name)) as $dict\r\n| .data[] \r\n| (.reading | keys_unsorted[]) as $k\r\n| {time} + { ($dict[$k]) : .reading[$k] }\r\n\r\n```\r\n### Output\r\n```\r\n{\r\n  &quot;time&quot;: &quot;2019-01-01T02:00:00Z&quot;,\r\n  &quot;Cats&quot;: {\r\n    &quot;value&quot;: 90,\r\n    &quot;note&quot;: &quot;start&quot;\r\n  }\r\n}\r\n{\r\n  &quot;time&quot;: &quot;2019-01-01T02:00:00Z&quot;,\r\n  &quot;Dogs&quot;: {\r\n    &quot;value&quot;: 100\r\n  }\r\n}\r\n```\r\n\r\n",
                "title": "Processing JSON with jq - handling array index/name into output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1577256774,
        "creation_date": 1577245212,
        "last_edit_date": 1577252832,
        "question_id": 59475031,
        "body_markdown": "I&#39;m trying to use jq to parse a JSON file for me.  I want to get a value from a definition header into the output data in place of an index.  A simplified example:\r\n\r\n```\r\n{\r\n  &quot;header&quot;: {\r\n    &quot;type&quot;: {\r\n      &quot;0&quot;: {\r\n             &quot;name&quot;: &quot;Cats&quot;\r\n           },\r\n      &quot;3&quot;: {\r\n             &quot;name&quot;: &quot;Dogs&quot;\r\n           }\r\n    }\r\n  },\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;time&quot;: &quot;2019-01-01T02:00:00Z&quot;,\r\n      &quot;reading&quot;: { \r\n                   &quot;0&quot;: {&quot;value&quot;: 90, &quot;note&quot;: &quot;start&quot; },\r\n                   &quot;3&quot;: {&quot;value&quot;: 100 }\r\n                 } \r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nUsing a jq command like `jq &#39;.data[] | {time: .time, data: .reading[]}&#39;` gives me:\r\n\r\n```{\r\n  &quot;time&quot;: &quot;2019-01-01T02:00:00Z&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;value&quot;: 90,\r\n    &quot;note&quot;: &quot;start&quot;\r\n  }\r\n}\r\n{\r\n  &quot;time&quot;: &quot;2019-01-01T02:00:00Z&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;value&quot;: 100\r\n  }\r\n}\r\n```\r\nI need to get &quot;Cats&quot; or &quot;Dogs&quot; into the result, heading towards an SQL insert.\r\n\r\nSomething like:\r\n```\r\n{\r\n  &quot;time&quot;: &quot;2019-01-01T02:00:00Z&quot;,\r\n  &quot;data&quot;: {\r\n    &quot;type: &quot;Cats&quot;,      &lt;- line added\r\n    &quot;value&quot;: 90,\r\n    &quot;note&quot;: &quot;start&quot;\r\n  }\r\n}\r\n...\r\n```\r\n\r\nOr better yet:\r\n```\r\n{\r\n  &quot;time&quot;: &quot;2019-01-01T02:00:00Z&quot;,\r\n  &quot;Cats&quot;: {                    &lt;- label set to &quot;Cats&quot; instead of &quot;data&quot;\r\n    &quot;value&quot;: 90,\r\n    &quot;note&quot;: &quot;start&quot;\r\n  }\r\n}\r\n...\r\n```\r\nIs there a way I can get - what I see as the array index &quot;0&quot; or &quot;3&quot; - to be added as &quot;Cats&quot; or &quot;Dogs&quot;?",
        "link": "https://stackoverflow.com/questions/59475031/processing-json-with-jq-handling-array-index-name-into-output",
        "title": "Processing JSON with jq - handling array index/name into output"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16606925,
                    "reputation": 2623,
                    "user_id": 12001122,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cbdc902860ae6648e386684fed3fcb85?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "JSRB",
                    "link": "https://stackoverflow.com/users/12001122/jsrb"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577361227,
                "post_id": 59487933,
                "comment_id": 105150735,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1577375215,
                "creation_date": 1577375215,
                "answer_id": 59490571,
                "question_id": 59487933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to multiply the .b value in an object by 3, you could write:\r\n\r\n    .b *= 3",
                "title": "How do I multiply two json with jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1577383617,
                "creation_date": 1577383617,
                "answer_id": 59491897,
                "question_id": 59487933,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to define a multiplication operation on JSON objects, consider:\r\n```\r\ndef multiply(o):\r\n  reduce (o|keys_unsorted[]) as $k (.; .[$k] *= o[$k]);\r\n```\r\n\r\nUsing your example:\r\n\r\n    {&quot;a&quot;: 1, &quot;b&quot;: 2, &quot;c&quot;: 3} | multiply({&quot;b&quot;:3})\r\n\r\nyields:\r\n```\r\n{\r\n  &quot;a&quot;: 1,\r\n  &quot;b&quot;: 6,\r\n  &quot;c&quot;: 3\r\n}\r\n```\r\n\r\n",
                "title": "How do I multiply two json with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1577383617,
        "creation_date": 1577360396,
        "question_id": 59487933,
        "body_markdown": "Got `{&quot;a&quot;: 1, &quot;b&quot;: 2, &quot;c&quot;: 3}`\r\n\r\nwant it be `{&quot;a&quot;: 1, &quot;b&quot;: 6, &quot;c&quot;: 3}`\r\n\r\nbut if I `{&quot;a&quot;: 1, &quot;b&quot;: 2, &quot;c&quot;: 3} * {&quot;b&quot;: 3}` it ends up `{&quot;a&quot;: 1, &quot;b&quot;: 3, &quot;c&quot;: 3}`.\r\n\r\nHow do I make it happen with jq?",
        "link": "https://stackoverflow.com/questions/59487933/how-do-i-multiply-two-json-with-jq",
        "title": "How do I multiply two json with jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577420892,
                "post_id": 59490059,
                "comment_id": 105165560,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1577374661,
                "creation_date": 1577374661,
                "answer_id": 59490471,
                "question_id": 59490059,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might be looking for something like that :\r\n\r\n    jq &#39;.JAVA_OPTS |= . + &quot; -Dhttps.protocols=TLSv1.2&quot;&#39; \r\n\r\n[Try it here](https://jqplay.org/s/9_01xLwOTv).",
                "title": "How to update a key/value using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1577391195,
        "creation_date": 1577372309,
        "last_edit_date": 1577391195,
        "question_id": 59490059,
        "body_markdown": "I have a key/value below in a JSON\r\n\r\n    JAVA_OPTS=&quot;JAVA_OPTS&quot;: &quot;-Xms1g -Xmx2g -Dapi.version=v1 -Dspring.profiles.active=test -Dservice.name=xyz&quot;\r\n\r\nUsing jq i want to insert one more string to this key/value pair `&quot;-Dhttps.protocols=TLSv1.2&quot;`\r\n\r\nSo the output should looks like \r\n\r\n    JAVA_OPTS=&quot;JAVA_OPTS&quot;: &quot;-Xms1g -Xmx2g -Dapi.version=v1 -Dspring.profiles.active=test -Dservice.name=xyz -Dhttps.protocols=TLSv1.2&quot;",
        "link": "https://stackoverflow.com/questions/59490059/how-to-update-a-key-value-using-jq",
        "title": "How to update a key/value using jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1577378795,
                "post_id": 59491079,
                "comment_id": 105156529,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1577378804,
                "post_id": 59491079,
                "comment_id": 105156534,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1317803,
                    "reputation": 10918,
                    "user_id": 1264304,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/bd81fb6370a901321913b1465efa8e51?s=256&d=identicon&r=PG",
                    "display_name": "rokpoto.com",
                    "link": "https://stackoverflow.com/users/1264304/rokpoto-com"
                },
                "reply_to_user": {
                    "account_id": 468289,
                    "reputation": 190915,
                    "user_id": 874188,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/091f411d57db5be8298e057a32e5ad72?s=256&d=identicon&r=PG",
                    "display_name": "tripleee",
                    "link": "https://stackoverflow.com/users/874188/tripleee"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577378999,
                "post_id": 59491079,
                "comment_id": 105156597,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1577379310,
                "creation_date": 1577379310,
                "answer_id": 59491237,
                "question_id": 59491079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One solution is to use `to_entries` then `map` to extract only the values:\r\n\r\n    $ echo &#39;{\r\n       &quot;a&quot; : 1,\r\n       &quot;b&quot; : 2\r\n    }&#39; | jq &#39;to_entries|map(.value)&#39;\r\n    [\r\n      1,\r\n      2\r\n    ]\r\n\r\nAnother solution, simpler and faster, is to use just `map(.)`:\r\n\r\n    $ echo &#39;{\r\n       &quot;a&quot; : 1,\r\n       &quot;b&quot; : 2\r\n    }&#39; | jq &#39;map(.)&#39;\r\n    [\r\n      1,\r\n      2\r\n    ]\r\n\r\n\r\n",
                "title": "Extract json values as array with jq in bash"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1577383846,
                "last_edit_date": 1577383846,
                "creation_date": 1577379459,
                "answer_id": 59491263,
                "question_id": 59491079,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\n    echo $json | jq &#39;[.[]]&#39;\r\n\r\n\r\noutput: \r\n\r\n    [\r\n      1,\r\n      2\r\n    ]\r\n\r\n\r\n\r\n",
                "title": "Extract json values as array with jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1577610629,
        "creation_date": 1577378441,
        "last_edit_date": 1577610629,
        "question_id": 59491079,
        "body_markdown": "How to extract json&#39;s values as JSON array with `jq`?\r\n\r\nFor example for the below json:\r\n\r\n    {\r\n       &quot;a&quot; : 1,\r\n       &quot;b&quot; : 2\r\n    }\r\n\r\nI would like to extract values as JSON array: \r\n\r\n`[\r\n1,\r\n2\r\n]`\r\n\r\nHow to do it with `jq`?\r\nI found a way to extract keys only in the [docs][1]: \r\n\r\n`echo $json | jq keys` returns:\r\n\r\n    [\r\n    &quot;a&quot;,\r\n    &quot;b&quot;\r\n    ]\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#TypesandValues",
        "link": "https://stackoverflow.com/questions/59491079/extract-json-values-as-array-with-jq-in-bash",
        "title": "Extract json values as array with jq in bash"
    },
    {
        "tags": [
            "json",
            "bash",
            "pipe",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1577397564,
                "last_edit_date": 1577397564,
                "creation_date": 1577391188,
                "answer_id": 59493051,
                "question_id": 59492888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Create objects for each input line:\r\n\r\n    echo -e &quot;l1\\nl2\\nl3&quot; | jq -c -R &#39;{&quot;listing&quot;: .}&#39;\r\n\r\nOutput:\r\n\r\n    {&quot;listing&quot;:&quot;l1&quot;}\r\n    {&quot;listing&quot;:&quot;l2&quot;}\r\n    {&quot;listing&quot;:&quot;l3&quot;}",
                "title": "Wrap Bash/Unix line oriented pipe in a json structure"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1577419801,
                "last_edit_date": 1577419801,
                "creation_date": 1577391287,
                "answer_id": 59493065,
                "question_id": 59492888,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should do it:\r\n\r\n    jq -cR &#39;{listing: .}&#39;\r\n\r\nThis assumes there are no superfluous spaces at the beginning of the input lines. If leading and trailing spaces are to be removed, you could use this composite filter:\r\n\r\n    sub(&quot;^ +&quot;;&quot;&quot;) | sub(&quot; +$&quot;;&quot;&quot;)",
                "title": "Wrap Bash/Unix line oriented pipe in a json structure"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1577518060,
        "creation_date": 1577390199,
        "last_edit_date": 1577518060,
        "question_id": 59492888,
        "body_markdown": "\r\nHow can I convert this\r\n\r\n    http://www.google.co.uk\r\n    http://www.reddit.com\r\n    http://www.ebay.com\r\n\r\nto this using `jq` if possible:\r\n\r\n    { &quot;listing&quot;: &quot;http://www.google.co.uk&quot; }\r\n    { &quot;listing&quot;: &quot;http://www.reddit.com&quot; }\r\n    { &quot;listing&quot;: &quot;http://www.ebay.com&quot; }\r\n\r\n\r\n\r\n\r\nWhat I tried:\r\n\r\n    $ echo &quot;    http://www.google.co.uk\r\n    &gt;     http://www.reddit.com\r\n    &gt;     http://www.ebay.com&quot;  |  jq --slurp --raw-input &#39;split(&quot;\\n&quot;)[:-1] | map({ listing: .})&#39;\r\n    [\r\n      {\r\n        &quot;listing&quot;: &quot;    http://www.google.co.uk&quot;\r\n      },\r\n      {\r\n        &quot;listing&quot;: &quot;    http://www.reddit.com&quot;\r\n      },\r\n      {\r\n        &quot;listing&quot;: &quot;    http://www.ebay.com&quot;\r\n      }\r\n    ]\r\n\r\n\r\nBraces and stuff cannot be in a line of its own, because I&#39;m doing &quot;line oriented processing&quot; where each line represents a &quot;row&quot; of data.",
        "link": "https://stackoverflow.com/questions/59492888/wrap-bash-unix-line-oriented-pipe-in-a-json-structure",
        "title": "Wrap Bash/Unix line oriented pipe in a json structure"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577717647,
                "post_id": 59532410,
                "comment_id": 105235024,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1989180,
                    "reputation": 6207,
                    "user_id": 1783632,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://i.sstatic.net/hEh0s.jpg?s=256",
                    "display_name": "Shahar Hamuzim Rajuan",
                    "link": "https://stackoverflow.com/users/1783632/shahar-hamuzim-rajuan"
                },
                "reply_to_user": {
                    "account_id": 15778755,
                    "reputation": 1303,
                    "user_id": 11385808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/321f8b770bfd0099048493cebba39edd?s=256&d=identicon&r=PG",
                    "display_name": "Dmitry",
                    "link": "https://stackoverflow.com/users/11385808/dmitry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577719952,
                "post_id": 59532410,
                "comment_id": 105235998,
                "content_license": "CC BY-SA 4.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": 1577726498,
                "post_id": 59532410,
                "comment_id": 105238722,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1577720265,
                "creation_date": 1577720265,
                "answer_id": 59533269,
                "question_id": 59532410,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "***Found the solution:***\r\n\r\n[https://unix.stackexchange.com/questions/460059/jq-how-to-print-only-the-value-of-key-under-properties/460064][1]\r\n\r\n\r\n    aws secretsmanager get-secret-value --secret-id Build-db --query SecretString --output text | jq -r &#39;&quot;{ \\(.password) }&quot;&#39;\r\n\r\nWhich returns:\r\n\r\n    { CHANGE_ME }\r\n\r\n\r\n  [1]: https://unix.stackexchange.com/questions/460059/jq-how-to-print-only-the-value-of-key-under-properties/460064",
                "title": "jq - get only the value without the key from a command output (json)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1577720265,
        "creation_date": 1577716036,
        "question_id": 59532410,
        "body_markdown": "I&#39;m trying to use jq to get only the vale without the key from a command output,\r\n\r\nfor some reason, it doesn&#39;t parse as I see in most of the examples.\r\n\r\n    jenkins@10.0.0.0:/tmp$ aws secretsmanager get-secret-value --secret-id Build-db --query SecretString --output text\r\n    {&quot;username&quot;:&quot;build_write&quot;,&quot;password&quot;:&quot;CHANGE_ME&quot;}\r\n\r\nthis is my command with **jq** and the output:\r\n\r\n    jenkins@10.0.0.0:/tmp$ aws secretsmanager get-secret-value --secret-id Build-db --query SecretString --output text| jq -r &#39;{&quot;password&quot;}&#39;\r\n    {&quot;password&quot;: &quot;CHANGE_ME&quot;}\r\n\r\nBut the expected result should be only the value: `{&quot;CHANGE_ME&quot;}`",
        "link": "https://stackoverflow.com/questions/59532410/jq-get-only-the-value-without-the-key-from-a-command-output-json",
        "title": "jq - get only the value without the key from a command output (json)"
    },
    {
        "tags": [
            "windows",
            "cmd",
            "echo",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1577853432,
                "creation_date": 1577853432,
                "answer_id": 59550012,
                "question_id": 59549459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of several alternatives:\r\n\r\n\r\n      jq -r &quot;[.foo2, .foo] | join(\\&quot;;\\&quot;)&quot;",
                "title": "Windows CMD parse"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1577853432,
        "creation_date": 1577841766,
        "last_edit_date": 1577842663,
        "question_id": 59549459,
        "body_markdown": "How do I keep the results on the same line?\r\n\r\n```\r\nC:\\WINDOWS\\system32&gt;echo {&quot;foo&quot;: 0, &quot;foo2&quot;: 1} | jq &quot;.foo2, .foo&quot;\r\n\r\n1\r\n0\r\n```\r\nWould like to get:\r\n```\r\n1;0\r\n```",
        "link": "https://stackoverflow.com/questions/59549459/windows-cmd-parse",
        "title": "Windows CMD parse"
    },
    {
        "tags": [
            "json",
            "string",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1813273,
                    "reputation": 1492,
                    "user_id": 1648920,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/9JQUl.png?s=256",
                    "display_name": "JohnnyJS",
                    "link": "https://stackoverflow.com/users/1648920/johnnyjs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577870815,
                "post_id": 59551206,
                "comment_id": 105271279,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1315338,
                    "reputation": 2328,
                    "user_id": 1262357,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://www.gravatar.com/avatar/0858097ef67d054ac5f6d7b54486baee?s=256&d=identicon&r=PG",
                    "display_name": "Gruber",
                    "link": "https://stackoverflow.com/users/1262357/gruber"
                },
                "reply_to_user": {
                    "account_id": 1813273,
                    "reputation": 1492,
                    "user_id": 1648920,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://i.sstatic.net/9JQUl.png?s=256",
                    "display_name": "JohnnyJS",
                    "link": "https://stackoverflow.com/users/1648920/johnnyjs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1577913967,
                "post_id": 59551206,
                "comment_id": 105280876,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 9,
                "is_accepted": true,
                "score": 9,
                "last_activity_date": 1577927667,
                "last_edit_date": 1577927667,
                "creation_date": 1577870885,
                "answer_id": 59551309,
                "question_id": 59551206,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I tried playing around with your json on [jqplay][1].\r\n\r\nI got the desired result -\r\n\r\n    Email address for user Angela Sleney is &quot;asleney0@nytimes.com&quot;\r\n    Email address for user Clint Ducroe is &quot;cducroe1@aboutads.info&quot;\r\n    Email address for user Aurthur Tebb is &quot;atebb2@fastcompany.com&quot;\r\n\r\nwith this filter - \r\n\r\n    .[] | &quot;Email address for user \\(.first_name) \\(.last_name) is \\&quot;\\(.email)\\&quot;&quot;\r\nPlay around with the [`string interpolation \\(foo)`][2] to get your result.\r\n\r\n\r\n  [1]: https://jqplay.org/#\r\n  [2]: https://stedolan.github.io/jq/manual/v1.6/#Stringinterpolation-%5C(foo)",
                "title": "How can I print an arbitrary string with JQ?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1580372029,
                "last_edit_date": 1592644375,
                "creation_date": 1580353639,
                "answer_id": 59978554,
                "question_id": 59551206,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this:\n\n`jq -r &#39;.[] | .first_name + &quot; &quot; + .last_name + &quot; &quot; + .email&#39;`\n\n&gt; Addition: +\n&gt;\n&gt; The operator + takes two filters:\n&gt;\n&gt; - Applies them both to the same input\n&gt; - Adds the results together. \n\n\n----------\n\n\n&gt; The term “adding” here has a different meaning depending on the types involved:\n&gt;\n&gt; - Numbers are added by normal arithmetic.\n&gt; - Arrays are added by concatenating each other forming a larger array.\n&gt; - Strings are added by appending one with another to form a larger string.\n&gt;\n&gt; **Refer here for more details:**\n&gt;\n&gt; Source: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions\n",
                "title": "How can I print an arbitrary string with JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 6,
        "last_activity_date": 1580372029,
        "creation_date": 1577869764,
        "last_edit_date": 1577888208,
        "question_id": 59551206,
        "body_markdown": "I&#39;d like to print with JQ arbitrary composed strings.\r\n\r\nSuppose I have a json document* as follow:\r\n\r\n```js\r\n[{\r\n  &quot;first_name&quot;: &quot;Angela&quot;,\r\n  &quot;last_name&quot;: &quot;Sleney&quot;,\r\n  &quot;email&quot;: &quot;asleney0@nytimes.com&quot;\r\n}, {\r\n  &quot;first_name&quot;: &quot;Clint&quot;,\r\n  &quot;last_name&quot;: &quot;Ducroe&quot;,\r\n  &quot;email&quot;: &quot;cducroe1@aboutads.info&quot;\r\n}, {\r\n  &quot;first_name&quot;: &quot;Aurthur&quot;,\r\n  &quot;last_name&quot;: &quot;Tebb&quot;,\r\n  &quot;email&quot;: &quot;atebb2@fastcompany.com&quot;\r\n}]\r\n```\r\n\r\nand with data from above let&#39;s say just for example (could be any string) I&#39;d like to print with JQ 3 lines as follow:\r\n\r\n```lang-none\r\nEmail address for user Angela Sleney is &quot;asleney0@nytimes.com&quot;\r\nEmail address for user Clint Ducroe is &quot;cducroe1@aboutads.info&quot;\r\nEmail address for user Aurthur Tebb is &quot;atebb2@fastcompany.com&quot;\r\n```\r\n\r\nHow can I do this? \r\n\r\n---\r\n\r\nBest I was able to do was to print the data 1 per line with:\r\n\r\n```jq\r\njq -r &#39;.[] | .first_name, .last_name, .email, &quot;&quot;&#39;\r\n```\r\n But result was \r\n\r\n```lang-none\r\nAngela\r\nSleney\r\nasleney0@nytimes.com\r\n\r\nClint\r\nDucroe\r\ncducroe1@aboutads.info\r\n\r\nAurthur\r\nTebb\r\natebb2@fastcompany.com\r\n```\r\n\r\n\r\n*NB: the data comes from random [generator][1], no real names or emails.\r\n\r\n\r\n  [1]: https://mockaroo.com/",
        "link": "https://stackoverflow.com/questions/59551206/how-can-i-print-an-arbitrary-string-with-jq",
        "title": "How can I print an arbitrary string with JQ?"
    },
    {
        "tags": [
            "linux",
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 13,
                "is_accepted": true,
                "score": 13,
                "last_activity_date": 1577874773,
                "last_edit_date": 1577874773,
                "creation_date": 1577874101,
                "answer_id": 59551649,
                "question_id": 59551619,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You may use this:\r\n\r\n    json_val=&#39;{&quot;code&quot;:&quot;lyz1To6ZTWClDHSiaeXyxg&quot;,&quot;redirect_to&quot;:&quot;http://example.com/client-redirect-uri?code=lyz1To6ZTWClDHSiaeXyxg&quot;}&#39;\r\n    code_val=$(jq -r &#39;.code&#39; &lt;&lt;&lt; &quot;$json_val&quot;)\r\n    echo &quot;$code_val&quot;\r\n\r\n&lt;p/&gt;\r\n\r\n    lyz1To6ZTWClDHSiaeXyxg\r\n\r\nNote following changes:\r\n\r\n- Wrap complete json string in single quotes\r\n- use of `$(...)` for command substitution\r\n- Use of `&lt;&lt;&lt;` (here-string) to avoid a sub-shell creation\r\n\r\nPS: If you&#39;re getting `json` text from a curl command and want to store multiple fields in shell variables then use:\r\n\r\n    read -r code_val redirect_to &lt; &lt;(curl ... | jq -r &#39;.code + &quot;\\t&quot; + .redirect_to&#39;)\r\n\r\nWhere `...` is your curl command.\r\n",
                "title": "How to extract value from json contained in a variable using jq in bash"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1652283406,
                "last_edit_date": 1652283406,
                "creation_date": 1577896563,
                "answer_id": 59554200,
                "question_id": 59551619,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If try to do it manually:\r\n\r\n    $ echo {&quot;code&quot;:&quot;lyz1To6ZTWClDHSiaeXyxg&quot;,&quot;redirect_to&quot;:&quot;http://example.com/client-redirect-uri?code=lyz1To6ZTWClDHSiaeXyxg&quot;} | jq &#39;.code&#39;\r\n\r\n...it throws parse numeric letter error.\r\n\r\nseems like you did not escape the string of the `echo` command. in your case, escaping with a singe-quote (apostrophe `&#39;`) will do - same as you  did with  the `jq` json-path argument (`&#39;.code&#39;`)\r\n\r\n    $ echo &#39;{&quot;code&quot;:&quot;lyz1To6ZTWClDHSiaeXyxg&quot;,&quot;redirect_to&quot;:&quot;http://example.com/client-redirect-uri?code=lyz1To6ZTWClDHSiaeXyxg&quot;}&#39; | jq &#39;.code&#39;\r\n    &quot;lyz1To6ZTWClDHSiaeXyxg&quot;\r\n\r\n\r\n",
                "title": "How to extract value from json contained in a variable using jq in bash"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1652283406,
        "creation_date": 1577873786,
        "question_id": 59551619,
        "body_markdown": "I am writing a bash script which has a json value stored in a variable now i want to extract the values in that json using Jq. The code used is. \r\n\r\n    json_val={&quot;code&quot;:&quot;lyz1To6ZTWClDHSiaeXyxg&quot;,&quot;redirect_to&quot;:&quot;http://example.com/client-redirect-uri?code=lyz1To6ZTWClDHSiaeXyxg&quot;}\r\n      code_val= echo&quot;$json_val&quot; | jq &#39;.code&#39;\r\n                                              \r\n\r\nThis throws an error of no such file or direcotry.\r\n\r\nIf i change this to \r\n\r\n    json_val={&quot;code&quot;:&quot;lyz1To6ZTWClDHSiaeXyxg&quot;,&quot;redirect_to&quot;:&quot;http://example.com/client-redirect-uri?code=lyz1To6ZTWClDHSiaeXyxg&quot;}\r\n      code_val=echo&quot; $json_val &quot; | jq &#39;.code&#39;\r\n\r\n              \r\n\r\n This does not throws any error but the value in code_val is null.\r\n\r\nIf try to do it manually `echo {&quot;code&quot;:&quot;lyz1To6ZTWClDHSiaeXyxg&quot;,&quot;redirect_to&quot;:&quot;http://example.com/client-redirect-uri?code=lyz1To6ZTWClDHSiaeXyxg&quot;} | jq &#39;.code&#39;` it throws parse numeric letter error. \r\n\r\nhow can i do it in first case.",
        "link": "https://stackoverflow.com/questions/59551619/how-to-extract-value-from-json-contained-in-a-variable-using-jq-in-bash",
        "title": "How to extract value from json contained in a variable using jq in bash"
    },
    {
        "tags": [
            "jq",
            "mosquitto"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1577887279,
                "creation_date": 1577887279,
                "answer_id": 59553160,
                "question_id": 59552469,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One way is to “drill down”:\r\n\r\n    .Status.Power",
                "title": "mosquito_sub to jq get value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1577887279,
        "creation_date": 1577881359,
        "question_id": 59552469,
        "body_markdown": "I have MQTT mosquitto_sub running on linux bash that outputs this JSON data received from power plug:\r\n\r\n    #mosquitto_sub -t stat/sensors/# | jq -r &#39;.&#39;\r\n    {\r\n      &quot;Status&quot;: {\r\n        &quot;Module&quot;: 52,\r\n        &quot;FriendlyName&quot;: [\r\n          &quot;stecker2&quot;\r\n        ],\r\n        &quot;Topic&quot;: &quot;sensors&quot;,\r\n        &quot;ButtonTopic&quot;: &quot;0&quot;,\r\n        &quot;Power&quot;: 0,\r\n        &quot;PowerOnState&quot;: 3,\r\n        &quot;LedState&quot;: 1,\r\n        &quot;SaveData&quot;: 1,\r\n        &quot;SaveState&quot;: 1,\r\n        &quot;SwitchTopic&quot;: &quot;0&quot;,\r\n        &quot;SwitchMode&quot;: [\r\n          0,\r\n          0,\r\n          0,\r\n          0,\r\n          0,\r\n          0,\r\n          0,\r\n          0\r\n        ],\r\n        &quot;ButtonRetain&quot;: 0,\r\n        &quot;SwitchRetain&quot;: 0,\r\n        &quot;SensorRetain&quot;: 0,\r\n        &quot;PowerRetain&quot;: 0\r\n      }\r\n    }\r\nHow can I query for the &quot;Power&quot;: 0 value only? I only need the &quot;0&quot;.\r\nI tried with \r\n\r\n    jq -r &#39;.Power&#39;\r\nbut that only returns\r\n\r\n    null\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59552469/mosquito-sub-to-jq-get-value",
        "title": "mosquito_sub to jq get value"
    },
    {
        "tags": [
            "json",
            "terminal",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1577890975,
                "creation_date": 1577890975,
                "answer_id": 59553544,
                "question_id": 59553403,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`group_by/1` expects its input to be an array. By calling .[] first, you are effectively undoing the work of the -s option.\r\n\r\nBy the way, an alternative to using -s is to use `inputs` with the -n command-line option, but in this case it makes little difference. When you don’t actually need to read all the entire stream of inputs at once, though, using `inputs` is in general more efficient.",
                "title": "jq group_by does not play nice with .[]"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1577890975,
        "creation_date": 1577889426,
        "question_id": 59553403,
        "body_markdown": "I have a json file locally called `pokemini.json`. These are the contents of it; \r\n\r\n```\r\n{&quot;name&quot;:&quot;Bulbasaur&quot;,&quot;type&quot;:[&quot;Grass&quot;,&quot;Poison&quot;],&quot;total&quot;:318,&quot;hp&quot;:45,&quot;attack&quot;:49}\r\n{&quot;name&quot;:&quot;Ivysaur&quot;,&quot;type&quot;:[&quot;Grass&quot;,&quot;Poison&quot;],&quot;total&quot;:405,&quot;hp&quot;:60,&quot;attack&quot;:62}\r\n{&quot;name&quot;:&quot;Venusaur&quot;,&quot;type&quot;:[&quot;Grass&quot;,&quot;Poison&quot;],&quot;total&quot;:525,&quot;hp&quot;:80,&quot;attack&quot;:82}\r\n{&quot;name&quot;:&quot;VenusaurMega Venusaur&quot;,&quot;type&quot;:[&quot;Grass&quot;,&quot;Poison&quot;],&quot;total&quot;:625,&quot;hp&quot;:80,&quot;attack&quot;:100}\r\n{&quot;name&quot;:&quot;Charmander&quot;,&quot;type&quot;:[&quot;Fire&quot;],&quot;total&quot;:309,&quot;hp&quot;:39,&quot;attack&quot;:52}\r\n{&quot;name&quot;:&quot;Charmeleon&quot;,&quot;type&quot;:[&quot;Fire&quot;],&quot;total&quot;:405,&quot;hp&quot;:58,&quot;attack&quot;:64}\r\n{&quot;name&quot;:&quot;Charizard&quot;,&quot;type&quot;:[&quot;Fire&quot;,&quot;Flying&quot;],&quot;total&quot;:534,&quot;hp&quot;:78,&quot;attack&quot;:84}\r\n{&quot;name&quot;:&quot;CharizardMega Charizard X&quot;,&quot;type&quot;:[&quot;Fire&quot;,&quot;Dragon&quot;],&quot;total&quot;:634,&quot;hp&quot;:78,&quot;attack&quot;:130}\r\n{&quot;name&quot;:&quot;CharizardMega Charizard Y&quot;,&quot;type&quot;:[&quot;Fire&quot;,&quot;Flying&quot;],&quot;total&quot;:634,&quot;hp&quot;:78,&quot;attack&quot;:104}\r\n{&quot;name&quot;:&quot;Squirtle&quot;,&quot;type&quot;:[&quot;Water&quot;],&quot;total&quot;:314,&quot;hp&quot;:44,&quot;attack&quot;:48}\r\n```\r\n\r\nThere are a few types of pokemon in here and I want to do some aggregation with `jq`. \r\n\r\nI could, per example, write this command; \r\n\r\n```\r\n&gt; jq -s -c &#39;group_by(.type[0]) | .[]&#39; pokemini.json\r\n[{&quot;name&quot;:&quot;Charmander&quot;,&quot;type&quot;:[&quot;Fire&quot;],&quot;total&quot;:309,&quot;hp&quot;:39,&quot;attack&quot;:52},{&quot;name&quot;:&quot;Charmeleon&quot;,&quot;type&quot;:[&quot;Fire&quot;],&quot;total&quot;:405,&quot;hp&quot;:58,&quot;attack&quot;:64},{&quot;name&quot;:&quot;Charizard&quot;,&quot;type&quot;:[&quot;Fire&quot;,&quot;Flying&quot;],&quot;total&quot;:534,&quot;hp&quot;:78,&quot;attack&quot;:84},{&quot;name&quot;:&quot;CharizardMega Charizard X&quot;,&quot;type&quot;:[&quot;Fire&quot;,&quot;Dragon&quot;],&quot;total&quot;:634,&quot;hp&quot;:78,&quot;attack&quot;:130},{&quot;name&quot;:&quot;CharizardMega Charizard Y&quot;,&quot;type&quot;:[&quot;Fire&quot;,&quot;Flying&quot;],&quot;total&quot;:634,&quot;hp&quot;:78,&quot;attack&quot;:104}]\r\n[{&quot;name&quot;:&quot;Bulbasaur&quot;,&quot;type&quot;:[&quot;Grass&quot;,&quot;Poison&quot;],&quot;total&quot;:318,&quot;hp&quot;:45,&quot;attack&quot;:49},{&quot;name&quot;:&quot;Ivysaur&quot;,&quot;type&quot;:[&quot;Grass&quot;,&quot;Poison&quot;],&quot;total&quot;:405,&quot;hp&quot;:60,&quot;attack&quot;:62},{&quot;name&quot;:&quot;Venusaur&quot;,&quot;type&quot;:[&quot;Grass&quot;,&quot;Poison&quot;],&quot;total&quot;:525,&quot;hp&quot;:80,&quot;attack&quot;:82},{&quot;name&quot;:&quot;VenusaurMega Venusaur&quot;,&quot;type&quot;:[&quot;Grass&quot;,&quot;Poison&quot;],&quot;total&quot;:625,&quot;hp&quot;:80,&quot;attack&quot;:100}]\r\n[{&quot;name&quot;:&quot;Squirtle&quot;,&quot;type&quot;:[&quot;Water&quot;],&quot;total&quot;:314,&quot;hp&quot;:44,&quot;attack&quot;:48}]\r\n```\r\n\r\nI am aware that the `-c` flag is what is causing it to print line by line and that I need `-s` to handle the fact that my json file is more like jsonlines that actualy json. It should also be pointed that out there are only three types of pokemon detected because I can grouping over `.type[0]` (note that `[0]`). \r\n\r\nI don&#39;t get why this does not work though; \r\n\r\n```\r\n&gt; jq -s &#39;.[] | group_by(.type[0])&#39; pokemini.json\r\njq: error (at pokemini.json:10): Cannot index string with string &quot;type&quot;\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59553403/jq-group-by-does-not-play-nice-with",
        "title": "jq group_by does not play nice with .[]"
    },
    {
        "tags": [
            "jq",
            "fromjson"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1577922462,
                "creation_date": 1577922462,
                "answer_id": 59557023,
                "question_id": 59556986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The solution turned out to be \r\n\r\n`map(if .test|type == &quot;string&quot; then .test=(.test|fromjson) else . end)`\r\n\r\nI&#39;m guessing `.test=.test|fromjson` confused jq",
                "title": "jq, re-assign field if it is a string with its parsed JSON representation"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1577934641,
                "creation_date": 1577934641,
                "answer_id": 59557907,
                "question_id": 59556986,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq filter can be simplified to:\r\n\r\n\r\n    map(if .test|type == &quot;string&quot; then .test |= fromjson else . end)\r\n\r\nor even:\r\n\r\n    map(.test |= if type == &quot;string&quot; then fromjson else . end)",
                "title": "jq, re-assign field if it is a string with its parsed JSON representation"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1578005209,
        "creation_date": 1577922038,
        "last_edit_date": 1578005209,
        "question_id": 59556986,
        "body_markdown": "I have the following JSON:\r\n\r\n    [\r\n    {\r\n        &quot;test&quot;: &quot;[\\&quot;example\\&quot;]&quot;\r\n    },\r\n    {\r\n        \r\n        &quot;test&quot;: [&quot;example2&quot;]\r\n    }\r\n    ]\r\n\r\nFor each object, I want to 1] check if &quot;test&quot; is a string and 2] if test is a string, parse it into an actual JSON array and then re-assign it. So the output would be:\r\n\r\n    [\r\n    {\r\n        &quot;test&quot;: [&quot;example&quot;]\r\n    },\r\n    {\r\n        \r\n        &quot;test&quot;: [&quot;example2&quot;]\r\n    }\r\n    ]\r\n\r\nI have tried the following code: `map(if .test|type == &quot;string&quot; then .test= .test|fromjson else . end)`. However, I get an error saying only strings can be parsed. I assume this is because jq thinks `.test` is not a string, but, I know .test is a string because of the if statement, so I&#39;m not sure what is wrong.",
        "link": "https://stackoverflow.com/questions/59556986/jq-re-assign-field-if-it-is-a-string-with-its-parsed-json-representation",
        "title": "jq, re-assign field if it is a string with its parsed JSON representation"
    },
    {
        "tags": [
            "precision",
            "jq",
            "number-formatting"
        ],
        "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": 1577947931,
                "post_id": 59558912,
                "comment_id": 105286714,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1578003057,
                "last_edit_date": 1578003057,
                "creation_date": 1578001103,
                "answer_id": 59570334,
                "question_id": 59558912,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The &quot;master&quot; version of jq now generally preserves the &quot;external&quot; number format, e.g. \r\n```\r\n$ jq -n &#39;0.0000875&#39;\r\n0.0000875\r\n```\r\n\r\nThe [relevant commit][1] date was Oct 21, 2019.\r\n\r\nFor some installation guidelines, see https://github.com/stedolan/jq/wiki/Installation\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/commit/cf4b48c7ba30cb30e116b523cff036ea481459f6",
                "title": "How to extract float values in number format instead of exponential values using jq?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1578003057,
        "creation_date": 1577944934,
        "last_edit_date": 1578003023,
        "question_id": 59558912,
        "body_markdown": "Im extracting few fields from a list of jsons in a file using jq and one of the field contains a float value (eg.float 0.0000875) which when extracted through jq changed to &#39;8.75e-05&#39;. Is there a way we can extract these values without being converted to exponential form?",
        "link": "https://stackoverflow.com/questions/59558912/how-to-extract-float-values-in-number-format-instead-of-exponential-values-using",
        "title": "How to extract float values in number format instead of exponential values using jq?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1577975174,
                "creation_date": 1577975174,
                "answer_id": 59564980,
                "question_id": 59564652,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the [man](https://stedolan.github.io/jq/manual/) it states you have an option to use [map](https://stedolan.github.io/jq/manual/#map(x),map_values(x)) - which essentially means walking over each result and returning something (in our case, same data, constructed differently.)\r\n\r\nThis means that for each row you are creating new object, and put some values inside \r\n\r\nPay attention, you do need another iterator within, since we want one object per row.\r\n(we simply need to map the values in different way it is constructed right now.)\r\n\r\nSo the solution might look like so:\r\n\r\n     jq -r &#39;.pokemon[]|{name:.name, id:.id, types:.types|map(.type.name)}&#39; pokemon.json",
                "title": "Jq convert an object into an array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1577986060,
        "creation_date": 1577973704,
        "last_edit_date": 1577986060,
        "question_id": 59564652,
        "body_markdown": "I have the following file &quot;Pokemon.json&quot;, it&#39;s a stripped down list of Pok&#233;mon, listing their Pok&#233;dex ID, name and an array of Object Types.\r\n\r\n```json\r\n[{\r\n  &quot;name&quot;: &quot;onix&quot;,\r\n  &quot;id&quot;: 95,\r\n  &quot;types&quot;: [{\r\n      &quot;slot&quot;: 2,\r\n      &quot;type&quot;: {\r\n        &quot;name&quot;: &quot;ground&quot;\r\n      }\r\n    },\r\n    {\r\n      &quot;slot&quot;: 1,\r\n      &quot;type&quot;: {\r\n        &quot;name&quot;: &quot;rock&quot;\r\n      }\r\n    }\r\n  ]\r\n}, {\r\n  &quot;name&quot;: &quot;drowzee&quot;,\r\n  &quot;id&quot;: 96,\r\n  &quot;types&quot;: [{\r\n    &quot;slot&quot;: 1,\r\n    &quot;type&quot;: {\r\n      &quot;name&quot;: &quot;psychic&quot;\r\n    }\r\n  }]\r\n}]\r\n```\r\n\r\nThe output I&#39;m trying to achieve is, extracting the name value of the type object and inserting it into an array.\r\nI can easily get an array of all the types with \r\n\r\n```\r\njq -r &#39;.pokemon[].types[].type.name&#39; pokemon.json\r\n```\r\n\r\nBut I&#39;m missing the key part to transform the name field into it&#39;s own array \r\n\r\n```json\r\n[ {\r\n  &quot;name&quot;: &quot;onix&quot;,\r\n  &quot;id&quot;: 95,\r\n  &quot;types&quot;: [ &quot;rock&quot;, &quot;ground&quot; ]\r\n}, {\r\n  &quot;name&quot;: &quot;drowzee&quot;,\r\n  &quot;id&quot;: 96,\r\n  &quot;types&quot;: [ &quot;psychic&quot; ]\r\n} ]\r\n```\r\n\r\nAny help appreciated, thank you!",
        "link": "https://stackoverflow.com/questions/59564652/jq-convert-an-object-into-an-array",
        "title": "Jq convert an object into an array"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 166270,
                    "reputation": 135171,
                    "user_id": 390278,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/84715fec547362389d02f5be0ed12814?s=256&d=identicon&r=PG",
                    "display_name": "Jeff Mercado",
                    "link": "https://stackoverflow.com/users/390278/jeff-mercado"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1578012277,
                "post_id": 59571431,
                "comment_id": 105311390,
                "content_license": "CC BY-SA 4.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": 1578014635,
                "post_id": 59571431,
                "comment_id": 105311888,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1578042468,
                "last_edit_date": 1578042468,
                "creation_date": 1578021138,
                "answer_id": 59572735,
                "question_id": 59571431,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the number of items in the .files array is variable, the following will focus on producing TSV (tab-separated values).  You can easily adapt this solution to your requirements regarding a table with a variable number of columns.\r\n\r\nFirst, ignoring the headers, note that the following filter, when used in conjunction with the -r command-line option, produces the output as shown:\r\n```\r\nmap({id, severity, name, files})\r\n| sort_by(.id)[]\r\n| [.severity, .name, .files[]]\r\n| @tsv\r\n```\r\n### Output\r\n```\r\nlow\tAWS IAM policy attached to users\tmain.tf\r\nmedium\tAWS S3 object versioning is disabled\tcloudtrail.tf.json\tcloudtrail.tf\r\nmedium\tAWS VPC NACL allows traffic from blocked ports\tSG.tf\r\nmedium\tAWS security group allow egress traffic from blocked ports - 21,22,135,137-139,445,69\tsecuritygroup22.tf\r\nmedium\tAWS Access logging not enabled on S3 buckets\tcloudtrail.tf.json\tcloudtrail.tf\r\nmedium\tAWS VPC allows unauthorized peering\tvpcpeering.tf\r\nmedium\tAWS IAM password policy does not have a minimum of 14 characters\tiampassword.tf\r\nmedium\tAWS security group allows traffic from blocked ports\tsecuritygroup22.tf\r\nhigh\tAWS Security Groups allow internet traffic to SSH port (22)\tsecuritygroup22.tf\r\nmedium\tAWS EC2 instance have SSH port open to internet\tsecuritygroup22.tf\r\nmedium\tAWS IAM password policy allows password reuse\tiampassword.tf\r\nmedium\tAWS VPC NACL allow egress traffic from blocked ports\tSG.tf\r\nhigh\tAWS Security Groups with Inbound rule overly permissive to All Traffic\tsecuritygroup22.tf\r\n```\r\n\r\n## Headers\r\nA modular way to deal with the header row is to define `headers`, e.g. along these lines:\r\n```\r\ndef headers:\r\n  [&quot;Severity&quot;,&quot;Name&quot;,&quot;Files&quot;],\r\n  [&quot;--------&quot;,&quot;----&quot;,&quot;-----&quot;] ;\r\n\r\n```\r\n\r\nWith this def, we essentially just add `headers` to the previous jq program:\r\n\r\n```\r\nheaders,\r\n(map({id, severity, name, files})\r\n | sort_by(.id)[]\r\n | [.severity, .name, .files[]])\r\n| @tsv\r\n\r\n```\r\n\r\n## Using a different &quot;join&quot; character for .files\r\n\r\nInstead of the line:\r\n    [.severity, .name, .files[]]\r\n\r\nyou might wish to use a different &quot;join&quot; character for the files, e.g.\r\n\r\n    [.severity, .name, (.files|join(&quot;;&quot;))]\r\n\r\n\r\nSeason to taste.\r\n\r\n\r\n",
                "title": "jq: error (at &lt;stdin&gt;:131): Cannot iterate over string (&quot;Files&quot;)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1592434021,
        "creation_date": 1578008567,
        "last_edit_date": 1592434021,
        "question_id": 59571431,
        "body_markdown": "I am trying to parse JSON and getting stuck when it comes to iterating over a array.\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;severity&quot;: &quot;low&quot;,\r\n    &quot;name&quot;: &quot;AWS IAM policy attached to users&quot;,\r\n    &quot;rule&quot;: &quot;$.resource[*].aws_iam_policy_attachment[*].*[*].users exists and $.resource[*].aws_iam_policy_attachment[*].*[*].users[*] is not empty&quot;,\r\n    &quot;files&quot;: [\r\n      &quot;main.tf&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;1903f355-b68f-4d9c-84dd-c46abe4f8673&quot;\r\n  },\r\n  {\r\n    &quot;severity&quot;: &quot;medium&quot;,\r\n    &quot;name&quot;: &quot;AWS VPC allows unauthorized peering&quot;,\r\n    &quot;rule&quot;: &quot;$.resource[*].aws_vpc_peering_connection[*].*[*].peer_vpc_id does not equal $.resource[*].aws_vpc_peering_connection[*].*[*].vpc_id&quot;,\r\n    &quot;files&quot;: [\r\n      &quot;vpcpeering.tf&quot;,\r\n      &quot;main.tf&quot;\r\n    ],\r\n    &quot;id&quot;: &quot;59356130-d856-470d-a08e-b2a0ba2a4ac7&quot;\r\n  }\r\n]\r\n```\r\n\r\n```\r\n. += [{&quot;severity&quot;: &quot;Severity&quot;,&quot;name&quot;: &quot;Name&quot;,&quot;files&quot;: &quot;Files&quot;,&quot;id&quot;: &quot;0&quot;}, {&quot;severity&quot;: &quot;--------&quot;,&quot;name&quot;: &quot;------------------------------------&quot;,&quot;files&quot;: &quot;--------&quot;,&quot;id&quot;: &quot;01&quot;}] |  sort_by(.id) | .[] | [&quot;| &quot; + .severity, &quot;| &quot; + .name, &quot;| &quot; + (.files | join (&quot;,&quot;)) , &quot;| &quot; ]\r\n```\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:131): Cannot iterate over string (&quot;Files&quot;)\r\nexit status 5\r\n```\r\n\r\nhttps://jqplay.org/s/KzNXa7NqKq\r\n\r\n\r\nI am trying to print the results in tabular format.\r\n\r\n    Severity. Name.                                 Files\r\n    low       AWS IAM policy attached to users.     main.tf\r\n    low       AWS VPC allows unauthorized peering.  vpcpeering.tf, main.tf",
        "link": "https://stackoverflow.com/questions/59571431/jq-error-at-stdin131-cannot-iterate-over-string-files",
        "title": "jq: error (at &lt;stdin&gt;:131): Cannot iterate over string (&quot;Files&quot;)"
    },
    {
        "tags": [
            "base64",
            "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": 1578071252,
                "post_id": 59576828,
                "comment_id": 105331359,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1578057036,
                "last_edit_date": 1578057036,
                "creation_date": 1578055216,
                "answer_id": 59578821,
                "question_id": 59576828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem most likely is due to the embedded newlines that that are created during the encoding part of the image. You can just remove them by using `tr -d \\\\n` in your original attempt which an be slightly re-written succinctly with inputs from `jq` capabilities to read from standard input.\r\n\r\n    jq -Rn &#39;.instances[0].image.b64 = inputs&#39; &lt; &lt;(base64 volunteers.jpg | tr -d \\\\n) &gt; input.json\r\n\r\nThe `-n` part is to avoid `jq` reading a separate input stream of its own and `-R` for reading raw input. Here we feed the encoded content as if it were in a file using `bash` process substitution syntax `&lt;(..)` and feed this created file to `jq`\r\n\r\nand then decoding back the created JSON as \r\n\r\n    jq -r &#39;.instances[0].image.b64&#39; input.json | base64 -d &gt; output.jpg\r\n\r\n---\r\n\r\nRe-writing your original attempt with minor enhancements and without using a temporary file for storing the JSON\r\n\r\n    JSON=&#39;{&quot;instances&quot;: [{&quot;image&quot;: {&quot;b64&quot;: &quot;&#39;&quot;$(base64 volunteers.jpg | tr -d \\\\n)&quot;&#39;&quot; }}]}&#39;\r\n    jq -r &#39;.instances[0].image.b64&#39; &lt;&lt;&lt;&quot;$JSON&quot; | base64 -d &gt;output.jpg\r\n\r\nor use `printf()` inplace of the here-strings(`&lt;&lt;&lt;`)\r\n\r\n    printf &#39;%s\\n&#39; &quot;$JSON&quot; | jq -r &#39;.instances[0].image.b64&#39; | base64 -d &gt;output.jpg",
                "title": "Encoding base64 image string into JSON and decoding it back using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1578057012,
                "creation_date": 1578057012,
                "answer_id": 59579191,
                "question_id": 59576828,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The invocation\r\n\r\n    cat &#39;/&quot;&#39; input.json &#39;/&quot;&#39;\r\n\r\n\r\nis hopelessly muddled: `cat input.json` would suffice.  Even better, assuming input.json contains valid JSON, you could write:\r\n```\r\n&lt; input.json jq -r &#39;.instances[0].image.b64&#39; | base64 -d &gt;output.jpg   \r\n\r\n```\r\n\r\n    ",
                "title": "Encoding base64 image string into JSON and decoding it back using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1578057036,
        "creation_date": 1578046946,
        "last_edit_date": 1578055811,
        "question_id": 59576828,
        "body_markdown": "I have these 3 commands those work correctly and encode the image as json.\r\n\r\n    encoded_string=$(base64 volunteers.jpg)\r\n    \r\n    payload=&quot;{\\&quot;instances\\&quot;: [{\\&quot;image\\&quot;: {\\&quot;b64\\&quot;: \\&quot;$encoded_string\\&quot;}}]}&quot;\r\n    \r\n    echo $payload &gt;input.json\r\n\r\nBut how do I convert it back to jpg format? This returns an error &quot;**base64: invalid input**&quot;\r\n\r\n    cat &#39;/&quot;&#39; input.json &#39;/&quot;&#39; | jq -r &#39;.instances[0].image.b64&#39; | base64 -d &gt;output.jpg\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59576828/encoding-base64-image-string-into-json-and-decoding-it-back-using-jq",
        "title": "Encoding base64 image string into JSON and decoding it back using jq"
    },
    {
        "tags": [
            "json",
            "ansible",
            "jinja2",
            "jq",
            "jmespath"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1578155678,
                "last_edit_date": 1592644375,
                "creation_date": 1578140988,
                "answer_id": 59590654,
                "question_id": 59590507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given *my_dict* the play\n\n```\n  vars:\n    my_dict:\n      key1: { &quot;key1a&quot;: [&quot;key1aa&quot;: &quot;value1aa&quot;, &quot;key1ab&quot;: &quot;value1ab&quot;]}\n      key2: { &quot;key2a&quot;: [&quot;key2aa&quot;: &quot;value2aa&quot;, &quot;key2ab&quot;: &quot;value2ab&quot;]}\n  tasks:\n    - set_fact:\n        my_list: &quot;{{ my_list|default([]) + [{item.key: item.value}] }}&quot;\n      loop: &quot;{{ my_dict|dict2items }}&quot;\n    - debug:\n        msg: &quot;{{ my_list|to_json }}&quot;\n```\n\ngives\n\n```\nmsg: &#39;[{&quot;key2&quot;: {&quot;key2a&quot;: [{&quot;key2aa&quot;: &quot;value2aa&quot;}, {&quot;key2ab&quot;: &quot;value2ab&quot;}]}},\n       {&quot;key1&quot;: {&quot;key1a&quot;: [{&quot;key1aa&quot;: &quot;value1aa&quot;}, {&quot;key1ab&quot;: &quot;value1ab&quot;}]}}]&#39;\n```\n\nThe output was printed with `yaml` callback (`export ANSIBLE_STDOUT_CALLBACK=yaml`). Then the output was split manually after the first item of the list.\n\n&lt;hr&gt;\n\n**json_query**\n\nIt is also possible to create the list with `jmespath` i.e. `json_query`. For example, the task below gives the same result\n\n    - set_fact:\n        my_list: &quot;{{ my_dict|\n                     dict2items|\n                     json_query(&#39;[].[{key: key, value: value}]&#39;)|\n                     map(&#39;items2dict&#39;)|\n                     list }}&quot;\n&lt;hr&gt;\n\n**to_nice_yaml**\n\n  It&#39;s easier to see the data&#39;s structure when printed with the filter `to_nice_yaml`. For example\n\n    - debug:\n        msg: &quot;{{ my_list|to_nice_yaml }}&quot;\n\ngives\n\n      msg: |-\n        -   key2:\n                key2a:\n                -   key2aa: value2aa\n                -   key2ab: value2ab\n        -   key1:\n                key1a:\n                -   key1aa: value1aa\n                -   key1ab: value1ab\n\n&lt;hr&gt;\n\n**filter_plugins**\n\nIt&#39;s also possible to use custom [Filter plugins](https://docs.ansible.com/ansible/latest/dev_guide/developing_plugins.html#filter-plugins). For example with the plugin\n\n```\n$ cat filter_plugins/dict_utils.py\n\ndef dict2list(d):\n    l = []\n    for i in d:\n        h = {i:d[i]}\n        l.append(h)\n    return l\n\nclass FilterModule(object):\n\n    def filters(self):\n        return {\n            &#39;dict2list&#39;: dict2list\n        }\n```\n\nthe task below gives the same result\n\n    - set_fact:\n        my_list: &quot;{{ my_dict|dict2list }}&quot;\n&lt;hr&gt;\n\nFor your convenience:\n\n* [source code of the playbook](https://github.com/vbotka/ansible-examples/blob/master/examples/example-103/dict2items-4.yml)\n* [filter plugins](https://github.com/vbotka/ansible-plugins)",
                "title": "JMESPath to generate an array of objects from an object of objects"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1578141786,
                "creation_date": 1578141786,
                "answer_id": 59590754,
                "question_id": 59590507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Note that your array in both examples is not correct JSON syntax (array elements should be inside an object).\r\n\r\nSo, given this example:\r\n\r\n    cat file\r\n    {\r\n      &quot;key1&quot;: { &quot;key1a&quot;: [{&quot;key1aa&quot;: &quot;value1aa&quot;}, {&quot;key1ab&quot;: &quot;value1ab&quot;}] },\r\n      &quot;key2&quot;: { &quot;key2a&quot;: [{&quot;key2aa&quot;: &quot;value2aa&quot;}, {&quot;key2ab&quot;: &quot;value2ab&quot;}] }\r\n    }\r\n\r\nYou can use `jq`:\r\n\r\n    &lt;file jq &#39;to_entries|map({(.key):.value})&#39;\r\n\r\n",
                "title": "JMESPath to generate an array of objects from an object of objects"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1578229828,
                "last_edit_date": 1578229828,
                "creation_date": 1578141855,
                "answer_id": 59590769,
                "question_id": 59590507,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is not possible with jmespath (i.e. json_query) **alone** unless you are ready to loose the top level key. In this case, you can simply apply the wildcard jmespath expression (i.e. `*`) to your object.\r\n\r\nIf you do not want to loose the top level keys and you still want to keep jmespath as part of the equation, the following example meets those requirements but needs some more filters.\r\n\r\nSome details about the scenario:\r\n\r\n* Transform the initial hash to a list of `{key: XXX, value: YYY}` hashes with [`dict2items`](https://docs.ansible.com/ansible/latest/user_guide/playbooks_filters.html#dict-filter)\r\n* Use `json_query` to transform that list of hashes (i.e. `[{}, {}]`) to a list of list of hashes (i.e. `[[{}], [{}]]`)\r\n* Map the [`items2dict` filter](https://docs.ansible.com/ansible/latest/user_guide/playbooks_filters.html#items2dict-filter) on each element of the result list\r\n* Finally the [`list` filter](https://jinja.palletsprojects.com/en/2.10.x/templates/#list) will transform the temporary object from `map` to a usable list.\r\n\r\n\r\n```\r\n---\r\n- name: Transform hash to list with jmespath and dict2items/items2dict\r\n  hosts: localhost\r\n  gather_facts: false\r\n\r\n  vars:\r\n    my_object: {\r\n      &quot;key1&quot;: { &quot;key1a&quot;: [&quot;key1aa&quot;: &quot;value1aa&quot;, &quot;key1ab&quot;: &quot;value1ab&quot;] },\r\n      &quot;key2&quot;: { &quot;key2a&quot;: [&quot;key2aa&quot;: &quot;value2aa&quot;, &quot;key2ab&quot;: &quot;value2ab&quot;] }\r\n    }\r\n\r\n  tasks:\r\n    - name: Do transform with json_query\r\n      debug:\r\n        msg: &gt;-\r\n          {{\r\n            my_object\r\n            | dict2items\r\n            | json_query(&#39;[].[{key: key, value: value}]&#39;)\r\n            | map(&#39;items2dict&#39;)\r\n            | list\r\n          }}\r\n```\r\n\r\nWhich gives:\r\n\r\n```\r\n\r\nPLAY [Transform hash to list with jmespath and dict2items/items2dict] ***************************************************************************************************************************************************************************************************\r\n\r\nTASK [Do transform with json_query] *************************************************************************************************************************************************************************************************************************************\r\nok: [localhost] =&gt; {\r\n    &quot;msg&quot;: [\r\n        {\r\n            &quot;key1&quot;: {\r\n                &quot;key1a&quot;: [\r\n                    {\r\n                        &quot;key1aa&quot;: &quot;value1aa&quot;\r\n                    },\r\n                    {\r\n                        &quot;key1ab&quot;: &quot;value1ab&quot;\r\n                    }\r\n                ]\r\n            }\r\n        },\r\n        {\r\n            &quot;key2&quot;: {\r\n                &quot;key2a&quot;: [\r\n                    {\r\n                        &quot;key2aa&quot;: &quot;value2aa&quot;\r\n                    },\r\n                    {\r\n                        &quot;key2ab&quot;: &quot;value2ab&quot;\r\n                    }\r\n                ]\r\n            }\r\n        }\r\n    ]\r\n}\r\n\r\nPLAY RECAP **************************************************************************************************************************************************************************************************************************************************************\r\nlocalhost                  : ok=1    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0 \r\n```",
                "title": "JMESPath to generate an array of objects from an object of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 3,
        "last_activity_date": 1578229828,
        "creation_date": 1578139803,
        "last_edit_date": 1578143929,
        "question_id": 59590507,
        "body_markdown": "I have the following example json document (object of objects):\r\n\r\n    {\r\n       &quot;key1&quot;: { &quot;key1a&quot;: [{&quot;key1aa&quot;: &quot;value1aa&quot;}, {&quot;key1ab&quot;: &quot;value1ab&quot;}],... },\r\n       &quot;key2&quot;: { &quot;key2a&quot;: [{&quot;key2aa&quot;: &quot;value2aa&quot;}, {&quot;key2ab&quot;: &quot;value2ab&quot;}],... },\r\n       ...\r\n    }\r\n\r\nAnd I try to reshape it to an Array of that objects like\r\n\r\n    [\r\n      { &quot;key1&quot;: { &quot;key1a&quot;: [{&quot;key1aa&quot;: &quot;value1aa&quot;}, {&quot;key1ab&quot;: &quot;value1ab&quot;}],... }},\r\n      { &quot;key2&quot;: { &quot;key2a&quot;: [{&quot;key2aa&quot;: &quot;value2aa&quot;}, {&quot;key2ab&quot;: &quot;value2ab&quot;}],... }},\r\n      ...\r\n    ]\r\n\r\nWhat I can use is JMESPath inside Ansible&#39;s jinja2 filter json_query\r\n\r\nHow is that possible?\r\n\r\nThanks\r\n\r\nDavid",
        "link": "https://stackoverflow.com/questions/59590507/jmespath-to-generate-an-array-of-objects-from-an-object-of-objects",
        "title": "JMESPath to generate an array of objects from an object of objects"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1578225220,
                "creation_date": 1578225220,
                "answer_id": 59599582,
                "question_id": 59599459,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ jq -c &#39;.nodes | to_entries | map(.value.&quot;:ip&quot;)&#39; input\r\n    [&quot;10.0.0.1&quot;,&quot;10.0.0.2&quot;,&quot;10.0.0.3&quot;]\r\n\r\n",
                "title": "Shell JQ : Format output to specific string with delimeter"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1578226311,
        "creation_date": 1578224257,
        "last_edit_date": 1578226311,
        "question_id": 59599459,
        "body_markdown": "I want to have an output that instead of delimeter **space** it should be like this **&quot;, &quot;** using **jq**\r\n\r\n**nodes.json**\r\n\r\n    {\r\n      &quot;nodes&quot;: {\r\n        &quot;node1.local&quot;: {\r\n          &quot;:ip&quot;: &quot;10.0.0.1&quot;,\r\n          &quot;ports&quot;: [],\r\n          &quot;:memory&quot;: 1024,\r\n          &quot;:bootstrap&quot;: &quot;bootstrap.sh&quot;\r\n        },\r\n        &quot;node2.local&quot;: {\r\n          &quot;:ip&quot;: &quot;10.0.0.2&quot;,\r\n          &quot;ports&quot;: [],\r\n          &quot;:memory&quot;: 1024,\r\n          &quot;:bootstrap&quot;: &quot;bootstrap.sh&quot;\r\n        },\r\n        &quot;node3.local&quot;: {\r\n          &quot;:ip&quot;: &quot;10.0.0.3&quot;,\r\n          &quot;ports&quot;: [],\r\n          &quot;:memory&quot;: 1024,\r\n          &quot;:bootstrap&quot;: &quot;bootstrap.sh&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nhere is my command use\r\n\r\n    ips=`cat /vagrant/nodes.json | jq -r &#39;.nodes | to_entries[] | [.value.&quot;:ip&quot;] | @tsv&#39;`\r\n    echo [\\&quot;$ips\\&quot;]\r\n\r\nwhere the output is \r\n\r\n    [&quot;10.0.0.1 10.0.0.2 10.0.0.3&quot;]\r\n\r\nand i want it to be like this\r\n\r\n    [&quot;10.0.0.1&quot;, &quot;10.0.0.2&quot;, &quot;10.0.0.3&quot;]",
        "link": "https://stackoverflow.com/questions/59599459/shell-jq-format-output-to-specific-string-with-delimeter",
        "title": "Shell JQ : Format output to specific string with delimeter"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1578228041,
                "creation_date": 1578228041,
                "answer_id": 59599949,
                "question_id": 59599778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can simply use + operator:\r\n```\r\njq &#39;.nodes | to_entries | map(.value.&quot;:ip&quot; + &quot;:4546&quot;)&#39;\r\n```",
                "title": "JQ : Output with static value / variable"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1578228381,
                "last_edit_date": 1578228381,
                "creation_date": 1578228261,
                "answer_id": 59599979,
                "question_id": 59599778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `map_values` \r\n\r\n     jq -c &#39;.nodes | to_entries | map(.value.&quot;:ip&quot;)| map_values(.+&quot;:4546&quot;)&#39; nodes.jso",
                "title": "JQ : Output with static value / variable"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1578229117,
                "creation_date": 1578229117,
                "answer_id": 59600104,
                "question_id": 59599778,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another try :\r\n\r\n```\r\njq &#39;[.nodes[][&quot;:ip&quot;]+&quot;:4546&quot;]&#39; nodes.json\r\n```",
                "title": "JQ : Output with static value / variable"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1578229117,
        "creation_date": 1578226777,
        "last_edit_date": 1578227591,
        "question_id": 59599778,
        "body_markdown": "I want to have an output with static value using jq with static value **:4546**\r\n\r\n**nodes.json**\r\n\r\n    {\r\n      &quot;nodes&quot;: {\r\n        &quot;node1.local&quot;: {\r\n          &quot;:ip&quot;: &quot;10.0.0.1&quot;,\r\n          &quot;ports&quot;: [],\r\n          &quot;:memory&quot;: 1024,\r\n          &quot;:bootstrap&quot;: &quot;bootstrap.sh&quot;\r\n        },\r\n        &quot;node2.local&quot;: {\r\n          &quot;:ip&quot;: &quot;10.0.0.2&quot;,\r\n          &quot;ports&quot;: [],\r\n          &quot;:memory&quot;: 1024,\r\n          &quot;:bootstrap&quot;: &quot;bootstrap.sh&quot;\r\n        },\r\n        &quot;node3.local&quot;: {\r\n          &quot;:ip&quot;: &quot;10.0.0.3&quot;,\r\n          &quot;ports&quot;: [],\r\n          &quot;:memory&quot;: 1024,\r\n          &quot;:bootstrap&quot;: &quot;bootstrap.sh&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nhere is my command use\r\n\r\n    ips=`jq -c &#39;.nodes | to_entries | map(.value.&quot;:ip&quot;)&#39; nodes.json`\r\n    echo $ips\r\n\r\nwhere the output is \r\n\r\n    [&quot;10.0.0.1&quot;, &quot;10.0.0.2&quot;, &quot;10.0.0.3&quot;]\r\n\r\nand i want it to be like this\r\n\r\n    [&quot;10.0.0.1:4546&quot;, &quot;10.0.0.2:4546&quot;, &quot;10.0.0.3:4546&quot;]",
        "link": "https://stackoverflow.com/questions/59599778/jq-output-with-static-value-variable",
        "title": "JQ : Output with static value / variable"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1578306897,
                "last_edit_date": 1578306897,
                "creation_date": 1578300460,
                "answer_id": 59609050,
                "question_id": 59605183,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to do something like below. You need to `group_by()` and then later do the processing\r\n\r\n    jq &#39;.items | {org: group_by(.org) | map({id: .[0].org, orgProperties: [{properties: { methodId: map({id: .methodId}) }}]})} &#39; input.json\r\n\r\nI don&#39;t think there exists a way to increase the debug verbose level thrown by `jq` unless probably tinkering with the code to add your own debug statements and run a custom build.\r\n\r\nI personally build-up the filter from one component at a time, observe its output and manipulate things on top of that. To break down the functionality of above\r\n\r\n - The JSON is reconstructed completely after the `&#39;.items | {org: .. ` portion of the filter. The result of the subsequent part forms what is now below the top level `&quot;org&quot;` section the expected output.\r\n - Once you do a `group_by(.org)`, you get a result that has two array entries, one with 2 objects (id `750141`) and the other with a single object (id `750142`). \r\n - Then you run the code inside `map(..)` to the object list returned from the previous step\r\n - We only need the unique key name in the final result, so we just use the `.[0].org` in the first array. This will work even you have multiple repetitive key names. Pause and have a look at the output until this point\r\n\r\n \r\n        {\r\n          &quot;org&quot;: [\r\n            {\r\n              &quot;id&quot;: &quot;750141&quot;\r\n            },\r\n            {\r\n              &quot;id&quot;: &quot;750142&quot;\r\n            }\r\n          ]\r\n        }\r\n\r\n - Now construct the rest of the output with `orgProperties: [{properties: { methodId: ...` which creates the sub-nodes as\r\n\r\n        &quot;orgProperties&quot;: [\r\n        {\r\n            &quot;properties&quot;: {\r\n                &quot;methodId&quot;: \r\n\r\n - Create the final sub array with `map({id: .methodId})` to create a key value pair with the list of IDs\r\n\r\n \r\n\r\n",
                "title": "Converting flat JSON into a nested JSON grouping by common key names"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1578306897,
        "creation_date": 1578267568,
        "last_edit_date": 1578303483,
        "question_id": 59605183,
        "body_markdown": "I was using JQPlay to play around the format. I am not able to understand how to use reduce to group by child structure. I want to group based on the org or the parent id. \r\n\r\njust update my jqplay filter, but not able to remove two tags to group by id.\r\n\r\n### jq play syntax- \r\n\r\nI am using below syntax in jqplay.org. Also can you please advise how debug anything after pipe symbol.\r\n\r\n    .items | {&quot;org&quot; : map( {id : .org, orgProperties : [{&quot;properties&quot; : {&quot;methodId&quot; : [{&quot;id&quot; : .methodId}]}}]})| group_by(.id) | map( reduce .[] as $x (.[0]|{}; .orgProperties+= ($x | .orgProperties)))}\r\n\r\n## Input JSON\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;org&quot;: &quot;750141&quot;,\r\n          &quot;methodId&quot;: &quot;1-10F7IAK7&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;750141&quot;,\r\n          &quot;methodId&quot;: &quot;1-10TP18L0&quot;\r\n        },\r\n        {\r\n          &quot;org&quot;: &quot;750142&quot;,\r\n          &quot;methodId&quot;: &quot;1-10TP18L1&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n## Output JSON\r\n\r\n```\r\n{\r\n  &quot;org&quot;: [\r\n    {\r\n      &quot;orgProperties&quot;: [\r\n        {\r\n          &quot;properties&quot;: {\r\n            &quot;methodId&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;1-10F7IAK7&quot;\r\n              }\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          &quot;properties&quot;: {\r\n            &quot;methodId&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;1-10TP18L0&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;orgProperties&quot;: [\r\n        {\r\n          &quot;properties&quot;: {\r\n            &quot;methodId&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;1-10TP18L1&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\n## Expected JSON Output\r\n\r\n```\r\n{\r\n  &quot;org&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;750141&quot;,\r\n      &quot;orgProperties&quot;: [\r\n        {\r\n          &quot;properties&quot;: {\r\n            &quot;methodId&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;1-10F7IAK7&quot;\r\n              },\r\n\t\t\t  {\r\n                &quot;id&quot;: &quot;1-10TP18L0&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    },\r\n\t    {\r\n      &quot;id&quot;: &quot;750142&quot;,\r\n      &quot;orgProperties&quot;: [\r\n        {\r\n          &quot;properties&quot;: {\r\n            &quot;methodId&quot;: [\r\n              {\r\n                &quot;id&quot;: &quot;1-10TP18L1&quot;\r\n              }\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n} \r\n```",
        "link": "https://stackoverflow.com/questions/59605183/converting-flat-json-into-a-nested-json-grouping-by-common-key-names",
        "title": "Converting flat JSON into a nested JSON grouping by common key names"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1578337339,
                "creation_date": 1578337339,
                "answer_id": 59617555,
                "question_id": 59613182,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The capture function seems suited to your task.\r\n\r\nFrom the [manual](https://stedolan.github.io/jq/manual/v1.6/#RegularexpressionsPCRE): `capture(regex; flags)` &quot;Collects the named captures in a JSON object, with the name of each capture as the key, and the matched string as the corresponding value.&quot;\r\n\r\n    jq &#39;.flags[]\r\n    | capture(&quot;(?&lt;foo&gt;^f\\\\d+$)&quot;),\r\n      capture(&quot;(?&lt;bar&gt;^b\\\\d+$)&quot;),\r\n      capture(&quot;(?&lt;foo&gt;f\\\\d+)(?&lt;bar&gt;b\\\\d+)&quot;),\r\n      capture(&quot;(?&lt;bar&gt;b\\\\d+)(?&lt;foo&gt;f\\\\d+)&quot;)\r\n    | .[] |= ( sub(&quot;\\\\D&quot;; &quot;&quot;) | tonumber )&#39;\r\n\r\nThe capture lines create these objects:\r\n\r\n    {\r\n      &quot;foo&quot;: &quot;f1&quot;\r\n    }\r\n    {\r\n      &quot;bar&quot;: &quot;b2&quot;\r\n    }\r\n    {\r\n      &quot;foo&quot;: &quot;f3&quot;,\r\n      &quot;bar&quot;: &quot;b4&quot;\r\n    }\r\n    {\r\n      &quot;bar&quot;: &quot;b6&quot;,\r\n      &quot;foo&quot;: &quot;f5&quot;\r\n    }\r\n\r\nThe last line updates the values in those objects by removing non-digits and converting the result to a number.\r\n",
                "title": "How to merge jq JSON objects generated by comma-separated filters"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1655125272,
        "creation_date": 1578318098,
        "last_edit_date": 1655125272,
        "question_id": 59613182,
        "body_markdown": "I&#39;m trying to use jq to convert some command-line flags into a JSON equivalent.\r\n\r\nThe flags look like this, where the idea is to convert the (optional) f flag into a JSON &quot;foo&quot; field, and the (optional) b flag into a JSON &quot;bar&quot; field:\r\n\r\n```\r\n{\r\n  &quot;flags&quot;: [\r\n\t&quot;f1&quot;,\r\n\t&quot;b2&quot;,\r\n\t&quot;f3b4&quot;,\r\n\t&quot;b6f5&quot;\r\n  ]\r\n}\r\n```\r\n\r\nGetting the foo fields is easy:\r\n```\r\n.flags[] | match(&quot;f([0-9][0-9]*)&quot;) | .captures[0].string | tonumber | { &quot;foo&quot;: . }\r\n```\r\n\r\nSame for the bar fields (please say if there are better ways to do this with jq):\r\n```\r\n.flags[] | match(&quot;b([0-9][0-9]*)&quot;) | .captures[0].string | tonumber | { &quot;bar&quot;: . }\r\n```\r\n\r\nHow can I merge the output of these two filters together so that each input flags line gets mapped to a single JSON object with none / one / both of the optional fields?\r\n\r\nThe two relevant mechanisms are jq&#39;s comma operator (to share a single stream between multiple filters) and jq&#39;s + operator (to merge together objects into a single object). Applying the comma operator is straightforward:\r\n\r\n```\r\n.flags[] | (match(&quot;f([0-9][0-9]*)&quot;) | .captures[0].string | tonumber | { &quot;foo&quot;: . }), (match(&quot;b([0-9][0-9]*)&quot;) | .captures[0].string | tonumber | { &quot;bar&quot;: . })\r\n```\r\n\r\nHowever, this yields a separate object for each match:\r\n\r\n```\r\n{\r\n  &quot;foo&quot;: 1\r\n}\r\n{\r\n  &quot;bar&quot;: 2\r\n}\r\n{\r\n  &quot;foo&quot;: 3\r\n}\r\n{\r\n  &quot;bar&quot;: 4\r\n}\r\n{\r\n  &quot;foo&quot;: 5\r\n}\r\n{\r\n  &quot;bar&quot;: 6\r\n}\r\n```\r\n\r\nSo the specific problem here is how to join these two objects together using the + operator. The final output I&#39;m trying to get here is where the foo and bar fields sit together in the same object:\r\n\r\n```\r\n{\r\n  &quot;foo&quot;: 1\r\n}\r\n{\r\n  &quot;bar&quot;: 2\r\n}\r\n{\r\n  &quot;foo&quot;: 3,\r\n  &quot;bar&quot;: 4\r\n}\r\n{\r\n  &quot;foo&quot;: 5,\r\n  &quot;bar&quot;: 6\r\n}\r\n```\r\n\r\nWhat is the best way to achieve this with jq?",
        "link": "https://stackoverflow.com/questions/59613182/how-to-merge-jq-json-objects-generated-by-comma-separated-filters",
        "title": "How to merge jq JSON objects generated by comma-separated filters"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9226197,
                    "reputation": 1522,
                    "user_id": 6853917,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6bHh1.jpg?s=256",
                    "display_name": "Stephen M Irving",
                    "link": "https://stackoverflow.com/users/6853917/stephen-m-irving"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1578326114,
                "post_id": 59614943,
                "comment_id": 105393375,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9226197,
                    "reputation": 1522,
                    "user_id": 6853917,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6bHh1.jpg?s=256",
                    "display_name": "Stephen M Irving",
                    "link": "https://stackoverflow.com/users/6853917/stephen-m-irving"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1578326180,
                "post_id": 59614943,
                "comment_id": 105393403,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "reply_to_user": {
                    "account_id": 9226197,
                    "reputation": 1522,
                    "user_id": 6853917,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6bHh1.jpg?s=256",
                    "display_name": "Stephen M Irving",
                    "link": "https://stackoverflow.com/users/6853917/stephen-m-irving"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1578326862,
                "post_id": 59614943,
                "comment_id": 105393763,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9226197,
                    "reputation": 1522,
                    "user_id": 6853917,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/6bHh1.jpg?s=256",
                    "display_name": "Stephen M Irving",
                    "link": "https://stackoverflow.com/users/6853917/stephen-m-irving"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1578326935,
                "post_id": 59614943,
                "comment_id": 105393806,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 141612,
                    "reputation": 162638,
                    "user_id": 348785,
                    "user_type": "registered",
                    "accept_rate": 97,
                    "profile_image": "https://www.gravatar.com/avatar/7f3dcb0c380783d1be77bfdd5fc5fda6?s=256&d=identicon&r=PG",
                    "display_name": "kev",
                    "link": "https://stackoverflow.com/users/348785/kev"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1723004493,
                "post_id": 59614943,
                "comment_id": 139004549,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1578337671,
                "last_edit_date": 1578337671,
                "creation_date": 1578326230,
                "answer_id": 59615177,
                "question_id": 59614943,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is an easy-to-use HTML entity encoder/decoder called `he` that was written in JavaScript. It is *not* `jq` based, but it should allow you to do what you are attempting with relative ease.\r\n\r\nhttps://github.com/mathiasbynens/he\r\n\r\n**INSTALL:**\r\n\r\nVia npm:\r\n\r\n`npm install he`\r\n\r\nVia Bower:\r\n\r\n`bower install he`\r\n\r\nVia Component:\r\n\r\n`component install mathiasbynens/he`\r\n\r\nIn a browser:\r\n\r\n```html\r\n&lt;script src=&quot;he.js&quot;&gt;&lt;/script&gt;\r\n```\r\n\r\nIn Node.js, io.js, Narwhal, and RingoJS:\r\n\r\n``` javascript\r\nvar he = require(&#39;he&#39;);\r\n```\r\n\r\nIn Rhino:\r\n\r\n`load(&#39;he.js&#39;);`\r\n\r\nUsing an AMD loader like RequireJS:\r\n\r\n```requirejs\r\nrequire(\r\n  {\r\n    &#39;paths&#39;: {\r\n      &#39;he&#39;: &#39;path/to/he&#39;\r\n    }\r\n  },\r\n  [&#39;he&#39;],\r\n  function(he) {\r\n    console.log(he);\r\n  }\r\n);\r\n```\r\n\r\n**Using as a CLI tool:** \r\n\r\nInstall `he` using the `-g` global flag\r\n\r\n`npm i -g he`\r\n\r\nYou will be then able to encode or decode HTML entities from the command line:\r\n\r\n```bash\r\n$ he --encode &#39;f&#246;o ♥ b&#229;r &#119558; baz&#39;\r\n&gt; f&amp;#xF6;o &amp;#x2665; b&amp;#xE5;r &amp;#x1D306; baz\r\n\r\n$ he --encode --use-named-refs &#39;f&#246;o ♥ b&#229;r &#119558; baz&#39;\r\n&gt; f&amp;ouml;o &amp;hearts; b&amp;aring;r &amp;#x1D306; baz\r\n\r\n$ he --decode &#39;f&amp;ouml;o &amp;hearts; b&amp;aring;r &amp;#x1D306; baz&#39;\r\n&gt; f&#246;o ♥ b&#229;r &#119558; baz\r\n```\r\n\r\n**Decoding Programmatically:**\r\n\r\n```javascript\r\nhe.decode(html, options)\r\n```\r\n\r\nThis function takes a string of HTML and decodes any named and numerical character references in it using the algorithm described in section 12.2.4.69 of the HTML spec.\r\n\r\n```javascript\r\nhe.decode(&#39;foo &amp;copy; bar &amp;ne; baz &amp;#x1D306; qux&#39;);\r\n// → &#39;foo &#169; bar ≠ baz &#119558; qux&#39;\r\n```",
                "title": "convert HTML entities in a JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1578443014,
        "creation_date": 1578325259,
        "last_edit_date": 1578326839,
        "question_id": 59614943,
        "body_markdown": "&lt;br&gt;\r\nI have a this kind of awful JSON file `{ &quot;foo&quot;: &quot;bar &amp;rsquo; foo &amp;rsquo;&quot; }`.\r\n\r\nIs there a way - using preferably jq - to convert the HTML entities then in this example to convert `&amp;rsquo;` in `’`.\r\n\r\nI need to convert them programmatically. This JSON is only an example.\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/59614943/convert-html-entities-in-a-json",
        "title": "convert HTML entities in a JSON"
    },
    {
        "tags": [
            "bash",
            "escaping",
            "jq",
            "aws-cli",
            "aws-secrets-manager"
        ],
        "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": 1578330709,
                "post_id": 59615607,
                "comment_id": 105395730,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1058066,
                    "reputation": 4534,
                    "user_id": 1060339,
                    "user_type": "registered",
                    "accept_rate": 73,
                    "profile_image": "https://i.sstatic.net/IIK04.jpg?s=256",
                    "display_name": "trubliphone",
                    "link": "https://stackoverflow.com/users/1060339/trubliphone"
                },
                "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": 1578390736,
                "post_id": 59615607,
                "comment_id": 105414077,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1578336433,
                "creation_date": 1578336433,
                "answer_id": 59617375,
                "question_id": 59615607,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Following script worked for me :\r\n\r\n```\r\n#!/bin/sh\r\n\r\nSECRET_ID=$1\r\nSECRET_STRING=$2\r\nEXISTING_SECRET=`aws secretsmanager get-secret-value --secret-id $SECRET_ID | jq &#39;.SecretString | fromjson&#39;`\r\nNEW_SECRET=`echo &quot;$EXISTING_SECRET $SECRET_STRING&quot; | jq  -s add`\r\naws secretsmanager put-secret-value --secret-id $SECRET_ID --secret-string &quot;$NEW_SECRET&quot;\r\n```",
                "title": "escaping characters when passing JSON to aws secretsmanager"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1707911450,
                "creation_date": 1707911450,
                "answer_id": 77994078,
                "question_id": 59615607,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It is a problem with the output format (json by default):\r\n\r\naws secretsmanager get-secret-value --secret-id &quot;mysecretid&quot; --query SecretString --output text",
                "title": "escaping characters when passing JSON to aws secretsmanager"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1707911450,
        "creation_date": 1578328064,
        "question_id": 59615607,
        "body_markdown": "I have tried to write a script that updates AWS secrets.  Yes, the `update-secret` command already does this, but that will overwrite existing secrets instead of merging them w/ the new content.\r\n\r\nFor example, suppose **my-environment/my-application/secrets** has the following content:\r\n\r\n    { &quot;db_1_pwd&quot;: &quot;secret&quot;}\r\n\r\nIf I run my script, like this:\r\n\r\n    &gt;&gt; update_secret my-environment/my-application/secrets &#39;{&quot;db_2_pwd&quot;: &quot;secreter&quot;}&#39;\r\n\r\nI would expect the new content to be:\r\n\r\n    { &quot;db_1_pwd&quot;: &quot;secret&quot;, &quot;db_2_pwd&quot;: &quot;secreter&quot;}\r\n\r\nInstead, the new content winds up being this (unescaped) string:\r\n\r\n    &quot;{\\&quot;db_1_pwd\\&quot;:\\&quot;secret\\&quot;,\\&quot;db_2_pwd\\&quot;:\\&quot;secreter\\&quot;}&quot;\r\n\r\nHere is my script:\r\n\r\n    #!/bin/sh\r\n    \r\n    SECRET_ID=$1\r\n    SECRET_STRING=$2\r\n    \r\n    EXISTING_SECRET=`aws secretsmanager get-secret-value --secret-id $SECRET_ID | jq &#39;.SecretString | fromjson&#39;`\r\n    NEW_SECRET=`echo $EXISTING_SECRET $SECRET_STRING | jq  -s &#39;add tostring&#39;`\r\n    \r\n    echo $NEW_SECRET  # this is printed out for debug purposes\r\n\r\n    aws secretsmanager put-secret-value --secret-id $SECRET_ID --secret-string $NEW_SECRET\r\n\r\n\r\nNote that it does print out `&quot;{\\&quot;db_1_pwd\\&quot;:\\&quot;secret\\&quot;,\\&quot;db_2_pwd\\&quot;:\\&quot;secreter\\&quot;}&quot;` in the echo statement and if I type this on the command line:\r\n\r\n    &gt;&gt; aws secretsmanager put-secret-value --secret-id my-environment/my-application/secrets --secret-string &quot;{\\&quot;db_1_pwd\\&quot;:\\&quot;secret\\&quot;,\\&quot;db_2_pwd\\&quot;:\\&quot;secreter\\&quot;}&quot;\r\n\r\nit works.  \r\n\r\nClearly the script is having issues w/ escaping the quotation marks.  Any suggestions on how to fix this?  \r\n\r\n(*It&#39;s probably something to do w/ bash as opposed to AWS*)\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59615607/escaping-characters-when-passing-json-to-aws-secretsmanager",
        "title": "escaping characters when passing JSON to aws secretsmanager"
    },
    {
        "tags": [
            "json",
            "bash",
            "templates",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1578368804,
                "creation_date": 1578368804,
                "answer_id": 59621912,
                "question_id": 59617956,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Would you please try:\r\n```\r\nwhile IFS=&quot;,&quot; read -r name profile os; do\r\n    jq &quot;.name = \\&quot;$name\\&quot; | .profile = \\&quot;$profile\\&quot; | .selector.os = \\&quot;$os\\&quot;&quot; &lt; template.json\r\ndone &lt; ii.json\r\n```\r\nOutput:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;Mark&quot;,\r\n  &quot;profile&quot;: &quot;controller-install&quot;,\r\n  &quot;selector&quot;: {\r\n    &quot;mac&quot;: &quot;4c:pc:ef:4d:33:29&quot;,\r\n    &quot;os&quot;: &quot;installed&quot;\r\n  }\r\n}\r\n{\r\n  &quot;name&quot;: &quot;Chris&quot;,\r\n  &quot;profile&quot;: &quot;controller-install&quot;,\r\n  &quot;selector&quot;: {\r\n    &quot;mac&quot;: &quot;4c:pc:ef:4d:33:29&quot;,\r\n    &quot;os&quot;: &quot;installed&quot;\r\n  }\r\n}\r\n```\r\nHope it meets your requirement.\r\n",
                "title": "How do I assign multiple values to a .json template using jq &amp; bash scripting?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1578431298,
                "last_edit_date": 1578431298,
                "creation_date": 1578377645,
                "answer_id": 59623111,
                "question_id": 59617956,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Is your template a file that you&#39;re passing in? Or is that just the general structure? You can read the (csv) file raw, split on commas, and generate the json.\r\n\r\n    $ jq -R &#39;\r\n    split(&quot;,&quot;) as [$name, $profile, $os]\r\n      | {$name, $profile: selector: {mac: &quot;4c:pc:ef:4d:33:29&quot;, $os}}\r\n    &#39; input.csv\r\n\r\nOtherwise, load the template and update the fields as necessary. You could update them individually or just merge.\r\n\r\n    $ jq -R --argfile template template.json &#39;\r\n    split(&quot;,&quot;) as [$name, $profile, $os]\r\n      | $template * {$name, $profile, selector: {$os}}\r\n    &#39; input.csv",
                "title": "How do I assign multiple values to a .json template using jq &amp; bash scripting?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1578380270,
                "creation_date": 1578380270,
                "answer_id": 59623591,
                "question_id": 59617956,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A “pure jq” solution:\r\n\r\n        jq -R —-argfile template template.json ’\r\n          split(&quot;,&quot;) as [$name,$profile,$os],\r\n          | $template\r\n          | .name = $name \r\n          | .profile = $profile\r\n          | .selector.os = $os&#39; ii.json\r\n\r\nThis assumes a bash or bash-like shell. In general, putting the jq program into a file and invoking jq with the -f option, might be the way to go.\r\n",
                "title": "How do I assign multiple values to a .json template using jq &amp; bash scripting?"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1578431298,
        "creation_date": 1578339419,
        "last_edit_date": 1578380331,
        "question_id": 59617956,
        "body_markdown": "I have a file that contains lines of values for &quot;name&quot;, &quot;profile&quot;, &quot;os&quot;. I have created a bash script that organizes the values in a format I want. I have a template already created with other values that I will use (see below). Using jq (if possible), how can I replace the old values with the new ones?  \r\n\r\nFile (ii.json):\r\n\r\n    Mark,controller-install,installed\r\n    Chris,controller-install,installed\r\n\r\nTEPMLATE: \r\n\r\n    {\r\n      &quot;name&quot;: &quot;jeff&quot;,\r\n      &quot;profile&quot;: &quot;worker-install&quot;,\r\n      &quot;selector&quot;: {\r\n        &quot;mac&quot;: &quot;4c:pc:ef:4d:33:29&quot;,\r\n        &quot;os&quot;: &quot;n/a&quot;\r\n      }\r\n    }",
        "link": "https://stackoverflow.com/questions/59617956/how-do-i-assign-multiple-values-to-a-json-template-using-jq-bash-scripting",
        "title": "How do I assign multiple values to a .json template using jq &amp; bash scripting?"
    },
    {
        "tags": [
            "json",
            "linux",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1578502408,
                "last_edit_date": 1578502408,
                "creation_date": 1578411464,
                "answer_id": 59631519,
                "question_id": 59629569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you wanted to append the object from `file2.json` to the `nodes` array it is fairly straightforward:\r\n```\r\njq -s &#39;.[0].nodes += [ .[1].nodes[0] ] | .[0]&#39; file1.json file2.json\r\n```\r\nOutput:\r\n```json\r\n{\r\n  &quot;nodes&quot;: [\r\n    {\r\n      &quot;pm_addr&quot;: &quot;192.100.0.4&quot;,\r\n      &quot;name&quot;: &quot;TB1-OSC-A&quot;\r\n    },\r\n    {\r\n      &quot;pm_addr&quot;: &quot;192.100.0.6&quot;,\r\n      &quot;name&quot;: &quot;TB1-OSC-B&quot;\r\n    },\r\n    {\r\n      &quot;pm_addr&quot;: &quot;192.100.0.7&quot;,\r\n      &quot;name&quot;: &quot;TB1-OSC-C&quot;\r\n    },\r\n    {\r\n      &quot;pm_addr&quot;: &quot;192.100.0.4&quot;,\r\n      &quot;name&quot;: &quot;TB1-OSC-D&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nHowever, because you want to insert the object, it becomes more tricky, as `jq` AFAIK does not support insertion into arrays, only prepending and appending.\r\n\r\nBelow is a rather convoluted example of how to do this by splicing it in:\r\n\r\n_parse.jq_\r\n```jq\r\n# Find the desired index and store it as $n\r\n(.[0].nodes | map(.name == &quot;TB1-OSC-B&quot;) | index(true)) as $n   |\r\n\r\n# Splice the object from the second file  into the first\r\n.[0].nodes =   .[0].nodes[0:($n|tonumber+1)]   +\r\n             [ .[1].nodes[0] ]                 +\r\n               .[0].nodes[($n|tonumber+1):(.[0].nodes|length)] |\r\n\r\n# Only output the now modified object from the first file \r\n.[0]\r\n```\r\nRun it like this:\r\n```\r\njq -sf parse.jq file1.json file2.json\r\n```\r\nOutput in this case:\r\n```json\r\n{\r\n  &quot;nodes&quot;: [\r\n    {\r\n      &quot;pm_addr&quot;: &quot;192.100.0.4&quot;,\r\n      &quot;name&quot;: &quot;TB1-OSC-A&quot;\r\n    },\r\n    {\r\n      &quot;pm_addr&quot;: &quot;192.100.0.6&quot;,\r\n      &quot;name&quot;: &quot;TB1-OSC-B&quot;\r\n    },\r\n    {\r\n      &quot;pm_addr&quot;: &quot;192.100.0.4&quot;,\r\n      &quot;name&quot;: &quot;TB1-OSC-D&quot;\r\n    },\r\n    {\r\n      &quot;pm_addr&quot;: &quot;192.100.0.7&quot;,\r\n      &quot;name&quot;: &quot;TB1-OSC-C&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Add JSON Object at specific location"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1578536604,
                "creation_date": 1578536604,
                "answer_id": 59656391,
                "question_id": 59629569,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a clear and maintainable solution is having suitable utility functions.\r\n\r\n## Utility functions for jq 1.3\r\n```\r\ndef insert_at(i; x): .[:i] + [x] + .[i:];\r\n\r\ndef indicesof(f):\r\n  . as $in\r\n  | range(0;length) | select( $in[.] | f );\r\n\r\ndef insert_after(f; x):\r\n  [indicesof(f)] as $ix\r\n  | if ($ix|length) &gt; 0\r\n    then insert_at($ix[0]+1; x) \r\n    else . end;\r\n```\r\n\r\n## Utility functions for jq 1.4 or later\r\njq 1.4 allows a more efficient solution, courtesy of `first/1`:\r\n```\r\ndef insert_at($i; $x): .[:$i] + [$x] + .[$i:];\r\n\r\ndef indicesof(f):\r\n  . as $in\r\n  | range(0;length) | select( $in[.] | f );\r\n\r\ndef insert_after(f; $x):\r\n  (first(indicesof(f)) // null) as $i\r\n  | if $i then insert_at($i + 1; $x) else . end;\r\n```\r\n\r\n## Solution\r\nWith these utility functions, solutions to the given problem can be expressed directly. For example, assuming an invocation along the lines of:\r\n\r\n    jq -s -f merge.jq file1.json file2.json\r\n\r\n```\r\n\r\n.[1].nodes[0] as $file2\r\n| .[0]\r\n| .nodes |= insert_after(.name == &quot;TB1-OSC-B&quot;; $file2)\r\n```\r\n\r\nThis can easily be modified depending on the detailed requirements.",
                "title": "Add JSON Object at specific location"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1578536604,
        "creation_date": 1578404409,
        "last_edit_date": 1578405720,
        "question_id": 59629569,
        "body_markdown": "Here are my two json files content:\r\n\r\nfile1.json\r\n\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;pm_addr&quot;: &quot;192.100.0.4&quot;,\r\n          &quot;name&quot;: &quot;TB1-OSC-A&quot;\r\n        },\r\n        {\r\n          &quot;pm_addr&quot;: &quot;192.100.0.6&quot;,\r\n          &quot;name&quot;: &quot;TB1-OSC-B&quot;\r\n        },\r\n        {\r\n          &quot;pm_addr&quot;: &quot;192.100.0.7&quot;,\r\n          &quot;name&quot;: &quot;TB1-OSC-C&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nfile2.json\r\n\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;pm_addr&quot;: &quot;192.100.0.4&quot;,\r\n          &quot;name&quot;: &quot;TB1-OSC-D&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI want to add the contents of file2.json to file1.json but after the json object : **TB1-OSC-B** i.e., second json entry. In this case the entry is present at second location but it may be present any where else aswell.\r\nMy final json file should look like this:\r\n\r\nfile3.json\r\n\r\n    {\r\n      &quot;nodes&quot;: [\r\n        {\r\n          &quot;pm_addr&quot;: &quot;192.100.0.4&quot;,\r\n          &quot;name&quot;: &quot;TB1-OSC-A&quot;\r\n        },\r\n        {\r\n          &quot;pm_addr&quot;: &quot;192.100.0.6&quot;,\r\n          &quot;name&quot;: &quot;TB1-OSC-B&quot;\r\n        },\r\n        {\r\n          &quot;pm_addr&quot;: &quot;192.100.0.4&quot;,\r\n          &quot;name&quot;: &quot;TB1-OSC-D&quot;\r\n        },\r\n    \t{\r\n          &quot;pm_addr&quot;: &quot;192.100.0.7&quot;,\r\n          &quot;name&quot;: &quot;TB1-OSC-C&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nI am using jq version : 1.3 and I have no way to upgade it. I tried using add and =+ parameters provided by jq. But it did not help.\r\n\r\nThanks in advnace",
        "link": "https://stackoverflow.com/questions/59629569/add-json-object-at-specific-location",
        "title": "Add JSON Object at specific location"
    },
    {
        "tags": [
            "linux",
            "shell",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1578500004,
                "post_id": 59649802,
                "comment_id": 105460728,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16903100,
                    "reputation": 17,
                    "user_id": 12223931,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-e-V9z6w_7f4/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rcxt1kONDxi2HWzMFHDr7PuIVr1VQ/s256-rj/photo.jpg",
                    "display_name": "Neil Roy",
                    "link": "https://stackoverflow.com/users/12223931/neil-roy"
                },
                "reply_to_user": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1578500307,
                "post_id": 59649802,
                "comment_id": 105460904,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1578501704,
                "last_edit_date": 1578501704,
                "creation_date": 1578500053,
                "answer_id": 59649846,
                "question_id": 59649802,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not just a string but [tag:json], and you need a `json` parser : \r\n\r\n    jq -r &#39;.cookie&#39; file.json\r\n\r\n## Output:\r\n\r\n    sessionId=lhadasdfsdffdhjseodfjdksfjlsdjflsdjfldfjlsdf\r\n\r\nYou can even manipulate content with this tool :\r\n\r\n    jq -r &#39;.cookie = &quot;foobar&quot;&#39; file.json\r\n\r\n##&#160;Output \r\n\r\n    {\r\n      &quot;uri&quot;: &quot;/login-sessions&quot;,\r\n      &quot;cookie&quot;: &quot;foobar&quot;\r\n    }\r\n\r\n",
                "title": "How do i edit out a particular output from a string?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1578518358,
        "creation_date": 1578499905,
        "last_edit_date": 1578518358,
        "question_id": 59649802,
        "body_markdown": "I have a following string output.\r\n\r\n    {&quot;uri&quot;:&quot;/login-sessions&quot;,&quot;cookie&quot;:&quot;sessionId=lhadasdfsdffdhjseodfjdksfjlsdjflsdjfldfjlsdf&quot;}\r\n\r\nI wanted to extract only `&quot;sessionId=lhadasdfsdffdhjseodfjdksfjlsdjflsdjfldfjlsdf&quot;` using sed and grep.\r\n\r\nTried the below command but i dont see any output\r\n\r\n    grep -`E &quot;&quot;cookie&quot;:&quot;\r\nNote : Above is a sting and not json dict.\r\nNot sure what needs to be done here.\r\nCan you help me out ?",
        "link": "https://stackoverflow.com/questions/59649802/how-do-i-edit-out-a-particular-output-from-a-string",
        "title": "How do i edit out a particular output from a string?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1578548581,
                "post_id": 59655060,
                "comment_id": 105475932,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 48930,
                    "reputation": 4428,
                    "user_id": 145504,
                    "user_type": "registered",
                    "accept_rate": 62,
                    "profile_image": "https://www.gravatar.com/avatar/30b3db431ea2a3dbed966d71c98d205c?s=256&d=identicon&r=PG",
                    "display_name": "rgov",
                    "link": "https://stackoverflow.com/users/145504/rgov"
                },
                "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": 1578599018,
                "post_id": 59655060,
                "comment_id": 105500926,
                "content_license": "CC BY-SA 4.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": 1578600102,
                "post_id": 59655060,
                "comment_id": 105501376,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1578602129,
                "last_edit_date": 1578602129,
                "creation_date": 1578525036,
                "answer_id": 59655061,
                "question_id": 59655060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": " I came up with this using the `mapfile` built-in from Bash 4:\r\n\r\n    while mapfile -n 100 LINES &amp;&amp; ((${#LINES[@]})); do\r\n        echo &quot;Uploading ${#LINES[@]} records...&quot;\r\n        echo &quot;${LINES[@]}&quot; | curl --silent ... --data-binary @- &gt;/dev/null\r\n    done &lt; &lt;(jq --stream -cn &#39;fromstream(1|truncate_stream(inputs))&#39; &lt; data.json)\r\n",
                "title": "Batch processing of a large JSON file with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1578584207,
                "last_edit_date": 1578584207,
                "creation_date": 1578548917,
                "answer_id": 59657905,
                "question_id": 59655060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use GNU parallel:\r\n\r\n```\r\n&lt; data.json jq --stream -nc &#39;\r\n    fromstream(1|truncate_stream(inputs))&#39; |\r\n  parallel --pipe -N100 curl ...\r\n```\r\n\r\nOr more generically:\r\n```\r\n&lt; data.json jq --stream -nc &#39;\r\n    fromstream( inputs|(.[0] |= .[1:]) | select(. != [[]]) )&#39; |\r\n  parallel --pipe -N100 curl ...\r\n```",
                "title": "Batch processing of a large JSON file with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1578603998,
                "creation_date": 1578603998,
                "answer_id": 59672105,
                "question_id": 59655060,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If your input is an array, then the paths will all start with a number (the index into the array). You could effectively paginate that array by filtering by the indices.\r\n\r\n    $ jq --stream -n --argjson skip 0 --argjson top 100 &#39;\r\n    [fromstream(1|truncate_stream(\r\n        inputs | . as [[$index]] | select($index &gt;= $skip and $index &lt; $skip + $top)\r\n    ))]\r\n    &#39; data.json | curl ...\r\n\r\nJust set the skip argument to the appropriate offset.\r\n\r\nI set up an example in the playground so you can play around with it. [jqplay](https://jqplay.org/s/ykntRWS17I)",
                "title": "Batch processing of a large JSON file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1578603998,
        "creation_date": 1578525036,
        "last_edit_date": 1578600145,
        "question_id": 59655060,
        "body_markdown": "I have a large JSON file which is an array of many objects which I want to submit to an API that accepts bulk data uploads. I&#39;ve learned that I can use jq&#39;s stream mode to avoid loading the entire file into memory:\r\n\r\n    jq --stream -nc &#39;fromstream(1|truncate_stream(inputs))&#39; &lt; data.json | curl ...\r\n\r\nI&#39;d like to batch this so I&#39;m making a request in batches for, say, 100 objects at a time.",
        "link": "https://stackoverflow.com/questions/59655060/batch-processing-of-a-large-json-file-with-jq",
        "title": "Batch processing of a large JSON file with jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1578539327,
                "creation_date": 1578539327,
                "answer_id": 59656692,
                "question_id": 59656085,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With the sample JSON, the invocation\r\n\r\n    jq -r &#39;.[] | [.Name, .DataClasses[]] | @csv&#39;\r\n\r\nproduces:\r\n\r\n```\r\n&quot;Evite&quot;,&quot;Dates of birth&quot;,&quot;Email addresses&quot;,&quot;Genders&quot;,&quot;Names&quot;,&quot;Passwords&quot;,&quot;Phone numbers&quot;,&quot;Physical addresses&quot;\r\n&quot;VerificationsIO&quot;,&quot;Dates of birth&quot;,&quot;Email addresses&quot;,&quot;Employers&quot;,&quot;Genders&quot;,&quot;Geographic locations&quot;,&quot;IP addresses&quot;,&quot;Job titles&quot;,&quot;Names&quot;,&quot;Phone numbers&quot;,&quot;Physical addresses&quot;\r\n```\r\n",
                "title": "How to use jq to turning mixed JSON into CSV"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1578539327,
        "creation_date": 1578533961,
        "question_id": 59656085,
        "body_markdown": "can&#39;t figure this one out... I want to collapse this JSON so that just the NAME field and the values of DATACLASSES of each record are output to a CSV file.  It&#39;s taxing my jq-fu as it has to mix a string with a nested array and somehow get it into a CSV.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;Name&quot;: &quot;Evite&quot;,\r\n    &quot;Title&quot;: &quot;Evite&quot;,\r\n    &quot;Domain&quot;: &quot;evite.com&quot;,\r\n    &quot;BreachDate&quot;: &quot;2013-08-11&quot;,\r\n    &quot;AddedDate&quot;: &quot;2019-07-14T14:51:51Z&quot;,\r\n    &quot;ModifiedDate&quot;: &quot;2019-07-14T14:51:51Z&quot;,\r\n    &quot;PwnCount&quot;: 100985047,\r\n    &quot;Description&quot;: &quot;In April 2019, the social planning website for managing online invitations &lt;a href=\\&quot;https://www.evite.com/security/update?usource=lc&amp;lctid=1800182\\&quot; target=\\&quot;_blank\\&quot; rel=\\&quot;noopener\\&quot;&gt;Evite identified a data breach of their systems&lt;/a&gt;. Upon investigation, they found unauthorised access to a database archive dating back to 2013. The exposed data included a total of 101 million unique email addresses, most belonging to recipients of invitations. Members of the service also had names, phone numbers, physical addresses, dates of birth, genders and passwords stored in plain text exposed. The data was provided to HIBP by a source who requested it be attributed to &amp;quot;JimScott.Sec@protonmail.com&amp;quot;.&quot;,\r\n    &quot;LogoPath&quot;: &quot;https://haveibeenpwned.com/Content/Images/PwnedLogos/Evite.png&quot;,\r\n    &quot;DataClasses&quot;: [\r\n      &quot;Dates of birth&quot;,\r\n      &quot;Email addresses&quot;,\r\n      &quot;Genders&quot;,\r\n      &quot;Names&quot;,\r\n      &quot;Passwords&quot;,\r\n      &quot;Phone numbers&quot;,\r\n      &quot;Physical addresses&quot;\r\n    ],\r\n    &quot;IsVerified&quot;: true,\r\n    &quot;IsFabricated&quot;: false,\r\n    &quot;IsSensitive&quot;: false,\r\n    &quot;IsRetired&quot;: false,\r\n    &quot;IsSpamList&quot;: false\r\n  },\r\n  {\r\n    &quot;Name&quot;: &quot;VerificationsIO&quot;,\r\n    &quot;Title&quot;: &quot;Verifications.io&quot;,\r\n    &quot;Domain&quot;: &quot;verifications.io&quot;,\r\n    &quot;BreachDate&quot;: &quot;2019-02-25&quot;,\r\n    &quot;AddedDate&quot;: &quot;2019-03-09T19:29:54Z&quot;,\r\n    &quot;ModifiedDate&quot;: &quot;2019-03-09T20:49:51Z&quot;,\r\n    &quot;PwnCount&quot;: 763117241,\r\n    &quot;Description&quot;: &quot;In February 2019, the email address validation service &lt;a href=\\&quot;https://securitydiscovery.com/800-million-emails-leaked-online-by-email-verification-service\\&quot; target=\\&quot;_blank\\&quot; rel=\\&quot;noopener\\&quot;&gt;verifications.io suffered a data breach&lt;/a&gt;. Discovered by &lt;a href=\\&quot;https://twitter.com/mayhemdayone\\&quot; target=\\&quot;_blank\\&quot; rel=\\&quot;noopener\\&quot;&gt;Bob Diachenko&lt;/a&gt; and &lt;a href=\\&quot;https://twitter.com/vinnytroia\\&quot; target=\\&quot;_blank\\&quot; rel=\\&quot;noopener\\&quot;&gt;Vinny Troia&lt;/a&gt;, the breach was due to the data being stored in a MongoDB instance left publicly facing without a password and resulted in 763 million unique email addresses being exposed. Many records within the data also included additional personal attributes such as names, phone numbers, IP addresses, dates of birth and genders. No passwords were included in the data. The Verifications.io website went offline during the disclosure process, although &lt;a href=\\&quot;https://web.archive.org/web/20190227230352/https://verifications.io/\\&quot; target=\\&quot;_blank\\&quot; rel=\\&quot;noopener\\&quot;&gt;an archived copy remains viewable&lt;/a&gt;.&quot;,\r\n    &quot;LogoPath&quot;: &quot;https://haveibeenpwned.com/Content/Images/PwnedLogos/VerificationsIO.png&quot;,\r\n    &quot;DataClasses&quot;: [\r\n      &quot;Dates of birth&quot;,\r\n      &quot;Email addresses&quot;,\r\n      &quot;Employers&quot;,\r\n      &quot;Genders&quot;,\r\n      &quot;Geographic locations&quot;,\r\n      &quot;IP addresses&quot;,\r\n      &quot;Job titles&quot;,\r\n      &quot;Names&quot;,\r\n      &quot;Phone numbers&quot;,\r\n      &quot;Physical addresses&quot;\r\n    ],\r\n    &quot;IsVerified&quot;: true,\r\n    &quot;IsFabricated&quot;: false,\r\n    &quot;IsSensitive&quot;: false,\r\n    &quot;IsRetired&quot;: false,\r\n    &quot;IsSpamList&quot;: false\r\n  }\r\n]\r\n```\r\n\r\nI can flatten out DataClasses only with this jq pipeline: \r\n\r\n```\r\njq -r  &#39;.[] | {DataClasses} | .[] | @csv&#39;\r\n```\r\n\r\nBut it&#39;s missing the name string and I have not been able to puzzle out how to include it. \r\n\r\nThe context is to generate a report from haveibeenpwned.com (where the JSON is returned from) that will contain the breach name and details from the DataClasses as to the nature of the breach so it can be nicely summarized and notifications emailed to affected parties. Easy enough to script this -- We have the API key, etc, but can&#39;t quite figure out how to get the JSON to cooperate ;) \r\n\r\nIf this basic approach of having it all in a CSV (where it can be easily mangled in perl or python), any suggestions on how best handle it elegantly via jq mangling that will allow us to easily reference the NAME of the breach and the items in its associated DATACLASSES array would be most helpful\r\n\r\nAny advice is greatly appreciated.\r\n\r\nThank-you\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59656085/how-to-use-jq-to-turning-mixed-json-into-csv",
        "title": "How to use jq to turning mixed JSON into CSV"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "group-by",
            "jq",
            "reshape"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1578582126,
                "creation_date": 1578582126,
                "answer_id": 59666762,
                "question_id": 59666195,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `map` to create an input for `from_entries`:\r\n\r\n    map({key: .Agents, value: .Count}) | {Count: length, Agents: from_entries}\r\n\r\n`map` produces a list of objects like `[{&quot;key&quot;: &quot;a&quot;, &quot;value&quot;: 1}, ...]`. `from_entries` turns that into a single object `{&quot;a&quot;: 1, ...}`. In the final object, both `length` and `from_entries` get the same array as input, and their outputs are used to create the final object with `Count` and `Agents` keys.",
                "title": "Reshape a jq array with summarized data"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1578582906,
                "last_edit_date": 1578582906,
                "creation_date": 1578582173,
                "answer_id": 59666772,
                "question_id": 59666195,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another variant using `reduce` would be to do. The reduce expression takes the array as input and puts the key as the `Agents` and the value as its corresponding `Count` value.\r\n\r\n    jq &#39;{ Count: length, Agents: (reduce .[] as $d ({}; .[$d.Agents] = $d.Count)) }&#39;\r\n\r\nThe Object Value Iterator `.[]` used to construct the JSON. For a given `.[&quot;a&quot;]`, it returns `&quot;a&quot;` which is how the keys are constructed in the final JSON.\r\n",
                "title": "Reshape a jq array with summarized data"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 3,
        "last_activity_date": 1578588187,
        "creation_date": 1578580226,
        "last_edit_date": 1578588187,
        "question_id": 59666195,
        "body_markdown": "New to jq but I&#39;ve managed to group a load of data which I would now like summarized in a different format. Original data after group by and mapping:\r\n\r\n    [\r\n      {\r\n        &quot;Agents&quot;: &quot;a&quot;,\r\n        &quot;Count&quot;: 1\r\n      },\r\n      {\r\n        &quot;Agents&quot;: &quot;b&quot;,\r\n        &quot;Count&quot;: 50\r\n      },\r\n      {\r\n        &quot;Agents&quot;: &quot;c&quot;,\r\n        &quot;Count&quot;: 25\r\n      },\r\n      {\r\n        &quot;Agents&quot;: &quot;d&quot;,\r\n        &quot;Count&quot;: 1\r\n      },\r\n      {\r\n        &quot;Agents&quot;: &quot;e&quot;,\r\n        &quot;Count&quot;: 4\r\n      },\r\n      {\r\n        &quot;Agents&quot;: &quot;f&quot;,\r\n        &quot;Count&quot;: 4\r\n      },\r\n      {\r\n        &quot;Agents&quot;: &quot;g&quot;,\r\n        &quot;Count&quot;: 4\r\n      }\r\n    ]\r\n\r\n\r\nand I would like this output:\r\n\r\n    {\r\n      &quot;Count&quot;: 7,\r\n      &quot;Agents&quot;: {\r\n        &quot;a&quot;: 1,\r\n        &quot;b&quot;: 50,\r\n        &quot;c&quot;: 25,\r\n        &quot;d&quot;: 1,\r\n        &quot;e&quot;: 4,\r\n        &quot;f&quot;: 4,\r\n        &quot;g&quot;: 4\r\n      }\r\n    }\r\n\r\nHow exactly might I do this in jq please because it requires mapping the values as field names?",
        "link": "https://stackoverflow.com/questions/59666195/reshape-a-jq-array-with-summarized-data",
        "title": "Reshape a jq array with summarized data"
    },
    {
        "tags": [
            "bash",
            "path",
            "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": 1578618923,
                "post_id": 59674319,
                "comment_id": 105507171,
                "content_license": "CC BY-SA 4.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": 1578619108,
                "post_id": 59674319,
                "comment_id": 105507212,
                "content_license": "CC BY-SA 4.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": 1578619140,
                "post_id": 59674319,
                "comment_id": 105507218,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5501891,
                    "reputation": 31,
                    "user_id": 4370987,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c6dce7865ef94feede84626d0c825735?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Reddy Stark",
                    "link": "https://stackoverflow.com/users/4370987/reddy-stark"
                },
                "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": 1578619619,
                "post_id": 59674319,
                "comment_id": 105507287,
                "content_license": "CC BY-SA 4.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": 1578621112,
                "post_id": 59674319,
                "comment_id": 105507562,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5501891,
                    "reputation": 31,
                    "user_id": 4370987,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c6dce7865ef94feede84626d0c825735?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Reddy Stark",
                    "link": "https://stackoverflow.com/users/4370987/reddy-stark"
                },
                "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": 1578627906,
                "post_id": 59674319,
                "comment_id": 105508836,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1578630590,
                "creation_date": 1578630590,
                "answer_id": 59675525,
                "question_id": 59674319,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following addresses the bulk of the requirements but leaves the parsing of the &quot;INPUT ARGS&quot; as an exercise.\r\n\r\n## Property File\r\n```\r\ndef propertyValue(property):\r\n  &quot;\\(property)=\\(.[property])&quot;;\r\n\r\ndef propertyValue(arrayvaluedproperty; property):\r\n  .[arrayvaluedproperty] as $a\r\n  | range(0; $a|length) as $i\r\n  | &quot;\\(arrayvaluedproperty)_\\($i)_\\(property)=\\($a[$i][property])&quot;;\r\n\r\npropertyValue(&quot;description&quot;),\r\npropertyValue(&quot;assets&quot;; &quot;url&quot;)\r\n\r\n```\r\n## Transformed JSON\r\n```\r\ndef updateProperty(p):\r\n  .[p] = &quot;${\\(p)}&quot;;\r\n\r\ndef updateProperty(arrayvaluedproperty; p):\r\n  .[arrayvaluedproperty] as $a\r\n  | reduce range(0; $a|length) as $i (.;\r\n    .[arrayvaluedproperty][$i] = &quot;${\\(arrayvaluedproperty)_\\($i)_\\(p)}&quot;);\r\n\r\n\r\nupdateProperty(&quot;description&quot;)\r\n| updateProperty(&quot;assets&quot;; &quot;url&quot;)\r\n```\r\n",
                "title": "Use JQ to extract an array of paths and also replace those values by it own path"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1578981775,
        "creation_date": 1578618750,
        "last_edit_date": 1578981775,
        "question_id": 59674319,
        "body_markdown": "Idk if JQ is able to do it in an easy way, but I would like to ask the experts here before moving to another tool.\r\n\r\nI will receive an array with JSON paths that need to be extracted.\r\n\r\nThose selected keys and their values, will generate a property file, and also  be replaced in the JSON itself.\r\n\r\nExample:\r\n\r\nINPUT ARGS: &quot;description&quot; &quot;assets.url&quot;  \r\n**^^^ we can change this INPUT format to assets[].url if it makes easier to handle arrays ^^^**\r\n\r\nJSON:\r\n\r\n     {\r\n            &quot;title&quot;: &quot;TEST TITLE&quot;,\r\n            &quot;description&quot;: &quot;TEST DESCRIPTION&quot;,\r\n            &quot;type&quot;: &quot;Promo&quot;,\r\n            &quot;assets&quot;: [{\r\n               &quot;content_type&quot;: &quot;image&quot;,\r\n               &quot;url&quot;: &quot;https://www.fakesite.com/image.jpg&quot;\r\n               }, {\r\n               &quot;content_type&quot;: &quot;image&quot;,\r\n               &quot;url&quot;: &quot;https://www.fakesite.com/image2.jpg&quot;\r\n            }]\r\n        }\r\n\r\n\r\nExpected OUTPUT:\r\n\r\n1) a property file (key=value)\r\n\r\n    description=TEST DESCRIPTION\r\n    assets_0_url=https://www.fakesite.com/image.jpg\r\n    assets_1_url=https://www.fakesite.com/image2.jpg\r\n\r\n2) a transformed JSON file\r\n\r\n     {\r\n            &quot;title&quot;: &quot;TEST TITLE&quot;,\r\n            &quot;description&quot;: &quot;${description}&quot;,\r\n            &quot;type&quot;: &quot;Promo&quot;,\r\n            &quot;assets&quot;: [{\r\n               &quot;content_type&quot;: &quot;image&quot;,\r\n               &quot;url&quot;: &quot;${assets_0_url}&quot;\r\n               }, {\r\n               &quot;content_type&quot;: &quot;image&quot;,\r\n               &quot;url&quot;: &quot;${assets_1_url}&quot;\r\n            }]\r\n        }\r\n\r\nThe OUTPUT keys (in this case: description, assets_0_url, assets_1_url) don&#39;t need to follow this format, but it needs to be numbered and unique in case of arrays.\r\n\r\nThe only requirement is that the OUTPUT property file&#39;s keys matches with the replaced values in the OUTPUT JSON.\r\n\r\nPROPERTY:\r\n\r\n**description**=TEST DESCRIPTION\r\n\r\nJSON:\r\n\r\n&quot;description&quot;: &quot;**${description}**&quot;,\r\n\r\n\r\nWhat I made so far:\r\n\r\n    FIELDS=&quot;description\\|assets.*url&quot;\r\n    OUTPUT=$(jq -r &#39;paths(scalars) as $p | &quot;\\($p|join(&quot;_&quot;))=\\(getpath($p))&quot;&#39; $FILE | grep $FIELDS)\r\n    printf &quot;%s\\r&quot; &quot;$OUTPUT&quot; &gt; json.properties\r\n\r\nWhich gives me the following json.properties file:\r\n\r\n    description=TEST DESCRIPTION\r\n    assets_0_url=https://www.fakesite.com/image.jpg\r\n    assets_1_url=https://www.fakesite.com/image2.jpg\r\n\r\n   \r\nIs that possible with JQ?\r\n\r\n\r\nThanks in advance\r\n",
        "link": "https://stackoverflow.com/questions/59674319/use-jq-to-extract-an-array-of-paths-and-also-replace-those-values-by-it-own-path",
        "title": "Use JQ to extract an array of paths and also replace those values by it own path"
    },
    {
        "tags": [
            "arrays",
            "json",
            "select",
            "null",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1578645033,
                "creation_date": 1578645033,
                "answer_id": 59677956,
                "question_id": 59677955,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "after giving this a good nights sleep, and trying out what the manual has to offer on this the most simple solution I have come up with is \r\n\r\n\r\n```\r\n{k:.id,m:[.j[] | select(.f==4)|.d][0]}\r\n```\r\n\r\nhttps://jqplay.org/s/Ao8_GuHWI4\r\n\r\nI did not read the whole manual, but i guess at some point it will say that it falls upwards by the multiplicity of the partial results or something which would yield more than one result if the select would find more items! \r\n\r\nin the given solution this does not prevail only returning 1 result even if the select would match up with more items \r\n\r\nhowever you can come around it by actually doing it right with the alternative operator ;) \r\n\r\n```\r\n{k:.id,m:([.j[] | select(.f==4)|.d][]//null)}\r\n```\r\n\r\nhttps://jqplay.org/s/uBG5c969pf\r\n",
                "title": "jq empty result by select on array"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1578648718,
                "creation_date": 1578648718,
                "answer_id": 59678869,
                "question_id": 59677955,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s just a matter of parentheses.  \r\n\r\nWith your data, the following modification of your original query produces the result shown below:\r\n\r\n    {k:.id, m: ((.j[] | select(.f==4)|.d) // null)}\r\n\r\n#### Result:\r\n\r\n    {&quot;k&quot;:&quot;4&quot;,&quot;m&quot;:null}\r\n\r\n",
                "title": "jq empty result by select on array"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1578648718,
        "creation_date": 1578645033,
        "question_id": 59677955,
        "body_markdown": "given the following JSON : \r\n\r\n```\r\n{\r\n  &quot;id&quot;: &quot;4&quot;,\r\n  &quot;j&quot;: [\r\n    {\r\n      &quot;f&quot;: 1,\r\n      &quot;d&quot;: &quot;x1&quot;\r\n    },\r\n    {\r\n      &quot;f&quot;: 2,\r\n      &quot;d&quot;: &quot;x2&quot;\r\n    },\r\n    {\r\n      &quot;f&quot;: 3,\r\n      &quot;d&quot;: &quot;x3&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nthe following query yields an empty result if  selector is changed to a non existent filter value\r\n\r\nworks as intended: \r\n```\r\n{k:.id,m:.j[] | select(.f==3)|.d}\r\n```\r\nhttps://jqplay.org/s/E8rS0Mf_so\r\n\r\nempty: \r\n```\r\n{k:.id,m:.j[] | select(.f==4)|.d}\r\n```\r\n\r\n\r\nthe result I wanted should be something like:\r\n \r\n```\r\n{\r\n  &quot;k&quot;: &quot;4&quot;,\r\n  &quot;m&quot;: null\r\n}\r\n\r\n```\r\n\r\n \r\nthe solution proposed in https://stackoverflow.com/questions/54361098/how-to-manage-empty-select-results does not work easily \r\n\r\n```\r\n{k:.id,m:(.j[] | select(.f==4)|.d//null)}\r\n```\r\nneither with the questionmark as proposed in documentation next to [alternative](https://stedolan.github.io/jq/manual/#Alternativeoperator://)\r\n \r\n\r\n",
        "link": "https://stackoverflow.com/questions/59677955/jq-empty-result-by-select-on-array",
        "title": "jq empty result by select on array"
    },
    {
        "tags": [
            "json",
            "database",
            "jq",
            "string-matching"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1578714945,
                "creation_date": 1578714945,
                "answer_id": 59691503,
                "question_id": 59685626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The key to a reasonably efficient solution is to begin by collecting the plausible candidates using `inputs` with the -n command-line option of jq. With this in mind, we can write:\r\n```\r\n# Winnow recursively\r\ndef winnow($s; $i):\r\n  if ($s|length) &lt; $i then . # no further winnowing\r\n  else $s[0:$i] as $ss\r\n  | map(select(.oui | startswith($ss))) as $result\r\n  | if ($result|length) == 0 then . # prior\r\n    elif ($result|length) == 1 then $result\r\n    else $result | winnow($s; $i+1)\r\n    end\r\n  end;\r\n\r\ndef bestMatch($s):\r\n  $s[0:1] as $first\r\n  | [inputs | select(.oui | startswith($first))]\r\n  | (select(length&gt;0) | winnow($s; 2)) // &quot;Unknown&quot;\r\n  | if type == &quot;array&quot; and length == 1 then .[0] else . end\r\n  ;\r\n```\r\n\r\n## Examples\r\n\r\n    bestMatch(&quot;14:18:77:34:23:12&quot;)\r\n\r\nyields the JSON object with .oui == &quot;14:18:77&quot;;\r\n\r\n\r\n    bestMatch(&quot;00:50:C2:73:E3:27&quot;) \r\n\r\nyields the JSON object with .oui == &quot;00:50:C2:73:E&quot;",
                "title": "find Network card Manufacturer from macaddress.io MAC json database"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1578793677,
        "creation_date": 1578674238,
        "last_edit_date": 1578793677,
        "question_id": 59685626,
        "body_markdown": "Is there an efficient way to query macaddress.io json Mac database using jq to find a network car manufacturer.\r\nthe database is freely available at https://macaddress.io/database-download (select json + download\r\n```{\r\n  &quot;oui&quot;: &quot;00:50:C2:73:E&quot;,\r\n  &quot;isPrivate&quot;: false,\r\n  &quot;companyName&quot;: &quot;Quantec Networks GmbH&quot;,\r\n  &quot;companyAddress&quot;: &quot;Rieselwiese 1 Vienenburg Niedersachsen 38690 DE&quot;,\r\n  &quot;countryCode&quot;: &quot;DE&quot;,\r\n  &quot;assignmentBlockSize&quot;: &quot;IAB&quot;,\r\n  &quot;dateCreated&quot;: &quot;2007-05-14&quot;,\r\n  &quot;dateUpdated&quot;: &quot;2015-08-29&quot;\r\n}\r\n```\r\nFor a DeLL Computer, I can query like this:\r\n```cat macaddress.io-db.json |jq &#39;select(.oui|test(&quot;14:18:77&quot;))&#39;```\r\nUnfortunately, for the above record, there are multiple company name matching 00:50:C2 and you need to give more digit to have the unique correct answer.\r\n\r\nThe ugly approach is to loop on the full MAC address removing one digit until query succeed.\r\n\r\nSo for a DeLL computer, this will loop 6 times before we get a result:\r\nLet&#39;s take the 14:18:77:34:23:12 MAC as example:\r\n\r\n```\r\n1st query: 14:18:77:34:23:1 =&gt; no answer\r\n2nd query: 14:18:77:34:23 =&gt; no answer\r\n3rd query: 14:18:77:34:2 =&gt; no answer\r\n4th query: 14:18:77:34 =&gt; no answer\r\n5th query: 14:18:77:3 =&gt; no answer\r\n6th query: 14:18:77 =&gt; we get the DeLL record:\r\n{\r\n  &quot;oui&quot;: &quot;14:18:77&quot;,\r\n  &quot;isPrivate&quot;: false,\r\n  &quot;companyName&quot;: &quot;Dell Inc&quot;,\r\n  &quot;companyAddress&quot;: &quot;One Dell way Round Rock 78682 US&quot;,\r\n  &quot;countryCode&quot;: &quot;US&quot;,\r\n  &quot;assignmentBlockSize&quot;: &quot;MA-L&quot;,\r\n  &quot;dateCreated&quot;: &quot;2015-06-13&quot;,\r\n  &quot;dateUpdated&quot;: &quot;2019-07-01&quot;\r\n}\r\n```\r\n\r\nI wonder if there is a smarter approach that would return the best match given a full MAC.\r\n\r\nFor example: 14:18:77:34:23:12 MAC would match the 14:18:77 record (DeLL)\r\n\r\nAnd 00:50:C2:73:E3:27 MAC would match 00:50:C2:73:E record and not 00:50:C2:73:F record.\r\n\r\nAny idea/tips/jq command to accomplish the above &quot;soft/smart&quot; matching?\r\n\r\n(Goal is, given a full MAC (in upper or lower case), to retrieve the companyName field or &quot;Unknown&quot; (or &quot;&quot;) if not found.)\r\n\r\nNote that oui field are unique and there are no subset (if XX:YY:ZZ:TT exists, you cannot have XX:YY:ZZ (but you can have XX:YY:ZZ:UU)). Knowing that, means that the longest match is unique (single record).\r\n",
        "link": "https://stackoverflow.com/questions/59685626/find-network-card-manufacturer-from-macaddress-io-mac-json-database",
        "title": "find Network card Manufacturer from macaddress.io MAC json database"
    },
    {
        "tags": [
            "environment-variables",
            "key",
            "command-line-arguments",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1578682044,
                "creation_date": 1578682044,
                "answer_id": 59687394,
                "question_id": 59686938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "## Environment variables\r\n\r\nIn your sub-expression:\r\n\r\n    {&quot;env.MSPID&quot;:.[1]}\r\n\r\nyou have quoted `env.MSPID` thereby making it a literal string.  Since you want to invoke the `env` function, you should instead write:\r\n\r\n    { (env.MSPID):.[1]}\r\n\r\nThe parentheses are needed to ensure that jq will evaluate the parenthesized expression properly.\r\n\r\n##  {$MSP:.[1]}\r\n\r\nAs noted above, when an expression must be evaluated to determine the string-value of a key, the expression must be parenthesized, e.g.\r\n\r\n     {($MSP):.[1]}\r\n\r\n\r\n",
                "title": "Cannot use/pass shell variables using jq on command line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1578682104,
        "creation_date": 1578679865,
        "last_edit_date": 1578682104,
        "question_id": 59686938,
        "body_markdown": "I am fairly new to jq and I am using this tutorial to add a new Org to a hyperledger fabric network.\r\n\r\nThere is extensive use of jq throughout the tutorial, especially modifying json files.\r\n\r\nThe tutorial uses an example Org name but I am trying to make the org name dynamic. Everything works out well except when I try to pass variables to jq.\r\n\r\nHere are the jq commands and their outputs.\r\n\r\njq version: 1.5.1\r\n\r\n$ export MSPID=Org4MSP\r\n$ echo $MSPID\r\nOrg4MSP\r\n\r\nTrying to pass the variable using env.\r\n\r\nKeyword: env.MSPID\r\n\r\n$ jq -s &#39;.[0] * {&quot;channel_group&quot;:{&quot;groups&quot;:{&quot;Application&quot;:{&quot;groups&quot;: {&quot;env.MSPID&quot;:.[1]}}}}}&#39; config.json org4.json\r\n\r\n_Output snippet: Instead of printing Org4MSP, it prints the literal string env.MSPID_\r\n\r\n          &quot;env.MSPID&quot;: {\r\n            &quot;groups&quot;: {},\r\n            &quot;mod_policy&quot;: &quot;Admins&quot;,\r\n            &quot;policies&quot;: {\r\n              &quot;Admins&quot;: {\r\n                &quot;mod_policy&quot;: &quot;Admins&quot;,\r\n                &quot;policy&quot;: {\r\n                  &quot;type&quot;: 1,\r\n                  &quot;value&quot;: {\r\n                    &quot;identities&quot;: [\r\n                      {\r\n \r\nTrying to pass the variable using --arg option\r\n\r\nKeyword: &quot;$MSP&quot;\r\n\r\n\r\njq --arg MSP &quot;$MSPID&quot; -s &#39;.[0] * {&quot;channel_group&quot;:{&quot;groups&quot;:{&quot;Application&quot;:{&quot;groups&quot;: {&quot;$MSP&quot;:.[1]}}}}}&#39; config.json org4.json\r\n\r\n_Output snippet: Instead of printing Org4MSP, it prints the literal string $MSP_\r\n\r\n          &quot;$MSP&quot;: {\r\n            &quot;groups&quot;: {},\r\n            &quot;mod_policy&quot;: &quot;Admins&quot;,\r\n            &quot;policies&quot;: {\r\n              &quot;Admins&quot;: {\r\n                &quot;mod_policy&quot;: &quot;Admins&quot;,\r\n                &quot;policy&quot;: {\r\n                  &quot;type&quot;: 1,\r\n                  &quot;value&quot;: {\r\n                    &quot;identities&quot;: [\r\n                      {\r\n\r\nTrying to pass a variable using --arg option and without using double quotes:\r\n\r\nkeyword: $MSP\r\n\r\n$ jq --arg MSP &quot;$MSPID&quot; -s &#39;.[0] * {&quot;channel_group&quot;:{&quot;groups&quot;:{&quot;Application&quot;:{&quot;groups&quot;: {$MSP:.[1]}}}}}&#39; config.json org4.json\r\n\r\njq: error: syntax error, unexpected &#39;:&#39;, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\n.[0] * {&quot;channel_group&quot;:{&quot;groups&quot;:{&quot;Application&quot;:{&quot;groups&quot;: {$MSP:.[1]}}}}}                                                                \r\n\r\njq: 1 compile error\r\n\r\nTrying to pass variable using env. and without double quotes:\r\n\r\nkeyword: env.MSPID\r\n\r\n$ jq -s &#39;.[0] * {&quot;channel_group&quot;:{&quot;groups&quot;:{&quot;Application&quot;:{&quot;groups&quot;: {env.MSPID:.[1]}}}}}&#39; config.json org4.json\r\n\r\njq: error: syntax error, unexpected FIELD, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n\r\n.[0] * {&quot;channel_group&quot;:{&quot;groups&quot;:{&quot;Application&quot;:{&quot;groups&quot;: {env.MSPID:.[1]}}}}}                                                               \r\n\r\njq: 1 compile error\r\n\r\nI apologize if this seems to be a trivial question but I have searched online and in docs and do not understand why the JSON key will not convert to the shell variable&#39;s value.\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/59686938/cannot-use-pass-shell-variables-using-jq-on-command-line",
        "title": "Cannot use/pass shell variables using jq on command line"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1578888751,
                "last_edit_date": 1578888751,
                "creation_date": 1578795479,
                "answer_id": 59700418,
                "question_id": 59700329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Read it as a stream.\r\n\r\n    $ jq --stream -r &#39;select(.[1]|scalars!=null) | &quot;\\(.[0]|join(&quot;.&quot;)): \\(.[1]|tojson)&quot;&#39; short.json",
                "title": "How to print path and key values of JSON file using JQ"
            },
            {
                "up_vote_count": 9,
                "is_accepted": false,
                "score": 9,
                "last_activity_date": 1578846581,
                "last_edit_date": 1578846581,
                "creation_date": 1578805809,
                "answer_id": 59701104,
                "question_id": 59700329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A simple jq query to achieve the requested format:\r\n\r\n     paths(scalars) as $p\r\n     | $p + [getpath($p)] \r\n     | join(&quot;,&quot;)\r\n\r\nIf your jq is ancient and you cannot upgrade, insert `| map(tostring)` before the last line above.\r\n\r\n## Output with the -r option\r\n```\r\nReservations,0,Instances,0,ImageId,ami-a\r\nReservations,0,Instances,0,InstanceId,i-a\r\nReservations,0,Instances,0,InstanceType,t2.micro\r\nReservations,0,Instances,0,KeyName,ubuntu\r\n```\r\n\r\n## Caveat\r\nIf a key or atomic value contains &quot;,&quot; then of course using a comma may be inadvisable.  For this reason, it might be preferable to use a character such as TAB that cannot appear in a JSON key or atomic value.  Consider therefore using `@tsv`:\r\n\r\n    paths(scalars) as $p\r\n    | $p + [getpath($p)]\r\n    | @tsv\r\n\r\n(The comment above about ancient versions of jq applies here too.)",
                "title": "How to print path and key values of JSON file using JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1666767359,
                "creation_date": 1666767359,
                "answer_id": 74203742,
                "question_id": 59700329,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use -c paths as follows:\r\n\r\n    cat short.json | jq -c paths | tr -d &#39;[&#39; | tr -d &#39;]&#39;\r\n\r\nI am using **jq-1.5-1-a5b5cbe**",
                "title": "How to print path and key values of JSON file using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1666767359,
        "creation_date": 1578793989,
        "last_edit_date": 1578809001,
        "question_id": 59700329,
        "body_markdown": "I would like to print each path and value of a [tag:JSON] file with included key values line by line. I would like the output to be comma delimited or at least very easy to cut and sort using Linux command line tools. Given the following [tag:JSON] and [tag:JQ], I have been given [tag:JQ] code which seems to do this for the test JSON, but I am not sure it works in all cases or is the proper approach.   \r\n\r\nIs there a function in [tag:JQ] which does this automatically? If not, is there a &quot;most concise best way&quot; to do it?\r\n\r\nMy wish would be something like:\r\n\r\n```\r\n$ cat short.json | jq -doit &#39;.&#39;\r\nReservations,0,Instances,0,ImageId,ami-a\r\nReservations,0,Instances,0,InstanceId,i-a\r\nReservations,0,Instances,0,InstanceType,t2.micro\r\nReservations,0,Instances,0,KeyName,ubuntu\r\n\r\n\r\n```\r\nTest JSON:    \r\n```\r\n$ cat short.json | jq &#39;.&#39;\r\n{\r\n  &quot;Reservations&quot;: [\r\n    {\r\n      &quot;Groups&quot;: [],\r\n      &quot;Instances&quot;: [\r\n        {\r\n          &quot;ImageId&quot;: &quot;ami-a&quot;,\r\n          &quot;InstanceId&quot;: &quot;i-a&quot;,\r\n          &quot;InstanceType&quot;: &quot;t2.micro&quot;,\r\n          &quot;KeyName&quot;: &quot;ubuntu&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}  \r\n```\r\n\r\nCode Recommended:  \r\nhttps://unix.stackexchange.com/questions/561460/how-to-print-path-and-key-values-of-json-file  \r\nSupporting:  \r\nhttps://unix.stackexchange.com/questions/515573/convert-json-file-to-a-key-path-with-the-resulting-value-at-the-end-of-each-k    \r\nJQ Code Too long and complicated!    \r\n\r\n``` \r\njq -r &#39;\r\npaths(scalars) as $p\r\n  | [ ( [ $p[] | tostring ] | join(&quot;.&quot;) )\r\n    , ( getpath($p) | tojson )\r\n    ]\r\n  | join(&quot;: &quot;)\r\n&#39; short.json  \r\n\r\nResult:  \r\nReservations.0.Instances.0.ImageId: &quot;ami-a&quot;\r\nReservations.0.Instances.0.InstanceId: &quot;i-a&quot;\r\nReservations.0.Instances.0.InstanceType: &quot;t2.micro&quot;\r\nReservations.0.Instances.0.KeyName: &quot;ubuntu&quot;  \r\n\r\n  \r\n```\r\n",
        "link": "https://stackoverflow.com/questions/59700329/how-to-print-path-and-key-values-of-json-file-using-jq",
        "title": "How to print path and key values of JSON file using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq",
            "directory-structure",
            "pathname"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14881806,
                    "reputation": 16277,
                    "user_id": 10746224,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/znUL5.jpg?s=256",
                    "display_name": "Lord Elrond",
                    "link": "https://stackoverflow.com/users/10746224/lord-elrond"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1578892659,
                "post_id": 59710786,
                "comment_id": 105573426,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1578894691,
                "creation_date": 1578894691,
                "answer_id": 59711167,
                "question_id": 59710786,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following assumes:\r\n\r\n*  the input is a valid JSON array of &quot;/&quot;-style pathnames of files;\r\n*  pathnames are all absolute (i.e., begin with &quot;/&quot;).\r\n\r\n```\r\nreduce .[] as $entry ({};\r\n  ($entry | split(&quot;/&quot;) ) as $names\r\n   | $names[1:-1] as $p\r\n   | setpath($p; getpath($p) + [$names[-1]]) )\r\n```\r\n\r\n## Example\r\n### Input\r\n```\r\n[\r\n    &quot;/parent/child1/grandchild1&quot;,\r\n    &quot;/parent/child1/grandchild2&quot;,\r\n    &quot;/parent/child2/grandchild3&quot;,\r\n    &quot;/parent/child2/grandchild4&quot;,\r\n    &quot;/parent2/child2/grandchild5&quot;\r\n]\r\n```\r\n\r\n### Output\r\n```\r\n{\r\n  &quot;parent&quot;: {\r\n    &quot;child1&quot;: [\r\n      &quot;grandchild1&quot;,\r\n      &quot;grandchild2&quot;\r\n    ],\r\n    &quot;child2&quot;: [\r\n      &quot;grandchild3&quot;,\r\n      &quot;grandchild4&quot;\r\n    ]\r\n  },\r\n  &quot;parent2&quot;: {\r\n    &quot;child2&quot;: [\r\n      &quot;grandchild5&quot;\r\n    ]\r\n  }\r\n}\r\n```",
                "title": "Convert file paths into JSON structure using bash / jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1578897975,
        "creation_date": 1578891540,
        "last_edit_date": 1578897975,
        "question_id": 59710786,
        "body_markdown": "Can we convert the below example using jq for bash (https://stedolan.github.io/jq/)?\r\n\r\nThe requirement is to convert the file paths into json as given in the below example\r\n\r\n```\r\nconst data = [\r\n    &quot;/parent/child1/grandchild1&quot;\r\n    &quot;/parent/child1/grandchild2&quot;\r\n    &quot;/parent/child2/grandchild1&quot;\r\n];\r\n\r\nconst output = {};\r\nlet current;\r\n\r\nfor (const path of data) {\r\n    current = output;\r\n\r\n    for (const segment of path.split(&#39;/&#39;)) {\r\n        if (segment !== &#39;&#39;) {\r\n            if (!(segment in current)) {\r\n                current[segment] = {};\r\n            }\r\n\r\n            current = current[segment];\r\n        }\r\n    }\r\n}\r\n\r\nconsole.log(output);\r\n```",
        "link": "https://stackoverflow.com/questions/59710786/convert-file-paths-into-json-structure-using-bash-jq",
        "title": "Convert file paths into JSON structure using bash / jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1578940410,
                "creation_date": 1578940410,
                "answer_id": 59722261,
                "question_id": 59717547,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`type` is your friend:\r\n\r\n    if type == &quot;array&quot; then .[] else . end\r\n    | [.name, .surname]\r\n    | @csv&#39;",
                "title": "jq: detect if input is a list or a dict"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1578940410,
        "creation_date": 1578921856,
        "question_id": 59717547,
        "body_markdown": "I need the similar CSV output for both single dict and list of dicts.\r\n\r\nBut I can&#39;t understand, how to make it with `jq`.\r\n\r\nCase 1: input is a **dict**:\r\n```shell\r\n$ curl --silent &#39;https://uinames.com/api/?amount=1&#39; \r\n{&quot;name&quot;:&quot;Daniel&quot;,&quot;surname&quot;:&quot;Gligor&quot;,&quot;gender&quot;:&quot;male&quot;,&quot;region&quot;:&quot;Romania&quot;}\r\n\r\n```\r\nand my corresponding `jq` expression:\r\n```shell\r\n$ curl --silent &#39;https://uinames.com/api/?amount=1&#39; |\r\n  jq -r &#39;[.name, .surname] | @csv&#39;\r\n&quot;Angel&quot;,&quot;S&#238;rghie&quot;\r\n```\r\n\r\nCase 2: input is a **list of dicts**:\r\n```shell\r\n$ curl --silent &#39;https://uinames.com/api/?amount=2&#39; \r\n[{&quot;name&quot;:&quot;Summer&quot;,&quot;surname&quot;:&quot;Lee&quot;,&quot;gender&quot;:&quot;female&quot;,&quot;region&quot;:&quot;Canada&quot;},{&quot;name&quot;:&quot;J&#250;lius&quot;,&quot;surname&quot;:&quot;Dzurjanin&quot;,&quot;gender&quot;:&quot;male&quot;,&quot;region&quot;:&quot;Slovakia&quot;}]\r\n```\r\n\r\nMy expression:\r\n```shell\r\n$ curl --silent &#39;https://uinames.com/api/?amount=2&#39; |\r\n&gt; jq -r &#39;.[] | [.name, .surname] | @csv&#39;\r\n&quot;Francisca&quot;,&quot;Navarro&quot;\r\n&quot;Larisa&quot;,&quot;Dănescu&quot;\r\n```\r\n\r\nI tried a lot of variants with `if/else`, `select()`, `path()`, `//`, etc.. Unfortunately, I can&#39;t create working expresion. \r\n",
        "link": "https://stackoverflow.com/questions/59717547/jq-detect-if-input-is-a-list-or-a-dict",
        "title": "jq: detect if input is a list or a dict"
    },
    {
        "tags": [
            "json",
            "bash",
            "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": 1578931299,
                "post_id": 59717714,
                "comment_id": 105590520,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1578931882,
                "creation_date": 1578931882,
                "answer_id": 59720191,
                "question_id": 59717714,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This requires `jq` 1.6 in order to use the `--args` option.\r\n\r\n\r\n    $ jq --arg wd &quot;$(basename &quot;$PWD&quot;)&quot; &#39;.docs+={($wd): $ARGS.positional | map(&quot;\\($wd)/\\(.)&quot;)}&#39; ../RandomFile.json --args *\r\n    {\r\n      &quot;docs&quot;: {\r\n        &quot;Doc&quot;: [\r\n          &quot;doc1&quot;\r\n        ],\r\n        &quot;Readme&quot;: [\r\n          &quot;Readme/Readme.md&quot;,\r\n          &quot;Readme/Readyou.md&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\n1. The shell is used to pass the base name of the current working directory as the variable `$wd`.\r\n2. The shell is also used to pass the names of all the files in the current working directory as separate arguments.\r\n3. The file to edit is assumed to be `../RandomFile.json`; if you only know that there is *a* JSON file in the parent, you can use `../*.json` instead.\r\n4. Use `+=` to update the `.docs` object of the original with a new key (the working directory) and list of file names. `map` prefixes each element of `$ARGS.positional` with `$wd`.",
                "title": "Append new element to JSON object in specific format using bash and jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1578931882,
        "creation_date": 1578922481,
        "question_id": 59717714,
        "body_markdown": "I would like to append an element to an existing JSON file where I have the working directory as the key and the working directory + the contents as the value in a string array format.\r\n\r\nLets say I have the following structure:\r\n\r\n```\r\n Docs (Directory)\r\n |\r\n +-- RandomFile.json\r\n |    \r\n +-- Readme (Working Directory)\r\n |  |  \r\n |  +-- Readme.md\r\n |  +-- Readyou.md\r\n\r\n```\r\nWhat I would like to achieve is the structure below with the working directory as the prefix for every element in the array.\r\n\r\n```\r\n&quot;Readme&quot;: [&quot;Readme/Readme.md&quot;, &quot;Readme/Readyou.md&quot;]\r\n```\r\nFrom the output above, I would like to append that to the contents of the **RandomFile.json** which currently looks like this:\r\n\r\n```\r\n{\r\n  &quot;docs&quot;: {\r\n    &quot;Doc&quot;: [&quot;doc1&quot;]\r\n  }\r\n}\r\n```\r\n\r\nto this:\r\n\r\n```\r\n{\r\n  &quot;docs&quot;: {\r\n    &quot;Doc&quot;: [&quot;doc1&quot;],\r\n    &quot;Readme&quot;: [&quot;Readme/Readme.md&quot;, &quot;Readme/Readyou.md&quot;]\r\n  }\r\n}\r\n```\r\n\r\nIs it something that can be managed straightforward using bash and jq?\r\n",
        "link": "https://stackoverflow.com/questions/59717714/append-new-element-to-json-object-in-specific-format-using-bash-and-jq",
        "title": "Append new element to JSON object in specific format using bash and jq"
    },
    {
        "tags": [
            "bash",
            "select",
            "filter",
            "arguments",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1578939995,
                "creation_date": 1578939995,
                "answer_id": 59722142,
                "question_id": 59720680,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In the first example, `[$app]` is wrong: this expression produces an array. The jq program should be:\r\n\r\n    select(.app == $app).version\r\n\r\n",
                "title": "JQ select and passing arguments"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1578939995,
        "creation_date": 1578933716,
        "last_edit_date": 1578934300,
        "question_id": 59720680,
        "body_markdown": "I am trying to passing variables to JQ but the following code is not working as expected:\r\n\r\n    echo &#39;{\r\n       &quot;app&quot;: &quot;K8s&quot;,\r\n       &quot;version&quot;: &quot;1.8&quot;,\r\n       &quot;date&quot;: &quot;2018-10-10&quot;\r\n    }&#39; | jq --arg app &#39;K8s&#39; -c &#39;select(.app == [$app]).version&#39;\r\n\r\nHowever, following example works:\r\n\r\n    echo &#39;{\r\n       &quot;app&quot;: &quot;K8s&quot;,\r\n       &quot;version&quot;: &quot;1.8&quot;,\r\n       &quot;date&quot;: &quot;2018-10-10&quot;\r\n    }&#39; | jq -r --arg app app &#39;select(.[$app] == &quot;K8s&quot;).version&#39;\r\n\r\nwhy the first example is not working?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/59720680/jq-select-and-passing-arguments",
        "title": "JQ select and passing arguments"
    },
    {
        "tags": [
            "json",
            "transform",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1578960615,
                "creation_date": 1578960615,
                "answer_id": 59725917,
                "question_id": 59725789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One of many possibilities:\r\n```\r\n.[]\r\n| {transactions: \r\n    [(.transactiondatajson|fromjson)\r\n     + {rawData: (.rawtransactiondata|fromjson)} ] }\r\n```   ",
                "title": "Using jq to extract multiple fields and create a new object"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1578961582,
        "creation_date": 1578959399,
        "last_edit_date": 1578961582,
        "question_id": 59725789,
        "body_markdown": "I have this particular json object,\r\n\r\n    [\r\n        {\r\n            &quot;userid&quot; : &quot;fe2e48b7-858b-4a0d-964a-efb8483a00c4&quot;,\r\n            &quot;lastupdateddate&quot; : &quot;84798000-13cd-11ea-8080-808080808080&quot;,\r\n            &quot;transactionid&quot; : &quot;10383117.2216238756&quot;,\r\n            &quot;accountid&quot; : &quot;10383117.10921962&quot;,\r\n            &quot;misctransactiondata&quot; : null,\r\n            &quot;rawtransactiondata&quot; : &quot;{\\&quot;id\\&quot;:\\&quot;1234567\\&quot;,\\&quot;account_id\\&quot;:\\&quot;456451962\\&quot;}&quot;,\r\n            &quot;source&quot; : &quot;gateway&quot;,\r\n            &quot;transactiondatajson&quot; : &quot;{\\&quot;version\\&quot;:\\&quot;v1\\&quot;,\\&quot;transactionId\\&quot;:\\&quot;4234234.2216238756\\&quot;,\\&quot;accountId\\&quot;:\\&quot;345345345.10921962\\&quot;}&quot;,\r\n            &quot;version&quot; : &quot;v1&quot;\r\n        }\r\n    ]\r\n\r\nwhich I&#39;d like to transform into,\r\n\r\n    {\r\n        &quot;transactions&quot;: [\r\n            {\r\n                &quot;version&quot;: &quot;v1&quot;,\r\n                &quot;transactionId&quot;: &quot;4234234.2216238756&quot;,\r\n                &quot;accountId&quot;: &quot;345345345.10921962&quot;,\r\n                &quot;rawData&quot;: {\r\n                    &quot;id&quot;: &quot;1234567&quot;,\r\n                    &quot;account_id&quot;: &quot;456451962&quot;\r\n                }\r\n            }\r\n        ]\r\n    }\r\n\r\nCurrently I have,\r\n\r\n    jq &#39;{transactions: [.[0] | (.transactiondatajson|fromjson) ]}&#39;\r\n\r\nwhich creates the transactions array of objects however I&#39;m not entirely sure how to create the `rawData` nested object from `.rawtransactiondata`\r\n\r\nHow to best append the object with `jq` ?",
        "link": "https://stackoverflow.com/questions/59725789/using-jq-to-extract-multiple-fields-and-create-a-new-object",
        "title": "Using jq to extract multiple fields and create a new object"
    },
    {
        "tags": [
            "scope",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1579037486,
                "last_edit_date": 1579037486,
                "creation_date": 1579022878,
                "answer_id": 59738907,
                "question_id": 59738722,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It actually is possible to make an &quot;as&quot; variable visible inside a function without passing it in as a parameter (see &quot;Lexical Scoping&quot; below), but it is usually unnecessary, and in fact using &quot;as&quot; variables is often unnecessary as well.\r\n\r\n## Avoiding the &quot;as&quot; variable\r\nYou can simplify your original query to: \r\n\r\n    .myArray[.myFlags[]]\r\n\r\n## Using function arguments\r\nYou can write jq functions with one or more arguments.  This is the appropriate way to parameterize filters.\r\n\r\nThe syntax is quite conventional except that for functions with more than one argument, the semicolon (&quot;;&quot;) is used as the argument separator, both in the function definitions and invocations.\r\n\r\nNote also that jq function arguments can themselves be filters, e.g. you could write:\r\n\r\n```\r\ndef myFun(array; $ix): array | .[$ix];\r\n\r\nmyFun(.myArray; .myFlags[])\r\n```\r\n\r\n## Lexical scoping\r\n\r\nHere&#39;s an example showing how an &#39;as&#39; variable can be made visible inside a function:\r\n```\r\n[1,2] as $array | def myFun: $array[1]; myFun\r\n```\r\n\r\n",
                "title": "How can the scope of jq &#39;as&#39; variables be extended to pass down inside functions?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1579037486,
        "creation_date": 1579022148,
        "question_id": 59738722,
        "body_markdown": "With jq, I&#39;m trying to use entries in one array to index into a separate array. A simple JSON input would look like this:\r\n```\r\n{\r\n    &quot;myArray&quot;: [ &quot;AA&quot;, &quot;BB&quot;, &quot;CC&quot;, &quot;DD&quot;, &quot;EE&quot; ],\r\n\t&quot;myFlags&quot;: [ 4, 3, 2, 1, 0 ]\r\n}\r\n```\r\njq&#39;s nifty &#39;as&#39; operator is then able to bring the myArray array into scope and the indexing works fine:\r\n```\r\n.myArray as $Array | .myFlags | .[] | $Array[.]   ====&gt; yields &quot;EE&quot;,&quot;DD&quot;,&quot;CC&quot;,&quot;BB&quot;,&quot;AA&quot;\r\n```\r\n\r\nSo far so jq-manual. **However**, if I try and move the $Array array access down into a function, the as-variable scope disappears:\r\n```\r\ndef myFun: $Array[.]; .myArray as $Array | .myFlags | .[] | myFun\r\n\r\njq: error: $Array is not defined at &lt;top-level&gt;, line 1:\r\ndef myFun: $Array[.]; .myArray as $Array | .myFlags | .[] | myFun   \r\n```\r\nTo get around this, I currently pass down a temporary JSON object containing both the index and the array:\r\n```\r\ndef myFun: .a[.b]; .myArray as $Array | .myFlags | .[] | { a: $Array, b: . } | myFun\r\n```\r\nThough this works, I have to say I&#39;m not hugely comfortable with it.\r\n\r\nReally, this doesn&#39;t feel to me as though this is proper jq language behaviour. It seems to me that the &#39;as&#39;-scope ought to persist down into invoked def-functions. :-(\r\n\r\nIs there a better way of extending as-scope down into def-functions? Am I missing some jq subtlety?",
        "link": "https://stackoverflow.com/questions/59738722/how-can-the-scope-of-jq-as-variables-be-extended-to-pass-down-inside-functions",
        "title": "How can the scope of jq &#39;as&#39; variables be extended to pass down inside functions?"
    },
    {
        "tags": [
            "json",
            "bash",
            "unix",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1579043536,
                "last_edit_date": 1579043536,
                "creation_date": 1579040203,
                "answer_id": 59742557,
                "question_id": 59742247,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There are several problems with your attempt.  \r\n\r\nFirst, the keys with &quot;$&quot; in their names cannot be specified using the abbreviated `.foo` syntax; you could use `.[&quot;$foo&quot;]` instead.\r\n\r\nSecond, `@csv` expects an array of atomic values. Thus the keys with JSON objects as values must be handled specially.\r\n\r\nThird, the &quot;+&quot; is incorrect. The relevant connector here is &quot;,&quot;.\r\n \r\nWith your sample JSON, the following will work:\r\n```\r\n([&quot;user_id&quot;,&quot;server_received_time&quot;,&quot;app&quot;,&quot;device_carrier&quot;,&quot;$schema&quot;,&quot;city&quot;,&quot;uuid&quot;,&quot;event_time&quot;,&quot;platform&quot;,&quot;os_version&quot;,&quot;amplitude_id&quot;,&quot;processed_time&quot;,&quot;user_creation_time&quot;,&quot;version_name&quot;,&quot;ip_address&quot;,&quot;paying&quot;,&quot;dma&quot;,&quot;group_properties&quot;,&quot;user_properties&quot;,&quot;client_upload_time&quot;,&quot;$insert_id&quot;,&quot;event_type&quot;,&quot;library&quot;,&quot;amplitude_attribution_ids&quot;,&quot;device_type&quot;,&quot;device_manufacturer&quot;,&quot;start_version&quot;,&quot;location_lng&quot;,&quot;server_upload_time&quot;,&quot;event_id&quot;,&quot;location_lat&quot;,&quot;os_name&quot;,&quot;amplitude_event_type&quot;,&quot;device_brand&quot;,&quot;groups&quot;,&quot;event_properties&quot;,&quot;data&quot;,&quot;device_id&quot;,&quot;language&quot;,&quot;device_model&quot;,&quot;country&quot;,&quot;region&quot;,&quot;is_attribution_event&quot;,&quot;adid&quot;,&quot;session_id&quot;,&quot;device_family&quot;,&quot;sample_rate&quot;,&quot;idfa&quot;,&quot;client_event_time&quot;]),\r\n\r\n([.user_id,.server_received_time,.app,.device_carrier,.[&quot;$schema&quot;],.city,.uuid,.event_time,.platform,.os_version,.amplitude_id,.processed_time,.user_creation_time,.version_name,.ip_address,.paying,.dma,.group_properties,.user_properties,.client_upload_time,.[&quot;$insert_id&quot;],.event_type,.library,.amplitude_attribution_ids,.device_type,.device_manufacturer,.start_version,.location_lng,.server_upload_time,.event_id,.location_lat,.os_name,.amplitude_event_type,.device_brand,.groups,.event_properties,.data,.device_id,.language,.device_model,.country,.region,.is_attribution_event,.adid,.session_id,.device_family,.sample_rate,.idfa,.client_event_time]\r\n | map(if type==&quot;object&quot;\r\n       then to_entries\r\n       | map( &quot;\\(.key):\\(.value)&quot; )\r\n       | join(&quot;;&quot;)\r\n\t   else . end))\r\n| @csv\r\n```\r\n\r\n## A less error-prone solution\r\n\r\nSpecifying the long list of keys twice makes the above solution error-prone.  It would be better to specify the keys just once, and then programatically generate the rows.\r\n\r\nHere&#39;s a utility function that can be used to this end:\r\n\r\n    def toa($headers):\r\n      . as $in | $headers | map($in[.]);\r\n\r\n\r\nOr you could handle the object-valued keys inside `toa`:\r\n\r\n    def toa($headers):\r\n      def flat: \r\n         if type == &quot;object&quot; or type == &quot;array&quot;\r\n         then to_entries | map( &quot;\\(.key):\\(.value)&quot; ) | join(&quot;;&quot;) \r\n         else .\r\n         end;\r\n      . as $in | $headers | map($in[.] | flat);\r\n\r\n## JSONL\r\nIf the input is a stream of JSON objects of the type illustrated in the question, an efficient solution would use `inputs` with the -n command line option.  This could be along the lines of:\r\n\r\n```\r\nprint_header,\r\n(inputs | print_row)\r\n```\r\n",
                "title": "JSON will not convert with jq in Unix"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1579043536,
        "creation_date": 1579038469,
        "question_id": 59742247,
        "body_markdown": "Having difficulties converting this JSON. It is multi-line similar to what is below. The example data at the bottom is what is reads as-is once unzipped.\r\n\r\nAn example of what has been tried:\r\n```\r\njq -r &#39;(([[&quot;user_id&quot;,&quot;server_received_time&quot;,&quot;app&quot;,&quot;device_carrier&quot;,&quot;$schema&quot;,&quot;city&quot;,&quot;uuid&quot;,&quot;event_time&quot;,&quot;platform&quot;,&quot;os_version&quot;,&quot;amplitude_id&quot;,&quot;processed_time&quot;,&quot;user_creation_time&quot;,&quot;version_name&quot;,&quot;ip_address&quot;,&quot;paying&quot;,&quot;dma&quot;,&quot;group_properties&quot;,&quot;user_properties&quot;,&quot;client_upload_time&quot;,&quot;$insert_id&quot;,&quot;event_type&quot;,&quot;library&quot;,&quot;amplitude_attribution_ids&quot;,&quot;device_type&quot;,&quot;device_manufacturer&quot;,&quot;start_version&quot;,&quot;location_lng&quot;,&quot;server_upload_time&quot;,&quot;event_id&quot;,&quot;location_lat&quot;,&quot;os_name&quot;,&quot;amplitude_event_type&quot;,&quot;device_brand&quot;,&quot;groups&quot;,&quot;event_properties&quot;,&quot;data&quot;,&quot;device_id&quot;,&quot;language&quot;,&quot;device_model&quot;,&quot;country&quot;,&quot;region&quot;,&quot;is_attribution_event&quot;,&quot;adid&quot;,&quot;session_id&quot;,&quot;device_family&quot;,&quot;sample_rate&quot;,&quot;idfa&quot;,&quot;client_event_time&quot;]]) + [(.table.All[] | [.user_id,.server_received_time,.app,.device_carrier,.$schema,.city,.uuid,.event_time,.platform,.os_version,.amplitude_id,.processed_time,.user_creation_time,.version_name,.ip_address,.paying,.dma,.group_properties,.user_properties,.client_upload_time,.$insert_id,.event_type,.library,.amplitude_attribution_ids,.device_type,.device_manufacturer,.start_version,.location_lng,.server_upload_time,.event_id,.location_lat,.os_name,.amplitude_event_type,.device_brand,.groups,.event_properties,.data,.device_id,.language,.device_model,.country,.region,.is_attribution_event,.adid,.session_id,.device_family,.sample_rate,.idfa,.client_event_time])])[]|@csv&#39; test.json &gt; test.csv\r\n```\r\n\r\nAs well as some other jq options. I need every column regardless of the value, and the values as-is. Does anyone have thoughts on why we are running into issues? One error we get is:\r\n```\r\njq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n```\r\nOther jq lines have given the following error:\r\n```\r\nstring (...) cannot be csv-formatted, only array\r\n```\r\n\r\nThis is an excerpt from one of the JSON files:\r\n```{&quot;groups&quot;:{},&quot;country&quot;:&quot;United States&quot;,&quot;device_id&quot;:&quot;7f2d-8ac-45-86-edeR&quot;,&quot;is_attribution_event&quot;:false,&quot;server_received_time&quot;:&quot;2019-12-17 17:29:11.113000&quot;,&quot;language&quot;:&quot;English&quot;,&quot;event_time&quot;:&quot;2019-12-17 17:27:44.775000&quot;,&quot;user_creation_time&quot;:&quot;2019-11-08 13:15:32.919000&quot;,&quot;city&quot;:&quot;Sure&quot;,&quot;uuid&quot;:&quot;someID&quot;,&quot;device_model&quot;:&quot;Windows&quot;,&quot;amplitude_event_type&quot;:null,&quot;client_upload_time&quot;:&quot;2019-12-17 17:29:21.958000&quot;,&quot;data&quot;:{},&quot;library&quot;:&quot;amplitude-js\\/5.2.2&quot;,&quot;device_manufacturer&quot;:null,&quot;dma&quot;:&quot;Washington, DC (Townville, USA)&quot;,&quot;version_name&quot;:null,&quot;region&quot;:&quot;Virginia&quot;,&quot;group_properties&quot;:{},&quot;location_lng&quot;:null,&quot;device_family&quot;:&quot;Windows&quot;,&quot;paying&quot;:null,&quot;client_event_time&quot;:&quot;2019-12-17 17:27:55.620000&quot;,&quot;$schema&quot;:12,&quot;device_brand&quot;:null,&quot;user_id&quot;:&quot;email@gmail.com&quot;,&quot;event_properties&quot;:{&quot;title&quot;:&quot;Name&quot;,&quot;id&quot;:&quot;1-253251&quot;,&quot;applicationName&quot;:&quot;SomeName&quot;},&quot;os_version&quot;:&quot;18&quot;,&quot;device_carrier&quot;:null,&quot;server_upload_time&quot;:&quot;2019-12-17 17:29:11.135000&quot;,&quot;session_id&quot;:1576603675620,&quot;app&quot;:231165,&quot;amplitude_attribution_ids&quot;:null,&quot;event_type&quot;:&quot;CHANGE_PERSPECTIVE&quot;,&quot;user_properties&quot;:{},&quot;adid&quot;:null,&quot;device_type&quot;:&quot;Windows&quot;,&quot;$insert_id&quot;:&quot;126ba765-147f-403b-92c9-3537&quot;,&quot;event_id&quot;:23,&quot;amplitude_id&quot;:13414,&quot;processed_time&quot;:&quot;2019-12-17 17:29:12.760365&quot;,&quot;platform&quot;:&quot;Web&quot;,&quot;idfa&quot;:null,&quot;os_name&quot;:&quot;Edge&quot;,&quot;location_lat&quot;:null,&quot;ip_address&quot;:&quot;123.456.78.90&quot;,&quot;sample_rate&quot;:null,&quot;start_version&quot;:null}\r\n{&quot;groups&quot;:{},&quot;country&quot;:&quot;United States&quot;,&quot;device_id&quot;:&quot;3d-88c-45-b6-ed81277eR&quot;,&quot;is_attribution_event&quot;:false,&quot;server_received_time&quot;:&quot;2019-12-17 17:29:11.113000&quot;,&quot;language&quot;:&quot;English&quot;,&quot;event_time&quot;:&quot;2019-12-17 17:27:49.047000&quot;,&quot;user_creation_time&quot;:&quot;2019-11-08 13:15:32.919000&quot;,&quot;city&quot;:&quot;Sure&quot;,&quot;uuid&quot;:&quot;someID&quot;,&quot;device_model&quot;:&quot;Windows&quot;,&quot;amplitude_event_type&quot;:null,&quot;client_upload_time&quot;:&quot;2019-12-17 17:29:21.958000&quot;,&quot;data&quot;:{},&quot;library&quot;:&quot;amplitude-js\\/5.2.2&quot;,&quot;device_manufacturer&quot;:null,&quot;dma&quot;:&quot;Washington, DC (Townville, USA)&quot;,&quot;version_name&quot;:null,&quot;region&quot;:&quot;Virginia&quot;,&quot;group_properties&quot;:{},&quot;location_lng&quot;:null,&quot;device_family&quot;:&quot;Windows&quot;,&quot;paying&quot;:null,&quot;client_event_time&quot;:&quot;2019-12-17 17:27:59.892000&quot;,&quot;$schema&quot;:12,&quot;device_brand&quot;:null,&quot;user_id&quot;:&quot;email@gmail.com&quot;,&quot;event_properties&quot;:{&quot;title&quot;:&quot;Name&quot;,&quot;id&quot;:&quot;1-253251&quot;,&quot;applicationName&quot;:&quot;SomeName&quot;},&quot;os_version&quot;:&quot;18&quot;,&quot;device_carrier&quot;:null,&quot;server_upload_time&quot;:&quot;2019-12-17 17:29:11.135000&quot;,&quot;session_id&quot;:1576603675620,&quot;app&quot;:231165,&quot;amplitude_attribution_ids&quot;:null,&quot;event_type&quot;:&quot;CHANGE_PERSPECTIVE&quot;,&quot;user_properties&quot;:{},&quot;adid&quot;:null,&quot;device_type&quot;:&quot;Windows&quot;,&quot;$insert_id&quot;:&quot;e308c923-d8eb-48c6-8ea5-600&quot;,&quot;event_id&quot;:24,&quot;amplitude_id&quot;:515,&quot;processed_time&quot;:&quot;2019-12-17 17:29:12.760372&quot;,&quot;platform&quot;:&quot;Web&quot;,&quot;idfa&quot;:null,&quot;os_name&quot;:&quot;Edge&quot;,&quot;location_lat&quot;:null,&quot;ip_address&quot;:&quot;123.456.78.90&quot;,&quot;sample_rate&quot;:null,&quot;start_version&quot;:null}\r\n```\r\nThank you!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/59742247/json-will-not-convert-with-jq-in-unix",
        "title": "JSON will not convert with jq in Unix"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1579110626,
                "last_edit_date": 1579110626,
                "creation_date": 1579042107,
                "answer_id": 59742852,
                "question_id": 59742405,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The query that fails does so because the associativity is not what you want.  Adding parentheses to make your intentions clear is usually not a bad idea anyway:\r\n```\r\nif .foo == &quot;bar&quot; \r\n   and ([.bazes[] | .bat==&quot;blah&quot;] | any)\r\nthen .add = &quot;added&quot;\r\nelse . end   \r\n```\r\n### any/2\r\n\r\nYou could circumvent the issue, achieve a more efficient solution, and conform more closely to English usage by using `any/2`:\r\n```\r\nif .foo == &quot;bar&quot; \r\n   and any(.bazes[]; .bat==&quot;blah&quot;)\r\nthen .add = &quot;added&quot;\r\nelse . end  \r\n```",
                "title": "is there a better way to write a nested conditional in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1579110626,
        "creation_date": 1579039318,
        "question_id": 59742405,
        "body_markdown": "I tried to use the `if X and Y then A else B` in jq, but there is some hidden context going on which gives errors. It is as if the condition in X changes a context or state that Y and A then use, but if I nest the if statements I do not get that behavior.\r\n\r\nThis works:\r\n```\r\nif .foo == &quot;bar&quot; then \r\n  if  [.bazes[] | .bat==&quot;blah&quot;] | any then .add = &quot;added&quot; else . end \r\nelse . end \r\n```\r\n\r\nThis does not work:\r\n\r\n```\r\nif .foo == &quot;bar&quot; and [.bazes[] | .bat==&quot;blah&quot;] | any then \r\n   .add = &quot;added&quot;\r\nelse . end \r\n```",
        "link": "https://stackoverflow.com/questions/59742405/is-there-a-better-way-to-write-a-nested-conditional-in-jq",
        "title": "is there a better way to write a nested conditional in jq?"
    },
    {
        "tags": [
            "arrays",
            "string",
            "jq",
            "contains"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2345668,
                    "reputation": 13431,
                    "user_id": 2055998,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/2Vx3A.jpg?s=256",
                    "display_name": "PM 77-1",
                    "link": "https://stackoverflow.com/users/2055998/pm-77-1"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1579041080,
                "post_id": 59742685,
                "comment_id": 105633754,
                "content_license": "CC BY-SA 4.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"
                },
                "reply_to_user": {
                    "account_id": 2345668,
                    "reputation": 13431,
                    "user_id": 2055998,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/2Vx3A.jpg?s=256",
                    "display_name": "PM 77-1",
                    "link": "https://stackoverflow.com/users/2055998/pm-77-1"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579042141,
                "post_id": 59742685,
                "comment_id": 105634064,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1579042327,
                "creation_date": 1579042327,
                "answer_id": 59742897,
                "question_id": 59742685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, this is expected. From the documentation for `contains` (emphasis mine):\r\n\r\n&gt;An array B is contained in an array A if all elements in B\r\n       are contained in any **element in A**.\r\n\r\nSo it&#39;s not checking if `&quot;&quot;` is an element of `A`, but rather if `&quot;&quot;` is contained in one of the elements of `A`, and the empty string is a substring of every string.",
                "title": "In the jq utility, should contains([&quot;&quot;]) return true when the array being tested does not contain &quot;&quot;?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1579042546,
                "creation_date": 1579042546,
                "answer_id": 59742928,
                "question_id": 59742685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From the jq [docs][1]:\r\n\r\n&gt; A string B is contained in a string A if B is a substring of A. An array B is contained in an array A if all elements in B are contained in any element in A. \r\n\r\n`&quot;&quot;` is a substring of `&quot;a&quot;` (and `&quot;b&quot;` and `&quot;c&quot;`), so `&quot;a&quot;` contains `&quot;&quot;` and therefore `[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]` contains `[&quot;&quot;]`.\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
                "title": "In the jq utility, should contains([&quot;&quot;]) return true when the array being tested does not contain &quot;&quot;?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579043831,
                "creation_date": 1579043831,
                "answer_id": 59743143,
                "question_id": 59742685,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following does what I intend, which is to determine if the array contains the empty string as an element.\r\n```\r\n$ echo &#39;[&quot;a&quot;,&quot;&quot;,&quot;b&quot;]&#39; | jq &#39;any(.==&quot;&quot;)&#39;\r\ntrue\r\n$ echo &#39;[&quot;a&quot;,&quot;b&quot;]&#39; | jq &#39;any(.==&quot;&quot;)&#39;\r\nfalse\r\n$\r\n```\r\nThanks to those who responded.",
                "title": "In the jq utility, should contains([&quot;&quot;]) return true when the array being tested does not contain &quot;&quot;?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1579043831,
        "creation_date": 1579040993,
        "last_edit_date": 1579041878,
        "question_id": 59742685,
        "body_markdown": "I expect the last test to be false in the following.\r\n```\r\n$ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq &#39;contains([&quot;a&quot;])&#39;\r\ntrue\r\n$ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq &#39;contains([&quot;d&quot;])&#39;\r\nfalse\r\n$ echo &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;]&#39; | jq &#39;contains([&quot;&quot;])&#39;\r\ntrue\r\n$ jq --version\r\njq-1.6\r\n$\r\n```\r\nAm I missing something?",
        "link": "https://stackoverflow.com/questions/59742685/in-the-jq-utility-should-contains-return-true-when-the-array-being-tested",
        "title": "In the jq utility, should contains([&quot;&quot;]) return true when the array being tested does not contain &quot;&quot;?"
    },
    {
        "tags": [
            "linux",
            "sed",
            "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": 1579117523,
                "post_id": 59752862,
                "comment_id": 105662964,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579098182,
                "creation_date": 1579098182,
                "answer_id": 59753364,
                "question_id": 59752862,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can&#39;t match a json with a regex. The &quot;right way(TM)&quot; would be to first extract `Function` using a json aware tool like `jq`, then modify it with `sed`, then insert it back using json aware tool.\r\n\r\nSed by default uses [basic regex](https://www.regular-expressions.info/posix.html), so you need to change `(` `)` `+` into `\\(` `\\)` `\\{1,\\}` (the `\\+` is a GNU extension) or with GNU sed just use `sed -E` to use extended regex. Also the `\\\\1` would be interpreted as 2 characters `\\` with `1`, you want to use `\\1` with a single `\\`. But anyway, your regex is just invalid and does not match what you want (I guess). Also the `&quot;` are missing on the right side in the replacement string, so your command would just remove the `&quot;`. Just substitute what you need, try:\r\n\r\n    sed &#39;s/&quot;robot-support-dev-/&quot;robot-support-prod-/g;&#39;",
                "title": "Sed replace inside a json file with regex"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579099934,
                "creation_date": 1579099934,
                "answer_id": 59753898,
                "question_id": 59752862,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As @KamilCuk pointed out, there are some issues with the regex you are currently using. I think that if the occurrences you give as an example are the only possibilities, it would work if you match these groups:\r\n\r\n    sed -i &#39;s/&quot;robot-support\\(-\\|-.*-\\)dev-\\(.*\\)&quot;/&quot;robot-support\\1prod-\\2&quot;/g&#39;",
                "title": "Sed replace inside a json file with regex"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579117881,
                "last_edit_date": 1579117881,
                "creation_date": 1579102628,
                "answer_id": 59754768,
                "question_id": 59752862,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As pointed out elsewhere on this page, using `sed` for this type of problem is, at best, fraught with danger. Since the question has been tagged with [tag:jq], it should be pointed out that jq is an excellent match for this type of problem. In particular, a trivial solution can be obtained using the filter `sub` of arity 2 or 3, i.e. `sub/3`: sub(&quot;FROM&quot;; &quot;TO&quot;; &quot;g&quot;).\r\n\r\nYou might also wish to use `walk` so that you don&#39;t have to be concerned about where exactly the &quot;Function&quot; keys occur, e.g.\r\n\r\n```\r\nwalk( if type == &quot;object&quot; and (.Function|type) == &quot;string&quot;\r\n      then .Function |= sub( &quot;robot-support-(?&lt;a&gt;([^-]+-)?)dev-&quot;; &quot;robot-support-\\(.a)prod-&quot;; &quot;g&quot;)\r\n\t  else . end)\r\n",
                "title": "Sed replace inside a json file with regex"
            }
        ],
        "is_answered": false,
        "answer_count": 3,
        "score": -1,
        "last_activity_date": 1579117881,
        "creation_date": 1579096413,
        "last_edit_date": 1579097446,
        "question_id": 59752862,
        "body_markdown": "I have a huge json file, i will copy a part of it :\r\n\r\n    &quot;panels&quot;: [\r\n     &quot;targets&quot;: [\r\n    {\r\n      &quot;alias&quot;: &quot;First Prod&quot;,\r\n      &quot;dimensions&quot;: {\r\n        &quot;Function&quot;: &quot;robot-support-dev-create-human&quot;\r\n      },\r\n    }\r\n    {\r\n      &quot;alias&quot;: &quot;Second Prod&quot;,\r\n      &quot;dimensions&quot;: {\r\n        &quot;Function&quot;: &quot;robot-support-prototype-dev-beta-activate-human&quot;\r\n      },\r\n    }\r\n    {\r\n      &quot;alias&quot;: &quot;third Prod&quot;,\r\n      &quot;dimensions&quot;: {\r\n        &quot;Function&quot;: &quot;robot-support-dev-jira-kill-human&quot;\r\n      },\r\n    }  \r\n    {\r\n       &quot;alias&quot;: &quot;Somehting&quot;,\r\n \r\n\r\n     &quot;dimensions&quot;: {\r\n        &quot;Robotalias&quot;: &quot;default&quot;,\r\n        &quot;RobotName&quot;: &quot;Robot-prod-prototype&quot;,\r\n        &quot;Operation&quot;: &quot;Fight&quot;\r\n      },\r\n    ]\r\n    ]\r\n\r\nI want to perform a Regex on Function each time it contains the `robot-support-dev` to `robot-support-prod-...`\r\n\r\n\r\n    sed -i &#39; s/&quot;robot-support-([a-zA-Z0-9_]+)-dev-([^&quot;]+)&quot;/robot-support-\\\\1-prod-\\\\2/g;&#39;\r\n\r\nThis is what i did but there&#39;s something wrong with my regex maybe",
        "link": "https://stackoverflow.com/questions/59752862/sed-replace-inside-a-json-file-with-regex",
        "title": "Sed replace inside a json file with regex"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1579186493,
                "last_edit_date": 1579186493,
                "creation_date": 1579177955,
                "answer_id": 59769797,
                "question_id": 59768530,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` has a built-in variable  `input_filename` that represents the filename the filter is being applied on. So you can do something like\r\n\r\n    jq -n &#39;reduce inputs as $s (.; .[input_filename] += $s)&#39;  file1.json file2.json\r\n\r\nThe `reduce` expression takes the entire input objects and constructs the final JSON with the key as the filename being used.\r\n\r\nYou can go one level further and want to optionally remove the extension part of the JSON `.json`, use the trimming functions available. The below code assumes the input file is ending with `.json` and won’t work with any other extensions\n\n    jq -n &#39;reduce inputs as $s (.; (.[input_filename|rtrimstr(&quot;.json&quot;)]) += $s)&#39;",
                "title": "jq merge two json files and create a key as the filename for each in merged file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 5,
        "last_activity_date": 1579186493,
        "creation_date": 1579173474,
        "last_edit_date": 1579178814,
        "question_id": 59768530,
        "body_markdown": "**Question**: \r\n\r\nHow do you merge multiple JSON files using jq. Each of the merged objects must have their own key name in the final merged file.\r\n\r\n**file1.json** :\r\n\r\n    {\r\n      &quot;shoe&quot;: 0,\r\n      &quot;temp&quot;: &quot;10&quot;\r\n    }\r\n\r\n**file2.json**:\r\n\r\n    {\r\n      &quot;num&quot;: {\r\n        &quot;sock&quot;: 0,\r\n        &quot;ratio&quot;: {\r\n          &quot;cat&quot;: 100,\r\n          &quot;dog&quot;: 0\r\n        }\r\n      },\r\n      &quot;hair&quot;: &quot;blue&quot;\r\n    }\r\n\r\n**Desired merged output**:\r\n\r\n    {\r\n      &quot;file1&quot;: {\r\n        &quot;shoe&quot;: 0,\r\n        &quot;temp&quot;: &quot;10&quot;\r\n      },\r\n      &quot;file2&quot;: {\r\n        &quot;num&quot;: {\r\n          &quot;sock&quot;: 0,\r\n          &quot;ratio&quot;: {\r\n            &quot;cat&quot;: 100,\r\n            &quot;dog&quot;: 0\r\n          }\r\n        },\r\n        &quot;hair&quot;: &quot;blue&quot;\r\n      }\r\n    }\r\n\r\nAttempt 1:\r\nThe issue with the below is that the objects hierarchy is merged if that makes sense:\r\n\r\n    jq --slurp &#39;add&#39; file1.json file2.json\r\n\r\n**Attempt 1 Output (not what I want)**:\r\n\r\n    {\r\n      &quot;shoe&quot;: 0,\r\n      &quot;temp&quot;: &quot;10&quot;\r\n      &quot;num&quot;: {\r\n        &quot;sock&quot;: 0,\r\n        &quot;ratio&quot;: {\r\n          &quot;cat&quot;: 100,\r\n          &quot;dog&quot;: 0\r\n        }\r\n      },\r\n      &quot;hair&quot;: &quot;blue&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/59768530/jq-merge-two-json-files-and-create-a-key-as-the-filename-for-each-in-merged-file",
        "title": "jq merge two json files and create a key as the filename for each in merged file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1579193949,
                "last_edit_date": 1579193949,
                "creation_date": 1579193066,
                "answer_id": 59774283,
                "question_id": 59772878,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are not using the true features of `jq`. What you shown in a loop, iterating over all the JSON objects can be simply reduced to one `reduce()` construct that is sort of a `for` loop in `jq` given an initial value and runs the filter incrementally\r\n\r\n    jq &#39;reduce range(0, length) as $d (.; (.[$d].ver = ($d+1|tostring)) | (.[$d].date = &quot;2020-01-\\($d+1)&quot;)) &#39;\r\n\r\nA brief explanation of how it works\r\n\r\n 1. The range expression returns a list with numbers generated from 0 to upto the length of the objects in the array. For your given input it produces `0,1` which is assigned to `d`\r\n 2. The `reduce` expression given the input value `.` the whole JSON, runs by setting the values in each object indexed by `$d`. So `.[$d].ver` refers to the `ver` field in the zeroth index. This is done incrementally till all the objects are processed.\r\n 3. The same way the date field is modified using `[$d].date` with the value string prefixed (YYYY-MM-) and date is set accordingly.",
                "title": "Update values in json (array elements) using jq in loop"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1579193949,
        "creation_date": 1579188332,
        "question_id": 59772878,
        "body_markdown": "I have a input json file with an array. I need to updated two values (ver &amp; date) in each array element. I could come up with below script but need help. I have hardcoded the ver &amp; date to simplify the script.\r\n\r\ninput.json\r\n\r\n    [\r\n      {\r\n        &quot;svcname&quot;: &quot;svc1&quot;,\r\n        &quot;repo&quot;: &quot;https://repo.mycom.org/repocontext/svc1-list&quot;,\r\n        &quot;ver&quot;: &quot;0.1&quot;,\r\n        &quot;date&quot;: &quot;2019-11-05&quot;\r\n      },\r\n      {\r\n        &quot;svcname&quot;: &quot;svc1&quot;,\r\n        &quot;repo&quot;: &quot;https://repo.mycom.org/repocontext/svc1-list&quot;,\r\n        &quot;ver&quot;: &quot;0.1&quot;,\r\n        &quot;date&quot;: &quot;2019-12-21&quot;\r\n      }\r\n    ]\r\n\r\n\r\nScript:\r\n\r\n    #!/bin/bash\r\n    set +x\r\n    injson=input.json\r\n    updatedjson=$(jq .[] ${injson})\r\n    \r\n    services=$(cat ${injson} | jq &#39;.[] | .svcname&#39; | tr -d \\&quot;)\r\n    i=1\r\n    for svc in $services; do \r\n    \r\n            echo &quot;==&gt;$svc&quot;\r\n            echo &quot;======&gt; input json=${updatedjson}&quot;\r\n            echo &quot;======&gt; update ver=${i}&quot;\r\n            updatedjson=$(echo ${updatedjson} | jq &quot;. | select( .name ==\\&quot;$svc\\&quot;).ver=\\&quot;$i\\&quot;&quot; | jq . )\r\n            svcdate=&quot;2020-01-$i&quot;\r\n            echo &quot;======&gt; update date=$svcdate&quot;\r\n            updatedjson=$(echo ${updatedjson} | jq &quot;. | select( .name ==\\&quot;$svc\\&quot;).date=\\&quot;$svcdate\\&quot;&quot; | jq . )\r\n            echo &quot;============================================&quot;\r\n            echo\r\n            i=`expr $i + 1`\r\n    \r\n    done\r\n    \r\n    echo &quot;======= write to file =====&quot;\r\n    echo ${updatedjson}\r\n    echo ${updatedjson} | jq . &gt; outjson.json",
        "link": "https://stackoverflow.com/questions/59772878/update-values-in-json-array-elements-using-jq-in-loop",
        "title": "Update values in json (array elements) using jq in loop"
    },
    {
        "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": 1,
                "creation_date": 1579195416,
                "post_id": 59774043,
                "comment_id": 105693586,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 177955,
                    "reputation": 4897,
                    "user_id": 409638,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/b2244263c61892ddd4d2b4d6b4786e6a?s=256&d=identicon&r=PG",
                    "display_name": "robert",
                    "link": "https://stackoverflow.com/users/409638/robert"
                },
                "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": 1579615339,
                "post_id": 59774043,
                "comment_id": 105819458,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1579272141,
                "last_edit_date": 1579272141,
                "creation_date": 1579197992,
                "answer_id": 59775471,
                "question_id": 59774043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Apart from the formatting, you might consider defining `nvl` as a 0-arity filter (which is more idiomatic and more efficient) or avoiding it altogether.  Assuming a bash or bash-like shell, you could write:\r\n\r\n```\r\n\r\n\r\njq &#39;def nvl: (.//[null])[];\r\n  .paths\r\n  | keys_unsorted[] as $path\r\n  | .[$path]\r\n  | keys_unsorted[] as $method\r\n  | .[$method]\r\n  | { $path,\r\n      $method,\r\n      produces: .produces | nvl,\r\n      consumes: .consumes | nvl\r\n    }&#39; swagger.json\r\n```\r\n\r\nConsider also using the -f command line option.\r\n\r\nNote that `false // 0` evaluates to 0, so you might want to modify the def accordingly.  It might be wise also to guard against other potential surprises.",
                "title": "extracting path, method and content-type from swagger json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1579272141,
        "creation_date": 1579192289,
        "last_edit_date": 1579193990,
        "question_id": 59774043,
        "body_markdown": "I already have a rough solution to this problem, but it&#39;s my first time working with JQ and I kind of feel like the result is a bit clunky, and I&#39;d like advice on how to clean it up, or suggestions how I might use more idiomatic forms.\r\n\r\nI have a [swagger][1] interface specification ([full file here][2]), and I want to extract info for each of the paths, the methods supported and the content-types expected in each case\r\n\r\nFor example, from:\r\n\r\n    {\r\n       &quot;paths&quot; : {\r\n          &quot;/1.0/kb/paymentGateways/hosted/form/{accountId}&quot; : {\r\n             &quot;post&quot; : {\r\n                &quot;produces&quot; : [\r\n                   &quot;application/json&quot;\r\n                ],\r\n                &quot;consumes&quot; : [\r\n                   &quot;application/json&quot;\r\n                ]\r\n          }\r\n    }\r\n \r\nI would like to produce:\r\n\r\n    {\r\n      &quot;path&quot;: &quot;/1.0/kb/paymentGateways/hosted/form/{accountId}&quot;,\r\n      &quot;method&quot;: &quot;post&quot;,\r\n      &quot;produces&quot;: &quot;application/json&quot;,\r\n      &quot;consumes&quot;: &quot;application/json&quot;\r\n    }\r\n\r\nand here is the jq query I used to do this:\r\n\r\n    jq &#39;def nvl(n): (n//[null])[];&#39;\\\r\n    &#39;.paths | keys[] as $path | .[$path] | keys[] as $method | .[$method] | &#39;\\\r\n    &#39;{ $path, $method, produces: nvl(.produces), consumes: nvl(.consumes)}&#39; swagger.json\r\n\r\nMany Thanks\r\n\r\n  [1]: https://swagger.io/\r\n  [2]: https://github.com/killbill/killbill-docs/blob/v3/swagger/file/swagger.json",
        "link": "https://stackoverflow.com/questions/59774043/extracting-path-method-and-content-type-from-swagger-json-with-jq",
        "title": "extracting path, method and content-type from swagger json with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2704333,
                    "reputation": 11178,
                    "user_id": 2334254,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://lh4.googleusercontent.com/-6e2XuTZAjgM/AAAAAAAAAAI/AAAAAAAAABU/JpF2-AkHsH4/s256-rj/photo.jpg",
                    "display_name": "kpie",
                    "link": "https://stackoverflow.com/users/2334254/kpie"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579197397,
                "post_id": 59775283,
                "comment_id": 105694577,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16473006,
                    "reputation": 13,
                    "user_id": 11901625,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-Uu_sWaXNW9A/AAAAAAAAAAI/AAAAAAAAUyc/hdgq4tfNH7g/s256-rj/photo.jpg",
                    "display_name": "Eric Vitta",
                    "link": "https://stackoverflow.com/users/11901625/eric-vitta"
                },
                "reply_to_user": {
                    "account_id": 2704333,
                    "reputation": 11178,
                    "user_id": 2334254,
                    "user_type": "registered",
                    "accept_rate": 57,
                    "profile_image": "https://lh4.googleusercontent.com/-6e2XuTZAjgM/AAAAAAAAAAI/AAAAAAAAABU/JpF2-AkHsH4/s256-rj/photo.jpg",
                    "display_name": "kpie",
                    "link": "https://stackoverflow.com/users/2334254/kpie"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579197794,
                "post_id": 59775283,
                "comment_id": 105694762,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1579200722,
                "last_edit_date": 1579200722,
                "creation_date": 1579199303,
                "answer_id": 59775755,
                "question_id": 59775283,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Ignoring the header line, it looks like the jq query you want is more like this:\r\n\r\n```\r\n.items[]\r\n| [.metadata.namespace,\r\n   .metadata.creationTimestamp,\r\n   .spec.hard[&quot;requests.storage&quot;],\r\n   .status.used[&quot;requests.storage&quot;],\r\n   .spec.hard[&quot;limits.cpu&quot;],\r\n   .spec.hard[&quot;limits.memory&quot;],\r\n   .status.used[&quot;limits.cpu&quot;],\r\n   .status.used[&quot;limits.memory&quot;]]\r\n| @tsv\r\n```\r\nFor CSV, use `@csv` instead of `@tsv`. In either case, you will probably want to invoke jq with the -r option.",
                "title": "I need to transform the output of the jq comand into a table"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1579200722,
        "creation_date": 1579197134,
        "last_edit_date": 1579199389,
        "question_id": 59775283,
        "body_markdown": "I am using this command to extract some information from a Json.\r\n\r\n    #!/bin/bash\r\n    \r\n    TOKEN=$(oc whoami -t)\r\n    ENDPOINT=$(oc config current-context | cut -d/ -f2 | tr - .)\r\n    NAMESPACE=$(oc config current-context | cut -d/ -f1)\r\n    \r\n    \r\n    curl -k \\\r\n        -H &quot;Authorization: Bearer $TOKEN&quot; \\\r\n        -H &#39;Accept: application/json&#39; \\\r\n        https://$ENDPOINT/api/v1/resourcequotas |   jq -jr &#39;[[.items[].metadata.namespace ], [.items[].metadata.creationTimestamp ], [.items[].spec.hard[&quot;requests.storage&quot;]],[.items[].status.used[&quot;requests.storage&quot;]],[.items[].spec.hard[&quot;limits.cpu&quot;]],[.items[].spec.hard[&quot;limits.memory&quot;]],[.items[].status.used[&quot;limits.cpu&quot;]],[.items[].status.used[&quot;limits.memory&quot;]]] &#39; &gt; item.txt\r\n\r\nWhen i execute the script it return an txt file with this: \r\n\r\n    [\r\n      [\r\n        &quot;glusterfs&quot;,\r\n        &quot;timpdv&quot;,\r\n        &quot;timpdv&quot;,\r\n        &quot;whatsappprd&quot;,\r\n        &quot;whatsappprd&quot;,\r\n        &quot;wso2ms&quot;,\r\n        &quot;wso2ms&quot;\r\n      ],\r\n      [\r\n        &quot;2019-12-12T13:47:25Z&quot;,\r\n        &quot;2019-01-10T19:53:29Z&quot;,\r\n        &quot;2019-01-10T20:36:18Z&quot;,\r\n        &quot;2019-02-15T17:39:43Z&quot;,\r\n        &quot;2019-02-13T18:20:30Z&quot;,\r\n        &quot;2019-12-12T13:49:57Z&quot;,\r\n        &quot;2019-12-12T13:50:45Z&quot;\r\n      ],\r\n      [\r\n        &quot;200Gi&quot;,\r\n        null,\r\n        &quot;300Gi&quot;,\r\n        null,\r\n        &quot;1150Gi&quot;,\r\n        null,\r\n        &quot;200Gi&quot;\r\n      ],\r\n      [\r\n        &quot;0&quot;,\r\n        null,\r\n        &quot;68Gi&quot;,\r\n        null,\r\n        &quot;1074Gi&quot;,\r\n        null,\r\n        &quot;0&quot;\r\n      ],\r\n      [\r\n        null,\r\n        &quot;16&quot;,\r\n        null,\r\n        &quot;192&quot;,\r\n        null,\r\n        &quot;80&quot;,\r\n        null\r\n      ],\r\n      [\r\n        null,\r\n        &quot;192Gi&quot;,\r\n\r\nAnd I need to return this data as a table, each value is a column.\r\nEx.\r\n```\r\nnamespace,        timestamp,              request.storage\r\n &quot;glusterfs&quot;,    &quot;2019-12-12T13:47:25Z&quot;,    &quot;200Gi&quot;,\r\n    &quot;timpdv&quot;,    &quot;2019-01-10T19:53:29Z&quot;,    null,\r\n    &quot;timpdv&quot;,    &quot;2019-01-10T20:36:18Z&quot;,    &quot;300Gi&quot;,\r\n```",
        "link": "https://stackoverflow.com/questions/59775283/i-need-to-transform-the-output-of-the-jq-comand-into-a-table",
        "title": "I need to transform the output of the jq comand into a table"
    },
    {
        "tags": [
            "bash",
            "shell",
            "environment-variables",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 923752,
                    "reputation": 56142,
                    "user_id": 954940,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/8VrIO.jpg?s=256",
                    "display_name": "Adam Jenkins",
                    "link": "https://stackoverflow.com/users/954940/adam-jenkins"
                },
                "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": 1579213382,
                "post_id": 59778578,
                "comment_id": 105701464,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 923752,
                    "reputation": 56142,
                    "user_id": 954940,
                    "user_type": "registered",
                    "accept_rate": 72,
                    "profile_image": "https://i.sstatic.net/8VrIO.jpg?s=256",
                    "display_name": "Adam Jenkins",
                    "link": "https://stackoverflow.com/users/954940/adam-jenkins"
                },
                "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": 1579213591,
                "post_id": 59778578,
                "comment_id": 105701533,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1579215445,
                "last_edit_date": 1579215445,
                "creation_date": 1579213355,
                "answer_id": 59778693,
                "question_id": 59778578,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What you want here is an *indirect reference*. Those can be done with `${!varname}`. As a trivial example limited to exactly two lines:\r\n\r\n```\r\n# read arg1_varname and arg2_varname from the first two lines of file.txt\r\n{ read -r arg1_varname; read -r arg2_varname; } &lt;file.txt\r\n\r\n# pass the variable named by the contents of arg1_varname as $arg1 in jq\r\n# and the variable named by the contents of arg2_varname as $arg2 in jq\r\njq -n --arg arg1_name &quot;$arg1_varname&quot; --arg arg1_value &quot;${!arg1_varname}&quot; \\\r\n      --arg arg2_name &quot;$arg2_varname&quot; --arg arg2_value &quot;${!arg2_varname}&quot; \\\r\n  &#39;{($arg1_name):$arg1_value, ($arg2_name):$arg2_value}&#39;\r\n```\r\n\r\nTo support an arbitrary number of key/value pairs, consider instead something like:\r\n\r\n```\r\n# Transform into NUL-separate key=value pairs (same format as /proc/*/environ)\r\nwhile IFS= read -r name; do                             # for each variable named in file.txt\r\n  printf &#39;%s=%s\\0&#39; &quot;$name&quot; &quot;${!name}&quot;                   # print its name and value, and a NUL\r\ndone \\\r\n  &lt;file.txt \\\r\n  | jq -Rs &#39;split(&quot;\\u0000&quot;)                             # split on those NULs\r\n            | [.[] | select(.)                          # ignore any empty strings\r\n               | capture(&quot;^(?&lt;name&gt;[^=]+)=(?&lt;val&gt;.*)$&quot;) # break into k/v pairs\r\n               | {(.name): .val}]                       # make each a JSON map\r\n            | add                                       # combine those maps\r\n  &#39;\r\n```",
                "title": "Generating a JSON map containing shell variables named in a list"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1579214735,
                "last_edit_date": 1579214735,
                "creation_date": 1579213960,
                "answer_id": 59778778,
                "question_id": 59778578,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try something along the following script in bash:\r\n\r\n\r\n    # array of arguments to pass to jq\r\n    jqarg=()\r\n    # the script to pass to jq\r\n    jqscript=&quot;&quot;\r\n    # just a number for the arg$num for indexing\r\n    # suggestion: just index using variable names...\r\n    num=1\r\n    \r\n    # for each variable name from the input\r\n    while IFS= read -r varname; do\r\n\r\n       # just an assertion - check if the variable is not empty\r\n       # the syntax ${!var} is indirect reference\r\n       # you could do more here, ex. see if such variable exists\r\n       # or if $varname is a valid variable name\r\n       if [[ -z &quot;${!varname}&quot; ]]; then\r\n            echo &quot;ERROR: variable $varname has empty value!&quot; &gt;&amp;2\r\n            exit 50\r\n       fi\r\n\r\n       # add the arguments to jqarg array\r\n       jqarg+=(--arg &quot;arg$num&quot; &quot;${!varname}&quot;)\r\n       # update jqscript\r\n       # if jqscript is not empty, add a comma on the end\r\n       if [[ -n &quot;$jqscript&quot; ]]; then\r\n          jqscript+=&quot;,&quot;\r\n       fi\r\n       # add the ENV_VAR_A:$arg&lt;number&gt;\r\n       jqscript+=&quot;$varname:\\$arg$num&quot;\r\n       # update number - one up!\r\n       num=$((num + 1))\r\n\r\n    # the syntax of while read loop is that input file is on the end\r\n    done &lt; input_file_with_variable_names.txt\r\n    \r\n    # finally execute jq\r\n    # note the `{` and `}` in `{$jqscript}` are concious\r\n    jq -n &quot;${jqarg[@]}&quot; &quot;{$jqscript}&quot;\r\n\r\nJust something that hopefully will give you a easier start with your journey in bash.\r\n\r\nI guess _I_ would do something unreadable with `xargs` like:\r\n\r\n    &lt; input_file_with_variable_names.txt xargs -d$&#39;\\n&#39; -n1 bash -c &#39;\r\n       printf %s\\\\0%s\\\\0%s\\\\0 --arg &quot;$1&quot; &quot;${!1}&quot;\r\n    &#39; -- |\r\n    xargs -0 sh -c &#39;jq -n &quot;$@&quot; &quot;$0&quot;&#39; &quot;{$(\r\n         sed &#39;s/\\(.*\\)/\\1: $\\1 /&#39; input_file_with_variable_names.txt | \r\n         paste -sd,\r\n    )}&quot;",
                "title": "Generating a JSON map containing shell variables named in a list"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1579217514,
                "last_edit_date": 1579217514,
                "creation_date": 1579215892,
                "answer_id": 59779106,
                "question_id": 59778578,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` can look up the values from the environment itself.\r\n\r\n    $ export A=1\r\n    $ export B=2\r\n    $ cat tmp.txt\r\n    A\r\n    B\r\n    $ jq -Rn &#39;[inputs] | map({key: ., value: $ENV[.]}) | from_entries&#39; tmp.txt\r\n    {\r\n      &quot;A&quot;: &quot;1&quot;,\r\n      &quot;B&quot;: &quot;2&quot;\r\n    }\r\n\r\nA few notes on how this works:\r\n\r\n  1. `-R` reads raw text, rather than trying to parse the input as JSON\r\n  2. `-n` prevents `jq` from reading input itself.\r\n  3. `inputs` reads all the input explicitly, allowing an array of names to be built.\r\n  4. `map` creates an array of objects with `key` and `value` as the keys; `.` is the current array input (a variable name), and `$ENV[.]` is the value of the environment variable whose name is the current array input.\r\n  5. `from_entries` finally coalesces all those `{&quot;key&quot;: ..., &quot;value&quot;: ...}` objects into a single object.",
                "title": "Generating a JSON map containing shell variables named in a list"
            },
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1579246239,
                "last_edit_date": 1579246239,
                "creation_date": 1579245887,
                "answer_id": 59782849,
                "question_id": 59778578,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Short and sweet (if you have jq 1.5 or higher):\r\n\r\n     jq -Rn &#39;[inputs | {(.): env[.]}] | add&#39; tmp.txt",
                "title": "Generating a JSON map containing shell variables named in a list"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 2,
        "last_activity_date": 1579246239,
        "creation_date": 1579212713,
        "last_edit_date": 1579215586,
        "question_id": 59778578,
        "body_markdown": "My shell-fu is at a below-beginner level. I have a file that contains some lines that happen to be the names of environment variables.\r\n\r\n\r\ne.g.\r\n```\r\nENV_VAR_A\r\nENV_VAR_B\r\n...\r\n```\r\n\r\n\r\nWhat I want to do is use this file to generate a JSON string containing the names and current values of the named variables using jq like this:\r\n\r\n```\r\njq -n --arg arg1 &quot;$ENV_VAR_A&quot; --arg arg2 &quot;$ENV_VAR_B&quot; &#39;{ENV_VAR_A:$arg1,ENV_VAR_B:$arg2}&#39;\r\n\r\n# if ENV_VAR_A=one and ENV_VAR_B=two then the preceding command would output \r\n# {&quot;ENV_VAR_A&quot;:&quot;one&quot;,&quot;ENV_VAR_B&quot;:&quot;two&quot;}\r\n```\r\n\r\nI&#39;m trying to create the jq command through a shell script and I have no idea what I&#39;m doing :(\r\n",
        "link": "https://stackoverflow.com/questions/59778578/generating-a-json-map-containing-shell-variables-named-in-a-list",
        "title": "Generating a JSON map containing shell variables named in a list"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1579214826,
                "post_id": 59778708,
                "comment_id": 105701918,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 233824,
                    "reputation": 47381,
                    "user_id": 499581,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/1ba2cebc4582467916f2ddd6128447f4?s=256&d=identicon&r=PG",
                    "display_name": "l&#39;L&#39;l",
                    "link": "https://stackoverflow.com/users/499581/lll"
                },
                "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": 1579214997,
                "post_id": 59778708,
                "comment_id": 105701980,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 233824,
                    "reputation": 47381,
                    "user_id": 499581,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://www.gravatar.com/avatar/1ba2cebc4582467916f2ddd6128447f4?s=256&d=identicon&r=PG",
                    "display_name": "l&#39;L&#39;l",
                    "link": "https://stackoverflow.com/users/499581/lll"
                },
                "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": 1579329741,
                "post_id": 59778708,
                "comment_id": 105737539,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1579353857,
                "creation_date": 1579353857,
                "answer_id": 59801016,
                "question_id": 59778708,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nBoth `@tsv` and `@csv` require their inputs to be flat arrays (i.e., arrays of atomic values).  There are many (infinitely many?) ways to &quot;flatten&quot; objects and arrays, so without knowing something about what you expect, I&#39;d just be guessing wildly. \r\n\r\nIf you want a wild guess, replace `.path + [.value[]]` by \r\n\r\n    .path + [.value[]|tostring]\r\n\r\nAt least that will always work (assuming the input is valid JSON) while producing easy-to-read results.\r\n",
                "title": "jq error &quot;object is not valid in a csv row&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1615326121,
        "creation_date": 1579213489,
        "question_id": 59778708,
        "body_markdown": "I&#39;m using `jq` to convert a nested `.json` file to `.csv`, however, there seems to be an issue when I have a particular **key**, **value** within the **JSON**. The script I&#39;m using comes from [this answer](https://stackoverflow.com/a/44748291/499581), which works if I eliminate one line from the input file.\r\n\r\n**ERROR**:\r\n\r\n    jq: error (at example.json:0): object ({&quot;favicon&quot;:...) is not valid in a csv row\r\n\r\nThe error message isn&#39;t very descriptive, since the object it mentions doesn&#39;t seem to be the culprit.\r\n\r\n**json2csv.jq**\r\n\r\n    paths as $path\r\n    | {path: $path, value: getpath($path)}\r\n    | select(.value|type == &quot;object&quot; )\r\n    | select( [.value[]][0] | type != &quot;object&quot;)\r\n    | .path + ([.value[]])\r\n    | @csv\r\n\r\n\r\n**example.json** (which validates with https://jsonlint.com):\r\n\r\n    {\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;id&quot;: 1234,\r\n          &quot;title&quot;: &quot;Title of Item&quot;,\r\n          &quot;internet&quot;: {\r\n            &quot;favicon&quot;: &quot;https://example.com/icon.png&quot;,\r\n            &quot;domain&quot;: &quot;https://example.com&quot;\r\n          },\r\n          &quot;image&quot;: {\r\n            &quot;gif&quot;: null,\r\n            &quot;main&quot;: &quot;https://example.com/image_large.png&quot;\r\n          },\r\n          &quot;description&quot;: {\r\n            &quot;origin&quot;: null,\r\n            &quot;resource&quot;: null\r\n          },\r\n          &quot;referral&quot;: {\r\n            &quot;owner&quot;: null,\r\n            &quot;name&quot;: null\r\n          },\r\n          &quot;url&quot;: &quot;https://example.com/image.png?version=1&quot;\r\n        }\r\n      ],\r\n      &quot;other&quot;: {\r\n        &quot;data&quot;: 0,\r\n        &quot;notes&quot;: 1,\r\n        &quot;total&quot;: 1,\r\n        &quot;misc&quot;: 1\r\n      }\r\n    }\r\n\r\nRemoving the following from the **JSON** doesn&#39;t throw error from `jq`:\r\n\r\n    , &quot;url&quot;: &quot;https://example.com/image.png?version=1&quot;\r\n\r\n**Invocation**:\r\n\r\n    $ jq -er -f json2csv.jq example.json\r\n\r\nI can&#39;t really change the `.json` file, because it needs the problematic line, so I&#39;m looking for a solution from `jq`.",
        "link": "https://stackoverflow.com/questions/59778708/jq-error-object-is-not-valid-in-a-csv-row",
        "title": "jq error &quot;object is not valid in a csv row&quot;"
    }
]