[
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1630076416,
                "last_edit_date": 1630076416,
                "creation_date": 1630074573,
                "answer_id": 68955137,
                "question_id": 68954848,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To get all both the `modern` and `intermediate` `openssl` arrays, we can use:\r\n```\r\njq &#39;.configurations | with_entries(select([.key] | inside([ &quot;modern&quot;, &quot;intermediate&quot; ])))[] | .ciphers.openssl&#39; input\r\n```\r\n\r\nThis will show:  \r\n```json\r\n[]\r\n[\r\n  &quot;ECDHE-ECDSA-AES128-GCM-SHA256&quot;,\r\n  &quot;ECDHE-RSA-AES128-GCM-SHA256&quot;,\r\n  &quot;ECDHE-ECDSA-AES256-GCM-SHA384&quot;,\r\n  &quot;ECDHE-RSA-AES256-GCM-SHA384&quot;,\r\n  &quot;ECDHE-ECDSA-CHACHA20-POLY1305&quot;,\r\n  &quot;ECDHE-RSA-CHACHA20-POLY1305&quot;,\r\n  &quot;DHE-RSA-AES128-GCM-SHA256&quot;,\r\n  &quot;DHE-RSA-AES256-GCM-SHA384&quot;\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nTo get a result with an object so we can see on what `key` those `openssl` certs are found, use something like:\r\n```\r\njq &#39;.configurations | to_entries | map(select([.key] | inside([ &quot;modern&quot;, &quot;intermediate&quot; ])) | { &quot;\\(.key)&quot;: .value.ciphers.openssl }) | add&#39; input\r\n```\r\n\r\nThis will produce:\r\n```json\r\n{\r\n  &quot;modern&quot;: [],\r\n  &quot;intermediate&quot;: [\r\n    &quot;ECDHE-ECDSA-AES128-GCM-SHA256&quot;,\r\n    &quot;ECDHE-RSA-AES128-GCM-SHA256&quot;,\r\n    &quot;ECDHE-ECDSA-AES256-GCM-SHA384&quot;,\r\n    &quot;ECDHE-RSA-AES256-GCM-SHA384&quot;,\r\n    &quot;ECDHE-ECDSA-CHACHA20-POLY1305&quot;,\r\n    &quot;ECDHE-RSA-CHACHA20-POLY1305&quot;,\r\n    &quot;DHE-RSA-AES128-GCM-SHA256&quot;,\r\n    &quot;DHE-RSA-AES256-GCM-SHA384&quot;\r\n  ]\r\n}\r\n```\r\n",
                "title": "jq: How can I get array values based on superordinate key name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1630179909,
        "creation_date": 1630073387,
        "last_edit_date": 1630179909,
        "question_id": 68954848,
        "body_markdown": "I&#39;m trying to use [jq](https://stackoverflow.com/tags/jq/info) to parse the output of https://ssl-config.mozilla.org/guidelines/5.6.json, a pretty simple JSON structure.\r\n\r\nHow can I get the &quot;openssl&quot; values if &quot;configurations&quot; is &quot;modern&quot; or &quot;intermediate&quot;?\r\n\r\nThe basic JSON structure would be:\r\n\r\n```\r\n{\r\n    &quot;configurations&quot;: { \r\n        &quot;intermediate&quot;: {\r\n            &quot;ciphers&quot;: {\r\n                &quot;openssl&quot;: [\r\n                    &quot;ECDHE-ECDSA-AES128-GCM-SHA256&quot;,\r\n                    &quot;ECDHE-RSA-AES128-GCM-SHA256&quot;,\r\n                    &quot;ECDHE-ECDSA-AES256-GCM-SHA384&quot;,\r\n                    &quot;ECDHE-RSA-AES256-GCM-SHA384&quot;,\r\n                    &quot;ECDHE-ECDSA-CHACHA20-POLY1305&quot;,\r\n                    &quot;ECDHE-RSA-CHACHA20-POLY1305&quot;,\r\n                    &quot;DHE-RSA-AES128-GCM-SHA256&quot;,\r\n                    &quot;DHE-RSA-AES256-GCM-SHA384&quot;\r\n                ]\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\nI had to shorten it in order to avoid the &quot;It looks like your post is mostly code; please add some more detail&quot; error message.\r\n",
        "link": "https://stackoverflow.com/questions/68954848/jq-how-can-i-get-array-values-based-on-superordinate-key-name",
        "title": "jq: How can I get array values based on superordinate key name"
    },
    {
        "tags": [
            "json",
            "dictionary",
            "jq",
            "edit"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1630189231,
                "creation_date": 1630189231,
                "answer_id": 68968528,
                "question_id": 68968413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&#129318; Apparently `[]` can be used on object too. I had though it was only for lists.\r\n\r\nThe following was all I needed.\r\n\r\n`.root[].leaf=&quot;updated&quot;`\r\n\r\n",
                "title": "update value of a map of objects"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1630190383,
                "creation_date": 1630190383,
                "answer_id": 68968615,
                "question_id": 68968413,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First you need to parse the json and then modify the resulting object as required using ```for ... in``` statement (example below)\r\n\r\n```\r\nconst flatJSON = &#39;{&quot;root&quot;:{&quot;branch1&quot;:{&quot;leaf&quot;:1},&quot;branch2&quot;:{&quot;leaf&quot;:2},&quot;branch3&quot;:{&quot;leaf&quot;:3}},&quot;another-root&quot;:{&quot;branch&quot;:123},&quot;foo&quot;:&quot;bar&quot;}&#39;;\r\n\r\nconst parsedJSON = JSON.parse(flatJSON);\r\nconst root = parsedJSON.root;\r\n\r\nfor (let property in root) {\r\n  root[property].leaf = &quot;updated&quot;; (or root[property][&quot;leaf&quot;] = &quot;updated&quot;;)\r\n}\r\n```\r\n\r\nIf you want to use jquery you have to replace ```for ... in``` statement with ```jQuery.each()``` method that iterates over both objects and arrays.\r\n\r\nDon&#39;t forget to convert it back to json with JSON.stringify() method (if required).\r\n\r\nHope that this helps.\r\nAll the best.",
                "title": "update value of a map of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1630346308,
        "creation_date": 1630188027,
        "last_edit_date": 1630228689,
        "question_id": 68968413,
        "body_markdown": "With jq, how can I transform the following:\r\n\r\n```\r\n{\r\n  &quot;root&quot;: {\r\n    &quot;branch1&quot;: {\r\n      &quot;leaf&quot;: 1\r\n    },\r\n    &quot;branch2&quot;: {\r\n      &quot;leaf&quot;: 2\r\n    },\r\n    &quot;branch3&quot;: {\r\n      &quot;leaf&quot;: 3\r\n    }\r\n  },\r\n  &quot;another-root&quot;: {\r\n      &quot;branch&quot;: 123\r\n  },\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n```\r\n\r\nto this:\r\n\r\n```\r\n{\r\n  &quot;root&quot;: {\r\n    &quot;branch1&quot;: {\r\n      &quot;leaf&quot;: &quot;updated&quot;\r\n    },\r\n    &quot;branch2&quot;: {\r\n      &quot;leaf&quot;: &quot;updated&quot;\r\n    },\r\n    &quot;branch3&quot;: {\r\n      &quot;leaf&quot;: &quot;updated&quot;\r\n    }\r\n  },\r\n  &quot;another-root&quot;: {\r\n      &quot;branch&quot;: 123\r\n  },\r\n  &quot;foo&quot;: &quot;bar&quot;\r\n}\r\n\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/68968413/update-value-of-a-map-of-objects",
        "title": "update value of a map of objects"
    },
    {
        "tags": [
            "json",
            "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": 1630209632,
                "post_id": 68969718,
                "comment_id": 121891395,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1630215901,
                "last_edit_date": 1630215901,
                "creation_date": 1630209775,
                "answer_id": 68969758,
                "question_id": 68969718,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you call `map()` over a dictionary, you operate on only its values, throwing the keys away. The value `&quot;snapshot-myrds-backup-1&quot;` has no `.Tags`, nor can you take item 11 of that nonexistent `Tags` entry.\r\n\r\n---\r\n\r\nWhat you want here is:\r\n\r\n\r\n```jq\r\n.Tags |= map(if .Key == &quot;Period&quot; then .Value = &quot;Weekly&quot; else . end)\r\n```\r\n\r\n`map()` is usually used to iterate over an array; for JSON objects, `map_values()` would usually be used to &quot;map&quot; over the object&#39;s values while retaining the keys, except for those whose values are mapped to `empty`.",
                "title": "JSON file update using jq (bash script)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1630224610,
        "creation_date": 1630209130,
        "last_edit_date": 1630224610,
        "question_id": 68969718,
        "body_markdown": "Need some help for change the value in JSON file using jq command.\r\n\r\n**Error:**\r\n\r\n```none\r\n[jenkins@devops-dev-02 New]$ jq &#39;map(if .Tags[11].Key == &quot;Period&quot; then .Tags[11].Value = &quot;Weekly&quot; else . end)&#39; create_snapshot.json\r\njq: error (at create_snapshot.json:54): Cannot index string with string &quot;Tags&quot;\r\n[jenkins@devops-dev-02 New]$\r\n```\r\n\r\n**JSON File:**\r\n```json\r\n{\r\n   &quot;DBSnapshotIdentifier&quot;:&quot;snapshot-myrds-backup-1&quot;,\r\n   &quot;DBInstanceIdentifier&quot;:&quot;myrds&quot;,\r\n   &quot;Tags&quot;:[\r\n      {\r\n         &quot;Key&quot;:&quot;Name&quot;,\r\n         &quot;Value&quot;:&quot;snapshot-myrds-backup-1&quot;\r\n      },\r\n      {\r\n         &quot;Key&quot;:&quot;Application&quot;,\r\n         &quot;Value&quot;:&quot;myapp&quot;\r\n      },\r\n      {\r\n         &quot;Key&quot;:&quot;Environment&quot;,\r\n         &quot;Value&quot;:&quot;Dev and QA&quot;\r\n      },\r\n      {\r\n         &quot;Key&quot;:&quot;Period&quot;,\r\n         &quot;Value&quot;:&quot;Daily&quot;\r\n      }\r\n   ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/68969718/json-file-update-using-jq-bash-script",
        "title": "JSON file update using jq (bash script)"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630400811,
                "post_id": 68989626,
                "comment_id": 121939234,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4741979,
                    "reputation": 31542,
                    "user_id": 3834415,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/jKHGm.jpg?s=256",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/3834415/chris"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630416996,
                "post_id": 68989626,
                "comment_id": 121946684,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4741979,
                    "reputation": 31542,
                    "user_id": 3834415,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/jKHGm.jpg?s=256",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/3834415/chris"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630417072,
                "post_id": 68989626,
                "comment_id": 121946715,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1630431821,
                "post_id": 68989626,
                "comment_id": 121953144,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4741979,
                    "reputation": 31542,
                    "user_id": 3834415,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://i.sstatic.net/jKHGm.jpg?s=256",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/3834415/chris"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630432428,
                "post_id": 68989626,
                "comment_id": 121953402,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1630354261,
                "last_edit_date": 1630354261,
                "creation_date": 1630354174,
                "answer_id": 68989779,
                "question_id": 68989626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The answer here is:\r\n\r\n```\r\njq &#39;map_values(.value)&#39;\r\n```\r\n\r\nAnd I got it from reading the docs... which wasn&#39;t ideal, but did pay off. ",
                "title": "JQ: How to simplify an object so that the name strings stay in place, and a child object simplifies to a single value?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1630374111,
                "creation_date": 1630374111,
                "answer_id": 68991961,
                "question_id": 68989626,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Another possibility:\r\n\r\n\r\n    .foo |= .value",
                "title": "JQ: How to simplify an object so that the name strings stay in place, and a child object simplifies to a single value?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1630417013,
        "creation_date": 1630353140,
        "last_edit_date": 1630417013,
        "question_id": 68989626,
        "body_markdown": "Suppose a json exists:\r\n\r\n```\r\n{\r\n  &quot;foo&quot;: {\r\n     &quot;descr&quot;: &quot;this is hard to ask&quot;,\r\n     &quot;value&quot;: &quot;but it must be easy to answer&quot;\r\n  }\r\n}\r\n```\r\n\r\nAnd the goal is:\r\n\r\n```\r\ncat foo.json | jq &#39;&lt;something&gt;&#39;\r\n{\r\n  &quot;foo&quot;: &quot;but it must be easy to answer&quot;\r\n}\r\n```\r\n\r\nIs there a way to do this simply in jq? ",
        "link": "https://stackoverflow.com/questions/68989626/jq-how-to-simplify-an-object-so-that-the-name-strings-stay-in-place-and-a-chil",
        "title": "JQ: How to simplify an object so that the name strings stay in place, and a child object simplifies to a single value?"
    },
    {
        "tags": [
            "json",
            "linux",
            "ubuntu",
            "command",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1630418385,
                "last_edit_date": 1630418385,
                "creation_date": 1630416189,
                "answer_id": 68999515,
                "question_id": 68996590,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `to_entries` function to convert an object such as `{&quot;a&quot;: 1, &quot;b&quot;: 2}` to an array of key-value objects such as `[{&quot;key&quot;: &quot;a&quot;, &quot;value&quot;: 1}, {&quot;key&quot;: &quot;b&quot;, &quot;value&quot;: 2}]`. Then map over this to pick the key and the parts of the value of interest.\r\n\r\nThe jq script would look like this:\r\n\r\n```jq\r\nto_entries | map([\r\n    .key,\r\n    .value.OSmodle,\r\n    .value.OSversion,\r\n    .value.IEversion,\r\n    (.value.hardwareUSB | join(&quot;&amp;&quot;)),\r\n    .value.OrderStatus])\r\n| [&quot;PCID&quot;, &quot;OSmodle&quot;, &quot;OSversion&quot;, &quot;IEversion&quot;, &quot;hardwareUSB&quot;, &quot;OrderStatus&quot;], .[]\r\n| @csv\r\n```\r\n\r\nOutput (with `-r`):\r\n\r\n```csv\r\n&quot;PCID&quot;,&quot;OSmodle&quot;,&quot;OSversion&quot;,&quot;IEversion&quot;,&quot;hardwareUSB&quot;,&quot;OrderStatus&quot;\r\n&quot;PCID000&quot;,&quot;LINUX&quot;,,&quot;2.15.0&quot;,&quot;Card reader&amp;keyboard&quot;,&quot;01&quot;\r\n&quot;PCID999&quot;,&quot;LINUX&quot;,&quot;4.0&quot;,,&quot;&quot;,&quot;01&quot;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/QFib_0hukW)",
                "title": "Convert json to csv using jq with different key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1630418385,
        "creation_date": 1630403707,
        "last_edit_date": 1630416664,
        "question_id": 68996590,
        "body_markdown": "Given an array of JSON objects, I&#39;d like to output a CSV where one of the rows contains each object key and the others are based on each object value.\r\n\r\nThe input json is:\r\n \r\n```json\r\n{\r\n  &quot;PCID000&quot;: {\r\n    &quot;OSmodle&quot;: &quot;LINUX&quot;,\r\n    &quot;IEversion&quot;: &quot;2.15.0&quot;,\r\n    &quot;hardwareUSB&quot;: [\r\n      &quot;Card reader&quot;,\r\n      &quot;keyboard&quot;\r\n    ],\r\n    &quot;OrderStatus&quot;: &quot;01&quot;\r\n  },\r\n  &quot;PCID999&quot;: {\r\n    &quot;OSmodle&quot;: &quot;LINUX&quot;,\r\n    &quot;OSversion&quot;: &quot;4.0&quot;,\r\n    &quot;hardwareUSB&quot;: [],\r\n    &quot;OrderStatus&quot;: &quot;01&quot;\r\n  }\r\n}\r\n```\r\n\r\nThe output would look something like this. The header can be hardcoded.\r\n\r\n```csv\r\nPCID,OSmodle,OSversion,IEversion,hardwareUSB, OrderStatus\r\n&quot;PCID000&quot;,&quot;LINUX&quot;,,&quot;2.15.0&quot;,&quot;Card reader&amp;keyboard&quot;,&quot;01&quot;\r\n&quot;PCID999&quot;,&quot;LINUX&quot;,&quot;4.0&quot;,,&quot;01\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/68996590/convert-json-to-csv-using-jq-with-different-key",
        "title": "Convert json to csv using jq with different key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1630423718,
                "last_edit_date": 1630423718,
                "creation_date": 1630423552,
                "answer_id": 69001403,
                "question_id": 69001362,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the [Array/String Slice operator][1]\r\n```\r\njq &#39;map(.id |= .[:8])&#39;\r\n```\r\n\r\n* Where `[:8]` means; take char `0` to `8`.\r\n* If you don&#39;t want to start from index `0`, use eg: `.[3:8]`\r\n\r\n\r\n----------\r\n\r\n\r\nThe above command will produce:\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;35a97c36&quot;,\r\n    &quot;name&quot;: &quot;this is title one&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;a547d011&quot;,\r\n    &quot;name&quot;: &quot;this is title two&quot;\r\n  }\r\n]\r\n```\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/pBwkHnY2su)\r\n\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Array/StringSlice:.[10:15]",
                "title": "How to reduce lenght of value from JSON using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1630424366,
        "creation_date": 1630423376,
        "last_edit_date": 1630424366,
        "question_id": 69001362,
        "body_markdown": "Sorry for wrong title. I cant find better title. I have json like this:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;35a97c36397886b93bd5619f38c676e739f7f834f82838dcfed602da1d3abf74&quot;,\r\n    &quot;name&quot;: &quot;this is title one&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;a547d0112840946aa9e5c266261888d6ab7706e69fc7bb7fdbf907ea2d3da735&quot;,\r\n    &quot;name&quot;: &quot;this is title two&quot;\r\n  }\r\n]\r\n```\r\nI want modify using jq and give output like this. I only pick 8 characthers from ID:\r\n```\r\n[\r\n  {\r\n    &quot;id&quot;: &quot;35a97c36&quot;,\r\n    &quot;name&quot;: &quot;this is title one&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: &quot;a547d011&quot;,\r\n    &quot;name&quot;: &quot;this is title two&quot;\r\n  }\r\n]\r\n```\r\n\r\nReally appreciate for any help.\r\nThanks",
        "link": "https://stackoverflow.com/questions/69001362/how-to-reduce-lenght-of-value-from-json-using-jq",
        "title": "How to reduce lenght of value from JSON using JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 14,
                "is_accepted": true,
                "score": 14,
                "last_activity_date": 1630430321,
                "last_edit_date": 1630430321,
                "creation_date": 1630429906,
                "answer_id": 69002826,
                "question_id": 69002792,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Replace \r\n\r\n```jq\r\n&quot;prefix-value-$hostname&quot;\r\n```\r\n\r\nwith\r\n\r\n```jq\r\n&quot;prefix-value-\\( $hostname )&quot;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/xt47t7a504)\r\n\r\nor\r\n\r\n```jq\r\n&quot;prefix-value-&quot; + $hostname\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/9k6fAk-7Xp)\r\n\r\n---\r\n\r\nNote that since host names can&#39;t contain line feeds, `-n` and `--arg` could be replaced with `-R` and stdin.\r\n\r\n```sh\r\necho my-hostname | jq -R &#39;{ Name: &quot;prefix-value-\\(.)&quot; }&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/JvYxfl71MU)\r\n",
                "title": "jq - concatenate passed arguments with strings"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1630430321,
        "creation_date": 1630429688,
        "question_id": 69002792,
        "body_markdown": "I&#39;m able to use arguments if they are not surrounded by quotes:\r\n\r\n    var=$(jq -n --arg hostname &quot;my-hostname&quot; &#39;{\r\n      Name: $hostname\r\n    }\r\n    )\r\n    \r\n    echo $var\r\n\r\nResult:\r\n\r\n    {\r\n      Name: &quot;my-hostname&quot;\r\n    }\r\n\r\nBut I want to concatenate the variable with an existing string, it ignores the value:\r\n\r\n    var=$(jq -n --arg hostname &quot;my-hostname&quot; &#39;{\r\n      Name: &quot;prefix-value-$hostname&quot;\r\n    }\r\n    )\r\n    \r\n    echo $var\r\n\r\nResult:\r\n\r\n    {\r\n      Name: &quot;prefix-value-&quot;\r\n    }\r\n\r\nExpected:\r\n\r\n    {\r\n      Name: &quot;prefix-value-my-hostname&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/69002792/jq-concatenate-passed-arguments-with-strings",
        "title": "jq - concatenate passed arguments with strings"
    },
    {
        "tags": [
            "json",
            "select",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 101080,
                    "reputation": 70949,
                    "user_id": 272109,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/32170c62eb744820e8afdd023379a95a?s=256&d=identicon&r=PG",
                    "display_name": "David Makogon",
                    "link": "https://stackoverflow.com/users/272109/david-makogon"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1630445662,
                "post_id": 69005505,
                "comment_id": 121957602,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1630489312,
                "creation_date": 1630489312,
                "answer_id": 69011350,
                "question_id": 69005505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You might want to separate this into two questions since #1 is a relatively simple select while #2, dealing with time calculations is a topic in its own right. In any case, for #1 you can use `with_entries` to convert `units` to series of maps with `key` and `value` fields, operate on those with `select` and convert back again. \r\n\r\n\r\n```\r\n$ jq &#39;{&quot;units&quot;: .units | with_entries(select(.value.&quot;screensProcesses&quot; | length &lt; 2))}&#39; file.json\r\n{\r\n  &quot;units&quot;: {\r\n    &quot;10000000553ff4cd&quot;: {\r\n      &quot;1_hostname&quot;: &quot;unit-b&quot;,\r\n      &quot;3_lastCheckIn&quot;: &quot;08/31/21 16:00&quot;,\r\n      &quot;screensProcesses&quot;: [\r\n        &quot;file1&quot;\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#:~:text=to_entries%2C%20from_entries%2C%20with_entries",
                "title": "Simple jq command line query"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1630489312,
        "creation_date": 1630445380,
        "last_edit_date": 1630452750,
        "question_id": 69005505,
        "body_markdown": "I have a larger dataset, but here is a sample of my json file.\r\n\r\n```\r\n{&quot;units&quot;: {\r\n  &quot;1000000043579e28&quot;: {\r\n    &quot;1_hostname&quot;: &quot;unit-a&quot;,\r\n    &quot;3_lastCheckIn&quot;: &quot;08/31/21 16:00&quot;,\r\n    &quot;screensProcesses&quot;: [\r\n      &quot;file1&quot;,\r\n      &quot;file2&quot; ]},\r\n  &quot;10000000553ff4cd&quot;: {\r\n    &quot;1_hostname&quot;: &quot;unit-b&quot;,\r\n     &quot;3_lastCheckIn&quot;: &quot;08/31/21 16:00&quot;,\r\n    &quot;screensProcesses&quot;: [\r\n      &quot;file1&quot; ]}\r\n}}\r\n```\r\nI would like to use the jq binary in linux. I&#39;m trying to do 2 queries. \r\n\r\n1. Units that have less than 2 &quot;screenProcesses&quot;.\r\n2. Units that haven&#39;t checked in over 24 hours. (I can modify how I write the date in json file if needed.",
        "link": "https://stackoverflow.com/questions/69005505/simple-jq-command-line-query",
        "title": "Simple jq command line query"
    },
    {
        "tags": [
            "json",
            "sum",
            "jq",
            "updates"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1630486544,
                "creation_date": 1630486544,
                "answer_id": 69010651,
                "question_id": 69010181,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nIn two steps in accordance with the task description:\r\n\r\n    (.breakdown.resources | map(.monthlyCost) | add) as $sum\r\n    | .breakdown.totalMonthlyCost = $sum\r\n\r\nThis can be written without the intermediate variable:\r\n\r\n    .breakdown.totalMonthlyCost \r\n     = (.breakdown.resources | map(.monthlyCost) | add)\r\n\r\nor more DRYly:\r\n\r\n    .breakdown\r\n     |= (.totalMonthlyCost = (.resources | map(.monthlyCost) | add))\r\n",
                "title": "How to sum values in json using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 3,
        "last_activity_date": 1630486582,
        "creation_date": 1630484499,
        "last_edit_date": 1630486582,
        "question_id": 69010181,
        "body_markdown": "I just started using jq parser as i need to parse some values out of a json file and make few changes and output an updated json file with the changes. Here is one of the samples out of many i&#39;m working on.\r\n\r\ninput json:\r\n```\r\n{\r\n  &quot;name&quot;: &quot;.&quot;,\r\n  &quot;metadata&quot;: {\r\n    &quot;path&quot;: &quot;.&quot;,\r\n    &quot;type&quot;: &quot;terraform_dir&quot;,\r\n    &quot;terraformWorkspace&quot;: &quot;default&quot;\r\n  },\r\n  &quot;pastBreakdown&quot;: {\r\n    &quot;resources&quot;: [],\r\n    &quot;totalHourlyCost&quot;: &quot;0&quot;,\r\n    &quot;totalMonthlyCost&quot;: &quot;0&quot;\r\n  },\r\n  &quot;breakdown&quot;: {\r\n    &quot;resources&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;vm01&quot;,\r\n        &quot;metadata&quot;: {},\r\n        &quot;hourlyCost&quot;: &quot;0.007989726027400584&quot;,\r\n        &quot;monthlyCost&quot;: 3.9660999999999986,\r\n        &quot;costComponents&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;vm01-201&quot;,\r\n            &quot;unit&quot;: &quot;years&quot;,\r\n            &quot;hourlyQuantity&quot;: &quot;0.0001141552511416&quot;,\r\n            &quot;monthlyQuantity&quot;: &quot;0.0833333333333333&quot;,\r\n            &quot;price&quot;: &quot;69.99&quot;,\r\n            &quot;hourlyCost&quot;: &quot;0.007989726027400584&quot;,\r\n            &quot;monthlyCost&quot;: &quot;5.832499999999997667&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;public_ip.example&quot;,\r\n        &quot;metadata&quot;: {},\r\n        &quot;hourlyCost&quot;: &quot;0.005&quot;,\r\n        &quot;monthlyCost&quot;: 2.482,\r\n        &quot;costComponents&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;IP address (static)&quot;,\r\n            &quot;unit&quot;: &quot;hours&quot;,\r\n            &quot;hourlyQuantity&quot;: &quot;1&quot;,\r\n            &quot;monthlyQuantity&quot;: &quot;730&quot;,\r\n            &quot;price&quot;: &quot;0.005&quot;,\r\n            &quot;hourlyCost&quot;: &quot;0.005&quot;,\r\n            &quot;monthlyCost&quot;: &quot;3.65&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;storage_account&quot;,\r\n        &quot;metadata&quot;: {},\r\n        &quot;hourlyCost&quot;: &quot;0.17575342465753424425&quot;,\r\n        &quot;monthlyCost&quot;: 87.24400000000001,\r\n        &quot;costComponents&quot;: [\r\n          {\r\n            &quot;name&quot;: &quot;Write&quot;,\r\n            &quot;unit&quot;: &quot;10K operations&quot;,\r\n            &quot;hourlyQuantity&quot;: &quot;0.136986301369863&quot;,\r\n            &quot;monthlyQuantity&quot;: &quot;100&quot;,\r\n            &quot;price&quot;: &quot;0.1&quot;,\r\n            &quot;hourlyCost&quot;: &quot;0.0136986301369863&quot;,\r\n            &quot;monthlyCost&quot;: &quot;10&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;List&quot;,\r\n            &quot;unit&quot;: &quot;10K operations&quot;,\r\n            &quot;hourlyQuantity&quot;: &quot;0.136986301369863&quot;,\r\n            &quot;monthlyQuantity&quot;: &quot;100&quot;,\r\n            &quot;price&quot;: &quot;0.05&quot;,\r\n            &quot;hourlyCost&quot;: &quot;0.00684931506849315&quot;,\r\n            &quot;monthlyCost&quot;: &quot;5&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;Read&quot;,\r\n            &quot;unit&quot;: &quot;10K operations&quot;,\r\n            &quot;hourlyQuantity&quot;: &quot;0.0136986301369863&quot;,\r\n            &quot;monthlyQuantity&quot;: &quot;10&quot;,\r\n            &quot;price&quot;: &quot;0.01&quot;,\r\n            &quot;hourlyCost&quot;: &quot;0.000136986301369863&quot;,\r\n            &quot;monthlyCost&quot;: &quot;0.1&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;All other operations&quot;,\r\n            &quot;unit&quot;: &quot;10K operations&quot;,\r\n            &quot;hourlyQuantity&quot;: &quot;0.136986301369863&quot;,\r\n            &quot;monthlyQuantity&quot;: &quot;100&quot;,\r\n            &quot;price&quot;: &quot;0.004&quot;,\r\n            &quot;hourlyCost&quot;: &quot;0.000547945205479452&quot;,\r\n            &quot;monthlyCost&quot;: &quot;0.4&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;retrieval&quot;,\r\n            &quot;unit&quot;: &quot;GB&quot;,\r\n            &quot;hourlyQuantity&quot;: &quot;1.3698630136986301&quot;,\r\n            &quot;monthlyQuantity&quot;: &quot;1000&quot;,\r\n            &quot;price&quot;: &quot;0.01&quot;,\r\n            &quot;hourlyCost&quot;: &quot;0.013698630136986301&quot;,\r\n            &quot;monthlyCost&quot;: &quot;10&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;write&quot;,\r\n            &quot;unit&quot;: &quot;GB&quot;,\r\n            &quot;hourlyQuantity&quot;: &quot;1.3698630136986301&quot;,\r\n            &quot;monthlyQuantity&quot;: &quot;1000&quot;,\r\n            &quot;price&quot;: &quot;0.0025&quot;,\r\n            &quot;hourlyCost&quot;: &quot;0.00342465753424657525&quot;,\r\n            &quot;monthlyCost&quot;: &quot;2.5&quot;\r\n          },\r\n          {\r\n            &quot;name&quot;: &quot;index&quot;,\r\n            &quot;unit&quot;: &quot;10K tags&quot;,\r\n            &quot;hourlyQuantity&quot;: &quot;0.0136986301369863&quot;,\r\n            &quot;monthlyQuantity&quot;: &quot;10&quot;,\r\n            &quot;price&quot;: &quot;0.03&quot;,\r\n            &quot;hourlyCost&quot;: &quot;0.000410958904109589&quot;,\r\n            &quot;monthlyCost&quot;: &quot;0.3&quot;\r\n          }\r\n        ]\r\n      }\r\n    ],\r\n    &quot;totalMonthlyCost&quot;: &quot;sum value&quot;\r\n```\r\n\r\nFrom the above json i need to sum the ```monthlyCost``` of each resources and update total value in ```totalMonthlyCost```\r\n\r\nSo the input would be ```&quot;3.9660999999999986 + 2.482 + 87.24400000000001&quot;``` the sum of these values should be updated in ```totalMonthlyCost```\r\n\r\nI have been trying various options but no luck. I could calculate the values within the array\r\nbut not sure how to update the value in ```totalMonthlyCost```",
        "link": "https://stackoverflow.com/questions/69010181/how-to-sum-values-in-json-using-jq",
        "title": "How to sum values in json using jq"
    },
    {
        "tags": [
            "json",
            "filtering",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1630500475,
                "creation_date": 1630500475,
                "answer_id": 69014038,
                "question_id": 69013938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following should work. This is as per this answer https://stackoverflow.com/a/37344498/1109657\r\n\r\n    validator-info --json | jq &#39;.Node_info.Metrics.&quot;average-per-second&quot;.&quot;read-transactions&quot;&#39;",
                "title": "Json filter not working on array while using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1630502008,
                "last_edit_date": 1630502008,
                "creation_date": 1630501664,
                "answer_id": 69014375,
                "question_id": 69013938,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; Json filter not working ***on array*** while using jq  \r\n\r\nThere are **no** arrays in your JSON, only objects\r\n\r\n\r\n----------\r\n\r\n\r\nSince there are some `-`&#39;s in your path, you&#39;ll need to pass the key as string like so:\r\n```\r\njq &#39;.Node_info.Metrics.&quot;average-per-second&quot;.&quot;read-transactions&quot;&#39;\r\n```\r\n\r\nThis will output (after making the JSON valid):\r\n```none\r\n0.1233\r\n```\r\n\r\n\r\n----------\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/Am64PnTUJK)\r\n",
                "title": "Json filter not working on array while using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1630502008,
        "creation_date": 1630500026,
        "last_edit_date": 1630500433,
        "question_id": 69013938,
        "body_markdown": "i have the following json format and trying to filter it using jq.\r\nMy requirement is to print the &quot;read-transactions&quot; value.\r\nI. tried the following but didnt succeed. \r\n\r\n```\r\nvalidator-info --json | jq .Node_info.Metrics[].read-transactions\r\n```\r\nExpected output is 0.1233\r\n\r\nAny idea what I&#39;m missing here?\r\n\r\n```\r\n{\r\nNode_info&quot;: {\r\n    &quot;Metrics&quot;: {\r\n      &quot;Delta&quot;: 0.12,\r\n      &quot;Lambda&quot;: 2410,\r\n      &quot;Omega&quot;: 220,\r\n      &quot;average-per-second&quot;: {\r\n        &quot;read-transactions&quot;: 0.1233,\r\n        &quot;write-transactions&quot;: 0.122334\r\n      },\r\n      }\r\n      }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69013938/json-filter-not-working-on-array-while-using-jq",
        "title": "Json filter not working on array while using jq"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14347533,
                    "reputation": 289,
                    "user_id": 10363993,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/-yjhBqLNug2w/AAAAAAAAAAI/AAAAAAAAJiY/Jm1saNyvDFY/s256-rj/photo.jpg",
                    "display_name": "TooNetCreation",
                    "link": "https://stackoverflow.com/users/10363993/toonetcreation"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630509061,
                "post_id": 69016101,
                "comment_id": 121976620,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1630536308,
                "last_edit_date": 1630536308,
                "creation_date": 1630509215,
                "answer_id": 69016444,
                "question_id": 69016101,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `tr` like this is a bit hacky, but:\r\n\r\n    $ cat input\r\n    \r\n    {\r\n      &quot;range&quot;: &quot;Sheet!A2:B100&quot;,\r\n      &quot;majorDimension&quot;: &quot;ROWS&quot;,\r\n      &quot;values&quot;: [\r\n        [\r\n          &quot;customer1_name&quot;,\r\n          &quot;customer1@email.com&quot;,\r\n          &quot;customer1_phone&quot;,\r\n          &quot;customer1_city&quot;\r\n        ],\r\n        [\r\n          &quot;customer2_name&quot;,\r\n          &quot;customer2@email.com&quot;,\r\n          &quot;customer2_phone&quot;,\r\n          &quot;customer2_city&quot;\r\n        ]\r\n      ]\r\n    }\r\n    $ jq -rc &#39;.values[]&#39; input | tr -d &#39;[&quot;]&#39; | while IFS=, read var1 var2 var3 var4; do echo &quot;$var1 $var2 $var3 $var4&quot;; done\r\n    customer1_name customer1@email.com customer1_phone customer1_city\r\n    customer2_name customer2@email.com customer2_phone customer2_city\r\n\r\nYou can also do:\r\n\r\n    $ jq -rc &#39;.values[][]&#39; input | while read name; read email; read phone; read city; do echo &quot;$name $email $phone $city&quot;; done;\r\n    customer1_name customer1@email.com customer1_phone customer1_city\r\n    customer2_name customer2@email.com customer2_phone customer2_city",
                "title": "multi extract values with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1666488150,
        "creation_date": 1630507880,
        "last_edit_date": 1666488150,
        "question_id": 69016101,
        "body_markdown": "I have this JSON file :\r\n\r\n    {\r\n      &quot;range&quot;: &quot;Sheet!A2:B100&quot;,\r\n      &quot;majorDimension&quot;: &quot;ROWS&quot;,\r\n      &quot;values&quot;: [\r\n        [\r\n          &quot;customer1_name&quot;,\r\n          &quot;customer1@email.com&quot;,\r\n          &quot;customer1_phone&quot;,\r\n          &quot;customer1_city&quot;\r\n        ],\r\n        [\r\n          &quot;customer2_name&quot;,\r\n          &quot;customer2@email.com&quot;,\r\n          &quot;customer2_phone&quot;,\r\n          &quot;customer2_city&quot;\r\n        ]\r\n      ]\r\n    }\r\n\r\nAnd, from a shell script, I would like to use JQ to extract every value for every block and assign them to some variables. here is expected result :\r\n\r\nFor this block :\r\n\r\n        [\r\n          &quot;customer1_name&quot;,\r\n          &quot;customer1@email.com&quot;,\r\n          &quot;customer1_phone&quot;,\r\n          &quot;customer1_city&quot;\r\n        ],\r\n\r\nResult should be like this :\r\n\r\n    VAR1 = &quot;customer1_name&quot;\r\n    VAR2 = &quot;customer1@email.com&quot;\r\n    VAR3 = &quot;customer1_phone&quot;\r\n    VAR4 = &quot;customer1_city&quot;\r\n\r\nAnd for this block :\r\n\r\n        [\r\n          &quot;customer2_name&quot;,\r\n          &quot;customer2@email.com&quot;,\r\n          &quot;customer2_phone&quot;,\r\n          &quot;customer2_city&quot;\r\n        ],\r\n\r\nResult should be like this :\r\n\r\n    VAR1 = &quot;customer2_name&quot;\r\n    VAR2 = &quot;customer2@email.com&quot;\r\n    VAR3 = &quot;customer2_phone&quot;\r\n    VAR4 = &quot;customer2_city&quot;\r\n\r\nThe idea is to read JSON file block by block to get/retrieve all the values inside VARS.\r\n",
        "link": "https://stackoverflow.com/questions/69016101/multi-extract-values-with-jq",
        "title": "multi extract values with JQ"
    },
    {
        "tags": [
            "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": 1630518660,
                "post_id": 69018477,
                "comment_id": 121980593,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 295664,
                    "reputation": 1423,
                    "user_id": 600194,
                    "user_type": "registered",
                    "accept_rate": 63,
                    "profile_image": "https://www.gravatar.com/avatar/0311a73f5754585465e80bf12bb4aea2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "lbj-ub",
                    "link": "https://stackoverflow.com/users/600194/lbj-ub"
                },
                "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": 1630519040,
                "post_id": 69018477,
                "comment_id": 121980723,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630519340,
                "post_id": 69018477,
                "comment_id": 121980832,
                "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"
                },
                "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": 1630523900,
                "post_id": 69018477,
                "comment_id": 121982413,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1630524599,
                "creation_date": 1630524599,
                "answer_id": 69019599,
                "question_id": 69018477,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following program produces the output shown below it:\r\n```\r\ndef q: &quot;\\&quot;\\(.)\\&quot;&quot;;\r\n\r\n.[]\r\n| to_entries[]\r\n| (.key|q) as $k\r\n| if .value|type == &quot;array&quot;\r\n  then .value[] | &quot;\\($k): \\(q)&quot;\r\n  else &quot;\\($k): \\(.value|q)&quot;\r\n  end\r\n```\r\n\r\nOutput:\r\n```\r\n&quot;a&quot;: &quot;A&quot;\r\n&quot;b&quot;: &quot;123&quot;\r\n&quot;c&quot;: &quot;C1&quot;\r\n&quot;c&quot;: &quot;C2&quot;\r\n```\r\n\r\nThis, or something very much like it, should be sufficient for using in a bash script, but if you really want the format shown in the Q, feel free to fiddle around.  A more useful way to spend your time would probably be to read up on jq-bash interoperability, e.g. here on SO:\r\n\r\n* https://stackoverflow.com/questions/67030229/is-there-a-way-to-output-jq-into-multiple-variables-for-bash-script\r\n\r\n* https://stackoverflow.com/questions/22528142/get-field-from-json-and-assign-to-variable-in-bash-script\r\n\r\n... and many others.",
                "title": "JQ how to combine heterogeneous objects into one array?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1630524599,
        "creation_date": 1630518443,
        "last_edit_date": 1630519008,
        "question_id": 69018477,
        "body_markdown": "How could I use JQ to parse the following JSON object and produce the output below?\r\n\r\nJSON Input:\r\n```\r\n{\r\n\t&quot;key1&quot;: {\r\n\t\t&quot;a&quot;: &quot;A&quot;\r\n\t},\r\n\t&quot;key2&quot;: {\r\n\t\t&quot;b&quot;: &quot;123&quot;\r\n\t},\r\n\t&quot;key3&quot;: {\r\n\t\t&quot;c&quot;: [&quot;C1&quot;, &quot;C2&quot;]\r\n\t}\r\n}\r\n```\r\n\r\nDesired Output:\r\n```\r\n[\r\n  &quot;a&quot;: &quot;A&quot;,\r\n  &quot;b&quot;: 123,\r\n  &quot;c&quot;: &quot;C1&quot;,\r\n  &quot;c&quot;: &quot;C2&quot;\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/69018477/jq-how-to-combine-heterogeneous-objects-into-one-array",
        "title": "JQ how to combine heterogeneous objects into one array?"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1630570112,
                "post_id": 69025923,
                "comment_id": 121993926,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1212419,
                    "reputation": 2795,
                    "user_id": 1180711,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/60fe122d5ed02d88aa279337d12c43aa?s=256&d=identicon&r=PG",
                    "display_name": "Sunil Kumar B M",
                    "link": "https://stackoverflow.com/users/1180711/sunil-kumar-b-m"
                },
                "reply_to_user": {
                    "account_id": 10015983,
                    "reputation": 144648,
                    "user_id": 9072753,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/EPmGy.jpg?s=256",
                    "display_name": "KamilCuk",
                    "link": "https://stackoverflow.com/users/9072753/kamilcuk"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630581071,
                "post_id": 69025923,
                "comment_id": 121998669,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1630567891,
        "creation_date": 1630567891,
        "question_id": 69025923,
        "body_markdown": "I have some json data which looks like below:\r\n\r\n```\r\n{&quot;spark.master&quot;: &quot;local&quot;}\r\n```\r\n\r\nI have this stored in a shell variable called `json_data`\r\n\r\n```\r\njson_data=&#39;{&quot;spark.master&quot;: &quot;local&quot;}&#39;\r\n```\r\n\r\nand parsing this using the jq shell utility.\r\n\r\nAs seen above, the key contains a period (.) character. If I try to read it directly using jq, it works fine\r\n\r\n```\r\n$ json_data=&#39;{&quot;spark.master&quot;: &quot;local&quot;}&#39;\r\n$ val=$(echo $json_data | jq .&#39;&quot;spark.master&quot;&#39;)\r\n$ echo $val\r\n&quot;local&quot;\r\n\r\n```\r\n\r\nBut if this key is stored in a variable, its not working\r\n```\r\n$ key=&quot;spark.master&quot;\r\n$ val=$(echo $json_data | jq .&#39;$key&#39;)\r\njq: error: syntax error, unexpected &#39;$&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.$key \r\njq: error: try .[&quot;field&quot;] instead of .field for unusually named fields at &lt;top-level&gt;, line 1:\r\n.$key\r\njq: 2 compile errors\r\n\r\n\r\n$ val=$(echo $json_data | jq .&quot;$key&quot;)\r\n$ echo $val\r\nnull\r\n\r\n```\r\n\r\nCan someone please help me identify what is going wrong here?",
        "link": "https://stackoverflow.com/questions/69025923/shell-script-jq-reading-a-json-key-with-period-inside-a-variable",
        "title": "Shell Script jq reading a json key with period (.) inside a variable"
    },
    {
        "tags": [
            "shell",
            "variables",
            "syntax-error",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2570367,
                    "reputation": 10875,
                    "user_id": 2229272,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oisED.png?s=256",
                    "display_name": "jas",
                    "link": "https://stackoverflow.com/users/2229272/jas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630574163,
                "post_id": 69026642,
                "comment_id": 121995694,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14879655,
                    "reputation": 428,
                    "user_id": 10744717,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bfc7f0d2964942bc5e01459ee2ca9ca4?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "K. Zhu",
                    "link": "https://stackoverflow.com/users/10744717/k-zhu"
                },
                "reply_to_user": {
                    "account_id": 2570367,
                    "reputation": 10875,
                    "user_id": 2229272,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oisED.png?s=256",
                    "display_name": "jas",
                    "link": "https://stackoverflow.com/users/2229272/jas"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630575077,
                "post_id": 69026642,
                "comment_id": 121996108,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 11,
                "is_accepted": true,
                "score": 11,
                "last_activity_date": 1630575994,
                "creation_date": 1630575994,
                "answer_id": 69027872,
                "question_id": 69026642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can assign a string to a variable that can be used inside a `jq` filter:\r\n\r\n```sh\r\nPRIV_KEY=&quot;44ab..._sk&quot;\r\njq --arg path &quot;$PRIV_KEY&quot; &#39;.organizations.Org1MSP.adminPrivateKey.path |= $path&#39; explorer/connection-profile/test-network.json \r\n```\r\n\r\nThis method is safer than trying to embed an expanded shell variable directly in the filter string because `jq` will properly handle arbitrary values instead of choking on things like quotes (Or their absence).\r\n\r\n---\r\n\r\nNote that `jq` takes filenames as arguments after the filter expression; no need for `cat` here (Unless that&#39;s standing in for `curl` or something, of course, and you&#39;re not using an existing file)",
                "title": "jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1649025728,
                "creation_date": 1649025728,
                "answer_id": 71730392,
                "question_id": 69026642,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "did you try this , i fixed the same error by setting the expression between &#39;&#39; and the values between &quot;&quot; \r\n\r\n    cat explorer/connection-profile/test-network.json | jq &#39;.organizations.Org1MSP.adminPrivateKey.path |= &quot;44ab&quot;&#39;",
                "title": "jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 9,
        "last_activity_date": 1649025728,
        "creation_date": 1630570978,
        "last_edit_date": 1630607026,
        "question_id": 69026642,
        "body_markdown": "```shell\r\ncat explorer/connection-profile/test-network.json | jq &quot;.organizations.Org1MSP.adminPrivateKey.path |= 44ab&quot;\r\n\r\njq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.organizations.Org1MSP.adminPrivateKey.path|=44ab                                               \r\njq: 1 compile error\r\n```\r\n\r\nbut it works fine with\r\n\r\n```shell\r\ncat explorer/connection-profile/test-network.json | jq &quot;.organizations.Org1MSP.adminPrivateKey.path |= 44&quot;\r\n```\r\n\r\nWhy?\r\n\r\nActually I am trying to use\r\n```shell\r\ncat explorer/connection-profile/test-network.json | jq &quot;.organizations.Org1MSP.adminPrivateKey.path |= ${PRIV_KEY}&quot;\r\n```\r\nwhere the ${PRIV_KEY} is 44ab..._sk",
        "link": "https://stackoverflow.com/questions/69026642/jq-error-syntax-error-unexpected-ident-expecting-end-unix-shell-quoting-is",
        "title": "jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;"
    },
    {
        "tags": [
            "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": 1630602533,
                "post_id": 69032773,
                "comment_id": 122008594,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1630595285,
                "creation_date": 1630595285,
                "answer_id": 69032847,
                "question_id": 69032773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assign the lookup object to a variable first:\r\n```\r\n{ &quot;radiogroup&quot;: &quot;radio&quot;, &quot;checkbox&quot;: &quot;checkbox&quot;, &quot;dropdown&quot;: &quot;select&quot;, &quot;text&quot;: &quot;text&quot;, &quot;rating&quot;: &quot;rate&quot;, &quot;boolean&quot;: &quot;switch&quot;, &quot;comment&quot;: &quot;textarea&quot; }\r\n  as $lookup | $lookup[.type]\r\n```",
                "title": "How to use result from a query as attribute to select from input?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1630596269,
                "last_edit_date": 1630596269,
                "creation_date": 1630595888,
                "answer_id": 69033018,
                "question_id": 69032773,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If both the `input` and `map` objects are in separate files we can use an alternative to [Botje](https://stackoverflow.com/a/69032847/5625547)&#39;s solution, were we read both object into a single array using the `-s` (slurp) option.\r\n\r\n----------\r\n\r\n\r\nThen we can\r\n```\r\njq -s &#39;.[1].type = .[0][.[1].type] | last&#39; map input\r\n```\r\n\r\n* Change `.type` (on second index) to the mapped value from the first index  \r\n    `.[1].type = .[0][.[1].type]`\r\n* Output only the second object  \r\n    `| last`\r\n\r\n\r\nWhich will produce\r\n\r\n```json\r\n{\r\n  &quot;type&quot;: &quot;select&quot;\r\n}\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\nExample from my local machine:\r\n```none\r\n$ jq . map\r\n{\r\n  &quot;radiogroup&quot;: &quot;radio&quot;,\r\n  &quot;checkbox&quot;: &quot;checkbox&quot;,\r\n  &quot;dropdown&quot;: &quot;select&quot;,\r\n  &quot;text&quot;: &quot;text&quot;,\r\n  &quot;rating&quot;: &quot;rate&quot;,\r\n  &quot;boolean&quot;: &quot;switch&quot;,\r\n  &quot;comment&quot;: &quot;textarea&quot;\r\n}\r\n$ jq . input\r\n{\r\n  &quot;type&quot;: &quot;dropdown&quot;\r\n}\r\n$\r\n$ jq -s &#39;.[1].type = .[0][.[1].type] | last&#39; map input\r\n{\r\n  &quot;type&quot;: &quot;select&quot;\r\n}\r\n$\r\n```",
                "title": "How to use result from a query as attribute to select from input?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1630649871,
        "creation_date": 1630595037,
        "last_edit_date": 1630649871,
        "question_id": 69032773,
        "body_markdown": "given a input `{ &quot;type&quot;: &quot;dropdown&quot;}`, I want to turn the type to `select`, based on the following type mapping, possible to do this in jq? Thanks\r\n```\r\n{\r\n        &quot;radiogroup&quot;: &quot;radio&quot;,\r\n        &quot;checkbox&quot;: &quot;checkbox&quot;,\r\n        &quot;dropdown&quot;: &quot;select&quot;,\r\n        &quot;text&quot;: &quot;text&quot;,\r\n        &quot;rating&quot;: &quot;rate&quot;,\r\n        &quot;boolean&quot;: &quot;switch&quot;,\r\n        &quot;comment&quot;: &quot;textarea&quot;\r\n    }\r\n```\r\n\r\nPS: check  https://jqplay.org/s/BQo197AF7Q for demo of using the lookup table approach.",
        "link": "https://stackoverflow.com/questions/69032773/how-to-use-result-from-a-query-as-attribute-to-select-from-input",
        "title": "How to use result from a query as attribute to select from input?"
    },
    {
        "tags": [
            "python",
            "linux",
            "jq",
            "centos7"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1630639259,
                "creation_date": 1630639259,
                "answer_id": 69039111,
                "question_id": 69038990,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If I understand the question correctly, this should do the trick:\r\n\r\nThe `target` parameter is the IP address you want to remove, while the `file_path` is the path of the json file\r\n\r\nedit: also, don&#39;t forget to `import json` or else it won&#39;t work\r\n\r\n```python\r\ndef remove_obj(target, file_path):\r\n    with open(file_path, &quot;r&quot;) as data_file:\r\n        data = json.load(data_file)\r\n\r\n    for obj in data:\r\n        if target in obj[&quot;targets&quot;]:\r\n            data.remove(obj)\r\n\r\n    with open(file_path, &quot;w&quot;) as data_file:\r\n        json.dump(data, data_file, indent=4)\r\n```",
                "title": "Remove specific data from json file in linux"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1630640157,
                "creation_date": 1630640157,
                "answer_id": 69039186,
                "question_id": 69038990,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using `jq`:\r\n\r\n```sh\r\n$ jq --arg ip 172.17.1.51 &#39;map(select(.targets | contains([$ip]) | not ))&#39; input.json \r\n[\r\n  {\r\n    &quot;targets&quot;: [\r\n      &quot;172.17.1.199&quot;\r\n    ],\r\n    &quot;labels&quot;: {\r\n      &quot;__meta_netbox_pop&quot;: &quot;st-1742&quot;,\r\n      &quot;__snmp_module__&quot;: &quot;arista_sw&quot;\r\n    }\r\n  }\r\n]\r\n```",
                "title": "Remove specific data from json file in linux"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1630640157,
        "creation_date": 1630637722,
        "question_id": 69038990,
        "body_markdown": "I have a json file with set of data with repeating fields. I need to remove an entry with specific data of a field.\r\n\r\nJson file:\r\n```\r\n[\r\n    {\r\n        &quot;targets&quot;: [\r\n            &quot;172.17.1.199&quot;\r\n        ],\r\n        &quot;labels&quot;: {\r\n            &quot;__meta_netbox_pop&quot;: &quot;st-1742&quot;,\r\n            &quot;__snmp_module__&quot;: &quot;arista_sw&quot;\r\n        }\r\n    },\r\n    {\r\n        &quot;targets&quot;: [\r\n            &quot;172.17.1.51&quot;\r\n        ],\r\n        &quot;labels&quot;: {\r\n            &quot;__meta_netbox_pop&quot;: &quot;st-1754&quot;,\r\n            &quot;__snmp_module__&quot;: &quot;arista_sw&quot;\r\n        }\r\n    }\r\n]\r\n```\r\nThe json file goes on and but this is an example of the whole json file.\r\n\r\nI need to remove an entry of `targets` with its `labels` given a data of the `target&#39;s` IP.\r\n\r\nInput:\r\n```\r\n172.17.1.51\r\n```\r\n\r\nexpected output:\r\n```\r\n[\r\n    {\r\n        &quot;targets&quot;: [\r\n            &quot;172.17.1.199&quot;\r\n        ],\r\n        &quot;labels&quot;: {\r\n            &quot;__meta_netbox_pop&quot;: &quot;st-1742&quot;,\r\n            &quot;__snmp_module__&quot;: &quot;arista_sw&quot;\r\n        }\r\n    }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/69038990/remove-specific-data-from-json-file-in-linux",
        "title": "Remove specific data from json file in linux"
    },
    {
        "tags": [
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1630644026,
                "creation_date": 1630644026,
                "answer_id": 69039594,
                "question_id": 69039593,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you can assume that the attribute names are the same in all array elements, you can use the `@csv` formatter along with `--raw-output`:\r\n\r\nPut this in a script like `json-records-to-csv.jq`, adjusting the shebang as needed:\r\n\r\n```jq\r\n#!/usr/bin/jq --raw-output -f\r\n\r\n# Like `keys`; extracts object values as an array.\r\ndef values:\r\n    to_entries | map(.value)\r\n;\r\n\r\n# Get the column names from the first array element keys\r\n(.[0] | keys | @csv)\r\n,\r\n# Get the values from every array element values\r\n(.[] | values | @csv)\r\n```\r\n\r\nUsage example:\r\n\r\n```bash\r\njson-records-to-csv.jq &lt;&lt;&#39;JSON&#39;\r\n[\r\n  {&quot;a&quot;: 11, &quot;b&quot;: 12, &quot;c&quot;: 13},\r\n  {&quot;a&quot;: 21, &quot;b&quot;: 22, &quot;c&quot;: 23},\r\n  {&quot;a&quot;: 31, &quot;b&quot;: 32, &quot;c&quot;: 33},\r\n  {&quot;a&quot;: 41, &quot;b&quot;: 42, &quot;c&quot;: 43}\r\n]\r\nJSON\r\n```\r\n\r\nOutput:\r\n\r\n```\r\n&quot;a&quot;,&quot;b&quot;,&quot;c&quot;\r\n11,12,13\r\n21,22,23\r\n31,32,33\r\n41,42,43\r\n```",
                "title": "How can I emit delimited text (like CSV) from Jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1630663026,
                "creation_date": 1630663026,
                "answer_id": 69043015,
                "question_id": 69039593,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq --raw-output &#39;map({ a, c }) | ( .[0] | keys_unsorted), (.[] | [.[]]) | @csv&#39;\r\n```\r\n\r\nWill produce:\r\n```csv\r\n&quot;a&quot;,&quot;c&quot;\r\n11,13\r\n21,23\r\n31,33\r\n41,43\r\n```\r\n\r\n\r\n----------\r\n\r\n\r\n[Online JqPlay Demo](https://jqplay.org/s/nSmcvPlvNS)",
                "title": "How can I emit delimited text (like CSV) from Jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1630663026,
        "creation_date": 1630644026,
        "question_id": 69039593,
        "body_markdown": "When using Jq for data processing, it&#39;s often more convenient to emit the processed text in some kind of &quot;delimited&quot; form that other CLI tools can consume, such as Awk, Cut, and the `read` builtin in Bash.\r\n\r\nIs there a straightforward way to achieve this?\r\n\r\nSample data:\r\n\r\n```\r\n[\r\n  {&quot;a&quot;: 11, &quot;b&quot;: 12, &quot;c&quot;: 13},\r\n  {&quot;a&quot;: 21, &quot;b&quot;: 22, &quot;c&quot;: 23},\r\n  {&quot;a&quot;: 31, &quot;b&quot;: 32, &quot;c&quot;: 33},\r\n  {&quot;a&quot;: 41, &quot;b&quot;: 42, &quot;c&quot;: 43}\r\n]\r\n```\r\n\r\nDesired output:\r\n\r\n```\r\na,c\r\n11,13\r\n21,21\r\n31,33\r\n41,43\r\n```",
        "link": "https://stackoverflow.com/questions/69039593/how-can-i-emit-delimited-text-like-csv-from-jq",
        "title": "How can I emit delimited text (like CSV) from Jq?"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630684750,
                "post_id": 69047630,
                "comment_id": 122032552,
                "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": 1630684799,
                "post_id": 69047630,
                "comment_id": 122032570,
                "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": 1630686911,
                "post_id": 69047630,
                "comment_id": 122033307,
                "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": 1630687027,
                "post_id": 69047630,
                "comment_id": 122033349,
                "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": 1630688252,
                "post_id": 69047630,
                "comment_id": 122033781,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1630689876,
                "creation_date": 1630689876,
                "answer_id": 69048648,
                "question_id": 69047630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following produces the required output:\r\n```\r\njq -n --stream &#39;\r\n  [{data: fromstream(5|truncate_stream(inputs))}]\r\n&#39; input.json \r\n```\r\n\r\nNeedless to say, there are other variations ...",
                "title": "jq parse json with stream flag into different json file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1630690426,
                "creation_date": 1630690426,
                "answer_id": 69048741,
                "question_id": 69047630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a solution that does not use `truncate_stream`:\r\n```\r\njq -n --stream &#39;\r\n [fromstream( \r\n   inputs\r\n   | (.[0] | index(&quot;data&quot;)) as $ix\r\n   | select($ix)\r\n   | .[0] |= .[$ix:] )]\r\n&#39; input.json\r\n```",
                "title": "jq parse json with stream flag into different json file"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1647903982,
                "last_edit_date": 1647903982,
                "creation_date": 1647837686,
                "answer_id": 71552894,
                "question_id": 69047630,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a step-by-step explanation of peak&#39;s answers.\r\n\r\nFirst let&#39;s convert the json to stream.\r\n\r\nhttps://jqplay.org/s/VEunTmDSkf\r\n\r\n```\r\n[[&quot;id&quot;,&quot;bioguide&quot;],&quot;E000295&quot;]\r\n[[&quot;id&quot;,&quot;thomas&quot;],&quot;02283&quot;]\r\n[[&quot;id&quot;,&quot;govtrack&quot;],412667]\r\n[[&quot;id&quot;,&quot;opensecrets&quot;],&quot;N00035483&quot;]\r\n[[&quot;id&quot;,&quot;lis&quot;],&quot;S376&quot;]\r\n[[&quot;id&quot;,&quot;lis&quot;]]\r\n[[&quot;bio&quot;,&quot;gender&quot;],&quot;F&quot;]\r\n[[&quot;bio&quot;,&quot;birthday&quot;],&quot;1970-07-01&quot;]\r\n[[&quot;bio&quot;,&quot;birthday&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;name&quot;],&quot;A&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;toolid&quot;],12345]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;time&quot;],&quot;2021-01-01&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;value&quot;],1]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,1,&quot;time&quot;],&quot;2021-01-02&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,1,&quot;value&quot;],10]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,1,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2,&quot;time&quot;],&quot;2021-01-03&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2,&quot;value&quot;],5]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;toolid&quot;],12346]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,0,&quot;time&quot;],&quot;2021-01-01&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,0,&quot;value&quot;],10]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,0,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,1,&quot;time&quot;],&quot;2021-01-02&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,1,&quot;value&quot;],100]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,1,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2,&quot;time&quot;],&quot;2021-01-03&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2,&quot;value&quot;],50]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;]]\r\n[[&quot;tooldatareports&quot;,0]]\r\n[[&quot;tooldatareports&quot;]]\r\n```\r\n\r\nNow do `.[0]` to extract the `path` portion of stream.\r\n\r\nhttps://jqplay.org/s/XdPrp8RuEj\r\n\r\n```\r\n[&quot;id&quot;,&quot;bioguide&quot;]\r\n[&quot;id&quot;,&quot;thomas&quot;]\r\n[&quot;id&quot;,&quot;govtrack&quot;]\r\n[&quot;id&quot;,&quot;opensecrets&quot;]\r\n[&quot;id&quot;,&quot;lis&quot;]\r\n[&quot;id&quot;,&quot;lis&quot;]\r\n[&quot;bio&quot;,&quot;gender&quot;]\r\n[&quot;bio&quot;,&quot;birthday&quot;]\r\n[&quot;bio&quot;,&quot;birthday&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;name&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;toolid&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;time&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,1,&quot;time&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,1,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,1,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2,&quot;time&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;toolid&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,0,&quot;time&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,0,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,0,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,1,&quot;time&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,1,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,1,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2,&quot;time&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2,&quot;value&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1]\r\n[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;]\r\n[&quot;tooldatareports&quot;,0]\r\n[&quot;tooldatareports&quot;]\r\n```\r\n\r\nLet me first quickly explain `index\\1`.\r\n\r\n`index(&quot;data&quot;)` of `[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;time&quot;],&quot;2021-01-01&quot;]` is 4 since that is the index of the first occurrence of &quot;data&quot;.\r\n\r\nKnowing that let&#39;s now do `.[0] | index(&quot;data&quot;)`.\r\n\r\nhttps://jqplay.org/s/ny0bV1xEED\r\n\r\n```\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\nnull\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\nnull\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\n4\r\nnull\r\nnull\r\nnull\r\nnull\r\n```\r\nAs you can see in our case the indexes are either 4 or null. We want to filter each `input` such that the corresponding index is not null. Those are the `input` that have &quot;data&quot; as part of their path.\r\n\r\n`(.[0] | index(&quot;data&quot;)) as $ix | select($ix)` does just that.  Remember that each `$ix` is mapped to each **input**. So only input with their `$ix` being not null are displayed.\r\n\r\nFor example see https://jqplay.org/s/NwcD7_USZE Here `inputs | select(null)` gives no output but `inputs | select(true)` outputs every `input`.\r\n\r\nThese are the filtered stream:\r\n\r\nhttps://jqplay.org/s/SgexvhtaGe\r\n\r\n```\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;time&quot;],&quot;2021-01-01&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;value&quot;],1]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,1,&quot;time&quot;],&quot;2021-01-02&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,1,&quot;value&quot;],10]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,1,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2,&quot;time&quot;],&quot;2021-01-03&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2,&quot;value&quot;],5]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,2]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,0,&quot;time&quot;],&quot;2021-01-01&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,0,&quot;value&quot;],10]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,0,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,1,&quot;time&quot;],&quot;2021-01-02&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,1,&quot;value&quot;],100]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,1,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2,&quot;time&quot;],&quot;2021-01-03&quot;]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2,&quot;value&quot;],50]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2,&quot;value&quot;]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;,2]]\r\n[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,1,&quot;data&quot;]]\r\n```\r\n\r\nBefore we go further let&#39;s review *update assignment*.\r\n\r\nHave a look at https://jqplay.org/s/g4P6j8f9FG\r\n\r\nLet&#39;s say we have input `[[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;time&quot;],&quot;2021-01-01&quot;]`.\r\n\r\nThen filter `.[0] |= .[4:]` produces `[[&quot;data&quot;,0,&quot;time&quot;],&quot;2021-01-01&quot;]`.\r\n\r\nWhy?\r\n\r\nRemember that right hand side (`.[4:]`) **inherits** the context of the left hand side(`.[0]`). So in this case it has the effect of updating the path `[&quot;tooldatareports&quot;,0,&quot;tooldata&quot;,0,&quot;data&quot;,0,&quot;time&quot;]` to `[&quot;data&quot;,0,&quot;time&quot;]`.\r\n\r\nLet&#39;s move on then.\r\n\r\nSo `(.[0] | index(&quot;data&quot;)) as $ix | select($ix) | .[0] |= .[$ix:]` has the output:\r\n\r\nhttps://jqplay.org/s/AwcQpVyHO2\r\n\r\n```\r\n[[&quot;data&quot;,0,&quot;time&quot;],&quot;2021-01-01&quot;]\r\n[[&quot;data&quot;,0,&quot;value&quot;],1]\r\n[[&quot;data&quot;,0,&quot;value&quot;]]\r\n[[&quot;data&quot;,1,&quot;time&quot;],&quot;2021-01-02&quot;]\r\n[[&quot;data&quot;,1,&quot;value&quot;],10]\r\n[[&quot;data&quot;,1,&quot;value&quot;]]\r\n[[&quot;data&quot;,2,&quot;time&quot;],&quot;2021-01-03&quot;]\r\n[[&quot;data&quot;,2,&quot;value&quot;],5]\r\n[[&quot;data&quot;,2,&quot;value&quot;]]\r\n[[&quot;data&quot;,2]]\r\n[[&quot;data&quot;]]\r\n[[&quot;data&quot;,0,&quot;time&quot;],&quot;2021-01-01&quot;]\r\n[[&quot;data&quot;,0,&quot;value&quot;],10]\r\n[[&quot;data&quot;,0,&quot;value&quot;]]\r\n[[&quot;data&quot;,1,&quot;time&quot;],&quot;2021-01-02&quot;]\r\n[[&quot;data&quot;,1,&quot;value&quot;],100]\r\n[[&quot;data&quot;,1,&quot;value&quot;]]\r\n[[&quot;data&quot;,2,&quot;time&quot;],&quot;2021-01-03&quot;]\r\n[[&quot;data&quot;,2,&quot;value&quot;],50]\r\n[[&quot;data&quot;,2,&quot;value&quot;]]\r\n[[&quot;data&quot;,2]]\r\n[[&quot;data&quot;]]\r\n```\r\nNow all we need to do is convert this stream back to json.\r\n\r\nhttps://jqplay.org/s/j2uyzEU_Rc\r\n\r\n`[fromstream(inputs)]` gives:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-01&quot;,\r\n        &quot;value&quot;: 1\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-02&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-03&quot;,\r\n        &quot;value&quot;: 5\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-01&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-02&quot;,\r\n        &quot;value&quot;: 100\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-03&quot;,\r\n        &quot;value&quot;: 50\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nThis is the output we wanted.",
                "title": "jq parse json with stream flag into different json file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1647903982,
        "creation_date": 1630684182,
        "last_edit_date": 1630718973,
        "question_id": 69047630,
        "body_markdown": "I have a json file as below called data.json, I want to parse the data with **jq** tool in **streaming mode**(do not load the whole file into memory), because the **real data have 20GB**\r\n\r\nthe streaming mode in jq seems to add a flag --stream and it will parse the json file row by row\r\n```\r\n{\r\n  &quot;id&quot;: {\r\n    &quot;bioguide&quot;: &quot;E000295&quot;,\r\n    &quot;thomas&quot;: &quot;02283&quot;,\r\n    &quot;govtrack&quot;: 412667,\r\n    &quot;opensecrets&quot;: &quot;N00035483&quot;,\r\n    &quot;lis&quot;: &quot;S376&quot;\r\n  },\r\n  &quot;bio&quot;: {\r\n    &quot;gender&quot;: &quot;F&quot;,\r\n    &quot;birthday&quot;: &quot;1970-07-01&quot;\r\n  },\r\n  &quot;tooldatareports&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;A&quot;,\r\n      &quot;tooldata&quot;: [\r\n        {\r\n          &quot;toolid&quot;: 12345,\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-01&quot;,\r\n              &quot;value&quot;: 1\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-02&quot;,\r\n              &quot;value&quot;: 10\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-03&quot;,\r\n              &quot;value&quot;: 5\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;toolid&quot;: 12346,\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-01&quot;,\r\n              &quot;value&quot;: 10\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-02&quot;,\r\n              &quot;value&quot;: 100\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-03&quot;,\r\n              &quot;value&quot;: 50\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nThe final result I hope it can become as below\r\n\r\nA list contains two dict, each dict contain 2 keys\r\n```\r\n[\r\n  {\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-01&quot;,\r\n        &quot;value&quot;: 1\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-02&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-03&quot;,\r\n        &quot;value&quot;: 5\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-01&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-02&quot;,\r\n        &quot;value&quot;: 100\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-03&quot;,\r\n        &quot;value&quot;: 50\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nFor this problem, I use the below command line to get a result, but it still has some differences.\r\n\r\ncat data.json | jq --stream &#39;select(.[0][0]==&quot;tooldatareports&quot; and .[0][2]==&quot;tooldata&quot; and .[1]!=null) | .&#39;\r\n\r\n1. the result is not a list contain a lot of dict\r\n2. for each time and value are separate in the different list\r\n\r\nDoes anyone have any idea about this?",
        "link": "https://stackoverflow.com/questions/69047630/jq-parse-json-with-stream-flag-into-different-json-file",
        "title": "jq parse json with stream flag into different json file"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1630748371,
                "last_edit_date": 1630748371,
                "creation_date": 1630747645,
                "answer_id": 69054030,
                "question_id": 69053857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your output is a json list, so you won&#39;t get away with a direct bash loop over it. The bash loop won&#39;t know what to do with the square brackets and will use each space and newline as a separator. Use `jq` again to get separate objects from your json list. That is done with `jq -c &#39;.[]&#39;`:\r\n\r\n    array=$(cat data.json |jq -n --stream &#39;[fromstream(inputs | (.[0] | index(&quot;data&quot;)) as $ix | select($ix) | .[0] |= .[$ix:])]&#39; | jq -c &#39;.[]&#39;)\r\n\r\nNow you have two objects in two separate lines and no spaces (`-c` = compact output) and you can loop over them in bash:\r\n\r\n    for d in $array\r\n    do\r\n        echo &quot;$d&quot;\r\n        # whatever else you need to do with them\r\n    done\r\n\r\n    {&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:1},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:10},{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:5}]}\r\n    {&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:10},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:100},{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:50}]}\r\n\r\n\r\n",
                "title": "how to for loop a jq array result in shell script"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1630748815,
                "last_edit_date": 1630748815,
                "creation_date": 1630748149,
                "answer_id": 69054096,
                "question_id": 69053857,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    $ jq -cn --stream &#39;[fromstream(inputs | (.[0] | index(&quot;data&quot;)) as $ix | select($ix) | .[0] |= .[$ix:])][]&#39; data.json | while read d; do echo &quot;item: $d&quot;; done\r\n    item: {&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:1},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:10},{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:5}]}\r\n    item: {&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:10},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:100},{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:50}]}\r\n\r\nNote that you can get very similar output with simpler `jq`:\r\n\r\n    jq -c &#39;.tooldatareports[].tooldata[].data&#39; data.json  | while read d; do echo &quot;item: $d&quot;; done\r\n    item: [{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:1},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:10},{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:5}]\r\n    item: [{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:10},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:100},{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:50}]\r\n\r\nAnd you can get identical output (this seems likely to be unnecessary) with:\r\n\r\n    $ jq -c &#39;.tooldatareports[].tooldata[].data | {&quot;data&quot;: .}&#39; data.json  | while read d; do echo &quot;item: $d&quot;; done\r\n    item: {&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:1},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:10},{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:5}]}\r\n    item: {&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:10},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:100},{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:50}]}",
                "title": "how to for loop a jq array result in shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 4,
        "last_activity_date": 1630748815,
        "creation_date": 1630746115,
        "last_edit_date": 1630746490,
        "question_id": 69053857,
        "body_markdown": "I have a json data as below\r\n```\r\n{\r\n  &quot;id&quot;: {\r\n    &quot;bioguide&quot;: &quot;E000295&quot;,\r\n    &quot;thomas&quot;: &quot;02283&quot;,\r\n    &quot;govtrack&quot;: 412667,\r\n    &quot;opensecrets&quot;: &quot;N00035483&quot;,\r\n    &quot;lis&quot;: &quot;S376&quot;\r\n  },\r\n  &quot;bio&quot;: {\r\n    &quot;gender&quot;: &quot;F&quot;,\r\n    &quot;birthday&quot;: &quot;1970-07-01&quot;\r\n  },\r\n  &quot;tooldatareports&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;A&quot;,\r\n      &quot;tooldata&quot;: [\r\n        {\r\n          &quot;toolid&quot;: 12345,\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-01&quot;,\r\n              &quot;value&quot;: 1\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-02&quot;,\r\n              &quot;value&quot;: 10\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-03&quot;,\r\n              &quot;value&quot;: 5\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;toolid&quot;: 12346,\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-01&quot;,\r\n              &quot;value&quot;: 10\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-02&quot;,\r\n              &quot;value&quot;: 100\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-03&quot;,\r\n              &quot;value&quot;: 50\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nnow I can use below command line to get a list containing two dict, \r\neach dict have a key &quot;data&quot;, value is a list,\r\n```\r\ncat data.json |jq -n --stream &#39;[fromstream(inputs | (.[0] | index(&quot;data&quot;)) as $ix | select($ix) | .[0] |= .[$ix:])]&#39;\r\n```\r\nI want to print each dict with a loop in shell script\r\n\r\nMy except in each loop have printed a dict, total have 2 dict \r\n\r\nBut it seems like a string\r\n\r\nbelow is my shell script\r\n```\r\narray=$(cat ernst.json | jq -n --stream &#39;[fromstream(inputs | (.[0] | index(&quot;data&quot;)) as $ix | select($ix) | .[0] |= .[$ix:])]&#39;)\r\n\r\nfor d in $array\r\ndo\r\n    echo $d\r\ndone\r\n```\r\nDoes anyone have any idea?",
        "link": "https://stackoverflow.com/questions/69053857/how-to-for-loop-a-jq-array-result-in-shell-script",
        "title": "how to for loop a jq array result in shell script"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1630874585,
                "creation_date": 1630874585,
                "answer_id": 69067073,
                "question_id": 69055207,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq -nM --stream &#39;\r\n [fromstream( \r\n   inputs\r\n   | (.[0] | index(&quot;id&quot;)) as $ix\r\n   | if $ix then .[0] |= .[1+$ix:] \r\n     else (.[0] | index(&quot;data&quot;)) as $ix\r\n     | if $ix then .[0] |= .[$ix:]\r\n       else (.[0] | index(&quot;tooldatareports&quot;)) as $ix\r\n       | (.[0][$ix:] | index(&quot;name&quot;)) as $jx\r\n       | if $jx then (.[0] |= .[$ix+$jx:] )\r\n         else (.[0] | index(&quot;toolid&quot;)) as $ix\r\n         | if $ix then .[0] |= .[$ix:] \r\n           else empty\r\n           end\r\n         end\r\n       end\r\n     end\r\n )]\r\n| .[0] as $general\r\n| [.[1:][] \r\n   | ($general + .)\r\n   | {bioguide,thomas,name,toolid,data} ]\r\n&#39; input.json \r\n```",
                "title": "How to add new key for each dict with jq streaming mode"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1630874585,
        "creation_date": 1630757818,
        "last_edit_date": 1630830406,
        "question_id": 69055207,
        "body_markdown": "I have a json below, I need to use stream mode(file is huge) to parse the data then convert it to another data structure\r\n\r\n```\r\n{\r\n  &quot;id&quot;: {\r\n    &quot;bioguide&quot;: &quot;E000295&quot;,\r\n    &quot;thomas&quot;: &quot;02283&quot;,\r\n    &quot;govtrack&quot;: 412667\r\n  },\r\n  &quot;bio&quot;: {\r\n    &quot;gender&quot;: &quot;F&quot;,\r\n    &quot;birthday&quot;: &quot;1970-07-01&quot;\r\n  },\r\n  &quot;tooldatareports&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;A&quot;,\r\n      &quot;tooldata&quot;: [\r\n        {\r\n          &quot;toolid&quot;: {\r\n            &quot;value&quot;: 12345\r\n          },\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-01&quot;,\r\n              &quot;value&quot;: 1\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-02&quot;,\r\n              &quot;value&quot;: 10\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-03&quot;,\r\n              &quot;value&quot;: 5\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;toolid&quot;: {\r\n            &quot;value&quot;: 12346\r\n          },\r\n          &quot;data&quot;: [\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-01&quot;,\r\n              &quot;value&quot;: 10\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-02&quot;,\r\n              &quot;value&quot;: 100\r\n            },\r\n            {\r\n              &quot;time&quot;: &quot;2021-01-03&quot;,\r\n              &quot;value&quot;: 50\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\nUse below command line can get the most data that I expect\r\nbut in each dict, have some key do not  have value, such as bioguide, thomas, name, toolid\r\n\r\n```\r\ncat data.json | jq -cn --stream &#39;[fromstream(inputs | (.[0] | index(&quot;data&quot;)) as $ix | select($ix) | .[0] |= .[$ix:]) | . +{&quot;bioguide&quot;:.id.bioguide[0], &quot;thomas&quot;:.id.thomas, &quot;name&quot;:.tooldatareports[0].name, &quot;toolid&quot;:.tooldatareports[0].tooldata.toolid.value}]&#39;\r\n```\r\n\r\nMy expected result is \r\n```\r\n[\r\n  {\r\n    &quot;bioguide&quot;: &quot;E000295&quot;,\r\n    &quot;thomas&quot;: &quot;02283&quot;,\r\n    &quot;name&quot;: &quot;A&quot;,\r\n    &quot;toolid&quot;: 12345,\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-01&quot;,\r\n        &quot;value&quot;: 1\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-02&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-03&quot;,\r\n        &quot;value&quot;: 5\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;bioguide&quot;: &quot;E000295&quot;,\r\n    &quot;thomas&quot;: &quot;02283&quot;,\r\n    &quot;name&quot;: &quot;A&quot;,\r\n    &quot;toolid&quot;: 12346,\r\n    &quot;data&quot;: [\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-01&quot;,\r\n        &quot;value&quot;: 10\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-02&quot;,\r\n        &quot;value&quot;: 100\r\n      },\r\n      {\r\n        &quot;time&quot;: &quot;2021-01-03&quot;,\r\n        &quot;value&quot;: 50\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nDoes anyone have any solution for this?",
        "link": "https://stackoverflow.com/questions/69055207/how-to-add-new-key-for-each-dict-with-jq-streaming-mode",
        "title": "How to add new key for each dict with jq streaming mode"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1630801590,
                "post_id": 69058307,
                "comment_id": 122054860,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13388313,
                    "reputation": 13,
                    "user_id": 9661451,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a9f162d094172bb4d3079cdbe004e666?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "K2-Beast",
                    "link": "https://stackoverflow.com/users/9661451/k2-beast"
                },
                "reply_to_user": {
                    "account_id": 2686715,
                    "reputation": 8666,
                    "user_id": 2320961,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AdwXN.png?s=256",
                    "display_name": "Nic3500",
                    "link": "https://stackoverflow.com/users/2320961/nic3500"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1630853996,
                "post_id": 69058307,
                "comment_id": 122063192,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1630806586,
                "creation_date": 1630806586,
                "answer_id": 69060076,
                "question_id": 69058307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the JSON has been fixed, consider the output of:\r\n```\r\n(null \r\n| {names,\r\n  ip_address,\r\n  &quot;discovered_data.mac_address&quot;,\r\n  &quot;discovered_data.discovered_name&quot;} | keys_unsorted) as $keys\r\n| $keys, \r\n  ({names: .names[],\r\n   ip_address,\r\n   &quot;discovered_data.mac_address&quot;: .discovered_data.mac_address,\r\n   &quot;discovered_data.discovered_name&quot;: .discovered_data.discovered_name }\r\n   | [.[]])\r\n| @csv\r\n```\r\nAssuming jq is invoked with the -r command-line option, this has the advantage of producing valid CSV.  If you prefer to have all the key names and values unquoted, you might wish to consider using `join(&quot;,&quot;)` instead of `@csv`, or some more sophisticated variation if you want to have your cake and eat it.",
                "title": "JQ to convert JSON to CSV for specific Keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1630854042,
        "creation_date": 1630782940,
        "last_edit_date": 1630854042,
        "question_id": 69058307,
        "body_markdown": "I am trying to convert JSON to CSV for selected keys using `jq`.\r\n\r\nfile.json\r\n```json\r\n{\r\n  &quot;_ref&quot;: &quot;ipv4address/Li5pcHY0X2FkZHJlc3yMDIuMS8w:10.202.202.1&quot;,\r\n  &quot;discovered_data&quot;: {\r\n    &quot;bgp_as&quot;: 64638,\r\n    &quot;device_model&quot;: &quot;catalyst37xxStack&quot;,\r\n    &quot;device_port_name&quot;: &quot;Vl2002&quot;,\r\n    &quot;device_port_type&quot;: &quot;propVirtual&quot;,\r\n    &quot;device_type&quot;: &quot;Switch-Router&quot;,\r\n    &quot;device_vendor&quot;: &quot;Cisco&quot;,\r\n    &quot;discovered_name&quot;: &quot;Test_Device.network.local&quot;,\r\n    &quot;discoverer&quot;: &quot;Network Insight&quot;,\r\n    &quot;first_discovered&quot;: 1580161888,\r\n    &quot;last_discovered&quot;: 1630773758,\r\n    &quot;mac_address&quot;: &quot;aa:bb:cc:dd:ee:ff&quot;,\r\n    &quot;mgmt_ip_address&quot;: &quot;10.202.202.1&quot;,\r\n    &quot;os&quot;: &quot;15.2(4)E10&quot;,\r\n    &quot;port_speed&quot;: &quot;Unknown&quot;,\r\n    &quot;port_vlan_name&quot;: &quot;TEST-DATA&quot;,\r\n    &quot;port_vlan_number&quot;: 2002\r\n  },\r\n  &quot;ip_address&quot;: &quot;10.202.202.1&quot;,\r\n  &quot;is_conflict&quot;: false,\r\n  &quot;mac_address&quot;: &quot;&quot;,\r\n  &quot;names&quot;: [&quot;Test_Device&quot;],\r\n  &quot;network&quot;: &quot;10.202.202.0/23&quot;,\r\n  &quot;network_view&quot;: &quot;TEST VIEW&quot;,\r\n  &quot;objects&quot;: [],\r\n  &quot;status&quot;: &quot;USED&quot;,\r\n  &quot;types&quot;: [\r\n    &quot;UNMANAGED&quot;\r\n  ],\r\n  &quot;usage&quot;: []\r\n}\r\n```\r\n\r\nmy desired output is:\r\n```csv\r\nnames,ip_address,discovered_data.mac_address,discovered_data.discovered_name\r\nTest_Device,10.202.202.1,aa:bb:cc:dd:ee:ff,Test_Device.network.local\r\n```\r\n\r\nSo far, I have tried using following command but getting some syntax error:\r\n```sh\r\njq -r &#39;map({names,ip_address,discovered_data.mac_address,discovered_data.discovered_name}) | (first | keys_unsorted) as $keys | map([to_entries[] | .value]) as $rows | $keys,$rows[] | @csv&#39; &lt; file.json\r\n``` \r\n",
        "link": "https://stackoverflow.com/questions/69058307/jq-to-convert-json-to-csv-for-specific-keys",
        "title": "JQ to convert JSON to CSV for specific Keys"
    },
    {
        "tags": [
            "arrays",
            "json",
            "unique",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1630807149,
                "creation_date": 1630807149,
                "answer_id": 69060097,
                "question_id": 69059937,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The task as I understand it can easily (and perhaps most easily) be accomplished using `unique`:\r\n\r\n    map( .bound_to |= unique )",
                "title": "Using jq unique_by with arrays"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1630808792,
        "creation_date": 1630804370,
        "last_edit_date": 1630808792,
        "question_id": 69059937,
        "body_markdown": "I am running jq 1.6. After hours of frustration trying different ways of using unique_by I decided I don&#39;t understand what it is doing and I haven&#39;t found an example similar to my use case\r\n\r\nI pipe curl output into a jq and do some processing. I then pipe the output to another jq to remove duplicates in &quot;sub&quot;arrays with:\r\n\r\n  jq &#39;. |= unique_by(.bound_to[].where_to)&#39;\r\n\r\nthe input being pipped into the above command looks like the below. I only want 1 entry in each bound_to array. As you can see record 2 and 3 have duplicates, yet unique_by doesn&#39;t remove them. Am I referencing it correctly or should I use a different filter combination?\r\n\r\nI don&#39;t get any errors, but I also still have all the bound_to entries in the output.\r\n\r\nthank you\r\n\r\n~~ INPUT TO JQ ~~\r\n```\r\n[{\r\n  &quot;location&quot;: &quot;S24C2B1F1&quot;,\r\n  &quot;bound_to&quot;: [\r\n    {\r\n      &quot;access_ids&quot;: [],\r\n      &quot;system_ssn&quot;: &quot;&quot;,\r\n      &quot;where_to&quot;: 11\r\n    }\r\n  ],\r\n  &quot;description&quot;: null,\r\n  &quot;ipv4&quot;: &quot;192.168.11.1&quot;,\r\n  &quot;id&quot;: &quot;50011&quot;\r\n},\r\n{\r\n  &quot;location&quot;: &quot;S24C2B1F2&quot;,\r\n  &quot;bound_to&quot;: [\r\n    {\r\n      &quot;access_ids&quot;: [],\r\n      &quot;system_ssn&quot;: &quot;&quot;,\r\n      &quot;where_to&quot;: 3\r\n    },\r\n    {\r\n      &quot;access_ids&quot;: [],\r\n      &quot;system_ssn&quot;: &quot;&quot;,\r\n      &quot;where_to&quot;: 3\r\n    },\r\n    {\r\n      &quot;access_ids&quot;: [],\r\n      &quot;system_ssn&quot;: &quot;&quot;,\r\n      &quot;where_to&quot;: 3\r\n    }\r\n  ],\r\n  &quot;description&quot;: null,\r\n  &quot;ipv4&quot;: &quot;10.10.3.254&quot;,\r\n  &quot;id&quot;: &quot;60003&quot;\r\n},\r\n{\r\n  &quot;location&quot;: &quot;S48C1B2F1&quot;,\r\n  &quot;bound_to&quot;: [\r\n    {\r\n      &quot;access_ids&quot;: [],\r\n      &quot;system_ssn&quot;: &quot;&quot;,\r\n      &quot;where_to&quot;: 10\r\n    },\r\n    {\r\n      &quot;access_ids&quot;: [],\r\n      &quot;system_ssn&quot;: &quot;&quot;,\r\n      &quot;where_to&quot;: 10\r\n    }\r\n  ],\r\n  &quot;description&quot;: null,\r\n  &quot;ipv4&quot;: &quot;192.168.10.1&quot;,\r\n  &quot;id&quot;: &quot;50010&quot;\r\n}\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/69059937/using-jq-unique-by-with-arrays",
        "title": "Using jq unique_by with arrays"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1630919981,
                "post_id": 69071926,
                "comment_id": 122077176,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1630919171,
                "creation_date": 1630919171,
                "answer_id": 69071968,
                "question_id": 69071926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The tricky part is you can&#39;t use `.0` as it&#39;s interpreted as a number, you need to use quotes:\r\n\r\n    jq &#39;.&quot;0&quot;.data_bags.passwords | keys&#39; file.json",
                "title": "How to filter JSON values with jq command?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1630919880,
                "creation_date": 1630919880,
                "answer_id": 69072110,
                "question_id": 69071926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or perhaps use `..`, e.g. along the lines of:\r\n\r\n    .. | objects | .passwords // empty",
                "title": "How to filter JSON values with jq command?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -3,
        "last_activity_date": 1630924704,
        "creation_date": 1630918947,
        "last_edit_date": 1630924704,
        "question_id": 69071926,
        "body_markdown": "I have the below JSON file\r\n\r\n    {\r\n    \t&quot;0&quot;: {\r\n    \t\t&quot;data_bags&quot;: {\r\n    \t\t\t&quot;license_keys&quot;: {\r\n    \t\t\t\t&quot;nagios&quot;: &quot;xxx&quot;\r\n    \t\t\t},\r\n    \t\t\t&quot;passwords&quot;: {\r\n    \t\t\t\t&quot;ONE&quot;: &quot;abcd&quot;,\r\n    \t\t\t\t&quot;TWO&quot;: &quot;efgh&quot;,\r\n    \t\t\t\t&quot;THREE&quot;: &quot;hhhhh&quot;,\r\n    \t\t\t\t&quot;FOUR&quot;: &quot;abcdefgh&quot;\r\n    \t\t\t}\r\n    \t\t}\r\n    \t}\r\n    }\r\n\r\nI would like to display password&#39;s with the help of `jq` command. Can someone please help?\r\n\r\ntried with below cmd:\r\n\r\n    cat .\\sample.json | jq-win64.exe -r &quot;.0.data_bags.passwords.license_keys.ONE&quot;\r\n\r\ngetting below error \r\n\r\n    jq: error: Invalid numeric literal at EOF at line 1, column 3 (while parsing &#39;.0.&#39;) at &lt;top-level&gt;, line 1:\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69071926/how-to-filter-json-values-with-jq-command",
        "title": "How to filter JSON values with jq command?"
    },
    {
        "tags": [
            "arrays",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1630954130,
                "last_edit_date": 1630954130,
                "creation_date": 1630943925,
                "answer_id": 69077423,
                "question_id": 69076304,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use the `transpose` function in `jq` to do the transposing of arrays, formed from keys/values.\r\n\r\n```none\r\njq &#39;[ to_entries[] | [.key, .value[]] ] | transpose&#39;\r\n```\r\nThe bulk of the magic is performed by the transpose built-in, but before that you just need to collect the values into an array of arrays. The CSV result can be generated with the `@csv` function.\r\n\r\n```none\r\njq --raw-output &#39;[ to_entries[] | [.key, .value[]] ] | transpose[] | @csv&#39;\r\n```\r\n\r\nYou could also use `map()` and be avoid the redundant `[..]` \r\n\r\n```none\r\njq &#39;to_entries | map([.key, .value[]]) | transpose&#39;\r\njq --raw-output &#39;to_entries | map([.key, .value[]]) | transpose[] | @csv&#39;\r\n```",
                "title": "Use JQ to form new arrays from items in arrays by index"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1630954130,
        "creation_date": 1630939103,
        "question_id": 69076304,
        "body_markdown": "I have some JSON data which is pretty typical CSV-style data, however it&#39;s represented in JSON. I am struggling to figure out the correct `jq` expression to convert the following JSON back to some JSON which can generate the appropriate CSV with `@csv`.\r\n\r\nThere&#39;s a fixed number of &#39;columns&#39;, i.e. the `&quot;AAA&quot;` values, but the number of values in each &#39;column&#39; is dynamic yet fixed across columns. That is, the length of the arrays `&quot;AAA&quot;`, `&quot;BBB&quot;`, `&quot;CCC&quot;`, etc are all the same, but the length is dynamic and can change between data sets.\r\n\r\nInput (note invalid numbers present, to illustrate example):\r\n```json\r\n{\r\n  &quot;AAA&quot;: [\r\n    111.1,\r\n    111.2,\r\n    111.3,\r\n    111..,\r\n    111.n\r\n  ],\r\n  &quot;BBB&quot;: [\r\n    222.1,\r\n    222.2,\r\n    222.3,\r\n    222..,\r\n    222.n\r\n  ],\r\n  &quot;CCC&quot;: [\r\n    333.1,\r\n    333.2,\r\n    333.3,\r\n    333..,\r\n    333.n\r\n  ],\r\n  &quot;DDD&quot;: [\r\n    444.1,\r\n    444.2,\r\n    444.3,\r\n    444..,\r\n    444.n\r\n  ],\r\n  &quot;EEE&quot;: [\r\n    555.1,\r\n    555.2,\r\n    555.3,\r\n    555..,\r\n    555.n\r\n  ]\r\n}\r\n```\r\n\r\nDesired output (note invalid numbers present, to illustrate example):\r\n```json\r\n{\r\n  [        \r\n    &quot;AAA&quot;, \r\n    &quot;BBB&quot;, \r\n    &quot;CCC&quot;, \r\n    &quot;DDD&quot;, \r\n    &quot;EEE&quot;  \r\n  ],\r\n  [\r\n    111.1,\r\n    222.1,\r\n    333.1,\r\n    444.1,\r\n    555.1\r\n  ],\r\n  [\r\n    111.2,\r\n    222.2,\r\n    333.2,\r\n    444.2,\r\n    555.2\r\n  ],\r\n  [\r\n    111.3,\r\n    222.3,\r\n    333.3,\r\n    444.3,\r\n    555.3\r\n  ],\r\n  [\r\n    111..,\r\n    222..,\r\n    333..,\r\n    444..,\r\n    555..\r\n  ],\r\n  [\r\n    111.n,\r\n    222.n,\r\n    333.n,\r\n    444.n,\r\n    555.n\r\n  ]\r\n}\r\n```\r\n\r\nHere is the desired CSV, for illustration purposes (as converting with `@csv` is pretty straightforward):\r\n\r\n```csv\r\nAAA,BBB,CCC,DDD,EEE\r\n111.1,222.1,333.1,444.1,555.1\r\n111.2,222.2,333.2,444.2,555.2\r\n111.3,222.3,333.3,444.3,555.3\r\n111..,222..,333..,444..,555..\r\n111.n,222.n,333.n,444.n,555.n\r\n```\r\n\r\nIf the required expression is far easier without the first array in the result object containing the `&quot;AAA&quot;` &#39;header&#39; values then I can easily live without them.\r\n\r\nThank you.\r\n",
        "link": "https://stackoverflow.com/questions/69076304/use-jq-to-form-new-arrays-from-items-in-arrays-by-index",
        "title": "Use JQ to form new arrays from items in arrays by index"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1630959637,
                "creation_date": 1630959637,
                "answer_id": 69079924,
                "question_id": 69079904,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.[]` are [Array/Object Value **Iterator&#39;s**](https://stedolan.github.io/jq/manual/#Array/ObjectValueIterator:.[]).\r\n\r\nSince you&#39;re dealing with an object, no need to use an iterator, you can target your array like so:\r\n\r\n```\r\njq &#39;.cmp.vr1.vr2.mpa = [ &quot;bar1&quot;, &quot;bar2&quot; ]&#39; input.json\r\n```\r\n\r\n[Snippet](https://jqplay.org/s/Ioj8q0uag8)",
                "title": "using jq to update a json value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1630960160,
        "creation_date": 1630959484,
        "last_edit_date": 1630960160,
        "question_id": 69079904,
        "body_markdown": "I have a JSON file like this:\r\n\r\n```\r\n{\r\n  &quot;cmp&quot;: {\r\n    &quot;vr1&quot;: {\r\n      &quot;vr2&quot;: {\r\n        &quot;mpa&quot;: [\r\n          &quot;foo1&quot;,\r\n          &quot;foo2&quot;          \r\n        ]\r\n      }\r\n    }\r\n  },  \r\n  &quot;at&quot;: &quot;&quot;,\r\n  &quot;pl&quot;: {\r\n    &quot;accountId&quot;: &quot;&quot;\r\n  },\r\n  &quot;sv&quot;: {\r\n    &quot;accountId&quot;: &quot;&quot;\r\n  }\r\n}\r\n```\r\nI am trying to use `jq` to replace the values in the JSON array `mpa` from [&quot;foo1&quot;, &quot;foo2&quot;] to [&quot;bar1&quot;, &quot;bar2&quot;]. How can I do this?\r\n\r\nMy attempt:\r\n\r\n```\r\njq -r -e \\\r\n\t.[].cmp.vr1.vr2.mpa=[&quot;bar1&quot;, &quot;bar2&quot;]\r\n\t&lt; /tmp/json-file.json\r\n```\r\n\r\nWhat am I missing?",
        "link": "https://stackoverflow.com/questions/69079904/using-jq-to-update-a-json-value",
        "title": "using jq to update a json value"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1631175079,
                "last_edit_date": 1631175079,
                "creation_date": 1630969818,
                "answer_id": 69080978,
                "question_id": 69080571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You haven&#39;t been very clear on what you intend. I infer that you&#39;re looking for a cartesian product of the input arrays, such that your output array has an object for each possible pairing of one object from file1&#39;s array and one object from file2&#39;s array, and that the output objects are the merging of the two paired input objects.\r\n\r\nAny time you combine two expressions that output multiple items in an object constructor or a binary operation you will get a cartesian product. Since the `+` operator merges together objects, it&#39;s a good candidate.\r\n\r\nThis should do what you want:\r\n\r\n```\r\njq -n --slurpfile file1 file1.json --slurpfile file2 file2.json &#39;[$file2[0][] + $file1[0][]|{a,b,x,y,z}]&#39;\r\n```\r\n\r\nWe need the first `[0]` to &quot;unwrap&quot; the extra array that `--slurpfile` introduces. The following `[]` iterates over all the objects in your input array. Since both subexpressions to the `+` operator produce multiple items, we get the desired cartesian product. Lastly the `{a,b,x,y,z}` is used to put the output fields in the order you desire - it&#39;s largely cosmetic and you can omit it if you don&#39;t care.",
                "title": "Multiply arrays in JQ"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638176175,
                "creation_date": 1638176175,
                "answer_id": 70151996,
                "question_id": 69080571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    jq -c &quot;.[]&quot; file1.json  &gt; f1.jl\r\n    jq -c &quot;.[]&quot; file2.json  &gt; f2.jl\r\n    while read a; do while read b; do echo $a $b | jq -s &#39;add&#39; -c ; done &lt; f2.jl  ; done &lt; f1.jl | jq -s \r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "Multiply arrays in JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1680508380,
                "last_edit_date": 1680508380,
                "creation_date": 1680505611,
                "answer_id": 75916807,
                "question_id": 69080571,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This is another option:\r\n\r\n\r\n    jq &#39;.&#39;  -s file1.json file2.json | jq &#39;( .[0] as $a | .[1] as $b | [$a[]+$b[]] )&#39;\r\n\r\nWhen you run only this command:\r\n\r\n    jq &#39;.&#39;  -s file1.json file2.json\r\n\r\nthe result is:\r\n\r\n    [\r\n        [\r\n         {&quot;a&quot;: &quot;1&quot;, &quot;b&quot;: &quot;2&quot;},\r\n         {&quot;a&quot;: &quot;3&quot;, &quot;b&quot;: &quot;4&quot;}\r\n        ],\r\n        \r\n        [\r\n         {&quot;x&quot;: &quot;10&quot;, &quot;y&quot;: &quot;12&quot;, &quot;z&quot;: &quot;15&quot;},\r\n         {&quot;x&quot;: &quot;20&quot;, &quot;y&quot;: &quot;22&quot;, &quot;z&quot;: &quot;25&quot;}\r\n        ] \r\n    ]\r\n\r\nAnd when you run the command:\r\n\r\n    jq &#39;.&#39;  -s file1.json file2.json | jq &#39;( .[0] as $a | .[1] as $b | [$a[]+$b[]] )&#39;\r\n\r\n\r\nThe result is:\r\n\r\n    [\r\n      {\r\n        &quot;a&quot;: &quot;1&quot;,\r\n        &quot;b&quot;: &quot;2&quot;,\r\n        &quot;x&quot;: &quot;10&quot;,\r\n        &quot;y&quot;: &quot;12&quot;,\r\n        &quot;z&quot;: &quot;15&quot;\r\n      },\r\n      {\r\n        &quot;a&quot;: &quot;3&quot;,\r\n        &quot;b&quot;: &quot;4&quot;,\r\n        &quot;x&quot;: &quot;10&quot;,\r\n        &quot;y&quot;: &quot;12&quot;,\r\n        &quot;z&quot;: &quot;15&quot;\r\n      },\r\n      {\r\n        &quot;a&quot;: &quot;1&quot;,\r\n        &quot;b&quot;: &quot;2&quot;,\r\n        &quot;x&quot;: &quot;20&quot;,\r\n        &quot;y&quot;: &quot;22&quot;,\r\n        &quot;z&quot;: &quot;25&quot;\r\n      },\r\n      {\r\n        &quot;a&quot;: &quot;3&quot;,\r\n        &quot;b&quot;: &quot;4&quot;,\r\n        &quot;x&quot;: &quot;20&quot;,\r\n        &quot;y&quot;: &quot;22&quot;,\r\n        &quot;z&quot;: &quot;25&quot;\r\n      }\r\n    ]\r\n\r\n",
                "title": "Multiply arrays in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1680508380,
        "creation_date": 1630965202,
        "last_edit_date": 1631005956,
        "question_id": 69080571,
        "body_markdown": "I have 2 arrays in 2 files and I&#39;m trying to multiply them using JQ.\r\n\r\n**file1.json**:\r\n\r\n    [\r\n     {&quot;a&quot;: &quot;1&quot;, &quot;b&quot;: &quot;2&quot;},\r\n     {&quot;a&quot;: &quot;3&quot;, &quot;b&quot;: &quot;4&quot;}\r\n    ]\r\n\r\n**file2.json**:\r\n\r\n    [\r\n     {&quot;x&quot;: &quot;10&quot;, &quot;y&quot;: &quot;12&quot;, &quot;z&quot;: &quot;15&quot;},\r\n     {&quot;x&quot;: &quot;20&quot;, &quot;y&quot;: &quot;22&quot;, &quot;z&quot;: &quot;25&quot;}\r\n    ]\r\n\r\nand the expected output:\r\n\r\n    [\r\n     {&quot;a&quot;: &quot;1&quot;, &quot;b&quot;: &quot;2&quot;, &quot;x&quot;: &quot;10&quot;, &quot;y&quot;: &quot;12&quot;, &quot;z&quot;: &quot;15&quot;},\r\n     {&quot;a&quot;: &quot;1&quot;, &quot;b&quot;: &quot;2&quot;, &quot;x&quot;: &quot;20&quot;, &quot;y&quot;: &quot;22&quot;, &quot;z&quot;: &quot;25&quot;},\r\n     {&quot;a&quot;: &quot;3&quot;, &quot;b&quot;: &quot;4&quot;, &quot;x&quot;: &quot;10&quot;, &quot;y&quot;: &quot;12&quot;, &quot;z&quot;: &quot;15&quot;},\r\n     {&quot;a&quot;: &quot;3&quot;, &quot;b&quot;: &quot;4&quot;, &quot;x&quot;: &quot;20&quot;, &quot;y&quot;: &quot;22&quot;, &quot;z&quot;: &quot;25&quot;}\r\n    ]\r\n\r\nWhen I do `jq .[0] * .[1] file1.json file2.json` it says\r\n\r\n&gt; array ... and array ... can&#39;t be multiplied",
        "link": "https://stackoverflow.com/questions/69080571/multiply-arrays-in-jq",
        "title": "Multiply arrays in JQ"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "jq",
            "aws-secrets-manager"
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 1,
        "last_activity_date": 1631077931,
        "creation_date": 1630981747,
        "last_edit_date": 1631077931,
        "question_id": 69081781,
        "body_markdown": "How to get secret key/value from aws secret manager. I am using the following bash script which doesn&#39;t give the expected result\r\n\r\n```\r\n#/bin/bash\r\n\r\nsecretList=$(aws secretsmanager get-secret-value --secret-id test | jq --raw-output &#39;.SecretString&#39; | jq -r &quot;to_entries|map(\\&quot;\\(.key)=\\(.value|tostring)\\&quot;)|.[]&quot;)\r\n\r\n\r\necho $secretList\r\n\r\n\r\nfor key in &quot;${!secretList[@]}&quot;\r\ndo\r\n  echo &quot;Key = $key&quot;\r\n  echo &quot;Value  = ${secretList[$key]}&quot;\r\ndone\r\n```\r\n\r\nCurrent result is \r\n\r\n```\r\ntest=test123 test2=sdf543\r\nKey = 0\r\nValue  = test=test123\r\ntest2=sdf543\r\n```\r\n\r\nExpected result is \r\n\r\n```\r\nKey = test\r\nValue  = test123\r\n\r\nKey = test2\r\nValue  = sdf543\r\n```\r\nHelp with this is much appreciated ",
        "link": "https://stackoverflow.com/questions/69081781/read-key-value-pairs-from-aws-secret-manager-into-an-array-in-bash",
        "title": "Read key-value pairs from AWS Secret Manager into an array in Bash"
    },
    {
        "tags": [
            "json",
            "streaming",
            "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": 1631006837,
                "post_id": 69085255,
                "comment_id": 122101071,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11782337,
                    "reputation": 325,
                    "user_id": 8621405,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-VoN0SKwv8zI/AAAAAAAAAAI/AAAAAAAAATw/icL43AfYMG0/s256-rj/photo.jpg",
                    "display_name": "CYC",
                    "link": "https://stackoverflow.com/users/8621405/cyc"
                },
                "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": 1631007954,
                "post_id": 69085255,
                "comment_id": 122101562,
                "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": 1631090115,
                "post_id": 69085255,
                "comment_id": 122126805,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631091744,
                "creation_date": 1631091744,
                "answer_id": 69100068,
                "question_id": 69085255,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input has been corrected, the following &quot;regular&quot; jq program produces the desired result:\r\n\r\n```\r\n[\r\n .jobname\r\n | (.keys + .toolJobs[].keys) as $one\r\n | .toolJobs[]\r\n | .keys as $two\r\n | .reports[]\r\n | (.keys + .property) as $three\r\n | .datas[]\r\n | (.keys + {data}) as $four\r\n | $one + $two + $three + $four\r\n]\r\n```\r\n\r\nIf your input is too large, you could reduce the memory requirements by creating a jq-to-jq pipeline, with the first invocation using the above program (or a --stream version of it) but with the outer brackets removed.\r\n\r\n\r\n\r\n",
                "title": "parse the nested json have same attribute with jq streaming mode"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1631091744,
        "creation_date": 1631005220,
        "question_id": 69085255,
        "body_markdown": "I want to parse the data from the below nested json file, but it has too many &quot;keys&quot; in the json, it makes hard to parse the data\r\n\r\n```\r\n{\r\n  &quot;jobname&quot;: {\r\n    &quot;keys&quot;: {\r\n        &quot;jobid&quot;:&quot;E000295&quot;,\r\n        &quot;car&quot;:&quot;BMW&quot;\r\n    },\r\n    &quot;property&quot;:{\r\n        &quot;doctype&quot;:&quot;File&quot;,\r\n        &quot;areadesc&quot;:[\r\n            {\r\n                &quot;areaid&quot;:&quot;qaz&quot;,\r\n                &quot;weather&quot;:&quot;hot&quot;,\r\n            },\r\n            {\r\n                &quot;areaid&quot;:&quot;wsx&quot;,\r\n                &quot;weather&quot;:&quot;code&quot;,\r\n            },\r\n            {\r\n                &quot;areaid&quot;:&quot;edc&quot;,\r\n                &quot;weather&quot;:&quot;hot&quot;,\r\n            },\r\n            {\r\n                &quot;areaid&quot;:&quot;rfv&quot;,\r\n                &quot;weather&quot;:&quot;hot&quot;,\r\n            }\r\n        ]\r\n    },\r\n    &quot;toolJobs&quot;:[\r\n        {\r\n            &quot;keys&quot;:{\r\n                &quot;toolid&quot;:&quot;123&quot;\r\n            },\r\n            &quot;reports&quot;:[\r\n                {\r\n                    &quot;keys&quot;:{\r\n                        &quot;oiltype&quot;:&quot;a&quot;,\r\n                        &quot;oilcountry&quot;:&quot;us&quot;\r\n                    },\r\n                    &quot;property&quot;:{&quot;reportid&quot;:&quot;001&quot;},\r\n                    &quot;datas&quot;:[\r\n                        {\r\n                            &quot;keys&quot;:{&quot;areaid&quot;:&quot;qaz&quot;},\r\n                            &quot;data&quot;:[\r\n                                {\r\n                                    &quot;time&quot;: &quot;2021-01-01&quot;,\r\n                                    &quot;value&quot;: 1\r\n                                },\r\n                                {\r\n                                    &quot;time&quot;: &quot;2021-01-02&quot;,\r\n                                    &quot;value&quot;: 3\r\n                                },\r\n                            ]\r\n                        },\r\n                        {\r\n                            &quot;keys&quot;:{&quot;areaid&quot;:&quot;wsx&quot;},\r\n                            &quot;data&quot;:[\r\n                                {\r\n                                    &quot;time&quot;: &quot;2021-01-03&quot;,\r\n                                    &quot;value&quot;: 5\r\n                                },\r\n                                {\r\n                                    &quot;time&quot;: &quot;2021-01-04&quot;,\r\n                                    &quot;value&quot;: 7\r\n                                },\r\n                            ]\r\n                        },\r\n                    ]\r\n                },\r\n                {\r\n                    &quot;keys&quot;:{\r\n                        &quot;oiltype&quot;:&quot;b&quot;,\r\n                        &quot;oilcountry&quot;:&quot;china&quot;\r\n                    },\r\n                    &quot;property&quot;:{&quot;reportid&quot;:&quot;002&quot;},\r\n                    &quot;datas&quot;:[\r\n                        {\r\n                            &quot;keys&quot;:{&quot;areaid&quot;:&quot;edc&quot;},\r\n                            &quot;data&quot;:[\r\n                                {\r\n                                    &quot;time&quot;: &quot;2021-01-05&quot;,\r\n                                    &quot;value&quot;: 2\r\n                                },\r\n                                {\r\n                                    &quot;time&quot;: &quot;2021-01-06&quot;,\r\n                                    &quot;value&quot;: 4\r\n                                },\r\n                            ]\r\n                        },\r\n                        {\r\n                            &quot;keys&quot;:{&quot;areaid&quot;:&quot;rfv&quot;},\r\n                            &quot;data&quot;:[\r\n                                {\r\n                                    &quot;time&quot;: &quot;2021-01-07&quot;,\r\n                                    &quot;value&quot;: 6\r\n                                },\r\n                                {\r\n                                    &quot;time&quot;: &quot;2021-01-08&quot;,\r\n                                    &quot;value&quot;: 8\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\nuntil now, I can use the below code to get the basic result, but some columns do not have, such as oiltype, oilcountry, reportid, areaid\r\n\r\n\r\n```\r\ncat tmp1.json |  jq -cn --stream &#39;\r\n [fromstream( \r\n   1|truncate_stream(inputs)\r\n   | (.[0][:2] | index(&quot;keys&quot;)) as $ix \r\n   | if $ix then .[0] |= .[1+$ix:] \r\n     else (.[0] | index(&quot;toolJobs&quot;)) as $iy | (.[0][$iy:$iy+3] | index(&quot;keys&quot;)) as $iz\r\n     | if $iz then .[0] |= .[1+$iy+$iz:]\r\n       else (.[0] | index(&quot;data&quot;)) as $ik\r\n       | if $ik then .[0] |= .[$ik:]\r\n         else empty\r\n         end\r\n       end\r\n     end \r\n  )] | .[0] as $header | .[1] as $tool | [.[2:][] | ($header+ $tool+.)] | .&#39;\r\n```\r\nThe result is \r\n\r\n[\r\n{&quot;jobid&quot;:&quot;E000295&quot;,&quot;car&quot;:&quot;BMW&quot;,&quot;toolid&quot;:&quot;123&quot;,&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:1},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:3}]},\r\n{&quot;jobid&quot;:&quot;E000295&quot;,&quot;car&quot;:&quot;BMW&quot;,&quot;toolid&quot;:&quot;123&quot;,&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:5},{&quot;time&quot;:&quot;2021-01-04&quot;,&quot;value&quot;:7}]},\r\n{&quot;jobid&quot;:&quot;E000295&quot;,&quot;car&quot;:&quot;BMW&quot;,&quot;toolid&quot;:&quot;123&quot;,&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-05&quot;,&quot;value&quot;:2},{&quot;time&quot;:&quot;2021-01-06&quot;,&quot;value&quot;:4}]},\r\n{&quot;jobid&quot;:&quot;E000295&quot;,&quot;car&quot;:&quot;BMW&quot;,&quot;toolid&quot;:&quot;123&quot;,&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-07&quot;,&quot;value&quot;:6},{&quot;time&quot;:&quot;2021-01-08&quot;,&quot;value&quot;:8}]}]\r\n\r\nI also try below code\r\n\r\n```\r\ncat tmp1.json |  jq -cn --stream &#39;\r\n [fromstream( \r\n   1|truncate_stream(inputs)\r\n   | (.[0][:2] | index(&quot;keys&quot;)) as $ix \r\n   | if $ix then .[0] |= .[1+$ix:] \r\n     else (.[0] | index(&quot;toolJobs&quot;)) as $iy | (.[0][$iy:$iy+3] | index(&quot;keys&quot;)) as $iz\r\n     | if $iz then .[0] |= .[1+$iy+$iz:]\r\n       else (.[0] | index(&quot;data&quot;)) as $ik\r\n       | if $ik then .[0] |= .[$ik:]\r\n         else (.[0] | index(&quot;reports&quot;)) as $iw | (.[0][$iw:$iw+3] | index(&quot;property&quot;)) as $ii\r\n         | if $ii then (.[0] |= .[$iw+$ii:])\r\n           else (.[0] | index(&quot;keys&quot;)) as $ij\r\n           | if $ij then (.[0] |= .[$ij:])\r\n             else empty\r\n             end\r\n           end\r\n         end\r\n       end\r\n     end \r\n  )] | .[0] as $header | .[1] as $prjob | [.[2:][] | ($header + $prjob + .)] | .&#39;\r\n```\r\nbut the result is strange\r\n\r\n[\r\n\r\n{&quot;jobid&quot;:&quot;E000295&quot;,&quot;car&quot;:&quot;BMW&quot;,&quot;property&quot;:{&quot;reportid&quot;:&quot;001&quot;},&quot;toolid&quot;:&quot;123&quot;,&quot;keys&quot;:{&quot;oiltype&quot;:&quot;a&quot;,&quot;oilcountry&quot;:&quot;us&quot;,&quot;areaid&quot;:&quot;qaz&quot;},&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-01&quot;,&quot;value&quot;:1},{&quot;time&quot;:&quot;2021-01-02&quot;,&quot;value&quot;:3}]},\r\n\r\n{&quot;jobid&quot;:&quot;E000295&quot;,&quot;car&quot;:&quot;BMW&quot;,&quot;property&quot;:{&quot;doctype&quot;:&quot;File&quot;,&quot;areadesc&quot;:[{&quot;areaid&quot;:&quot;qaz&quot;,&quot;weather&quot;:&quot;hot&quot;},{&quot;areaid&quot;:&quot;wsx&quot;,&quot;weather&quot;:&quot;code&quot;},{&quot;areaid&quot;:&quot;edc&quot;,&quot;weather&quot;:&quot;hot&quot;},{&quot;areaid&quot;:&quot;rfv&quot;,&quot;weather&quot;:&quot;hot&quot;}]},&quot;toolid&quot;:&quot;123&quot;,&quot;keys&quot;:{&quot;areaid&quot;:&quot;wsx&quot;},&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-03&quot;,&quot;value&quot;:5},{&quot;time&quot;:&quot;2021-01-04&quot;,&quot;value&quot;:7}]},\r\n\r\n{&quot;jobid&quot;:&quot;E000295&quot;,&quot;car&quot;:&quot;BMW&quot;,&quot;property&quot;:{&quot;reportid&quot;:&quot;002&quot;},&quot;toolid&quot;:&quot;123&quot;,&quot;keys&quot;:{&quot;oiltype&quot;:&quot;b&quot;,&quot;oilcountry&quot;:&quot;china&quot;,&quot;areaid&quot;:&quot;edc&quot;},&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-05&quot;,&quot;value&quot;:2},{&quot;time&quot;:&quot;2021-01-06&quot;,&quot;value&quot;:4}]},\r\n\r\n{&quot;jobid&quot;:&quot;E000295&quot;,&quot;car&quot;:&quot;BMW&quot;,&quot;property&quot;:{&quot;doctype&quot;:&quot;File&quot;,&quot;areadesc&quot;:[{&quot;areaid&quot;:&quot;qaz&quot;,&quot;weather&quot;:&quot;hot&quot;},{&quot;areaid&quot;:&quot;wsx&quot;,&quot;weather&quot;:&quot;code&quot;},{&quot;areaid&quot;:&quot;edc&quot;,&quot;weather&quot;:&quot;hot&quot;},{&quot;areaid&quot;:&quot;rfv&quot;,&quot;weather&quot;:&quot;hot&quot;}]},&quot;toolid&quot;:&quot;123&quot;,&quot;keys&quot;:{&quot;areaid&quot;:&quot;rfv&quot;},&quot;data&quot;:[{&quot;time&quot;:&quot;2021-01-07&quot;,&quot;value&quot;:6},{&quot;time&quot;:&quot;2021-01-08&quot;,&quot;value&quot;:8}]}\r\n\r\n]\r\n\r\nBelow is my expected result\r\n```\r\n[\r\n    {\r\n        &quot;jobid&quot;:&quot;E000295&quot;,\r\n        &quot;car&quot;:&quot;BMW&quot;,\r\n        &quot;toolid&quot;:&quot;123&quot;,\r\n        &quot;oiltype&quot;:&quot;a&quot;,\r\n        &quot;oilcountry&quot;:&quot;us&quot;,\r\n        &quot;reportid&quot;:&quot;001&quot;,\r\n        &quot;areaid&quot;:&quot;qaz&quot;,\r\n        &quot;data&quot;:[\r\n            {\r\n                &quot;time&quot;: &quot;2021-01-01&quot;,\r\n                &quot;value&quot;: 1\r\n            },\r\n            {\r\n                &quot;time&quot;: &quot;2021-01-02&quot;,\r\n                &quot;value&quot;: 3\r\n            },\r\n        ]\r\n    },\r\n    {\r\n        &quot;jobid&quot;:&quot;E000295&quot;,\r\n        &quot;car&quot;:&quot;BMW&quot;,\r\n        &quot;toolid&quot;:&quot;123&quot;,\r\n        &quot;oiltype&quot;:&quot;a&quot;,\r\n        &quot;oilcountry&quot;:&quot;us&quot;,\r\n        &quot;reportid&quot;:&quot;001&quot;,\r\n        &quot;areaid&quot;:&quot;wsx&quot;,\r\n        &quot;data&quot;:[\r\n            {\r\n                &quot;time&quot;: &quot;2021-01-03&quot;,\r\n                &quot;value&quot;: 5\r\n            },\r\n            {\r\n                &quot;time&quot;: &quot;2021-01-04&quot;,\r\n                &quot;value&quot;: 7\r\n            },\r\n        ]\r\n    },\r\n    {\r\n        &quot;jobid&quot;:&quot;E000295&quot;,\r\n        &quot;car&quot;:&quot;BMW&quot;,\r\n        &quot;toolid&quot;:&quot;123&quot;,\r\n        &quot;oiltype&quot;:&quot;b&quot;,\r\n        &quot;oilcountry&quot;:&quot;china&quot;,\r\n        &quot;reportid&quot;:&quot;002&quot;,\r\n        &quot;areaid&quot;:&quot;edc&quot;,\r\n        &quot;data&quot;:[\r\n            {\r\n                &quot;time&quot;: &quot;2021-01-05&quot;,\r\n                &quot;value&quot;: 2\r\n            },\r\n            {\r\n                &quot;time&quot;: &quot;2021-01-06&quot;,\r\n                &quot;value&quot;: 4\r\n            },\r\n        ]\r\n    },\r\n    {\r\n        &quot;jobid&quot;:&quot;E000295&quot;,\r\n        &quot;car&quot;:&quot;BMW&quot;,\r\n        &quot;toolid&quot;:&quot;123&quot;,\r\n        &quot;oiltype&quot;:&quot;b&quot;,\r\n        &quot;oilcountry&quot;:&quot;china&quot;,\r\n        &quot;reportid&quot;:&quot;002&quot;,\r\n        &quot;areaid&quot;:&quot;rfv&quot;,\r\n        &quot;data&quot;:[\r\n            {\r\n                &quot;time&quot;: &quot;2021-01-07&quot;,\r\n                &quot;value&quot;: 6\r\n            },\r\n            {\r\n                &quot;time&quot;: &quot;2021-01-08&quot;,\r\n                &quot;value&quot;: 8\r\n            },\r\n        ]\r\n    }\r\n]\r\n```\r\n\r\nDoes anyone have any idea?",
        "link": "https://stackoverflow.com/questions/69085255/parse-the-nested-json-have-same-attribute-with-jq-streaming-mode",
        "title": "parse the nested json have same attribute with jq streaming mode"
    },
    {
        "tags": [
            "timestamp",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631029952,
                "post_id": 69091003,
                "comment_id": 122111330,
                "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"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631034389,
                "post_id": 69091003,
                "comment_id": 122113038,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1631083839,
                "creation_date": 1631083839,
                "answer_id": 69098217,
                "question_id": 69091003,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As the error message says, the given date-time string does not match the given format.\r\nThis is because the former has a trailing &quot;Z&quot;, which is not accounted for in the latter.\r\n\r\nFor example, using jq, we see:\r\n```\r\n$ jq -ncM &#39;&quot;2021-09-07T08:29:29Z&quot;|strptime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;)&#39;\r\n[2021,8,7,8,29,29,2,249]\r\n```\r\nSo you could delete the &quot;Z&quot; in the date-time string  (e.g. by sub(&quot;Z$&quot;;&quot;&quot;)), or add it in the format string, as shown in the example.\r\n\r\n",
                "title": "Issue with timestamp format when trying to create my K8S cluster in AWS using a script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631083839,
        "creation_date": 1631028879,
        "last_edit_date": 1631029937,
        "question_id": 69091003,
        "body_markdown": "I try and run the script and i get the below error \r\n\r\n&gt; jq: error (at &lt;stdin&gt;:1): date &quot;2021-09-07T08:29:29Z&quot; does not match format &quot;%Y-%m-%dT%H:%M:%S&quot;\r\n\r\nMy script has this line which I guess is what causes the error \r\n\r\n```\r\nyq &#39;.metadata.creationTimestamp |= (. | strptime(&quot;%Y-%m-%dT%H:%M:%S&quot;) | strftime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;))&#39; | \\\r\n```\r\n\r\nI didn&#39;t write the script so I don&#39;t really know what that line means exactly. Anyone have any ideas what could be wrong? Is it a local issue with my timestamp format?",
        "link": "https://stackoverflow.com/questions/69091003/issue-with-timestamp-format-when-trying-to-create-my-k8s-cluster-in-aws-using-a",
        "title": "Issue with timestamp format when trying to create my K8S cluster in AWS using a script"
    },
    {
        "tags": [
            "json",
            "google-cloud-platform",
            "jq",
            "speech-to-text",
            "google-speech-to-text-api"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1631041864,
                "creation_date": 1631041864,
                "answer_id": 69093458,
                "question_id": 69093383,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The JSON you posted does not have a top-level &quot;response&quot; key.\r\n\r\nThis seems to do the trick:\r\n\r\n    .results[].alternatives[].transcript\r\n",
                "title": "&quot;Cannot iterate over null&quot; when using jq to extract google speech-to-text transcript data from json file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631041864,
        "creation_date": 1631041385,
        "question_id": 69093383,
        "body_markdown": "I&#39;m trying to extract all the &quot;transcript&quot; data from this file which is the result of a Google Speech-to-Text request : https://pastebin.com/MFF1Dav8 (Not sensitive data, just from an interview I conducted). \r\n\r\nTo do so I found a prewritten command which I&#39;m using : \r\n\r\n    jq &lt;interview.json &#39;.response.results[].alternatives[].transcript&#39; -r &gt; interview.txt\r\n\r\nExcept I get : \r\n\r\n    jq: error (at &lt;stdin&gt;:111181): Cannot iterate over null (null)\r\n\r\nHow can I work around this ? All I want is the raw transcript text.\r\nThank you ",
        "link": "https://stackoverflow.com/questions/69093383/cannot-iterate-over-null-when-using-jq-to-extract-google-speech-to-text-transc",
        "title": "&quot;Cannot iterate over null&quot; when using jq to extract google speech-to-text transcript data from json file"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631091958,
                "post_id": 69100098,
                "comment_id": 122127572,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1285808,
                    "reputation": 127,
                    "user_id": 8736520,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/f361605bcada66f621c30e6b38478352?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "papampi",
                    "link": "https://stackoverflow.com/users/8736520/papampi"
                },
                "reply_to_user": {
                    "account_id": 53229,
                    "reputation": 156838,
                    "user_id": 159145,
                    "user_type": "registered",
                    "accept_rate": 56,
                    "profile_image": "https://i.sstatic.net/9Mufm.png?s=256",
                    "display_name": "Dai",
                    "link": "https://stackoverflow.com/users/159145/dai"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631092585,
                "post_id": 69100098,
                "comment_id": 122127817,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631101797,
                "post_id": 69100098,
                "comment_id": 122131711,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1285808,
                    "reputation": 127,
                    "user_id": 8736520,
                    "user_type": "registered",
                    "accept_rate": 50,
                    "profile_image": "https://www.gravatar.com/avatar/f361605bcada66f621c30e6b38478352?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "papampi",
                    "link": "https://stackoverflow.com/users/8736520/papampi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631109812,
                "post_id": 69100098,
                "comment_id": 122135685,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1293198,
                    "reputation": 19192,
                    "user_id": 1244884,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/79435cc2571ffa23dfcef703f8d762e0?s=256&d=identicon&r=PG",
                    "display_name": "customcommander",
                    "link": "https://stackoverflow.com/users/1244884/customcommander"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631112547,
                "post_id": 69100098,
                "comment_id": 122136986,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1631112270,
                "creation_date": 1631112270,
                "answer_id": 69105189,
                "question_id": 69100098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From [OP&#39;s comment](https://stackoverflow.com/questions/69100098/using-jq-to-extract-data-from-api-that-has-no-key#comment122135685_69100098):\r\n\r\n&gt;for example I can check whats on 5th row for 1400 and whats for 1401 \r\n\r\n\r\n----------\r\n\r\nIf we loop over the arrays, we can use string interpolation to create the desired output using hard coded array indexes.\r\n\r\nFor example, index `0` and `5`:\r\n```\r\njq --slurp --raw-output &#39;.[] | &quot;\\(.[0]) - \\(.[5])&quot;&#39;\r\n```\r\n\r\nWill show:\r\n```none\r\n1400 - 562949953421312\r\n1401 - 0\r\n```\r\n\r\nAs you can test in this [online demo](https://jqplay.org/s/9n7L77qUep).",
                "title": "Using jq to extract data from API that has no key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631204740,
        "creation_date": 1631091862,
        "last_edit_date": 1631204740,
        "question_id": 69100098,
        "body_markdown": "I need to extract datas from an API which has no keys any idea how to do it?\r\nHow do I use jq to do this?\r\n\r\nThe Api output is like this:\r\n```\r\n[\r\n  &quot;1400&quot;,\r\n  0,\r\n  0,\r\n  0,\r\n  285697101361315840,\r\n  562949953421312,\r\n  &quot;2021-09-08T01:28:00.000Z&quot;,\r\n  false,\r\n  0,\r\n  0,\r\n  0\r\n]\r\n[\r\n  &quot;1401&quot;,\r\n  0,\r\n  0,\r\n  0,\r\n  263179103224463360,\r\n  0,\r\n  &quot;2021-09-08T01:28:00.000Z&quot;,\r\n  false,\r\n  0,\r\n  0,\r\n  0\r\n]\r\n...\r\n```\r\n\r\nSo I need data from rows 2 to 11 for each top row, here 1400 and 1401, for example I can check whats on 5th row for 1400 and whats for 1401.\r\n",
        "link": "https://stackoverflow.com/questions/69100098/using-jq-to-extract-data-from-api-that-has-no-key",
        "title": "Using jq to extract data from API that has no key"
    },
    {
        "tags": [
            "bash",
            "jq",
            "jo"
        ],
        "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": 1631106538,
                "post_id": 69102441,
                "comment_id": 122134000,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1526352,
                    "reputation": 1824,
                    "user_id": 1424695,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/4e745838fc760d8359c7cb8d3ffed109?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "theAnonymous",
                    "link": "https://stackoverflow.com/users/1424695/theanonymous"
                },
                "reply_to_user": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631108224,
                "post_id": 69102441,
                "comment_id": 122134888,
                "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": 1631108285,
                "post_id": 69102441,
                "comment_id": 122134911,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1631106687,
                "last_edit_date": 1631106687,
                "creation_date": 1631105951,
                "answer_id": 69103584,
                "question_id": 69102441,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Cf. https://unix.stackexchange.com/questions/366581/bash-associative-array-printing\r\n\r\n```\r\njo $(paste -d= &lt;(printf &quot;%s\\n&quot; &quot;${!rep_hostname[@]}&quot;) &lt;(printf &quot;%s\\n&quot; &quot;${rep_hostname[@]}&quot;))\r\n```\r\n\r\nThe `printf` commands will output associative keys and values by lines, the `paste -d= ...` will merge the produced lines bound by an `=` sign and lastly the `jo` processor will build a JSON from that.\r\n\r\nA more iterative equivalent could also be:\r\n```\r\nfor i in &quot;${!rep_hostname[@]}&quot;;do printf &quot;%s=%s\\n&quot; &quot;$i&quot; &quot;${rep_hostname[$i]}&quot;;done | jo\r\n```\r\n",
                "title": "Bash - Parse associative Array to JSON with k-v"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1631110567,
        "creation_date": 1631101471,
        "last_edit_date": 1631110567,
        "question_id": 69102441,
        "body_markdown": "The example here:\r\n\r\n    #!/bin/bash\r\n    \r\n    declare -A rep_hostname\r\n    rep_hostname=( [test1]=&#39;172.1.1.1&#39; [test2]=&#39;172.1.1.2&#39; [test3]=&#39;172.1.1.3&#39; )\r\n    \r\n    json=$(\r\n            jo members=&quot;$(\r\n                    jo -a &quot;${rep_hostname[@]}&quot; |\r\n                    jq -c &#39;to_entries | map({ &quot;_id&quot;: .key, &quot;host&quot;: .value })&#39;\r\n            )&quot;\r\n    )\r\n    \r\n    echo &quot;$json&quot;\r\n\r\n\r\noutputs the following:\r\n\r\n    {\r\n        &quot;members&quot;:[\r\n          {&quot;_id&quot;:0,&quot;host&quot;:&quot;172.1.1.3:2701&quot;},\r\n          {&quot;_id&quot;:1,&quot;host&quot;:&quot;172.1.1.2:2701&quot;},\r\n          {&quot;_id&quot;:2,&quot;host&quot;:&quot;172.1.1.1:2701&quot;}\r\n        ]\r\n    }\r\n\r\nHow to make the following JSON?\r\n\r\n    {\r\n        &quot;test1&quot;:&quot;172.1.1&quot;,\r\n        &quot;test2&quot;:&quot;172.1.1.2&quot;,\r\n        &quot;test3&quot;:&quot;172.1.1.3&quot;\r\n    }",
        "link": "https://stackoverflow.com/questions/69102441/bash-parse-associative-array-to-json-with-k-v",
        "title": "Bash - Parse associative Array to JSON with k-v"
    },
    {
        "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": 1,
                "creation_date": 1631105336,
                "post_id": 69102865,
                "comment_id": 122133415,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631106291,
                "creation_date": 1631106291,
                "answer_id": 69103659,
                "question_id": 69102865,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Considering the following file structure:\r\n\r\n```none\r\n==&gt; first.json &lt;==\r\n[ 1, 2, 3, 4, 5 ]\r\n\r\n==&gt; second.json &lt;==\r\n[ 6, 7, 8, 9, 10 ]\r\n\r\n==&gt; third.json &lt;==\r\n[ 11, 12, 13, 14, 15 ]\r\n```\r\n\r\nThen, we can create a single array containing those 3 files by using the following JQ command:\r\n```\r\njq -s add first.json second.json third.json\r\n```\r\n\r\nResult:\r\n```json\r\n[\r\n  1,\r\n  2,\r\n  3,\r\n  4,\r\n  5,\r\n  6,\r\n  7,\r\n  8,\r\n  9,\r\n  10,\r\n  11,\r\n  12,\r\n  13,\r\n  14,\r\n  15\r\n]\r\n```",
                "title": "jq: merge array files is splitting the arrays"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631275538,
        "creation_date": 1631103074,
        "last_edit_date": 1631275538,
        "question_id": 69102865,
        "body_markdown": "I&#39;ve several json files in my directory:\r\n\r\n```\r\n/home/jeusdi/projects/salut/mpi/hes-mpi-api-service/mock-expectations/\r\n├── cobertures-expectation.json\r\n├── comunitats-expectations.json\r\n├── localitats-expectations.json\r\n├── ocupacions-expectations.json\r\n├── paisos-expectations.json\r\n├── provincies-expectation.json\r\n└── tipusvia-expectation.json\r\n```\r\n\r\nEach one is an array. I need to merge them into a single json array file.\r\n\r\nI tried to use `-s` option like this:\r\n\r\n```\r\n$ jq -s &#39;.[]&#39; \\\r\n  ~/projects/salut/mpi/hes-mpi-api-service/mock-expectations/*.json &gt; \\\r\n  ~/projects/workarea/salut/mpi/mockserver/config/expectations.json\r\n```\r\n\r\nNevertheless, when I get the length of merged file, I&#39;m getting:\r\n\r\n```\r\n$ jq length ~/projects/workarea/salut/mpi/mockserver/config/expectations.json                                                                      \r\n1\r\n1\r\n142\r\n8\r\n3\r\n1\r\n1\r\n```\r\n\r\nI&#39;ve also tried this command:\r\n\r\n```\r\n$ jq -s . \\\r\n  ~/projects/salut/mpi/hes-mpi-api-service/mock-expectations/*.json &gt; \\\r\n  ~/projects/workarea/salut/mpi/mockserver/config/expectations.json\r\n```\r\n\r\nNevertheless length command is getting:\r\n\r\n```\r\n$ jq length ~/projects/workarea/salut/mpi/mockserver/config/expectations.json                                                                  \r\n7\r\n```\r\n\r\nAny ideas about how to merge all of those files into a single one json array file?",
        "link": "https://stackoverflow.com/questions/69102865/jq-merge-array-files-is-splitting-the-arrays",
        "title": "jq: merge array files is splitting the arrays"
    },
    {
        "tags": [
            "kubernetes",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 100740,
                    "reputation": 79490,
                    "user_id": 271415,
                    "user_type": "registered",
                    "accept_rate": 91,
                    "profile_image": "https://www.gravatar.com/avatar/8648256cc53b261c5e1d266380a256fc?s=256&d=identicon&r=PG",
                    "display_name": "jarmod",
                    "link": "https://stackoverflow.com/users/271415/jarmod"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631116525,
                "post_id": 69105302,
                "comment_id": 122138805,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3344464,
                    "reputation": 18486,
                    "user_id": 6309601,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/RNsPk.png?s=256",
                    "display_name": "P....",
                    "link": "https://stackoverflow.com/users/6309601/p"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631118854,
                "post_id": 69105302,
                "comment_id": 122139774,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1631117205,
                "creation_date": 1631117205,
                "answer_id": 69106405,
                "question_id": 69105302,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s hard to be sure from your example since I don&#39;t know what was in your input data, but I believe the [egress][1] field isn&#39;t guaranteed to be present. That would result in the error you see. You are also going to have trouble because when your select expression yields multiple results you will end up selecting the same item multiple times.\r\n\r\nYou might try the [any][2] function and the [.\\[\\]?][3] operator:\r\n\r\n```\r\n.items[]|select(any(.spec.egress[]?.to[]?;.ipBlock.cidr==&quot;1.2.3.4/32&quot;))|.metadata.name\r\n```\r\n\r\n[1]: https://kubernetes.io/docs/concepts/services-networking/network-policies/#networkpolicy-resource\r\n[2]: https://stedolan.github.io/jq/manual/#any,any(condition),any(generator;condition)\r\n[3]: https://stedolan.github.io/jq/manual/#.%5B%5D%3F",
                "title": "jq: select object if certain value exists"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631117205,
        "creation_date": 1631112711,
        "question_id": 69105302,
        "body_markdown": "I have a list with multiple objects in an items list and try to select every item with an specific value inside an optional array in this object.\r\nLet me explain by the actual problem:\r\nI read all networkpolicies from a kubernetes namespace and try to output the names of all networkpilicies, which allow access to a certain IP address\r\n\r\nThe closest I cloud get is:\r\n```\r\nkubectl get netpol -ojson|jq -r &#39;.items[]|select(.spec.egress[0].to[0].ipBlock.cidr==&quot;1.2.3.4/32&quot;)|.metadata.name&#39;\r\n```\r\n\r\nbut this only works, if the ip block is the first one in the array. I have no idea, how to iterate over all elements in the array.\r\nThis\r\n```\r\nkubectl get netpol -ojson|jq -r &#39;.items[]|select(.spec.egress[].to[].ipBlock.cidr==&quot;1.2.3.4/32&quot;)|.metadata.name&#39;\r\n```\r\ngives me an error `jq: error (at &lt;stdin&gt;:803): Cannot iterate over null (null)` \r\n\r\n\r\nFor reference, the egress block looks like this\r\n```\r\n    &quot;egress&quot;: [\r\n      {\r\n        &quot;ports&quot;: [\r\n          {\r\n            &quot;port&quot;: 1234,\r\n            &quot;protocol&quot;: &quot;TCP&quot;\r\n          }\r\n        ],\r\n        &quot;to&quot;: [\r\n          {\r\n            &quot;ipBlock&quot;: {\r\n              &quot;cidr&quot;: &quot;1.2.3.4/32&quot;\r\n            }\r\n          }\r\n        ]\r\n      }\r\n    ],\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69105302/jq-select-object-if-certain-value-exists",
        "title": "jq: select object if certain value exists"
    },
    {
        "tags": [
            "bash",
            "unix",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1631117198,
                "post_id": 69106186,
                "comment_id": 122139086,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1631116820,
                "creation_date": 1631116820,
                "answer_id": 69106306,
                "question_id": 69106186,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The here-string construct simply redirects standard input. You will separately need to tell `jq` to *read* standard input if you call it in a way where it receives file name arguments. The _de facto_ standard way to do that is to specify `-` as the input (pseudo-) filename.\r\n\r\nI believe one of your test cases didn&#39;t actually work, and just looked like it did because the input data was constructed so as to be a no-op.",
                "title": "Why can&#39;t jq&#39;s slurp handle a combination of here-strings and other files?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1631116941,
                "creation_date": 1631116941,
                "answer_id": 69106334,
                "question_id": 69106186,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "One idea would be to use process substitution which, in essence, provides `jq` with a (temp) file descriptor it can work with.\r\n\r\nUsing `awk` to demonstrate the file descriptor idea:\r\n\r\n    $ awk &#39;{print FILENAME}&#39; &lt;(echo &#39;abc&#39;)\r\n    /dev/fd/63\r\n\r\n\r\nDemonstrating with a few of your examples:\r\n\r\n    $ jq --slurp add zero &lt;(echo &#39;{&quot;key&quot;:1}&#39;)\r\n    {\r\n      &quot;key&quot;: 1\r\n    }\r\n    \r\n    $ jq --slurp add zero &lt;(echo &#39;{&quot;keyx&quot;:1}&#39;)\r\n    {\r\n      &quot;key&quot;: 0,\r\n      &quot;keyx&quot;: 1\r\n    }\r\n    \r\n    $ jq --slurp add &lt;(echo &#39;{&quot;key&quot;:0,&quot;anotherkey&quot;:2}&#39;) one\r\n    {\r\n      &quot;key&quot;: 1,\r\n      &quot;anotherkey&quot;: 2\r\n    }\r\n    \r\n    $ jq --slurp add &lt;(echo &#39;{&quot;key&quot;:0}&#39;) &lt;(echo &#39;{&quot;key&quot;:1}&#39;)\r\n    {\r\n      &quot;key&quot;: 1\r\n    }\r\n    \r\n    $ jq --slurp add &lt;(echo &#39;{&quot;key&quot;:0}&#39;) &lt;(echo &#39;{&quot;keyx&quot;:1}&#39;)\r\n    {\r\n      &quot;key&quot;: 0,\r\n      &quot;keyx&quot;: 1\r\n    }\r\n\r\n",
                "title": "Why can&#39;t jq&#39;s slurp handle a combination of here-strings and other files?"
            },
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1631131078,
                "last_edit_date": 1631131078,
                "creation_date": 1631119867,
                "answer_id": 69106975,
                "question_id": 69106186,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After reading through the comments this is my understanding:\r\n\r\n`&lt;&lt;&lt;` is evaluated by the shell first and redirects stdin. If `jq` receives no positional arguments after the filter, it reads from stdin. Therefore all these statements are equivalent:\r\n```\r\necho &quot;{}&quot; | jq --slurp add\r\n&lt;&lt;&lt; {} jq --slurp add\r\njq &lt;&lt;&lt; {} --slurp add\r\njq --slurp &lt;&lt;&lt; {} add\r\njq --slurp add &lt;&lt;&lt; {}\r\n```\r\n\r\nIf `jq` does receive positional arguments after the filter, it interprets them as filenames. It adheres to the convention of treating `-` as stdin.\r\n```\r\nbash-4.2# echo &#39;{&quot;one&quot;:1,&quot;two&quot;:1}&#39; &gt; first\r\nbash-4.2# echo &#39;{&quot;three&quot;:3}&#39; &gt; third\r\nbash-4.2# jq --slurp add first - third &lt;&lt;&lt; &#39;{&quot;two&quot;:2}&#39;\r\n{\r\n  &quot;one&quot;: 1,\r\n  &quot;two&quot;: 2,\r\n  &quot;three&quot;: 3\r\n}\r\n```\r\n",
                "title": "Why can&#39;t jq&#39;s slurp handle a combination of here-strings and other files?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1631131078,
        "creation_date": 1631116317,
        "last_edit_date": 1631118182,
        "question_id": 69106186,
        "body_markdown": "I want to merge some json in a file with some json generated at runtime. jq seems to have no difficulty if all the files passed to it are here-strings, or files in the system. But if I try to mix the file types it seems the here-strings are ignored, see snippet below:\r\n\r\nTwo normal files:\r\n```\r\nbash-4.2# echo &#39;{&quot;key&quot;:0}&#39; &gt; zero\r\nbash-4.2# echo &#39;{&quot;key&quot;:1}&#39; &gt; one\r\nbash-4.2# jq --slurp add zero one\r\n{\r\n  &quot;key&quot;: 1\r\n}\r\n```\r\n**Normal file and here-string (only normal file appears in result!):**\r\n```\r\nbash-4.2# jq --slurp add zero &lt;&lt;&lt; &#39;{&quot;key&quot;:1}&#39;\r\n{\r\n  &quot;key&quot;: 0\r\n}\r\n```\r\n**Here-string first, then normal file (only normal file appears in result!):**\r\n```\r\nbash-4.2# jq --slurp add &lt;&lt;&lt; &#39;{&quot;key&quot;:0,&quot;anotherkey&quot;:2}&#39; one\r\n{\r\n  &quot;key&quot;: 1\r\n}\r\n```\r\nSingle here-string (works fine):\r\n```\r\nbash-4.2# jq --slurp add &lt;&lt;&lt; &#39;{&quot;key&quot;:0}&#39;\r\n{\r\n  &quot;key&quot;: 0\r\n}\r\n```\r\n&lt;s&gt;Two here-strings (works fine):&lt;/s&gt; EDIT: Output is misleading, something else is going on here.\r\n```\r\nbash-4.2# jq --slurp add &lt;&lt;&lt; &#39;{&quot;key&quot;:0}&#39; &lt;&lt;&lt; &#39;{&quot;key&quot;:1}&#39;\r\n{\r\n  &quot;key&quot;: 1\r\n}\r\n```\r\nMy suspicion is that jq works just fine and I am ignorant of how bash resolves the here-strings. But, how would I debug this to improve my understanding?\r\n\r\nNote: A very easy workaround would be to evaluate my runtime json and produce a file, then merge the two files as above. I really want to know why the bold examples above don&#39;t produce what I would expect.",
        "link": "https://stackoverflow.com/questions/69106186/why-cant-jqs-slurp-handle-a-combination-of-here-strings-and-other-files",
        "title": "Why can&#39;t jq&#39;s slurp handle a combination of here-strings and other files?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1631144094,
                "last_edit_date": 1631144094,
                "creation_date": 1631139343,
                "answer_id": 69110223,
                "question_id": 69110148,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the update assignment `|=` operator to change a part of the structure:\r\n```\r\njq  &#39;.components.&quot;test.data.app&quot;[].config.&quot;allowed-test-mapper-data&quot;\r\n         |= if . then sort else empty end&#39; file.json\r\n```",
                "title": "Sorting strings in an array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1631144094,
        "creation_date": 1631138655,
        "question_id": 69110148,
        "body_markdown": "I have two json files here, both have the same content only in a different order, and these are to be checked for equality with a diff. \r\n\r\nI already sort the keys with jq -S, but now I have to make sure that the strings are sorted equally within the arrays. \r\n\r\nUnfortunately, I fail at the moment, I am not quite clear how I get to the right level and how I can sort the content. \r\n\r\nHere is an example structure of the jsons, the array &#39;allowed-test-mapper-data&#39; should be sorted in descending order\r\n\r\n\r\n```json\r\n{\r\n    &quot;accessCodeLife&quot;: 60,\r\n    &quot;accessCodeLifespan&quot;: 1800,\r\n    &quot;accessCodeType&quot;: 300,\r\n    &quot;components&quot;: {\r\n        &quot;test.data.app&quot;: [\r\n        {\r\n        &quot;config&quot;: {\r\n            &quot;allow-default-test-scopes&quot;: [\r\n                &quot;true&quot;\r\n            ]\r\n        },\r\n        &quot;name&quot;: &quot;Allowed Test Client&quot;,\r\n        &quot;id&quot;: &quot;allowed-testdata&quot;,\r\n        &quot;subComponents&quot;: {},\r\n        &quot;subType&quot;: &quot;testdata&quot;\r\n        },\r\n        {\r\n        &quot;config&quot;: {\r\n            &quot;allowed-test-mapper-data&quot;: [\r\n                &quot;alfred&quot;,\r\n                &quot;usa&quot;,\r\n                &quot;canada&quot;,\r\n                &quot;somedata&quot;,\r\n                &quot;alcohol&quot;,\r\n                &quot;brother&quot;\r\n                ]   \r\n            }\r\n        }\r\n        ]\r\n    }\r\n}\r\n\r\n```\r\n\r\n\r\nCan someone help me here ?\r\nWould be great :)  ",
        "link": "https://stackoverflow.com/questions/69110148/sorting-strings-in-an-array-with-jq",
        "title": "Sorting strings in an array with jq"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631183858,
                "post_id": 69116628,
                "comment_id": 122156845,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 462118,
                    "reputation": 1306,
                    "user_id": 864245,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/e467547a61b0317de60a8bdea836c6a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "turbonerd",
                    "link": "https://stackoverflow.com/users/864245/turbonerd"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631183948,
                "post_id": 69116628,
                "comment_id": 122156883,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631184013,
                "post_id": 69116628,
                "comment_id": 122156910,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 462118,
                    "reputation": 1306,
                    "user_id": 864245,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/e467547a61b0317de60a8bdea836c6a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "turbonerd",
                    "link": "https://stackoverflow.com/users/864245/turbonerd"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631184139,
                "post_id": 69116628,
                "comment_id": 122156960,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 462118,
                    "reputation": 1306,
                    "user_id": 864245,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/e467547a61b0317de60a8bdea836c6a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "turbonerd",
                    "link": "https://stackoverflow.com/users/864245/turbonerd"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631184442,
                "post_id": 69116628,
                "comment_id": 122157099,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631184529,
                "post_id": 69116628,
                "comment_id": 122157143,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 462118,
                    "reputation": 1306,
                    "user_id": 864245,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/e467547a61b0317de60a8bdea836c6a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "turbonerd",
                    "link": "https://stackoverflow.com/users/864245/turbonerd"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631188114,
                "post_id": 69116628,
                "comment_id": 122158566,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1631184356,
                "creation_date": 1631184356,
                "answer_id": 69116819,
                "question_id": 69116628,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From [OP&#39;s comment][1]:\r\n\r\n&gt;which is why I&#39;m trying to apply a transformation then select by it. I can transform the date to the correct value required by JQ\r\n\r\n\r\n----------\r\n\r\n\r\nRight after calling `select`, we can pipe the `.ts` value to remove the nanoseconds which JQ can&#39;t parse like so:\r\n\r\n```\r\njq &#39;map(select(.ts | (split(&quot;.&quot;)[0] + &quot;Z&quot;) | fromdateiso8601 &gt; 1631184310))&#39;\r\n```\r\n\r\nThe above timestamp (`1631184310`) will just select the second object as you can [try online here](https://jqplay.org/s/gWVcZQMjgY)\r\n\r\n  [1]: https://stackoverflow.com/questions/69116628/use-jq-to-transform-a-date-value-then-filter-by-it#comment122156960_69116628",
                "title": "Use jq to transform a date value then filter by it"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631184514,
        "creation_date": 1631183546,
        "last_edit_date": 1631184514,
        "question_id": 69116628,
        "body_markdown": "I have some data which takes the following format:\r\n\r\n\t[\r\n\t  {\r\n\t    &quot;level&quot;: &quot;error&quot;,\r\n\t    &quot;ts&quot;: &quot;2021-09-08T17:34:39.163Z&quot;,\r\n\t    &quot;caller&quot;: &quot;controller/events.go:39&quot;,\r\n\t    &quot;msg&quot;: &quot;Metric query failed for p50 Latency: request failed: Get \\&quot;https://blah\\&quot;: context deadline exceeded&quot;,\r\n\t    &quot;canary&quot;: &quot;blah&quot;,\r\n\t    &quot;stacktrace&quot;: &quot;github.com/fluxcd/flagger/pkg/controller.(*Controller).recordEventErrorf\\n\\t/workspace/pkg/controller/events.go:39\\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runMetricChecks\\n\\t/workspace/pkg/controller/scheduler_metrics.go:280\\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runAnalysis\\n\\t/workspace/pkg/controller/scheduler.go:682\\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).advanceCanary\\n\\t/workspace/pkg/controller/scheduler.go:380\\ngithub.com/fluxcd/flagger/pkg/controller.CanaryJob.Start.func1\\n\\t/workspace/pkg/controller/job.go:39&quot;\r\n\t  },\r\n\t  {\r\n\t    &quot;level&quot;: &quot;error&quot;,\r\n\t    &quot;ts&quot;: &quot;2021-09-09T11:22:33.162Z&quot;,\r\n\t    &quot;caller&quot;: &quot;controller/events.go:39&quot;,\r\n\t    &quot;msg&quot;: &quot;Metric query failed for p50 Latency: request failed: Get \\&quot;https://blah\\&quot;: context deadline exceeded&quot;,\r\n\t    &quot;canary&quot;: &quot;blah&quot;,\r\n\t    &quot;stacktrace&quot;: &quot;github.com/fluxcd/flagger/pkg/controller.(*Controller).recordEventErrorf\\n\\t/workspace/pkg/controller/events.go:39\\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runMetricChecks\\n\\t/workspace/pkg/controller/scheduler_metrics.go:280\\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).runAnalysis\\n\\t/workspace/pkg/controller/scheduler.go:682\\ngithub.com/fluxcd/flagger/pkg/controller.(*Controller).advanceCanary\\n\\t/workspace/pkg/controller/scheduler.go:380\\ngithub.com/fluxcd/flagger/pkg/controller.CanaryJob.Start.func1\\n\\t/workspace/pkg/controller/job.go:39&quot;\r\n\t  }\r\n\t]\r\n\r\nI am trying to filter this data by date, e.g. I want to find all of these events after a certain date. The timestamp `1631122500` should filter out the top entry here (with `ts` == `2021-09-08T17:34:39.163Z`).\r\n\r\nIf I apply the command `| jq -s &#39;.[] | select(.ts | fromdateiso8601 &gt; 1475625600)&#39;`, it returns the error `jq: error (at &lt;stdin&gt;:8): date &quot;2021-08-30T21:52:34.039Z&quot; does not match format &quot;%Y-%m-%dT%H:%M:%SZ&quot;`.\r\n\r\nI have managed to amend the `ts` field by applying the following modifications: `jq -s &#39;.[].ts | split(&quot;.&quot;)[0] | strptime(&quot;%Y-%m-%dT%H:%M:%S&quot;) | mktime | strftime(&quot;%Y-%m-%dT%H:%M:%SZ&quot;)&#39;`. This returns values like `&quot;2021-09-08T18:34:39Z&quot;` which is the format specified in the aforementioned error.\r\n\r\nWhat I can&#39;t get my head around is how I can transform each of these `ts` values to the correct format, then use `select` to filter by dates since a specified time. I tried piping `jq &lt;modify&gt;` to `| jq &lt;select&gt;` but this gave me an error about jq being unable to iterate over strings.",
        "link": "https://stackoverflow.com/questions/69116628/use-jq-to-transform-a-date-value-then-filter-by-it",
        "title": "Use jq to transform a date value then filter by it"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3758602,
                    "reputation": 10329,
                    "user_id": 3124333,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/51c25e0ab30c1059996d914d47ce5b26?s=256&d=identicon&r=PG",
                    "display_name": "SiKing",
                    "link": "https://stackoverflow.com/users/3124333/siking"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631217580,
                "post_id": 69124013,
                "comment_id": 122170715,
                "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": 1631217776,
                "post_id": 69124013,
                "comment_id": 122170772,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22649294,
                    "reputation": 5,
                    "user_id": 16824204,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJyDzb9qQJMJnpO7MUGTXrQwj9yDsd8WqjM9Agzj=k-s256",
                    "display_name": "MikeyR",
                    "link": "https://stackoverflow.com/users/16824204/mikeyr"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631219841,
                "post_id": 69124013,
                "comment_id": 122171403,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631220456,
                "creation_date": 1631220456,
                "answer_id": 69124542,
                "question_id": 69124013,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming valid JSON like\r\n\r\n    {\r\n      &quot;database_details&quot;: [\r\n         {\r\n    \t   &quot;age&quot;: &quot;false&quot;,\r\n    \t   &quot;help&quot;: &quot;xxxx&quot;,\r\n    \t   &quot;host&quot;: &quot;&quot;,\r\n    \t   &quot;servername&quot;: &quot;fra02&quot;,\r\n    \t   &quot;db_name&quot;: &quot;config_tools&quot;,\r\n    \t   &quot;pass&quot;: &quot;xxxx&quot;,\r\n    \t   &quot;user&quot;: &quot;default&quot;\r\n         },\r\n         {\r\n           &quot;age&quot;: &quot;false&quot;,\r\n           &quot;help&quot;: &quot;xxxx&quot;,\r\n           &quot;host&quot;: &quot;&quot;,\r\n           &quot;servername&quot;: &quot;fra03&quot;,\r\n           &quot;db_name&quot;: &quot;config_tools&quot;,\r\n           &quot;pass&quot;: &quot;xxxx&quot;,\r\n           &quot;user&quot;: &quot;default&quot;\r\n         }\r\n      ]\r\n    }\r\n\r\nyou can use the filter\r\n\r\n    .database_details |= (map({key: .servername, value: .}) | from_entries)\r\n\r\nThe  array associated with `database_details` is turned into an array of key/value pairs, which `from_entries` turns into a new object that `|=` assigns back to the key `database_details` in the original object.",
                "title": "add a parameter name to a json file with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631715590,
        "creation_date": 1631217146,
        "last_edit_date": 1631715590,
        "question_id": 69124013,
        "body_markdown": "I am trying to make my json file that looks like this\r\n\r\n```\r\n{\r\n    &quot;database_details&quot;: {\r\n    &quot;age&quot;: &quot;false&quot;,\r\n    &quot;help&quot;: &quot;xxxx&quot;,\r\n    &quot;host&quot;: &quot;&quot;,\r\n    &quot;servername&quot;: &quot;fra02&quot;,\r\n    &quot;db_name&quot;: &quot;config_tools&quot;,\r\n    &quot;pass&quot;: &quot;xxxx&quot;,\r\n    &quot;user&quot;: &quot;default&quot;,\r\n\r\n  },\r\n  {\r\n     &quot;age&quot;: &quot;false&quot;,\r\n    &quot;help&quot;: &quot;xxxx&quot;,\r\n    &quot;host&quot;: &quot;&quot;,\r\n    &quot;servername&quot;: &quot;fra03&quot;,\r\n    &quot;db_name&quot;: &quot;config_tools&quot;,\r\n    &quot;pass&quot;: &quot;xxxx&quot;,\r\n    &quot;user&quot;: &quot;default&quot;,\r\n  }\r\n}\r\n```\r\n\r\nto look like \r\n```\r\n{\r\n&quot;database_details&quot;: {\r\n&quot;fra02&quot;:{\r\n    &quot;age&quot;: &quot;false&quot;,\r\n    &quot;help&quot;: &quot;xxxx&quot;,\r\n    &quot;host&quot;: &quot;&quot;,\r\n    &quot;servername&quot;: &quot;fra02&quot;,\r\n    &quot;db_name&quot;: &quot;config_tools&quot;,\r\n    &quot;pass&quot;: &quot;xxxx&quot;,\r\n    &quot;user&quot;: &quot;default&quot;,\r\n},\r\n&quot;fra03&quot;: {\r\n  &quot;age&quot;: &quot;false&quot;,\r\n    &quot;help&quot;: &quot;xxxx&quot;,\r\n    &quot;host&quot;: &quot;&quot;,\r\n    &quot;servername&quot;: &quot;fra02&quot;,\r\n    &quot;db_name&quot;: &quot;config_tools&quot;,\r\n    &quot;pass&quot;: &quot;xxxx&quot;,\r\n    &quot;user&quot;: &quot;default&quot;,\r\n}\r\n}\r\n}\r\n```\r\n\r\nI have tried jq but not sure if that is the right approach?\r\nI have thought about using awk or sed but not sure that is the cleanest route?\r\n",
        "link": "https://stackoverflow.com/questions/69124013/add-a-parameter-name-to-a-json-file-with-jq",
        "title": "add a parameter name to a json file with jq"
    },
    {
        "tags": [
            "json",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1631219418,
                "creation_date": 1631219418,
                "answer_id": 69124392,
                "question_id": 69124229,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Form the JSON with the fields clubbed into an array and remove the fields thereafter \n\n    map(. + { lonlat : [.lon, .lat] } | del(.lat, .lon))\n\n[jqplay demo][1]\n\n\n  [1]: https://jqplay.org/s/-KoFfbNap-",
                "title": "JQ - merge two fields to an array with another field name"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1631219418,
        "creation_date": 1631218421,
        "question_id": 69124229,
        "body_markdown": "I&#39;m trying to change a data structure, but I&#39;m not able to find a clue how to do this with jq. I&#39;m curious to learn. \r\n\r\nInput:\r\n```\r\n[ \r\n  { &quot;capital&quot;: &quot;St. John&#39;s&quot;,\r\n    &quot;lat&quot;: 17.1172,\r\n    &quot;lon&quot;: -61.8457\r\n  },\r\n  { &quot;capital&quot;: &quot;Buenos Aires&quot;,\r\n    &quot;lat&quot;: -34.6051,\r\n    &quot;lon&quot;: -58.4004\r\n  },\r\n]\r\n```\r\n\r\nDesired output:\r\n```\r\n[ \r\n  { &quot;capital&quot;: &quot;St. John&#39;s&quot;,\r\n    &quot;lonlat&quot;: [ -61.8457, 17.1172]\r\n  },\r\n  { &quot;capital&quot;: &quot;Buenos Aires&quot;,\r\n    &quot;lonlat&quot;: [-58.4004, -34.6051]\r\n  },\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69124229/jq-merge-two-fields-to-an-array-with-another-field-name",
        "title": "JQ - merge two fields to an array with another field name"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4959604,
                    "reputation": 9011,
                    "user_id": 3991211,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1042922965/picture?type=large",
                    "display_name": "Geoduck",
                    "link": "https://stackoverflow.com/users/3991211/geoduck"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631227443,
                "post_id": 69125439,
                "comment_id": 122173175,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10872478,
                    "reputation": 995,
                    "user_id": 7993924,
                    "user_type": "registered",
                    "accept_rate": 7,
                    "profile_image": "https://www.gravatar.com/avatar/2c19983980f2d2bbbf23fcceb58f175d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bond",
                    "link": "https://stackoverflow.com/users/7993924/bond"
                },
                "reply_to_user": {
                    "account_id": 4959604,
                    "reputation": 9011,
                    "user_id": 3991211,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1042922965/picture?type=large",
                    "display_name": "Geoduck",
                    "link": "https://stackoverflow.com/users/3991211/geoduck"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631240178,
                "post_id": 69125439,
                "comment_id": 122174887,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631268832,
                "post_id": 69125439,
                "comment_id": 122182337,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10872478,
                    "reputation": 995,
                    "user_id": 7993924,
                    "user_type": "registered",
                    "accept_rate": 7,
                    "profile_image": "https://www.gravatar.com/avatar/2c19983980f2d2bbbf23fcceb58f175d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bond",
                    "link": "https://stackoverflow.com/users/7993924/bond"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631279532,
                "post_id": 69125439,
                "comment_id": 122186315,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 10872478,
                    "reputation": 995,
                    "user_id": 7993924,
                    "user_type": "registered",
                    "accept_rate": 7,
                    "profile_image": "https://www.gravatar.com/avatar/2c19983980f2d2bbbf23fcceb58f175d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bond",
                    "link": "https://stackoverflow.com/users/7993924/bond"
                },
                "reply_to_user": {
                    "account_id": 4959604,
                    "reputation": 9011,
                    "user_id": 3991211,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1042922965/picture?type=large",
                    "display_name": "Geoduck",
                    "link": "https://stackoverflow.com/users/3991211/geoduck"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631283153,
                "post_id": 69125439,
                "comment_id": 122187882,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631883270,
                "creation_date": 1631883270,
                "answer_id": 69223806,
                "question_id": 69125439,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` has a [builtin][1] `@csv` which renders an array\r\n\r\n&gt; as CSV with double quotes for strings, and quotes escaped by repetition.\r\n\r\nIf the additional quoting (as compared to your expected output) isn&#39;t an issue, the following\r\n\r\n    jq --raw-output &#39;\r\n      \r\n      # produce an array for each element in the input array\r\n      .[] | [\r\n        \r\n        # containing the first three columns unchanged\r\n        .generated_time, .platform, .id,\r\n        \r\n        # if the input element has a field named &quot;tags&quot;\r\n        if has(&quot;tags&quot;)\r\n        \r\n        # then add two more columns and replace an inexistant Gamma with &quot;NULL&quot;\r\n        then (.tags.Gamma // &quot;NULL&quot;, .created)\r\n        \r\n        # otherwise add two empty columns instead\r\n        else (null, null) end\r\n        \r\n      # and convert the array into CSV format\r\n      ] | @csv\r\n      \r\n    &#39; input.json\r\n\r\nwill produce\r\n\r\n    &quot;generated_time&quot;,&quot;platform&quot;,&quot;id&quot;,,\r\n    &quot;2021-09-09:12:03:12&quot;,&quot;earth&quot;,&quot;2eeee67748&quot;,&quot;Ray&quot;,&quot;2021-08-25 09:41:06&quot;\r\n    &quot;2021-09-09:12:03:12&quot;,&quot;sun&quot;,&quot;xxxxx12334&quot;,&quot;NULL&quot;,&quot;2021-08-25 10:11:31&quot;\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions",
                "title": "Parse JSON output with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631883270,
        "creation_date": 1631227310,
        "question_id": 69125439,
        "body_markdown": "Lets say I have an I/P json file as below. And I want to extract the O/P in a CSV format with the below fields. Specifically, I want to get the value of the key &quot;Gamma&quot; in the o/p if the key &quot;Gamma&quot; exists in &quot;tags&quot; map. If the key doesn&#39;t exists, it should just print a NULL value. The expected o/p is below.\r\n\r\n```\r\ngenerated_time,platform,id,,\r\n2021-09-09:12:03:12,earth,2eeee67748,Ray,2021-08-25 09:41:06\r\n2021-09-09:12:03:12,sun,xxxxx12334,NULL,2021-08-25 10:11:31\r\n\r\n```\r\n```\r\n[\r\n  { \r\n    &quot;generated_time&quot;: &quot;generated_time&quot;,\r\n    &quot;platform&quot;: &quot;platform&quot;,\r\n    &quot;id&quot;: &quot;id&quot;\r\n  },\r\n    {\r\n    &quot;generated_time&quot;: &quot;2021-09-09:12:03:12&quot;,\r\n    &quot;platform&quot;: &quot;earth&quot;,\r\n    &quot;id&quot;: &quot;2eeee67748&quot;,\r\n    &quot;tags&quot;: {\r\n      &quot;app&quot;: &quot;map&quot;,\r\n      &quot;Gamma&quot;: &quot;Ray&quot;,\r\n      &quot;null&quot;: [\r\n        &quot;allow-all-humans&quot;\r\n      ]\r\n          },\r\n    &quot;created&quot;: &quot;2021-08-25 09:41:06&quot;\r\n  },\r\n   { \r\n    &quot;generated_time&quot;: &quot;2021-09-09:12:03:12&quot;,\r\n    &quot;platform&quot;: &quot;sun&quot;,\r\n    &quot;id&quot;: &quot;xxxxx12334&quot;,\r\n    &quot;tags&quot;: {\r\n      &quot;component&quot;: &quot;machine&quot;,\r\n      &quot;environment&quot;: &quot;hot&quot;,\r\n      &quot;null&quot;: [\r\n        &quot;aallow-all-humans&quot;\r\n      ]\r\n    },\r\n    &quot;created&quot;: &quot;2021-08-25 10:11:31&quot;\r\n   }\r\n]\r\n\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69125439/parse-json-output-with-jq",
        "title": "Parse JSON output with JQ"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "environment-variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1631265825,
                "last_edit_date": 1631265825,
                "creation_date": 1631264508,
                "answer_id": 69129821,
                "question_id": 69129762,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Easy with `jq` and some string interpolation and `@sh` to properly quote the Value strings for shells:\r\n\r\n```\r\n$  jq -r &#39;.Parameters[] | &quot;\\(.Name | .[rindex(&quot;/&quot;)+1:])=\\(.Value | @sh)&quot;&#39; input.json\r\nCORS_ORIGIN=&#39;https://example.com&#39;\r\nDATABASE_URL=&#39;db://user:pass@host:3306/example&#39;\r\n```",
                "title": "How can I convert JSON to an environment variable file format?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 4,
        "last_activity_date": 1631265825,
        "creation_date": 1631264178,
        "question_id": 69129762,
        "body_markdown": "I am fetching a AWS Parameter Store JSON response using the AWS cli:\r\n```bash\r\necho $(aws ssm get-parameters-by-path --with-decryption --region eu-central-1 \\\r\n  --path &quot;${PARAMETER_STORE_PREFIX}&quot;) &gt;/home/ubuntu/.env.json\r\n```\r\nThis outputs something like:\r\n```json\r\n{\r\n  &quot;Parameters&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;/EXAMPLE/CORS_ORIGIN&quot;,\r\n      &quot;Value&quot;: &quot;https://example.com&quot;\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;/EXAMPLE/DATABASE_URL&quot;,\r\n      &quot;Value&quot;: &quot;db://user:pass@host:3306/example&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nInstead of writing to a JSON file, I&#39;d like to write to a `.env` file instead with the following format:\r\n```\r\nCORS_ORIGIN=&quot;https://example.com&quot;\r\nDATABASE_URL=&quot;db://user:pass@host:3306/example&quot;\r\n```\r\nHow could I achieve this? I found similar questions like https://stackoverflow.com/questions/48512914/exporting-json-to-environment-variables, but they do not deal with nested JSON / arrays",
        "link": "https://stackoverflow.com/questions/69129762/how-can-i-convert-json-to-an-environment-variable-file-format",
        "title": "How can I convert JSON to an environment variable file format?"
    },
    {
        "tags": [
            "json",
            "join",
            "merge",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631291282,
                "post_id": 69134020,
                "comment_id": 122191036,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6432822,
                    "reputation": 118,
                    "user_id": 4985271,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/SQGvO.jpg?s=256",
                    "display_name": "ewoj",
                    "link": "https://stackoverflow.com/users/4985271/ewoj"
                },
                "reply_to_user": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631292347,
                "post_id": 69134020,
                "comment_id": 122191404,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1631294072,
                "creation_date": 1631294072,
                "answer_id": 69135761,
                "question_id": 69134020,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an example of using INDEX and JOIN:\r\n\r\n```\r\njq --compact-output --slurpfile c1 c1.json &#39;\r\n    INDEX(\r\n        $c1[0].c1[];\r\n        .type\r\n    ) as $index |\r\n    JOIN(\r\n        $index;\r\n        .c2[];\r\n        .type;\r\n        reverse|add\r\n    )\r\n&#39; c2.json\r\n```\r\n\r\nThe first argument to INDEX needs to produce a stream of items, which is why we apply `[]` to get the items from the array individually. The second argument selects our index key.\r\n\r\nWe use the four argument version of JOIN. The first argument is the index itself, the second is a stream of objects to be joined to the index, the third argument selects the lookup key from the streamed objects, and the fourth argument is an expression to assemble the join object. The input to that expression is a stream of two-item arrays, each looking something like this:\r\n\r\n```\r\n[{&quot;c2id&quot;:1,&quot;type&quot;:&quot;alpha&quot;,&quot;serial&quot;:&quot;DDBB001&quot;},{&quot;c1id&quot;:1,&quot;type&quot;:&quot;alpha&quot;}]\r\n```\r\n\r\nSince we just want to combine all the keys and values from the objects we just use `add`, but we first `reverse` the array to nicely arrange the c1 fields before the c2 fields. The end result is as you hoped:\r\n\r\n```\r\n{&quot;c1id&quot;:1,&quot;type&quot;:&quot;alpha&quot;,&quot;c2id&quot;:1,&quot;serial&quot;:&quot;DDBB001&quot;}\r\n{&quot;c1id&quot;:2,&quot;type&quot;:&quot;beta&quot;,&quot;c2id&quot;:2,&quot;serial&quot;:&quot;DDBB007&quot;}\r\n{&quot;c1id&quot;:1,&quot;type&quot;:&quot;alpha&quot;,&quot;c2id&quot;:3,&quot;serial&quot;:&quot;DDTT005&quot;}\r\n{&quot;c1id&quot;:2,&quot;type&quot;:&quot;beta&quot;,&quot;c2id&quot;:4,&quot;serial&quot;:&quot;DDAA002&quot;}\r\n```",
                "title": "jq join on common key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1631858543,
        "creation_date": 1631285236,
        "last_edit_date": 1631858543,
        "question_id": 69134020,
        "body_markdown": "I&#39;m very new to `jq` and this post is a result of not understanding the mechanics behind `jq`. \r\nI could develop a bash script, which does what I want but jq and it&#39;s `JSON` super-powers have intrigued me and I&#39;d like to learn it by applying to real world scenarios. Here&#39;s one...\r\n\r\nBTW, I&#39;ve tried to make use of the existing jq related SO solutions for merging/joining JSONs but have failed.\r\n\r\nThe closest I came to what I needed was to use an INDEX and a concatenation of $x + . , however I was only getting the LAST item from my second (c2) `json`.\r\n\r\nSo, my problem is as follows:\r\n\r\nThere are Two `JSON` files:\r\n\r\n- `JSON` #1 will have unique &quot;id&quot; and &quot;type&quot; keys - among other key/value pairs, which I&#39;ve removed for better clarity of my post.\r\n\r\n- `JSON` #2 will contain multiples/non-unique &quot;type&quot; keys, which I&#39;d like to match these two JSON files on. This `JSON` #2 will also contain other key/value pairs, which are expected to be contained in the resultant output.\r\n\r\nMy output requirements are: \r\nI&#39;d like to obtain a (one per line or a single array) list of all combinations of matching key/values pairs between c1 and c2 array where the value of the &quot;type&quot; key (string) matches between c1 and c2 exactly.      \r\n\r\nOne more question, how much more difficult would it be to scale the solution to perform similar matching/joining between three `JSON` files at once - again on the same value of a particular key? \r\n\r\nAny assistance or even just hints on how to solve and understand how to solve this would be greatly appreciated!\r\n\r\n1st input file: `JSON` #1, Array c1 (collection 1)\r\n\r\n    { &quot;c1&quot;:\r\n    [\r\n    { &quot;c1id&quot;:1, &quot;type&quot;:&quot;alpha&quot; },\r\n    { &quot;c1id&quot;:2, &quot;type&quot;:&quot;beta&quot; }\r\n    ]\r\n    }\r\n\r\n2nd input file: `JSON` #2, Array c2 (collection 2)\r\n\r\n    {\r\n    &quot;c2&quot;:\r\n    [\r\n    { &quot;c2id&quot;:1,&quot;type&quot;:&quot;alpha&quot;,&quot;serial&quot;:&quot;DDBB001&quot;} ,\r\n    { &quot;c2id&quot;:2,&quot;type&quot;:&quot;beta&quot;,&quot;serial&quot;:&quot;DDBB007&quot;} ,\r\n    { &quot;c2id&quot;:3,&quot;type&quot;:&quot;alpha&quot;,&quot;serial&quot;:&quot;DDTT005&quot;} ,\r\n    { &quot;c2id&quot;:4,&quot;type&quot;:&quot;beta&quot;,&quot;serial&quot;:&quot;DDAA002&quot;} ,\r\n    { &quot;c2id&quot;:5,&quot;type&quot;:&quot;yotta&quot;,&quot;serial&quot;:&quot;DDCC017&quot;}\r\n    ]\r\n    }\r\n\r\n\r\nExpected output:\r\n\r\n    {&quot;c1id&quot;:1,&quot;type&quot;:&quot;alpha&quot;,&quot;c2id&quot;:1,&quot;serial&quot;:&quot;DDBB001&quot;}\r\n    {&quot;c1id&quot;:1,&quot;type&quot;:&quot;alpha&quot;,&quot;c2id&quot;:3,&quot;serial&quot;:&quot;DDTT005&quot;}\r\n    {&quot;c1id&quot;:2,&quot;type&quot;:&quot;beta&quot;,&quot;c2id&quot;:2,&quot;serial&quot;:&quot;DDBB007&quot;}\r\n    {&quot;c1id&quot;:2,&quot;type&quot;:&quot;beta&quot;,&quot;c2id&quot;:4,&quot;serial&quot;:&quot;DDAA002&quot;} \r\n\r\nYou will notice that type &quot;yotta&quot; from the c2 is not included in the output. This is expected. Only &quot;types&quot; which exist in c1 and match c2 are expected to be in the results. I guess this is implied by this being a matching/joining exercise - I added it just for clarity - I hope it worked.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69134020/jq-join-on-common-key",
        "title": "jq join on common key"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "merge",
            "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": 1631305943,
                "post_id": 69137721,
                "comment_id": 122195699,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17093560,
                    "reputation": 3,
                    "user_id": 12369102,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0087df1f8e45db7e305f2e92cb5bcdc2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ateny",
                    "link": "https://stackoverflow.com/users/12369102/ateny"
                },
                "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": 1631306214,
                "post_id": 69137721,
                "comment_id": 122195772,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631307661,
                "creation_date": 1631307661,
                "answer_id": 69137962,
                "question_id": 69137721,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s one way, but there are others:\r\n```\r\njq -s &#39;\r\n def to_n: tonumber? // null;\r\n def merge_values($x;$y): \r\n   if $x == $y then $x\r\n   elif $x == null then $y\r\n   elif $y == null then $x\r\n   else ($x|to_n) as $xn\r\n   | if $xn then ($y|to_n) as $yn | ($xn+$yn)|tostring\r\n     else [$x, $y]\r\n     end\r\n   end;\r\n def merge($x;$y):\r\n   reduce ($x + $y |keys_unsorted)[] as $k (null;\r\n     .[$k] = merge_values($x[$k]; $y[$k]) );\r\n\r\n   \r\n\r\n INDEX(.[0][]; .A) as $in1\r\n | INDEX(.[1][]; .A) as $in2\r\n | ($in1 + $in2|keys_unsorted) as $keys\r\n | reduce $keys[] as $k ([];\r\n     . + [merge($in1[$k]; $in2[$k]) ])\r\n\r\n    \r\n    \r\n&#39; input1.json inut2.json\r\n```\r\n",
                "title": "How to merge and aggregate values in 2 JSON files using jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1751735501,
                "last_edit_date": 1751735501,
                "creation_date": 1631442492,
                "answer_id": 69150566,
                "question_id": 69137721,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; _I can use other tools other than `jq` but prefer to ultimately keep the solution contained into a shell script I can call from the Terminal._\r\n\r\nYou could give the JSON-parser [tag:xidel] a try:\r\n```\r\n$ xidel -se &#39;\r\n  array{\r\n    let $src:=(\r\n      json-doc(&quot;Input1.json&quot;)(),\r\n      json-doc(&quot;Input2.json&quot;)()\r\n    )\r\n    for $name in distinct-values($src/A)\r\n    let $obj:=$src[A=$name]\r\n    return\r\n    if (count($obj) gt 1)\r\n    then map:merge(\r\n      for $key in map:keys($obj[1]) return\r\n      map:entry(\r\n        $key,\r\n        if ($obj[1]($key) castable as decimal)\r\n        then string($obj[1]($key) + $obj[2]($key))\r\n        else $obj[1]($key)\r\n      )\r\n    )\r\n    else $obj\r\n  }\r\n&#39;\r\n```\r\n[Intermediate steps.](https://gist.github.com/Reino17/e5bdce48b6e0f0824c707a7fed197f78)",
                "title": "How to merge and aggregate values in 2 JSON files using jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1631521993,
                "last_edit_date": 1631521993,
                "creation_date": 1631514273,
                "answer_id": 69158149,
                "question_id": 69137721,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq is beautiful for problems like this:\r\n\r\n```sh\r\n$ jq -n &#39;\r\nreduce inputs[] as {$A,$B,$C} ({};\r\n    .[$A] |= {\r\n        $A,\r\n        B: (.B + ($B|tonumber)),\r\n        C: (.C + ($C|tonumber))\r\n    }\r\n)\r\n| map({\r\n    A,\r\n    B: (.B|tostring),\r\n    C: (.C|tostring)\r\n  })\r\n&#39; input1.json input2.json\r\n```\r\n\r\nThe first reduce creates a map from the different &quot;A&quot; values to the aggregated result object. Then given the mapping, converts back to an array of the result objects adjusting the types of the results.\r\n\r\n[jqplay](https://jqplay.org/s/1hc39yALnm)",
                "title": "How to merge and aggregate values in 2 JSON files using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1751735501,
        "creation_date": 1631305687,
        "last_edit_date": 1631306350,
        "question_id": 69137721,
        "body_markdown": "I am using `jq` in a shell script to manipulate JSON files.\r\n\r\nI have 2 files and I&#39;d like to merge them into one file while also aggregating (sum) the values when names in the name/value pairs are the same.\r\n\r\nAs an example:\r\n\r\n*Input1.json*\r\n``` lang-js\r\n[\r\n  {\r\n    &quot;A&quot;: &quot;Name 1&quot;,\r\n    &quot;B&quot;: &quot;1.1&quot;,\r\n    &quot;C&quot;: &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;A&quot;: &quot;Name 2&quot;,\r\n    &quot;B&quot;: &quot;3.2&quot;,\r\n    &quot;C&quot;: &quot;4&quot;\r\n  }\r\n]\r\n```\r\n\r\n*Input2.json*\r\n\r\n``` lang-js\r\n[\r\n  {\r\n    &quot;A&quot;: &quot;Name 2&quot;,\r\n    &quot;B&quot;: &quot;5&quot;,\r\n    &quot;C&quot;: &quot;6&quot;\r\n  },\r\n  {\r\n    &quot;A&quot;: &quot;Name 3&quot;,\r\n    &quot;B&quot;: &quot;7&quot;,\r\n    &quot;C&quot;: &quot;8&quot;\r\n  }\r\n]\r\n```\r\n\r\nExpected result:\r\n\r\n*Output.json*\r\n``` lang-js\r\n[\r\n  {\r\n    &quot;A&quot;: &quot;Name 1&quot;,\r\n    &quot;B&quot;: &quot;1.1&quot;,\r\n    &quot;C&quot;: &quot;2&quot;\r\n  },\r\n  {\r\n    &quot;A&quot;: &quot;Name 2&quot;,\r\n    &quot;B&quot;: &quot;8.2&quot;,\r\n    &quot;C&quot;: &quot;10&quot;\r\n  },\r\n  {\r\n    &quot;A&quot;: &quot;Name 3&quot;,\r\n    &quot;B&quot;: &quot;7&quot;,\r\n    &quot;C&quot;: &quot;8&quot;\r\n  }\r\n]\r\n```\r\n\r\nI can use other tools other than `jq` but prefer to ultimately keep the solution contained into a shell script I can call from the Terminal.\r\n\r\nAny help is appreciated. Thank you.",
        "link": "https://stackoverflow.com/questions/69137721/how-to-merge-and-aggregate-values-in-2-json-files-using-jq",
        "title": "How to merge and aggregate values in 2 JSON files using jq?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1631361360,
                "creation_date": 1631361360,
                "answer_id": 69142764,
                "question_id": 69142574,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You want two things you missed:\r\n\r\n1. Pass your key as an `--arg name value` to `jq`.\r\n2. Tell `jq` to report boolean value as status-code with `-e` or `--exit-status`.\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\nfile=&#39;sample.json&#39;\r\nkey=&#39;foo.bar&#39;\r\n\r\nresult=&quot;$(\r\n  jq --exit-status --raw-output --arg k &quot;$key&quot; &#39;.[$k]&#39; &quot;$file&quot;\r\n)&quot;\r\nstatusCode=$?\r\nprintf &#39;result %s, statusCode %d\\n&#39; &quot;$result&quot; &quot;$statusCode&quot;\r\n```",
                "title": "Can&#39;t get jq command working from bash script with a key containing a dot"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631361360,
        "creation_date": 1631359945,
        "question_id": 69142574,
        "body_markdown": "I have a json file with keys containing dots.:\r\n```\r\n{\r\n&quot;a&quot;: &quot;b&quot;,\r\n&quot;foo.bar&quot;: true \r\n}\r\n```\r\nI want to get the value of certain keys using jq from a script. Running from the command line works:\r\n```\r\njq -r &quot;.[\\&quot;foo.bar\\&quot;]&quot; sample.json\r\ntrue\r\n```\r\nAnd I&#39;m basically doing the same thing from a bash script (except for some string expansion behaviour I can&#39;t grasp).:\r\n```\r\n#!/bin/bash\r\n\r\nfile=&quot;sample.json&quot;\r\nkey=&quot;foo.bar&quot;\r\ncommand=&quot;jq -r \\&quot;.[\\\\\\&quot;$key\\\\\\&quot;]\\&quot; $file&quot;\r\n# jq -r &quot;.[\\&quot;foo.bar\\&quot;]&quot; sample.json : Works in the console\r\n\r\nresult=$($command)\r\nstatusCode=$?\r\necho &quot;result $result, statusCode $statusCode&quot;\r\n# result .[&quot;foo.bar&quot;], statusCode 0\r\n```\r\n\r\n\r\nI tried more combinations, such as using single quote outer delimiter for the jq or replacing &quot;\\\\&quot; with &quot;\\x5C&quot;, and didn&#39;t find a working formula.\r\n\r\nI can&#39;t replace/remove the dots in the json files because they are an external dependency.\r\n\r\nEnvironment is bash 3.2, jq 1.6, mac os 11.5",
        "link": "https://stackoverflow.com/questions/69142574/cant-get-jq-command-working-from-bash-script-with-a-key-containing-a-dot",
        "title": "Can&#39;t get jq command working from bash script with a key containing a dot"
    },
    {
        "tags": [
            "json",
            "path",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1631365763,
                "creation_date": 1631365763,
                "answer_id": 69143318,
                "question_id": 69142882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Can you try this ?\r\n\r\n```\r\nKEY=&#39;.Resources.lc.Properties.UserData.&quot;Fn::Base64&quot;&#39;\r\njq &quot;$KEY&quot;&#39; = &quot;HHH&quot;&#39; my_data.json\r\n```",
                "title": "Trying to use jq to update a value with a variable path"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1631439946,
                "last_edit_date": 1631439946,
                "creation_date": 1631439141,
                "answer_id": 69150147,
                "question_id": 69142882,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The recommended approach here is to pass in the path as an array if possible, so that `setpath` can be used:\r\n```\r\nKEY=&#39;[&quot;Resources&quot;, &quot;lc&quot;, &quot;Properties&quot;, &quot;UserData&quot;, &quot;Fn::Base64&quot;]&#39;\r\njq --argjson p &quot;$KEY&quot; &#39;setpath( $p; &quot;HHH&quot;)&#39; my_data.json\r\n```\r\n\r\nIf that is not possible, next best would probably be to parse your $KEY string\r\nwith the inner double-quotation-marks removed:\r\n```\r\nKEY=&#39;.Resources.lc.Properties.UserData.Fn::Base64&#39;\r\njq -n --arg p &quot;$KEY&quot; &#39;setpath( $p|split(&quot;.&quot;)[1:]; &quot;HHH&quot;)&#39; my_data.json\r\n```\r\n\r\nNext to next-best would be to strip the inner double-quotation-marks,\r\ne.g. in the shell or using jq\r\n```\r\nKEY=&#39;.Resources.lc.Properties.UserData.Fn::Base64&#39;\r\njq -n --arg p &quot;$KEY&quot; &#39;\r\n  setpath( $p|gsub(&quot;\\&quot;&quot;;&quot;&quot;)|split(&quot;.&quot;)[1:]; &quot;HHH&quot;)\r\n&#39; my_data.json\r\n```\r\n",
                "title": "Trying to use jq to update a value with a variable path"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1631439976,
        "creation_date": 1631362174,
        "last_edit_date": 1631439976,
        "question_id": 69142882,
        "body_markdown": "I&#39;m trying to pass a JSON path into jq as a variable to update a value. this works great:\r\n\r\n    jq &#39;.Resources.lc.Properties.UserData.&quot;Fn::Base64&quot; = &quot;HHH&quot;&#39; my_data.json\r\n\r\n\r\nI can&#39;t get any combination like this to work:\r\n\r\n\r\n     KEY=&#39;.Resources.lc.Properties.UserData.&quot;Fn::Base64&quot;&#39;\r\n      jq --arg p &quot;$KEY&quot; &#39;$p = &quot;HHH&quot;&#39; my_data.json\r\n\r\nn\r\n\r\njq: error (at my_data.json:470): Invalid path expression with result &quot;.Resources.lc.Properties....\r\n\r\nThanks!\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69142882/trying-to-use-jq-to-update-a-value-with-a-variable-path",
        "title": "Trying to use jq to update a value with a variable path"
    },
    {
        "tags": [
            "git",
            "github",
            "jq",
            "xargs"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1631631550,
                "creation_date": 1631631550,
                "answer_id": 69180161,
                "question_id": 69151495,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "[Answered by Kusalananda](https://unix.stackexchange.com/a/668899/491657):\r\n&gt; 1. The individual arguments read by xargs should ideally be **quoted**.\r\n&gt; 2. xargs needs to call git clone with **two separate arguments**: the repository URL and the destination directory into which to clone it.\r\n\r\n`jq -r &#39;.[] | .html_url, .full_name&#39;` -&gt; `jq -r &#39;.[] | [ .html_url, .full_name ]&#39;`\r\n\r\n&gt; 3. Add the `@sh` operator to output a each such array as a line of shell-quoted words\r\n\r\n`jq -r &#39;.[] | [ .html_url, .full_name ]&#39;` -&gt; `jq -r &#39;.[] | [ .html_url, .full_name ] | @sh&#39;`\r\n\r\n---\r\n&gt; 4. Add `-n 2` so that xargs will call the utility with **two arguments** from its input stream at a time\r\n\r\n`xargs git clone` &gt; `xargs -n 2 git clone`\r\n\r\n---\r\n\r\n&gt; 5. Together:\r\n\r\n```shell\r\ncurl -s &quot;https://api.github.com/users/$UserName/repos?per_page=1000&quot; |\r\njq -r &#39;.[] | [ .html_url, .full_name ] | @sh&#39; |\r\nxargs -n 2 git clone\r\n```",
                "title": "How to clone repos inside a directory with their author name with REST API?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1631631550,
        "creation_date": 1631450322,
        "question_id": 69151495,
        "body_markdown": "I&#39;m using [this](https://gist.github.com/KyleMit/6ae40d4b39167112c675a8b8d744b93b) `bash` &amp; `jq` script:\r\n\r\n```bash\r\nUserName=CHANGEME; \\\r\ncurl -s https://api.github.com/users/$UserName/repos?per_page=1000 |\\\r\njq -r &#39;.[]|.clone_url&#39; |\\\r\nxargs -L1 git clone\r\n```\r\n\r\nIt will clone the repos into a directory using the REST API parameter `name` (repo.name). (Default behavior)\r\n\r\nI want it to clone the repos into a directory using the REST API parameter `full_name` (since it consists of `repo.owner` and `repo.name`), how do I get around to do that?\r\n\r\n---\r\nThis is what is created inside my directory:\r\n\r\n```\r\nrepo.name1\r\nrepo.name2\r\n```\r\n\r\nThis is what I want inside my directory:\r\n\r\n```\r\nrepo.owner1\\repo.name1\r\nrepo.owner2\\repo.name2\r\n```",
        "link": "https://stackoverflow.com/questions/69151495/how-to-clone-repos-inside-a-directory-with-their-author-name-with-rest-api",
        "title": "How to clone repos inside a directory with their author name with REST API?"
    },
    {
        "tags": [
            "json",
            "stream",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1631528377,
                "last_edit_date": 1631528377,
                "creation_date": 1631511741,
                "answer_id": 69157776,
                "question_id": 69157508,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the input file is just a stream of JSON entities, and since it seems each output row depends only on one of these, you can avoid memory issues most simply by NOT using the -s command-line option, and adapting your jq program accordingly. There should be no need to use the —stream option.",
                "title": "Streaming large json file to csv"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1631512822,
                "creation_date": 1631512822,
                "answer_id": 69157938,
                "question_id": 69157508,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As peak suggests, your output doesn&#39;t require the streaming parser of `jq` to be invoked. If you can efficiently filter out the required fields alone for the CSV output, you should be fine, i.e.\r\n\r\n```none\r\njq -r -cn &#39;[&quot;address&quot;,&quot;lat&quot;,&quot;lon&quot;], (inputs | [._source.name.default,._source.center_point.lat,._source.center_point.lon]) | @csv&#39;\r\n```",
                "title": "Streaming large json file to csv"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1631556423,
        "creation_date": 1631509556,
        "last_edit_date": 1631556423,
        "question_id": 69157508,
        "body_markdown": "I have a large JSON file contains a list of objects like this:\r\n\r\n    {\r\n       &quot;_index&quot;:&quot;pelias&quot;,\r\n       &quot;_type&quot;:&quot;address&quot;,\r\n       &quot;_id&quot;:&quot;jf808cdawi46z&quot;,\r\n       &quot;_score&quot;:1,\r\n       &quot;_source&quot;:{\r\n          &quot;center_point&quot;:{\r\n             &quot;lon&quot;:106.66307,\r\n             &quot;lat&quot;:10.959882\r\n          },\r\n          &quot;name&quot;:{\r\n             &quot;default&quot;:&quot;375/20 B&#249;i Quốc Kh&#225;nh, Ch&#225;nh Nghĩa, B&#236;nh Dương, Việt Nam&quot;\r\n          }\r\n       }\r\n    }\r\n    {\r\n       &quot;_index&quot;:&quot;pelias&quot;,\r\n       &quot;_type&quot;:&quot;address&quot;,\r\n       &quot;_id&quot;:&quot;jf808cdawi46z&quot;,\r\n       &quot;_score&quot;:1,\r\n       &quot;_source&quot;:{\r\n          &quot;center_point&quot;:{\r\n             &quot;lon&quot;:106.66307,\r\n             &quot;lat&quot;:10.959882\r\n          },\r\n          &quot;name&quot;:{\r\n             &quot;default&quot;:&quot;375/20 B&#249;i Quốc Kh&#225;nh, Ch&#225;nh Nghĩa, B&#236;nh Dương, Việt Nam&quot;\r\n          }\r\n       }\r\n    }\r\n\r\nI&#39;m using jq to convert it to a csv like this:\r\n\r\n    &quot;address&quot;,&quot;lat&quot;,&quot;lon&quot;\r\n    &quot;375/20 B&#249;i Quốc Kh&#225;nh, Ch&#225;nh Nghĩa, B&#236;nh Dương, Việt Nam&quot;,10.959882,106.66307\r\n    &quot;375/20 B&#249;i Quốc Kh&#225;nh, Ch&#225;nh Nghĩa, B&#236;nh Dương, Việt Nam&quot;,10.959882,106.66307\r\n\r\nI&#39;m using this code:\r\n\r\n    cat pelias_minify.json | jq -r -s &#39;. | [.[]  | {lat: ._source.center_point.lat, lon: ._source.center_point.lon, address: ._source.name.default}] | (map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv&#39; &gt; pes.csv\r\n\r\nThe problem is that this file has sized up to more than 2GB. I&#39;m studying to apply streaming but still can not understand how to use it. Any help, please? Many thanks.\r\n\r\nUpdate, I tried this code and I can stream the file output:\r\n\r\n    cat pelias_minify.json | jq -cn --stream &#39;fromstream(0|truncate_stream(inputs)) | {lat: ._source.center_point.lat, lon: ._source.center_point.lon, address: ._source.name.default}&#39;\r\n\r\nOuput:\r\n\r\n    {&quot;center_point&quot;:{&quot;lon&quot;:106.66307,&quot;lat&quot;:10.959882},&quot;name&quot;:{&quot;default&quot;:&quot;375/20 B&#249;i Quốc Kh&#225;nh, Ch&#225;nh Nghĩa, B&#236;nh Dương, Việt Nam&quot;}}\r\n    {&quot;center_point&quot;:{&quot;lon&quot;:106.66307,&quot;lat&quot;:10.959882},&quot;name&quot;:{&quot;default&quot;:&quot;375/20 B&#249;i Quốc Kh&#225;nh, Ch&#225;nh Nghĩa, B&#236;nh Dương, Việt Nam&quot;}}\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69157508/streaming-large-json-file-to-csv",
        "title": "Streaming large json file to csv"
    },
    {
        "tags": [
            "python",
            "json",
            "jq",
            "convertto-json"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631540847,
                "creation_date": 1631540847,
                "answer_id": 69163827,
                "question_id": 69163768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Open the file and use dictionary comprehension\r\n\r\n    with open(&#39;names.txt&#39;) as file:\r\n        d = {&#39;names&#39;: name.split(&#39; &#39;) for name in file}\r\n        \r\n    print(d)",
                "title": "convert space separated list of names within a file to json formatted json file"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631540851,
                "creation_date": 1631540851,
                "answer_id": 69163828,
                "question_id": 69163768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can just read the first line, split on whitespace, the create the desired dictionary\r\n\r\n    with open(&#39;names.txt&#39;) as f:\r\n        names = f.readline().spilt()\r\n        data = {&#39;names&#39;: names}\r\n\r\nTo later get this into valid json you can use `dump` or `dumps` depending what you need to pass this to\r\n\r\n    &gt;&gt;&gt; import json\r\n    &gt;&gt;&gt; json.dumps(data)\r\n    &#39;{&quot;names&quot;: [&quot;name1&quot;, &quot;name2&quot;, &quot;name3&quot;]}&#39;",
                "title": "convert space separated list of names within a file to json formatted json file"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1631547359,
                "last_edit_date": 1631547359,
                "creation_date": 1631540957,
                "answer_id": 69163847,
                "question_id": 69163768,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A [tag:jq] solution could be simplefied by passing the &#39;string&#39; as argument, then using `split()` to create an array like so:\r\n\r\n```none\r\njq -n --arg d &quot;$(cat input)&quot; &#39;{ &quot;names&quot;: $d | split(&quot; &quot;) }&#39;\r\n```\r\n\r\nLocal example:\r\n```\r\n$ cat input\r\nname1 name2 name3\r\n$\r\n$ jq -n --arg d &quot;$(cat input)&quot; &#39;{ &quot;names&quot;: $d | split(&quot; &quot;) }&#39;\r\n{\r\n  &quot;names&quot;: [\r\n    &quot;name1&quot;,\r\n    &quot;name2&quot;,\r\n    &quot;name3&quot;\r\n  ]\r\n}\r\n$\r\n$\r\n```",
                "title": "convert space separated list of names within a file to json formatted json file"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1631551522,
        "creation_date": 1631540605,
        "last_edit_date": 1631551522,
        "question_id": 69163768,
        "body_markdown": "I have a space separated list of names generated by a program, I need to convert this list to json. I can not change the program generating the file output. I need to convert the output in file names.txt to json. \r\n\r\nexample: file output is called names.txt. context is below. \r\n```none\r\nname1 name2 name3\r\n```\r\nThe json expectation is \r\n```json\r\n{\r\n    &quot;names&quot;: [\r\n        &quot;name1&quot;,\r\n        &quot;name2&quot;,\r\n        &quot;name3&quot;\r\n    ]\r\n}\r\n```\r\nI have [tag:boto3] and [tag:JQ] at my disposal. ",
        "link": "https://stackoverflow.com/questions/69163768/convert-space-separated-list-of-names-within-a-file-to-json-formatted-json-file",
        "title": "convert space separated list of names within a file to json formatted json file"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631581728,
                "creation_date": 1631581728,
                "answer_id": 69170689,
                "question_id": 69170688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "this may be achieved with `gsub`, `ascii_upcase`, and named capture groups:\r\n```\r\n$ echo &#39;&quot;lorum ipsum&quot;&#39; | jq &#39;gsub(&quot;(?&lt;x&gt;[A-z])(?&lt;y&gt;[A-z]+)&quot;; &quot;\\(.x|ascii_upcase)\\(.y)&quot;)&#39;\r\n&quot;Lorum Ipsum&quot;\r\n```",
                "title": "Titleize text with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631585866,
                "creation_date": 1631585866,
                "answer_id": 69171053,
                "question_id": 69170688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `nawk` `for` loop, `toupper`, `sub` and `substr` as below:\r\n```\r\necho &#39;lorum ipsum&#39; |  nawk &#39;{for(i=1;i&lt;=NF;i++)sub(/./,toupper(substr($i,1,1)),$i)}1&#39;\r\n```",
                "title": "Titleize text with jq"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1631762021,
                "creation_date": 1631762021,
                "answer_id": 69201908,
                "question_id": 69170688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given a string you consider calling a word, you may uppercase its first character by converting it into an array (`./&quot;&quot;`), modifying the first element (`first|=ascii_upcase`) and joining all elements back together (`add`) like so\r\n\r\n    ./&quot;&quot; | first |= ascii_upcase | add\r\n\r\nSimilarly, given a string of words, split it into an array of words, apply the above to each element using `map` and join them back together. Depending on what you (or the input data requires you to) consider a word, splitting the string might differ. Given your input example (`&quot;lorum ipsum&quot;`), using a single space character as word separator will suffice. I&#39;ll set it in a variable (`--arg ws &#39; &#39;`) and use it for splitting (`./$ws`) and joining (`join($ws)`):\r\n\r\n    echo &#39;&quot;lorum ipsum&quot;&#39; | jq --arg ws &#39; &#39; &#39;\r\n      \r\n      ./$ws | map(\r\n        \r\n        ./&quot;&quot; | first |= ascii_upcase | add\r\n        \r\n      ) | join($ws)\r\n      \r\n    &#39;",
                "title": "Titleize text with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1631762021,
        "creation_date": 1631581728,
        "question_id": 69170688,
        "body_markdown": "How can I titleize text (capitalize each word) with `jq`?\r\n\r\nExpected transformation: `&quot;lorum ipsum&quot;` → `&quot;Lorum Ipsum&quot;`\r\n",
        "link": "https://stackoverflow.com/questions/69170688/titleize-text-with-jq",
        "title": "Titleize text with jq"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1631587660,
                "last_edit_date": 1631587660,
                "creation_date": 1631587331,
                "answer_id": 69171197,
                "question_id": 69171091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```sh\r\njq -r &#39;.[] | .ip + &quot;:&quot; + ( .ports[].port | tostring )&#39; output.json\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/MownPooeEt)&lt;br&gt;\r\n[jqplay](https://jqplay.org/s/rLxSv6PjqV)\r\n\r\n---\r\n\r\nUsing `join`, it would be\r\n\r\n```sh\r\njq -r &#39;.[] | .ip as $ip | .ports[].port as $port | [ $ip, $port ] | join(&quot;:&quot;)&#39; output.json\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/X573h6bNpB)&lt;br&gt;\r\n[jqplay](https://jqplay.org/s/XvBF-VKedz)\r\n\r\n---\r\n\r\nBoth of these solutions work with multiple IP addresses and with multiple ports per IP address.\r\n",
                "title": "jq extract data of json"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631612009,
                "creation_date": 1631612009,
                "answer_id": 69175342,
                "question_id": 69171091,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using string interpolation :\r\n\r\n```\r\njq -r &#39;.[] | &quot;\\(.ip):\\(.ports[].port)&quot;&#39; output.json\r\n```",
                "title": "jq extract data of json"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1631612009,
        "creation_date": 1631586206,
        "last_edit_date": 1631587206,
        "question_id": 69171091,
        "body_markdown": "I have a file containing strings like :\r\n```[{   &quot;ip&quot;: &quot;127.0.0.1&quot;,   &quot;timestamp&quot;: &quot;1631581369&quot;, &quot;ports&quot;: [ {&quot;port&quot;: 80, &quot;proto&quot;: &quot;tcp&quot;, &quot;status&quot;: &quot;open&quot;, &quot;reason&quot;: &quot;syn-ack&quot;, &quot;ttl&quot;: 42} ] }]```\r\n\r\nI tried the following command to get the output \r\n\r\n``` cat output.json | jq -r &#39;.[].ip,.[].ports[].port &#39;```\r\n\r\nbut the lines  are seprated:\r\n\r\n``` \r\n127.0.0.1\r\n80\r\n```\r\nneed a string like :\r\n```127.0.0.1:80```\r\n\r\nI tried \r\n```cat output.json |   jq -r &#39;.[].ip,.[].ports[].port | join(&quot;:&quot;)&#39;```\r\n\r\nBut i get error of running this command:\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:69): Cannot iterate over string (&quot;127.0.0.1&quot;)\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69171091/jq-extract-data-of-json",
        "title": "jq extract data of json"
    },
    {
        "tags": [
            "json",
            "linux",
            "shell",
            "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": 0,
                "creation_date": 1631606326,
                "post_id": 69172746,
                "comment_id": 122260769,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1631627106,
                "last_edit_date": 1631627106,
                "creation_date": 1631616846,
                "answer_id": 69176430,
                "question_id": 69172746,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close\r\n\r\n    jq &#39;.config.list[.config.list|map(.key==&quot;vehicles&quot;)|index(true)].rows += [{&quot;data&quot;:[{&quot;key&quot;:&quot;fot&quot;,&quot;value&quot;:&quot;K&quot;},{&quot;key&quot;:&quot;seat&quot;,&quot;value&quot;:&quot;leon&quot;}],&quot;default&quot;:false}]&#39;\r\n\r\nsee https://stackoverflow.com/a/42248841/2235381",
                "title": "JQ: Add object to nested json with the same key names"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631627106,
        "creation_date": 1631600638,
        "question_id": 69172746,
        "body_markdown": "I having trouble of getting my json append with a new object into the `config -&gt; list -&gt; key(vehicles) -&gt; Rows`. But then only for `vehicles`.\r\n\r\nIm trying it with JQ: `cat file.json | jq &#39;.config.list[].rows[] += {&quot;data&quot;:[{&quot;key&quot;:&quot;fort&quot;,&quot;value&quot;:&quot;K&quot;},{&quot;key&quot;:&quot;seat&quot;,&quot;value&quot;:&quot;leon&quot;}],&quot;default&quot;:false}&#39;` But with this it is replacing and not appending because of the same names ?\r\n\r\nObject that needs to \r\n```\r\n                    {\r\n                        &quot;data&quot;: [\r\n                            {\r\n                                &quot;key&quot;: &quot;bike&quot;,\r\n                                &quot;value&quot;: &quot;yyy&quot;\r\n                            },\r\n                            {\r\n                                &quot;key&quot;: &quot;car&quot;,\r\n                                &quot;value&quot;: &quot;xxx&quot;\r\n                            }\r\n                        ],\r\n                        &quot;default&quot;: false\r\n                    }\r\n```\r\n\r\n\r\nSource Json:\r\n```\r\n{\r\n    &quot;id&quot;: &quot;1234&quot;,\r\n    &quot;name&quot;: &quot;CatList&quot;,\r\n    &quot;config&quot;: {\r\n        &quot;list&quot;: [\r\n            {\r\n                &quot;key&quot;: &quot;vehicles&quot;,\r\n                &quot;rows&quot;: [\r\n\r\n                    {\r\n                        &quot;data&quot;: [\r\n                            {\r\n                                &quot;key&quot;: &quot;bike&quot;,\r\n                                &quot;value&quot;: &quot;yyy&quot;\r\n                            },\r\n                            {\r\n                                &quot;key&quot;: &quot;car&quot;,\r\n                                &quot;value&quot;: &quot;xxx&quot;\r\n                            }\r\n                        ],\r\n                        &quot;default&quot;: false\r\n                    }\r\n\r\n\r\n                ]\r\n            },\r\n            {\r\n                &quot;key&quot;: &quot;boots&quot;,\r\n                &quot;rows&quot;: []\r\n            }\r\n        ],\r\n        &quot;data&quot;: [\r\n            {\r\n                &quot;key&quot;: &quot;GROUPS&quot;,\r\n                &quot;value&quot;: &quot;false&quot;\r\n            }\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\nWanted result:\r\n\r\n```\r\n{\r\n    &quot;id&quot;: &quot;1234&quot;,\r\n    &quot;name&quot;: &quot;CatList&quot;,\r\n    &quot;config&quot;: {\r\n        &quot;list&quot;: [\r\n            {\r\n                &quot;key&quot;: &quot;vehicles&quot;,\r\n                &quot;rows&quot;: [\r\n\r\n                    {\r\n                        &quot;data&quot;: [\r\n                            {\r\n                                &quot;key&quot;: &quot;bike&quot;,\r\n                                &quot;value&quot;: &quot;yyy&quot;\r\n                            },\r\n                            {\r\n                                &quot;key&quot;: &quot;car&quot;,\r\n                                &quot;value&quot;: &quot;xxx&quot;\r\n                            }\r\n                        ],\r\n                        &quot;default&quot;: false\r\n                    },\r\n                    {                             \r\n                        &quot;data&quot;: [                  &lt;-----\r\n                            {                      &lt;-----\r\n                                &quot;key&quot;: &quot;bike&quot;,     &lt;-----\r\n                                &quot;value&quot;: &quot;yyy&quot;     &lt;-----\r\n                            },                     &lt;-----\r\n                            {                      &lt;-----\r\n                                &quot;key&quot;: &quot;car&quot;,      &lt;-----\r\n                                &quot;value&quot;: &quot;xxx&quot;     &lt;-----\r\n                            }                      &lt;-----\r\n                        ],                         &lt;-----\r\n                        &quot;default&quot;: false           &lt;-----\r\n                    }\r\n\r\n\r\n                ]\r\n            },\r\n            {\r\n                &quot;key&quot;: &quot;boots&quot;,\r\n                &quot;rows&quot;: []\r\n            }\r\n        ],\r\n        &quot;data&quot;: [\r\n            {\r\n                &quot;key&quot;: &quot;GROUPS&quot;,\r\n                &quot;value&quot;: &quot;false&quot;\r\n            }\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69172746/jq-add-object-to-nested-json-with-the-same-key-names",
        "title": "JQ: Add object to nested json with the same key names"
    },
    {
        "tags": [
            "json",
            "unique",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 10,
                "is_accepted": true,
                "score": 10,
                "last_activity_date": 1631602058,
                "creation_date": 1631602058,
                "answer_id": 69173048,
                "question_id": 69172925,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the input is valid JSON, the following jq program will yield an array of the distinct names:\r\n\r\n    map(.name) | unique\r\n\r\nIf the input has superfluous commas as in the sample shown, you might wish to consider using a preprocessor, such as `any-json` or `hjson`.\r\n\r\n",
                "title": "jq get all unique values for a given key in a list of objects"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 6,
        "last_activity_date": 1637660448,
        "creation_date": 1631601498,
        "last_edit_date": 1637660448,
        "question_id": 69172925,
        "body_markdown": "Let&#39;s say I have an endpoint that returns the following array:\r\n\r\n```\r\n[\r\n  {&quot;name&quot;: &quot;Joe&quot;, &quot;age&quot;: 21},\r\n  {&quot;name&quot;: &quot;Steve&quot;, &quot;age&quot;: 27},\r\n  {&quot;name&quot;: &quot;Michelle&quot;, &quot;age&quot;: 32},\r\n  {&quot;name&quot;: &quot;Joe&quot;, &quot;age&quot;: 23},\r\n]\r\n```\r\n\r\nI know I can get all names using the following command (using httpie):\r\n\r\n```\r\nhttp https://some-endpoint | jq &#39;.[] | .name&#39;\r\n\r\n# output\r\nJoe\r\nSteve\r\nMichelle\r\nJoe\r\n```\r\n\r\nHow can I get all unique names (so there are no duplicates)?",
        "link": "https://stackoverflow.com/questions/69172925/jq-get-all-unique-values-for-a-given-key-in-a-list-of-objects",
        "title": "jq get all unique values for a given key in a list of objects"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631618428,
                "post_id": 69176379,
                "comment_id": 122265933,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5635704,
                    "reputation": 4118,
                    "user_id": 4461271,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/U313T.png?s=256",
                    "display_name": "midi",
                    "link": "https://stackoverflow.com/users/4461271/midi"
                },
                "reply_to_user": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631619886,
                "post_id": 69176379,
                "comment_id": 122266512,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2186012,
                    "reputation": 22650,
                    "user_id": 1934428,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/072774c5d4204a1c2385560e6114a887?s=256&d=identicon&r=PG",
                    "display_name": "user1934428",
                    "link": "https://stackoverflow.com/users/1934428/user1934428"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631619983,
                "post_id": 69176379,
                "comment_id": 122266567,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631620156,
                "creation_date": 1631620156,
                "answer_id": 69177219,
                "question_id": 69176379,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was able to access the values with the following command:\r\n\r\n    echo $i | jq -r &#39;.userName&#39;",
                "title": "Bash. How to access parameters while looping through json with jq?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631622948,
                "last_edit_date": 1631622948,
                "creation_date": 1631620384,
                "answer_id": 69177273,
                "question_id": 69176379,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all, you might want to &#39;clean&#39; your json, remove any trailing `,`&#39;s etc.\r\n\r\n\r\n----------\r\n\r\n\r\nAfter looping through [each line in the file](https://stackoverflow.com/questions/1521462/looping-through-the-content-of-a-file-in-bash) we just need one [`select()`][1] to get the matching object.\r\n\r\nThe script could look something like:\r\n```bash\r\n#!/bin/bash\r\n\r\nwhile read shop; do\r\n  echo &quot;Check: $shop&quot;\r\n  jq -r --arg storeName &quot;$shop&quot; &#39;.[] | select(.store.storeName == &quot;\\($storeName)&quot;) | &quot;\\(.userName) - \\(.store.storeName)&quot;&#39; details.json\r\ndone &lt; &quot;shops.txt&quot;\r\n```\r\n\r\nWhich will produce \r\n```none\r\nCheck: shop-a57ca0a3-120c-1a73-153b-fa4231cab768\r\nAnne - shop-a57ca0a3-120c-1a73-153b-fa4231cab768\r\n``` \r\n\r\n\r\n----------\r\n\r\nI guess this could be combined into a single [tag:jq] call, but it seems like you want to loop over each entry found\r\n\r\n\r\n----------\r\n\r\nYou can test this [tag:jq] selector on this [online JqPlay Demo](https://jqplay.org/s/jkHjTV6Jaw).\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#select(boolean_expression)",
                "title": "Bash. How to access parameters while looping through json with jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1631622948,
        "creation_date": 1631616618,
        "question_id": 69176379,
        "body_markdown": "i have a details.json file with a lot of entries and a shops.txt file like below. I like to have a little script which compares two values and just return the matching json entries.\r\n\r\n    [\r\n    {\r\n        &quot;userName&quot;: &quot;Anne&quot;,\r\n        &quot;email&quot;: &quot;anne@stack.com&quot;,\r\n        &quot;company&quot;: {\r\n            &quot;name&quot;: &quot;Stack GmbH&quot;,\r\n        },\r\n        &quot;details&quot;: {\r\n            &quot;key&quot;: &quot;EFHJKI-KJEFT-DHMNEB&quot;,\r\n            &quot;prod&quot;: &quot;Car&quot;,\r\n        },\r\n        &quot;store&quot;: {\r\n            &quot;id&quot;: &quot;05611a7f-a679-12ad-a3u2-0745e3650a03&quot;,\r\n            &quot;storeName&quot;: &quot;shop-a57ca0a3-120c-1a73-153b-fa4231cab768&quot;,\r\n        }\r\n    },\r\n    {\r\n        &quot;userName&quot;: &quot;Tom&quot;,\r\n        &quot;email&quot;: &quot;tom@stack.com&quot;,\r\n        &quot;company&quot;: {\r\n            &quot;name&quot;: &quot;Stack GmbH&quot;,\r\n        },\r\n        &quot;details&quot;: {\r\n            &quot;key&quot;: &quot;DFSGSE-FGEAR-GWRTGW&quot;,\r\n            &quot;prod&quot;: &quot;Bike&quot;,\r\n        },\r\n        &quot;store&quot;: null\r\n    },\r\n    ]\r\n\r\nThis is the other file &quot;shops.txt&quot; (can be a lot more of shops inside)\r\n\r\n    shop-a57ca0a3-120c-1a73-153b-fa4231cab768\r\n\r\nThe script is looping through the shops, for every shop it loops through the json and should compare the currentShop with the store.shop from json and then echo the user and the shop.\r\nBut I can not access the specific parameters inside the json. How can I do this?\r\n\r\n    #!/bin/bash\r\n    shops=&quot;shops.txt&quot;\r\n    while IFS= read -r line\r\n    do\r\n      currentShop=&quot;$line&quot;\r\n\r\n      jq -c &#39;.[.userName, .store.storeName]&#39; details.json | while read i; do\r\n      if [[ $i.store.storeName == *$currentShop* ]]; then\r\n      echo $i.userName\r\n      echo $currentShop\r\n      fi\r\n      done\r\n\r\n    done &lt; &quot;$shops&quot;\r\n\r\n\r\n    ",
        "link": "https://stackoverflow.com/questions/69176379/bash-how-to-access-parameters-while-looping-through-json-with-jq",
        "title": "Bash. How to access parameters while looping through json with jq?"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631631897,
                "post_id": 69179552,
                "comment_id": 122272153,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1631629987,
                "last_edit_date": 1631629987,
                "creation_date": 1631629626,
                "answer_id": 69179623,
                "question_id": 69179552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need to use [Generic Object Index][1] (`.[$var_name]`) to let [tag:jq] know the variable should be seen as a key\r\n\r\nThe command should look like:\r\n```none\r\njq -r --arg var_name &quot;$var_name&quot; &#39;.[$var_name]&#39; &lt;&lt;&lt; &quot;$temp1&quot;\r\n```\r\n\r\nWich will output:\r\n```none\r\nSmkfnkhnb48dh\r\n```\r\n\r\n----------\r\n\r\nNote: `&lt;&lt;&lt; &quot;$temp1&quot;` instead off the `echo`\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#GenericObjectIndex:.[%3Cstring%3E]",
                "title": "How to use variable with jq cmd in shell"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631630558,
                "creation_date": 1631630558,
                "answer_id": 69179864,
                "question_id": 69179552,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Let&#39;s look at the following statement:\r\n\r\n    echo $temp1 | jq -r &#39;.&quot;$var_name&quot;&#39;  &lt;---- return null\r\n\r\nYour problem is actually with the shell quoting and not `jq`.  The single quotes tell the shell not to interpolate (do variable substitution) among other things (like escaping white space and preventing globing).  Thus, `jq` is receiving literally .&quot;$var_name&quot; as it&#39;s script - which is not what you want.  You simply need to remove the single quotes and you&#39;ll be good:\r\n\r\n    echo $temp1 | jq -r .&quot;$var_name&quot;  &lt;---- Does this work?\r\n\r\nThat said, I would never write my script that way.  I would definitely want to include the &#39;.&#39; in the quoted string like this:\r\n\r\n    echo $temp1 | jq -r &quot;.$var_name&quot;  &lt;---- Does this work?\r\n\r\nSome would also suggest that you quote &quot;$temp1&quot; as well (typically all variable references should be quoted to protect against white space, but this is not a problem with echo):\r\n\r\n    echo &quot;$temp1&quot; | jq -r &quot;.$var_name&quot;  &lt;---- Does this work?\r\n\r\n\r\n\r\n\r\n\r\n",
                "title": "How to use variable with jq cmd in shell"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1631634411,
        "creation_date": 1631629353,
        "last_edit_date": 1631634411,
        "question_id": 69179552,
        "body_markdown": "I am facing issue with below commands. I need to use variable but it is returning me null whereas when I hardcode its value, it return me correct response.\r\nCan anybody help me whats the correct way of writing this command?\r\nMy intension is to pull value of corresponding key passed as a variable? \r\n\r\n    temp1=&quot;{    \\&quot;SSM_DEV_SECRET_KEY\\&quot;: \\&quot;Smkfnkhnb48dh\\&quot;,     \\&quot;SSM_DEV_GRAPH_DB\\&quot;: \\&quot;Prod=bolt://neo4j:Grt56@atc.preprod.test.com:7687\\&quot;,  \\&quot;SSM_DEV_RDS_DB\\&quot;: \\&quot;sqlite:////var/local/ecosystem_dashboard/config.db\\&quot;,     \\&quot;SSM_DEV_SUPPERUSER_USERNAME\\&quot;: \\&quot;admin\\&quot;,    \\&quot;SSM_DEV_SUPPERUSER_PASSWORD\\&quot;: \\&quot;9dW6JE8@KH9qiO006\\&quot;   }&quot;\r\n    \r\n    var_name=SSM_DEV_SECRET_KEY\r\n    echo $temp1 | jq -r &#39;.SSM_DEV_SECRET_KEY&#39;  &lt;----- return Smkfnkhnb48dh // output\r\n    echo $temp1 | jq -r &#39;.&quot;$var_name&quot;&#39;  &lt;---- return null\r\n    echo $temp1 | jq -r --arg var_name &quot;$var_name&quot; &#39;.&quot;$var_name&quot;&#39;  &lt;---- return null , alternative way\r\n\r\nUpdate: I am adding actual piece of where I am trying to use above fix. My intension is to first read all values which start with *SSM_DEV_...* and then get there original values from aws than replace it in. one key pair look like this --&gt; *SECRET_KEY=$SSM_DEV_SECRET_KEY*\r\n\r\n    temp0=&quot;dev&quot;\r\n    temp1=&quot;DEV&quot;\r\n    result1=$(aws secretsmanager get-secret-value --secret-id &quot;xxx-secret-$temp0&quot; | jq &#39;.SecretString&#39;)\r\n    while IFS= read -r line; do\r\n        if [[ &quot;$line&quot; == *&quot;=\\$SSM_$temp1&quot;* ]]; then\r\n            before=${line%%&quot;=&quot;*}\r\n            after=${line#*&quot;=&quot;}\r\n            var_name=&quot;${after:1}&quot;\r\n            jq -r --arg var_name &quot;$var_name&quot; &#39;.[$var_name]&#39; &lt;&lt;&lt; &quot;$result1&quot;\r\n        fi\r\n    done &lt; sample_file.txt\r\n\r\n\r\nFix: I have solved my issue which was of carriage return character.\r\nBelow cmd help me:\r\n\r\n    var_name=`echo ${after:1} | tr -d &#39;\\r&#39;`\r\n    jq -r --arg var_name &quot;$var_name&quot; &#39;.[$var_name]&#39; &lt;&lt;&lt; &quot;$result1&quot;",
        "link": "https://stackoverflow.com/questions/69179552/how-to-use-variable-with-jq-cmd-in-shell",
        "title": "How to use variable with jq cmd in shell"
    },
    {
        "tags": [
            "json",
            "shell",
            "command-line",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631632629,
                "creation_date": 1631632629,
                "answer_id": 69180429,
                "question_id": 69180158,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not sure if this is the way-to-go, but it gets the desired output by:\r\n\r\n* Using `--slurp`:\r\n* Catching the first 3 files as a single array variable  \r\n    `[ .[0] * .[1] * .[2] ] as $all`\r\n* Catching `owners` object as a single variable  \r\n    `.[3].owners as $owners`\r\n* Creating the object as desired  \r\n    `{ &quot;animals&quot;: $all, &quot;owners&quot;: $owners }`\r\n\r\n```none\r\njq \\\r\n    --slurp \\\r\n    &#39;[ .[0] * .[1] * .[2] ] as $all | .[3].owners as $owners | { &quot;animals&quot;: $all, &quot;owners&quot;: $owners }&#39; cats.json dogs.json snakes.json owners.json\r\n```\r\n\r\nWill produce:\r\n```json\r\n{\r\n  &quot;animals&quot;: [\r\n    {\r\n      &quot;cats&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;fluffles&quot;,\r\n          &quot;age&quot;: 10,\r\n          &quot;color&quot;: &quot;white&quot;\r\n        }\r\n      ],\r\n      &quot;dogs&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;sam&quot;,\r\n          &quot;age&quot;: 5,\r\n          &quot;color&quot;: &quot;black and white&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;rover&quot;,\r\n          &quot;age&quot;: 2,\r\n          &quot;color&quot;: &quot;brown and white&quot;\r\n        }\r\n      ],\r\n      &quot;snakes&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;noodles&quot;,\r\n          &quot;age&quot;: 10,\r\n          &quot;color&quot;: &quot;green&quot;\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;owners&quot;: [\r\n    &quot;peter&quot;,\r\n    &quot;william&quot;,\r\n    &quot;sally&quot;\r\n  ]\r\n}\r\n```",
                "title": "Merge multiple objects under a single object and add sibling object in one command"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1631645662,
                "creation_date": 1631645662,
                "answer_id": 69183207,
                "question_id": 69180158,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Suppose you had an (a priori) indeterminate or large numbers of types of animals, and just one `owners` file.  In such cases, it would be better (to save memory) not to use the `-s` option, and it would be easier to invoke jq with the owners file as the first data file, e.g. along the lines of:\r\n\r\n    jq -n -f program.jq owners.json $(ls *.json | grep -v owners.json)\r\n\r\nwhere program.jq contains a program such as:\r\n\r\n    input as $owners | {$owners, animals: [inputs]}\r\n\r\n(Notice how `{&quot;owners&quot;: $owners}` can be abbreviated.)\r\n\r\n",
                "title": "Merge multiple objects under a single object and add sibling object in one command"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1631648933,
        "creation_date": 1631631537,
        "question_id": 69180158,
        "body_markdown": "So I have three files:\r\n\r\n#### cats.json\r\n\r\n```json\r\n{\r\n  &quot;cats&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;fluffles&quot;,\r\n      &quot;age&quot;: 10,\r\n      &quot;color&quot;: &quot;white&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n#### dogs.json\r\n\r\n```json\r\n{\r\n  &quot;dogs&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;sam&quot;,\r\n      &quot;age&quot;: 5,\r\n      &quot;color&quot;: &quot;black and white&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;rover&quot;,\r\n      &quot;age&quot;: 2,\r\n      &quot;color&quot;: &quot;brown and white&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n#### snakes.json\r\n\r\n```json\r\n{\r\n  &quot;snakes&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;noodles&quot;,\r\n      &quot;age&quot;: 10,\r\n      &quot;color&quot;: &quot;green&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI wanted to merge these together, under an &quot;animals&quot; object. I&#39;ve found that will merge the files:\r\n\r\n```\r\njq -s &#39;{&quot;animals&quot;: .} &#39; cats.json dogs.json snakes.json &gt; animals.json\r\n```\r\n```json\r\n{\r\n  &quot;animals&quot;: [\r\n    {\r\n      &quot;cats&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;fluffles&quot;,\r\n          &quot;age&quot;: 10,\r\n          &quot;color&quot;: &quot;white&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;dogs&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;sam&quot;,\r\n          &quot;age&quot;: 5,\r\n          &quot;color&quot;: &quot;black and white&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;rover&quot;,\r\n          &quot;age&quot;: 2,\r\n          &quot;color&quot;: &quot;brown and white&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;snakes&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;noodles&quot;,\r\n          &quot;age&quot;: 10,\r\n          &quot;color&quot;: &quot;green&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nNow I have an additional object:\r\n\r\n#### owners.json\r\n\r\n```json\r\n{\r\n  &quot;owners&quot;: [\r\n    &quot;peter&quot;,\r\n    &quot;william&quot;,\r\n    &quot;sally&quot;\r\n  ]\r\n}\r\n```\r\n\r\nwhich I want to merge into the same file using \r\n\r\n```\r\njq -s &#39;.[0] + .[1]&#39; animals.json owners.json\r\n```\r\n\r\nCan I do both of these operations with just one `jq` command?\r\n\r\n```\r\njq -s &#39;{&quot;animals&quot;: .} &#39; cats.json dogs.json snakes.json &gt; animals.json\r\njq -s &#39;.[0] + .[1]&#39; animals.json owners.json\r\n```\r\n\r\nThe result would look like this:\r\n\r\n```json\r\n{\r\n  &quot;animals&quot;: [\r\n    {\r\n      &quot;cats&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;fluffles&quot;,\r\n          &quot;age&quot;: 10,\r\n          &quot;color&quot;: &quot;white&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;dogs&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;sam&quot;,\r\n          &quot;age&quot;: 5,\r\n          &quot;color&quot;: &quot;black and white&quot;\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;rover&quot;,\r\n          &quot;age&quot;: 2,\r\n          &quot;color&quot;: &quot;brown and white&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;snakes&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;noodles&quot;,\r\n          &quot;age&quot;: 10,\r\n          &quot;color&quot;: &quot;green&quot;\r\n        }\r\n      ]\r\n    }\r\n  ],\r\n  &quot;owners&quot;: [\r\n    &quot;peter&quot;,\r\n    &quot;william&quot;,\r\n    &quot;sally&quot;\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/69180158/merge-multiple-objects-under-a-single-object-and-add-sibling-object-in-one-comma",
        "title": "Merge multiple objects under a single object and add sibling object in one command"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631785718,
                "creation_date": 1631785718,
                "answer_id": 69206143,
                "question_id": 69183436,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First, we split the hostname string by a newline character (`.hostname /= &quot;\\n&quot;`) and do the same with the port string (`.port /= &quot;\\n&quot;`). Actually, we can combine these identical operations into one: `(.hostname, .port) /= &quot;\\n&quot;`\r\n\r\nNext, for every element of the port array (`.port[]`) we split by any non-digit character (`split(&quot;[^\\\\d]&quot;;&quot;g&quot;)`) resulting in an array of digit-only strings, from which we take the first element (`.[0]`), then a dash sign, and finally either the second element, if present, otherwise the first one again (`.[1]//.[0]`)\r\n\r\nWith your input in a file called input.json, the following should convert it into the desired format:\r\n\r\n    jq &#39;\r\n    \r\n      (.hostname, .port) /= &quot;\\n&quot; |\r\n      .port[] |= (split(&quot;[^\\\\d]&quot;;&quot;g&quot;) | &quot;\\(.[0])-\\(.[1]//.[0])&quot;)\r\n    \r\n    &#39; input.json\r\n\r\nRegarding your considerations:\r\n1. As we split at any non-digit character, it makes no difference what other character separates the values of a port range. If more than one character could separate them (e.g. an arrow `-&gt;` or with spaces before and after the dash sign ` - `), simply replace the regex `[^\\\\d]` with `[^\\\\d]+` for capturing more than one non-digit character.\r\n2. and 3. We always produce a range by including a dash sign and a second value, which depending on the presence of a second item may be either that or the first one again.\r\n\r\nRegarding your approach:\r\n\r\nInside `map` you used `select` which evaluates to `empty` if the condition (`contains(&quot;-&quot;) | not`) is not met. As `&quot;9500-9510&quot;` does indeed contain a dash sign, it didn&#39;t survive. An `if` statement *inside* the `select` statement wouldn&#39;t help because even if `select` doesn&#39;t evaluate to `empty` it still doesn&#39;t modify anything, it just reproduces its input unchanged. Therefore, if `select` is letting through both cases (containing and not containing dash signs) it becomes useless. You could, however, work with an `if` statement *outside* of the `select` statement, but I considered the above solution as a simpler approach.\r\n",
                "title": "jq filter to ignore values in select statement based on array values"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631785718,
        "creation_date": 1631647094,
        "question_id": 69183436,
        "body_markdown": "Given the following JSON input :\r\n\r\n```\r\n{\r\n  &quot;hostname&quot;: &quot;server1.domain.name\\nserver2.domain.name\\n*.gtld.net&quot;,\r\n  &quot;protocol&quot;: &quot;TCP&quot;,\r\n  &quot;port&quot;: &quot;8080\\n8443\\n9500-9510&quot;,\r\n  &quot;component&quot;: &quot;Component1&quot;,\r\n  &quot;hostingLocation&quot;: &quot;DC1&quot;\r\n}\r\n```\r\n\r\nI would like to obtain the following JSON output :\r\n\r\n```\r\n{\r\n  &quot;hostname&quot;: [\r\n    &quot;server1.domain.name&quot;,\r\n    &quot;server2.domain.name&quot;,\r\n    &quot;*.gtld.net&quot;\r\n  ],\r\n  &quot;protocol&quot;: &quot;TCP&quot;,\r\n  &quot;port&quot;: [\r\n    &quot;8080-8080&quot;,\r\n    &quot;8443-8443&quot;,\r\n    &quot;9500-9510&quot;\r\n  ],\r\n  &quot;component&quot;: &quot;Component1&quot;,\r\n  &quot;hostingLocation&quot;: &quot;DC1&quot;\r\n}\r\n```\r\n\r\nConsidering :\r\n\r\n 1. That the individual values in the `port` array may, or may not, be separated by a `-` character (I have no control over this).\r\n 2. That if an individual value in the `port` array does not contain the `-` separator, I then need to add it and then repeat the array value after the `-` separator. For example, `8080` becomes `8080-8080`, `8443` becomes `8443-8443` and so forth.\r\n3. And finally, that if a value in the `port` array is already of the format `value-value`, I should simply leave it unmodified.\r\n\r\nI&#39;ve been banging my head against this filter all afternoon, after reading many examples both here and in the official `jq` online documentation. I simply can&#39;t figure out how to accomodate consideration #3 above.\r\n\r\nThe filter I have now :\r\n\r\n`{hostname: .hostname | split(&quot;\\n&quot;), protocol: .protocol, port: .port | split(&quot;\\n&quot;) | map(select(. | contains(&quot;-&quot;) | not)+&quot;-&quot;+.), component: .component, hostingLocation: .hostingLocation}`\r\n\r\nYields the following output JSON :\r\n\r\n```\r\n{\r\n  &quot;hostname&quot;: [\r\n    &quot;server1.domain.name&quot;,\r\n    &quot;server2.domain.name&quot;,\r\n    &quot;*.gtld.net&quot;\r\n  ],\r\n  &quot;protocol&quot;: &quot;TCP&quot;,\r\n  &quot;port&quot;: [\r\n    &quot;8080-8080&quot;,\r\n    &quot;8443-8443&quot;\r\n  ],\r\n  &quot;component&quot;: &quot;Component1&quot;,\r\n  &quot;hostingLocation&quot;: &quot;DC1&quot;\r\n}\r\n```\r\n\r\nAs you can see above, I subsequently lose the `9500-9510` value as it already contains the `-` string which my filter weeds out.\r\n\r\nIf my logic does not fail me, I would need to stick an `if` statement within my `select` statement to conditionally only send array values that do not contain the string `-` to my select statement but leave array values that do contain the separator untouched. However, I cannot seem to figure this last piece out.\r\n\r\nI will happily accept any alternative filter that yields the desired output, however I am also really keen on understanding where my logics fails in the above filter.\r\n\r\nThanks in advance to anyone spending their valuable time helping me out!\r\n\r\n/Joel\r\n",
        "link": "https://stackoverflow.com/questions/69183436/jq-filter-to-ignore-values-in-select-statement-based-on-array-values",
        "title": "jq filter to ignore values in select statement based on array values"
    },
    {
        "tags": [
            "arrays",
            "json",
            "group-by",
            "count",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631728461,
                "last_edit_date": 1631728461,
                "creation_date": 1631659007,
                "answer_id": 69185195,
                "question_id": 69185056,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "    const traits = input.reduce((aggr, obj) =&gt; aggr.concat(obj.attributes), []);\r\n    const traitSet = traits.reduce((aggr, {trait, value}) =&gt; {\r\n     if(!aggr[trait]) {\r\n       aggr[trait] = {};\r\n     }\r\n    \r\n     if(!aggr[trait][value]){\r\n      aggr[trait][value] = 0;\r\n     }\r\n    \r\n     aggr[trait][value] = aggr[trait][value] + 1\r\n     return aggr;\r\n    }, {});\r\n    \r\n    \r\n    console.log(traitSet);\r\n    // or console.log(JSON.stringify(traitSet)) - since you asked for JSON\r\n\r\nJust a very quick version and vanilla version. This code can be made chained or less verbose by using libraries like lodash.",
                "title": "Unique count of json key/values using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1631672338,
                "creation_date": 1631672338,
                "answer_id": 69186381,
                "question_id": 69185056,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Having in mind the concepts of `group by` and `bag-of-words` as defined by:\r\n```\r\ndef bow(stream): \r\n  reduce stream as $word ({}; .[($word|tostring)] += 1);\r\n```\r\nit&#39;s not hard to see that the following produces the result shown immediately below:\r\n```\r\nmap(.attributes[])\r\n| group_by(.trait)\r\n| map( { (.[0].trait):  bow(.[].value) } )\r\n```\r\n```\r\n[{&quot;Color 1&quot;:{&quot;Blue&quot;:2}},{&quot;Color 2&quot;:{&quot;Yellow&quot;:1,&quot;Red&quot;:1}},{&quot;Hair&quot;:{&quot;Wild&quot;:2}}]\r\n```\r\n\r\nSo to get the result you want, simply add `| add` to the pipeline.\r\n\r\n\r\n\r\n\r\n",
                "title": "Unique count of json key/values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1631728461,
        "creation_date": 1631657759,
        "last_edit_date": 1631694745,
        "question_id": 69185056,
        "body_markdown": "I&#39;m really struggling trying to do this, so I apologize (jq isn&#39;t my forte).\r\n\r\nI have a file with a json array like this one:\r\n\r\n    [\r\n      {\r\n        &quot;name&quot;: &quot;aaaaa&quot;,\r\n        &quot;description&quot;: &quot;aaaaa&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;trait&quot;: &quot;Color 1&quot;,\r\n            &quot;value&quot;: &quot;Blue&quot;\r\n          },\r\n          {\r\n            &quot;trait&quot;: &quot;Color 2&quot;,\r\n            &quot;value&quot;: &quot;Yellow&quot;\r\n          },\r\n          {\r\n            &quot;trait&quot;: &quot;Hair&quot;,\r\n            &quot;value&quot;: &quot;Wild&quot;\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;bbbbb&quot;,\r\n        &quot;description&quot;: &quot;bbbbbb&quot;,\r\n        &quot;attributes&quot;: [\r\n          {\r\n            &quot;trait&quot;: &quot;Color 1&quot;,\r\n            &quot;value&quot;: &quot;Blue&quot;\r\n          },\r\n          {\r\n            &quot;trait&quot;: &quot;Color 2&quot;,\r\n            &quot;value&quot;: &quot;Red&quot;\r\n          },\r\n          {\r\n            &quot;trait&quot;: &quot;Hair&quot;,\r\n            &quot;value&quot;: &quot;Wild&quot;\r\n          }\r\n        ]\r\n      }\r\n    ]\r\n\r\nI&#39;d like to output a json object that shows the count of each trait so the end result would include something like\r\n\r\n    {\r\n       &quot;Color 1&quot;: {\r\n            &quot;Blue&quot;:2\r\n       },\r\n       &quot;Color 2&quot;:{\r\n            &quot;Yellow&quot;:1,\r\n            &quot;Red&quot;:1\r\n       },\r\n       &quot;Hair&quot;:{\r\n            &quot;Wild&quot;:2\r\n       }\r\n    }\r\n      \r\n\r\nThis is probably not too difficult but like I said, I suck at jq :)",
        "link": "https://stackoverflow.com/questions/69185056/unique-count-of-json-key-values-using-jq",
        "title": "Unique count of json key/values using jq"
    },
    {
        "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": 1,
                "creation_date": 1631685124,
                "post_id": 69187697,
                "comment_id": 122285351,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631691995,
                "creation_date": 1631691995,
                "answer_id": 69189005,
                "question_id": 69187697,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This one will give you an array of just the partitions with duplicates in the replicas field:\r\n\r\n```sh\r\n jq &#39;[.partitions[] | select((.replicas | length) != (.replicas | unique | length))]&#39; input.json\r\n```\r\n\r\nPretty-printed example output:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;topic&quot;: &quot;mytopic1&quot;,\r\n    &quot;partition&quot;: 1,\r\n    &quot;replicas&quot;: [\r\n      5,\r\n      5,\r\n      6\r\n    ],\r\n    &quot;log_dirs&quot;: [\r\n      &quot;any&quot;,\r\n      &quot;any&quot;\r\n    ]\r\n  }\r\n]\r\n```",
                "title": "jq - find duplicates in a value which is nested array of strings"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631691995,
        "creation_date": 1631685036,
        "question_id": 69187697,
        "body_markdown": "Assuming the below input, how can I detect the presence of duplicates in the replicas list? (replicas&quot;:[**5,5**,6]&quot;)\r\n\r\n```\r\n{&quot;version&quot;:1,\r\n &quot;partitions&quot;:\r\n   [{&quot;topic&quot;:&quot;mytopic1&quot;,&quot;partition&quot;:3,&quot;replicas&quot;:[4,5],&quot;log_dirs&quot;:[&quot;any&quot;,&quot;any&quot;]},\r\n    {&quot;topic&quot;:&quot;mytopic1&quot;,&quot;partition&quot;:1,&quot;replicas&quot;:[5,5,6],&quot;log_dirs&quot;:[&quot;any&quot;,&quot;any&quot;]},\r\n    {&quot;topic&quot;:&quot;mytopic2&quot;,&quot;partition&quot;:2,&quot;replicas&quot;:[6,5],&quot;log_dirs&quot;:[&quot;any&quot;,&quot;any&quot;]}]\r\n}\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69187697/jq-find-duplicates-in-a-value-which-is-nested-array-of-strings",
        "title": "jq - find duplicates in a value which is nested array of strings"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631707371,
                "post_id": 69192639,
                "comment_id": 122294092,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17646420,
                    "reputation": 759,
                    "user_id": 12807756,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/54205e2437eb9e5572540cb80b5b62fd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "WorkoutBuddy",
                    "link": "https://stackoverflow.com/users/12807756/workoutbuddy"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631707474,
                "post_id": 69192639,
                "comment_id": 122294145,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631707508,
                "post_id": 69192639,
                "comment_id": 122294155,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631707774,
                "post_id": 69192639,
                "comment_id": 122294277,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1631708234,
                "last_edit_date": 1631708234,
                "creation_date": 1631707921,
                "answer_id": 69192898,
                "question_id": 69192639,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Two things:\r\n\r\n- You have to specify a filter for jq &amp;ndash; just `.` to get the entire input\r\n- Once in a variable with whitespace, you must quote the string, else it shows up differently when you print it\r\n\r\n```sh\r\nvar=$(cat /etc/tfe-config/sources/fluent-bit.conf.tpl | jq -R -s &#39;.&#39;)\r\necho &quot;$var&quot; \r\n```\r\n\r\n---\r\n\r\nRelevant Q&amp;A:\r\n\r\n- https://stackoverflow.com/q/33247228/3266847 (and also [this GitHub issue][1])\r\n- https://stackoverflow.com/q/29378566/3266847\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/issues/1110",
                "title": "Transform file content into json string with jq doesn&#39;t work in command substitution"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631708325,
        "creation_date": 1631706861,
        "last_edit_date": 1631708325,
        "question_id": 69192639,
        "body_markdown": "This is working as expected:\r\n\r\n```bash\r\n$ cat /etc/tfe-config/sources/fluent-bit.conf.tpl | jq -R -s\r\n$ &quot;[OUTPUT]\\n    Name               cloudwatch_logs\\n    Match              *\\n    region             eu-central-1\\n    log_group_name     TFE-LogForwarding\\n    log_stream_name    TFE-AllLogs&quot;\r\n```\r\n\r\nHowever, assignment to a variable does not work:\r\n```\r\n$ MY_VARIABLE=$(cat /etc/tfe-config/sources/fluent-bit.conf.tpl | jq -R -s)\r\n$ echo $MY_VARIABLE \r\njq - commandline JSON processor [version 1.5]\r\nUsage: jq [options] &lt;jq filter&gt; [file...]\r\n\r\n        jq is a tool for processing JSON inputs, applying the\r\n        given filter to its JSON text inputs and producing the\r\n        filter&#39;s results as JSON on standard output.\r\n        The simplest filter is ., which is the identity filter,\r\n        copying jq&#39;s input to its output unmodified (except for\r\n        formatting).\r\n        For more advanced filters see the jq(1) manpage (&quot;man jq&quot;)\r\n        and/or https://stedolan.github.io/jq\r\n\r\n        Some of the options include:\r\n         -c             compact instead of pretty-printed output;\r\n       .... trimmed\r\n```\r\n\r\nI am on AWS EC2 machine with the latest Amazon Linux 2 image.\r\n\r\nWhat is going on here?\r\n\r\nThe file looks like this:\r\n```\r\n[OUTPUT]\r\n    Name               cloudwatch_logs\r\n    Match              *\r\n    region             eu-central-1\r\n    log_group_name     TFE-LogForwarding\r\n    log_stream_name    TFE-AllLogs\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69192639/transform-file-content-into-json-string-with-jq-doesnt-work-in-command-substitu",
        "title": "Transform file content into json string with jq doesn&#39;t work in command substitution"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 173397,
                    "reputation": 21942,
                    "user_id": 402037,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/hL5b7.png?s=256",
                    "display_name": "Andreas",
                    "link": "https://stackoverflow.com/users/402037/andreas"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631708800,
                "post_id": 69193083,
                "comment_id": 122294780,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1631708844,
                "creation_date": 1631708844,
                "answer_id": 69193139,
                "question_id": 69193083,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need `.AliasTarget.DNSName` to get the `.DNSName` **inside** the `.AliasTarget` object:\r\n\r\n```\r\n.ResourceRecordSets[] | &quot;\\(.Name) \\t\\(.Type) \\t\\(.AliasTarget.DNSName)&quot;\r\n```\r\n```none\r\n&quot;test.example.net. \\tA \\ttest.example.net.us-east-1.elb.amazonaws.com.&quot;\r\n```\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/vtMfBt7Lnv)",
                "title": "JQ Query for nested values"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1641885232,
        "creation_date": 1631708639,
        "last_edit_date": 1641885232,
        "question_id": 69193083,
        "body_markdown": "I&#39;m sure this has been answered, but I can only find similar questions.. nothing which actually answers mine.\r\n\r\nI have some JSON..\r\n\r\nexample:\r\n\r\n    {\r\n        &quot;Name&quot;: &quot;test.example.net.&quot;,\r\n        &quot;Type&quot;: &quot;A&quot;,\r\n        &quot;AliasTarget&quot;: {\r\n            &quot;HostedZoneId&quot;: &quot;XXX12345XX54321&quot;,\r\n            &quot;DNSName&quot;: &quot;test.example.net.us-east-1.elb.amazonaws.com.&quot;,\r\n            &quot;EvaluateTargetHealth&quot;: false\r\n        }\r\n    },\r\nI want to return the Name, Type &amp; DNSName only.\r\n\r\nI&#39;ve got close with..\r\n\r\n    .ResourceRecordSets[] | &quot;\\(.Name) \\t\\(.Type) \\t\\(.AliasTarget)&quot;\r\nBut that returns the entire array `AliasTarget` - I&#39;m trying to work out the correct syntax to pick out just `DNSName`\r\n\r\nAny ideas?",
        "link": "https://stackoverflow.com/questions/69193083/jq-query-for-nested-values",
        "title": "JQ Query for nested values"
    },
    {
        "tags": [
            "json",
            "select",
            "jq",
            "empty-list"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1631729906,
                "creation_date": 1631729906,
                "answer_id": 69198081,
                "question_id": 69194523,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could simply append the following to your existing pipeline:\r\n```\r\n| select(.services!=[])\r\n\r\n```\r\nOr you could rewrite the query:\r\n```\r\n.[]\r\n| [.clusters[].services[] \r\n   | select(.taskdef[] | .name==&quot;app&quot; and .version==&quot;1.3.2&quot;) \r\n   | .taskdef[] ] as $services\r\n| select($services!=[])\r\n| {profile, $services}\r\n\r\n```",
                "title": "Remove empty results with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1631730215,
        "creation_date": 1631713992,
        "last_edit_date": 1631730215,
        "question_id": 69194523,
        "body_markdown": "I want to remove the empty results and it currently looks like this\r\n\r\n    {\r\n      &quot;profile&quot;: &quot;test1&quot;,\r\n      &quot;services&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;app&quot;,\r\n          &quot;version&quot;: &quot;1.3.2&quot;\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      &quot;profile&quot;: &quot;test2&quot;,\r\n      &quot;services&quot;: []\r\n    }\r\nI don&#39;t want test2 to be presented since it&#39;s empty.\r\nThis is the command im currently running\r\n\r\n    cat data.json | jq &#39;.[] | {profile: .profile, services: [.clusters[].services[]| select(.taskdef[] | .name==&quot;app&quot; and .version==&quot;1.3.2&quot;) | .taskdef[] ]}&#39;\r\n\r\nAnd this a sample of data.json\r\n\r\n    [{\r\n\t\t&quot;profile&quot;: &quot;test1&quot;,\r\n\t\t&quot;clusters&quot;: [{\r\n\t\t\t\t&quot;cluster&quot;: &quot;test1-cluster1&quot;,\r\n\t\t\t\t&quot;services&quot;: [{\r\n\t\t\t\t\t&quot;servicename&quot;: &quot;cluster1-service&quot;,\r\n\t\t\t\t\t&quot;taskdef&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;app&quot;,\r\n\t\t\t\t\t\t&quot;version&quot;: &quot;1.3.3&quot;\r\n\t\t\t\t\t}]\r\n\t\t\t\t}]\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;cluster&quot;: &quot;test1-cluster2&quot;,\r\n\t\t\t\t&quot;services&quot;: [{\r\n\t\t\t\t\t&quot;servicename&quot;: &quot;cluster2-service&quot;,\r\n\t\t\t\t\t&quot;taskdef&quot;: [{\r\n\t\t\t\t\t\t&quot;name&quot;: &quot;app&quot;,\r\n\t\t\t\t\t\t&quot;version&quot;: &quot;1.3.2&quot;\r\n\t\t\t\t\t}]\r\n\t\t\t\t}]\r\n\t\t\t}\r\n\t\t]\r\n\t},\r\n\t{\r\n\t\t&quot;profile&quot;: &quot;test2&quot;,\r\n\t\t&quot;clusters&quot;: [{\r\n\t\t\t&quot;cluster&quot;: &quot;test2-cluster1&quot;,\r\n\t\t\t&quot;services&quot;: [{\r\n\t\t\t\t&quot;servicename&quot;: &quot;cluster1-service&quot;,\r\n\t\t\t\t&quot;taskdef&quot;: [{\r\n\t\t\t\t\t&quot;name&quot;: &quot;app&quot;,\r\n\t\t\t\t\t&quot;version&quot;: &quot;1.4.0&quot;\r\n\t\t\t\t}]\r\n\t\t\t}]\r\n\t\t}]\r\n\t}\r\n]\r\n\r\nI have been experimenting with select( lenght &gt; 0) but i cant get the syntax correct.",
        "link": "https://stackoverflow.com/questions/69194523/remove-empty-results-with-jq",
        "title": "Remove empty results with jq"
    },
    {
        "tags": [
            "bash",
            "makefile",
            "jq",
            "gnu-make"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 11902904,
                    "reputation": 6439,
                    "user_id": 8710344,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/b1f198f79adde1ffb8df546153d903a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "HardcoreHenry",
                    "link": "https://stackoverflow.com/users/8710344/hardcorehenry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631733154,
                "post_id": 69197789,
                "comment_id": 122304949,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19674984,
                    "reputation": 1846,
                    "user_id": 14403369,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/BaK0N.png?s=256",
                    "display_name": "urznow",
                    "link": "https://stackoverflow.com/users/14403369/urznow"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631743695,
                "post_id": 69197789,
                "comment_id": 122308007,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5108449,
                    "reputation": 382,
                    "user_id": 4095865,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/85917aa1739cdd188f6d4ff06023171d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adamcunnington",
                    "link": "https://stackoverflow.com/users/4095865/adamcunnington"
                },
                "reply_to_user": {
                    "account_id": 11902904,
                    "reputation": 6439,
                    "user_id": 8710344,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/b1f198f79adde1ffb8df546153d903a7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "HardcoreHenry",
                    "link": "https://stackoverflow.com/users/8710344/hardcorehenry"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631778693,
                "post_id": 69197789,
                "comment_id": 122315162,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5108449,
                    "reputation": 382,
                    "user_id": 4095865,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/85917aa1739cdd188f6d4ff06023171d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adamcunnington",
                    "link": "https://stackoverflow.com/users/4095865/adamcunnington"
                },
                "reply_to_user": {
                    "account_id": 19674984,
                    "reputation": 1846,
                    "user_id": 14403369,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/BaK0N.png?s=256",
                    "display_name": "urznow",
                    "link": "https://stackoverflow.com/users/14403369/urznow"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631778735,
                "post_id": 69197789,
                "comment_id": 122315178,
                "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": 0,
                "creation_date": 1631779262,
                "post_id": 69197789,
                "comment_id": 122315447,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5108449,
                    "reputation": 382,
                    "user_id": 4095865,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/85917aa1739cdd188f6d4ff06023171d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adamcunnington",
                    "link": "https://stackoverflow.com/users/4095865/adamcunnington"
                },
                "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": 1631779375,
                "post_id": 69197789,
                "comment_id": 122315490,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5108449,
                    "reputation": 382,
                    "user_id": 4095865,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/85917aa1739cdd188f6d4ff06023171d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adamcunnington",
                    "link": "https://stackoverflow.com/users/4095865/adamcunnington"
                },
                "reply_to_user": {
                    "account_id": 19674984,
                    "reputation": 1846,
                    "user_id": 14403369,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/BaK0N.png?s=256",
                    "display_name": "urznow",
                    "link": "https://stackoverflow.com/users/14403369/urznow"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631779391,
                "post_id": 69197789,
                "comment_id": 122315499,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5108449,
                    "reputation": 382,
                    "user_id": 4095865,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/85917aa1739cdd188f6d4ff06023171d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adamcunnington",
                    "link": "https://stackoverflow.com/users/4095865/adamcunnington"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631779551,
                "post_id": 69197789,
                "comment_id": 122315560,
                "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": 0,
                "creation_date": 1631779904,
                "post_id": 69197789,
                "comment_id": 122315715,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5108449,
                    "reputation": 382,
                    "user_id": 4095865,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/85917aa1739cdd188f6d4ff06023171d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adamcunnington",
                    "link": "https://stackoverflow.com/users/4095865/adamcunnington"
                },
                "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": 1631780092,
                "post_id": 69197789,
                "comment_id": 122315797,
                "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": 0,
                "creation_date": 1631780488,
                "post_id": 69197789,
                "comment_id": 122315961,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5108449,
                    "reputation": 382,
                    "user_id": 4095865,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/85917aa1739cdd188f6d4ff06023171d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adamcunnington",
                    "link": "https://stackoverflow.com/users/4095865/adamcunnington"
                },
                "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": 1631780774,
                "post_id": 69197789,
                "comment_id": 122316106,
                "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": 0,
                "creation_date": 1631780816,
                "post_id": 69197789,
                "comment_id": 122316119,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5108449,
                    "reputation": 382,
                    "user_id": 4095865,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://www.gravatar.com/avatar/85917aa1739cdd188f6d4ff06023171d?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "adamcunnington",
                    "link": "https://stackoverflow.com/users/4095865/adamcunnington"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631780868,
                "post_id": 69197789,
                "comment_id": 122316143,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1631797118,
                "last_edit_date": 1631797118,
                "creation_date": 1631733240,
                "answer_id": 69198652,
                "question_id": 69197789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It would be very helpful if you provide the complete rule you&#39;re trying to write.\r\n\r\nUsing `$(&lt;foo.yml)` can&#39;t work in a make recipe because make treats everything starting with a `$` as a make variable and expands it before running the shell.  You need to escape all `$` you want the shell to see, as `$$`.\r\n\r\nUsing `$$(&lt;foo.yml)` will work on some systems, but not other systems: that syntax is not defined by the POSIX standard and so shells that provide POSIX features will not do anything with it.  That&#39;s enhanced syntax for the bash shell.  Make always runs `/bin/sh` by default, so if your `/bin/sh` is really bash, it might work.  If not, not.\r\n\r\nUsing `$(shell cat foo.yml)` cannot work because make&#39;s shell function removes all newlines from the output before replacing it.\r\n\r\nSince we can&#39;t see your actual rule we can&#39;t really suggest the best alternative.  Is there some reason you can&#39;t use the simple, standard:\r\n\r\n    jq &lt; foo.yml\r\n\r\n?\r\n\r\n**ETA**\r\n\r\nAs explained, your shell is bash.  Make always by default uses `/bin/sh` as a shell (imagine the portability problems if make always used whatever shell the person invoking it was using).\r\n\r\nIf you can&#39;t figure out how to rewrite your makefile recipe to use standard POSIX syntax and you instead want to use bash-specific syntax, you can tell make to use bash as its shell:\r\n\r\n    SHELL := /bin/bash\r\n\r\nnow all the bash-specific magic will work in your recipes.  Of course your makefile will not work on systems that don&#39;t have `/bin/bash`.",
                "title": "How can I achieve $(&lt;some-file) inside a Makefile target?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1631780629,
                "last_edit_date": 1631780629,
                "creation_date": 1631779691,
                "answer_id": 69204626,
                "question_id": 69197789,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A much simpler and more portable rearticulation of the `jq` part would be\r\n\r\n```sh\r\njq --null-input --rawfile yaml .gitlab-ci.yml &#39;.content=$yaml&#39;\r\n```\r\nInside a `Makefile`, obviously double the dollar sign.\r\n\r\nA minor difference is that with `--rawfile` the final newline in the file is included, too.\r\n\r\nThe `--rawfile` option was introduced in `jq` 1.6.",
                "title": "How can I achieve $(&lt;some-file) inside a Makefile target?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1631797118,
        "creation_date": 1631728295,
        "last_edit_date": 1631780900,
        "question_id": 69197789,
        "body_markdown": "I am trying to implement the `jq` pipe `curl` command from https://docs.gitlab.com/ee/api/lint.html#use-jq-to-create-and-process-yaml--json-payloads but inside of a make file context.\r\n\r\nI have spent hours trying seemingly every single permutation of escaping and trying substitute commands but I can&#39;t get the equivelant to work. I have no problem outside of makefile.\r\n\r\nI tried substituting `&quot;$(&lt;foo.yml)&quot;` with `&quot;$$(&lt;foo.yml)&quot;` or `$(shell cat foo.yml)` and even `cat foo.yml | ... @-` but no luck. The `shell cat` was the closest I got but cat removes \\n characters which then makes the resultant JSON that I pass to GitLab come back with confusing errors:\r\n{&quot;valid&quot;:false,&quot;errors&quot;:[&quot;(\\u003cunknown\\u003e): block sequence entries are not allowed in this context at line 1 column 12&quot;],&quot;warnings&quot;:[],&quot;status&quot;:&quot;invalid&quot;}\r\n\r\nI compared the string with the working original version outside of Makefile context and the only thing different is the lack of \\n characters.\r\n\r\nPlease help! Thank you.\r\n\r\n**EDIT**\r\nAs requested, here are the extra details from the URL.\r\n\r\nThis is the command I am trying to move into a Makefile context. This command works fine from directly from my bash terminal.\r\n\r\n```bash\r\njq --null-input --arg yaml &quot;$(&lt;.gitlab-ci.yml)&quot; &#39;.content=$yaml&#39; | curl &quot;https://gitlab.com/api/v4/ci/lint?&quot; --header &quot;Content-Type: application/json&quot; --header &quot;PRIVATE-TOKEN: $GITLAB_PERSONAL_ACCESS_TOKEN&quot; --data @-\r\n```\r\n\r\nHere&#39;s the response:\r\n`{&quot;valid&quot;:true,&quot;errors&quot;:[],&quot;warnings&quot;:[],&quot;status&quot;:&quot;valid&quot;}`\r\n\r\nHere is my Makefile version:\r\n```makefile\r\n.PHONY: lint\r\nmake lint:\r\n\tjq --null-input &#39;.content=&quot;$(shell cat &quot;$(GITLAB_CI_FILE_PATH)&quot;)&quot;&#39; | curl --header &quot;Content-Type: application/json&quot; --header &quot;PRIVATE-TOKEN: $(GITLAB_PERSONAL_ACCESS_TOKEN)&quot; --data @- &quot;https://gitlab.com/api/v4/ci/lint&quot;\r\n```\r\n\r\nHere&#39;s the response:\r\n`{&quot;valid&quot;:false,&quot;errors&quot;:[&quot;(\\u003cunknown\\u003e): block sequence entries are not allowed in this context at line 1 column 12&quot;],&quot;warnings&quot;:[],&quot;status&quot;:&quot;invalid&quot;}`\r\n\r\nI know that this is because my makefile version does not contain newline characters.\r\n\r\nHere is the input YAML file:\r\n\r\n```yaml\r\ninclude:\r\n  - project: adamcunnington.info/MLG/common\r\n    file: /cicd/.gitlab-ci-python.yml\r\n```",
        "link": "https://stackoverflow.com/questions/69197789/how-can-i-achieve-some-file-inside-a-makefile-target",
        "title": "How can I achieve $(&lt;some-file) inside a Makefile target?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 4,
                "creation_date": 1631730418,
                "post_id": 69198107,
                "comment_id": 122304066,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1270084,
                    "reputation": 5516,
                    "user_id": 1226605,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/ad052087f658c0667ac37deca1ee61fb?s=256&d=identicon&r=PG",
                    "display_name": "devang",
                    "link": "https://stackoverflow.com/users/1226605/devang"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631730657,
                "post_id": 69198107,
                "comment_id": 122304136,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5301,
                    "reputation": 94077,
                    "user_id": 8454,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/2NlHs.png?s=256",
                    "display_name": "Andy Lester",
                    "link": "https://stackoverflow.com/users/8454/andy-lester"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631732885,
                "post_id": 69198107,
                "comment_id": 122304856,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1631731954,
                "creation_date": 1631731954,
                "answer_id": 69198446,
                "question_id": 69198107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.Accounts | map({ Id, Name })&#39;\r\n```\r\n\r\nWill produce\r\n```json\r\n[\r\n  {\r\n    &quot;Id&quot;: &quot;1&quot;,\r\n    &quot;Name&quot;: &quot;Joe&quot;\r\n  },\r\n  {\r\n    &quot;Id&quot;: &quot;2&quot;,\r\n    &quot;Name&quot;: &quot;Jack&quot;\r\n  }\r\n]\r\n```\r\n\r\nas you can try online using [this demo](https://jqplay.org/s/t6QAdSoS35).\r\n\r\n\r\n----------\r\n* `.Accounts` selects the `Accounts` key\r\n* `map()` will apply the following for each object &lt;sup&gt;[[docs][1]]&lt;/sup&gt;\r\n* Create object with `Id` and `Name` key &lt;sup&gt;[\\[docs\\]][2]&lt;/sup&gt;\r\n\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/#example21\r\n  [2]: https://stedolan.github.io/jq/manual/#example11",
                "title": "extract values from JSON using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1647999859,
                "creation_date": 1647999859,
                "answer_id": 71580899,
                "question_id": 69198107,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Demo https://jqplay.org/s/v01P2gDVc8\r\n\r\nYou can do \r\n\r\n```\r\n[.Accounts[] | {Id, Name}]\r\n```",
                "title": "extract values from JSON using jq"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1647999859,
        "creation_date": 1631730023,
        "last_edit_date": 1631730544,
        "question_id": 69198107,
        "body_markdown": "I have a JSON object that looks like this:\r\n\r\n\t{\r\n\t\t&quot;Accounts&quot;: [\r\n\t\t\t{\r\n\t\t\t\t&quot;Id&quot;: &quot;1&quot;,\r\n\t\t\t\t&quot;Name&quot;: &quot;Joe&quot;,\r\n\t\t\t\t&quot;Zip&quot;: &quot;11111&quot;\r\n\t\t\t},\r\n\t\t\t{\r\n\t\t\t\t&quot;Id&quot;: &quot;2&quot;,\r\n\t\t\t\t&quot;Name&quot;: &quot;Jack&quot;,\r\n\t\t\t\t&quot;Zip&quot;: &quot;22222&quot;\r\n\t\t\t}\r\n\t\t]\t\r\n\t}\r\n\r\nI am trying to write a `jq` query that gives me this:\r\n\r\n\t[\r\n\t\t{\r\n\t\t\t&quot;Id&quot;: &quot;1&quot;,\r\n\t\t\t&quot;Name&quot;: &quot;Joe&quot;\r\n\t\t},\r\n\t\t{\r\n\t\t\t&quot;Id&quot;: &quot;2&quot;,\r\n\t\t\t&quot;Name&quot;: &quot;Jack&quot;\r\n\t\t}\t\r\n\t]\r\n\r\nHow can I do that? Thanks.",
        "link": "https://stackoverflow.com/questions/69198107/extract-values-from-json-using-jq",
        "title": "extract values from JSON using jq"
    },
    {
        "tags": [
            "json",
            "shell",
            "unix",
            "jq",
            "diff"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14709065,
                    "reputation": 9923,
                    "user_id": 10622916,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/0022d8bc5b72b83b2ff1a2a54b571f03?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Bodo",
                    "link": "https://stackoverflow.com/users/10622916/bodo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631795785,
                "post_id": 69208284,
                "comment_id": 122322688,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1631795738,
                "creation_date": 1631795738,
                "answer_id": 69208552,
                "question_id": 69208284,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The jq minus operator does exactly what you need. Just use `--slurpfile` to get both files into variables:\r\n```\r\njq -n --slurpfile file1 file1.json --slurpfile file2 file2.json &#39;$file2[0] - $file1[0]&#39;\r\n```",
                "title": "Compare two JSON file and output unmatched values from a file using Jq in Shell script"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1631795738,
        "creation_date": 1631794656,
        "question_id": 69208284,
        "body_markdown": "How can I output the objects from a JSON file which doesn&#39;t match in another JSON file. For Example,\r\n\r\nfile1: \r\n```\r\n[\r\n{ \r\n  &quot;name&quot;: &quot;ABC&quot;,\r\n  &quot;age&quot;: &quot;23&quot;,\r\n  &quot;address&quot;: &quot;xyz&quot;\r\n},\r\n{\r\n  &quot;name&quot;: &quot;DEF&quot;,\r\n  &quot;age&quot;: &quot;24&quot;,\r\n  &quot;address&quot;: &quot;pqr&quot;\r\n}\r\n]\r\n```\r\n\r\nfile2: \r\n```\r\n[\r\n{ \r\n  &quot;name&quot;: &quot;ABC&quot;,\r\n  &quot;age&quot;: &quot;23&quot;,\r\n  &quot;address&quot;: &quot;xyz&quot;\r\n},\r\n{\r\n  &quot;name&quot;: &quot;GHI&quot;,\r\n  &quot;age&quot;: &quot;24&quot;,\r\n  &quot;address&quot;: &quot;pqr&quot;\r\n}\r\n]\r\n```\r\n\r\nI want the output from file2 which doesn&#39;t match in file1. Example:\r\n\r\noutput file:\r\n```\r\n[\r\n{\r\n  &quot;name&quot;: &quot;GHI&quot;,\r\n  &quot;age&quot;: &quot;24&quot;,\r\n  &quot;address&quot;: &quot;pqr&quot;\r\n}\r\n]\r\n```\r\n\r\nI am looking to do it in shell script using Jq. \r\n",
        "link": "https://stackoverflow.com/questions/69208284/compare-two-json-file-and-output-unmatched-values-from-a-file-using-jq-in-shell",
        "title": "Compare two JSON file and output unmatched values from a file using Jq in Shell script"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631866327,
                "last_edit_date": 1631866327,
                "creation_date": 1631809053,
                "answer_id": 69211895,
                "question_id": 69210892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the array file (inode) as reference and slurp its content ahead of processing the original file.\r\n\r\n```none\r\njq --slurpfile inode b.json &#39;\r\n  reduce range(0, ($inode[0]|length)) as $d (.; .[$d] += {inode: $inode[0][$d]})&#39; a.json\r\n```\r\n\r\nNote that, this works as long as there are equal number of elements in both your JSON arrays.\r\n\r\nAnother attempt without involving any &quot;slurps&quot; of the input file (probably faster than the earlier one)\r\n\r\n```none\r\njq -n &#39;input as $inode | input | \r\n  reduce range(0, length) as $d (.; .[$d] += {inode: $inode[$d]})&#39; b.json a.json\r\n```",
                "title": "Map array to other array values in JQ"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1631812324,
                "creation_date": 1631812324,
                "answer_id": 69212576,
                "question_id": 69210892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t reinvent the `transpose` wheel.\r\n``` shell\r\njq -s &#39;transpose | map(.[0] + {inode: .[1]})&#39; a.json b.json\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/4r3-H98nMf)&lt;/sup&gt;",
                "title": "Map array to other array values in JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1631866327,
        "creation_date": 1631804716,
        "last_edit_date": 1631854358,
        "question_id": 69210892,
        "body_markdown": "How to map array to other array values in jq? \r\n\r\nI have two JSON arrays. \r\n\r\n```\r\n[\r\n  {\r\n    &quot;date&quot;: &quot;2021/9/12&quot;,\r\n    &quot;rate&quot;: 7,\r\n    &quot;path&quot;: &quot;f&quot;\r\n  },\r\n  {\r\n    &quot;date&quot;: &quot;2021/9/13&quot;,\r\n    &quot;rate&quot;: 8,\r\n    &quot;path&quot;: &quot;f&quot;\r\n  },\r\n  {\r\n    &quot;date&quot;: &quot;2021/9/14&quot;,\r\n    &quot;rate&quot;: 8,\r\n    &quot;path&quot;: &quot;f&quot;\r\n  },\r\n]\r\n```\r\n```\r\n[\r\n  &quot;562949953740755&quot;,\r\n  &quot;562949953740743&quot;,\r\n  &quot;562949953740744&quot;\r\n]\r\n```\r\n\r\nI want to have a result like this below.\r\n\r\n```\r\n[\r\n  {\r\n    &quot;date&quot;: &quot;2021/9/12&quot;,\r\n    &quot;rate&quot;: 7,\r\n    &quot;path&quot;: &quot;f&quot;,\r\n    &quot;inode&quot;: &quot;562949953740755&quot;\r\n  },\r\n  {\r\n    &quot;date&quot;: &quot;2021/9/13&quot;,\r\n    &quot;rate&quot;: 8,\r\n    &quot;path&quot;: &quot;f&quot;,\r\n    &quot;inode&quot;: &quot;562949953740743&quot;\r\n  },\r\n  {\r\n    &quot;date&quot;: &quot;2021/9/14&quot;,\r\n    &quot;rate&quot;: 8,\r\n    &quot;path&quot;: &quot;f&quot;,\r\n    &quot;inode&quot;: &quot;562949953740744&quot;\r\n  },\r\n]\r\n```\r\n\r\nI tried: \r\nBut I have no clue how to achieve this. \r\n\r\n```\r\njq -s &#39;.[1] as $file | .[0] | (.[].path) |= (range($file|length) as $i | $file[$i]) &#39; &lt;(cat a.json) &lt;(cat b.json)\r\n```",
        "link": "https://stackoverflow.com/questions/69210892/map-array-to-other-array-values-in-jq",
        "title": "Map array to other array values in JQ"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1631828396,
                "last_edit_date": 1631828396,
                "creation_date": 1631826983,
                "answer_id": 69215276,
                "question_id": 69214919,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should achieve what you expected :\r\n\r\n```\r\njq -n &#39;{a:&quot;string&quot;,b:{k:&quot;k&quot;,v:1},c:12}|.b |= .v&#39;\r\n```\r\n\r\nIf you want to keep the structure of you script, add object test :\r\n\r\n```\r\njq -n &#39;\r\n  {a:&quot;string&quot;,b:{k:&quot;k&quot;,v:1},c:12} |\r\n  with_entries(.value|=(if type == &quot;object&quot; and .v? then .v else . end))\r\n&#39;\r\n```",
                "title": "Why is jq modify and if-then-else not working"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1631830438,
                "last_edit_date": 1631830438,
                "creation_date": 1631829961,
                "answer_id": 69215706,
                "question_id": 69214919,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.v?` only returns `null` if `.` is an object that *could* have a key `v`, but doesn&#39;t; otherwise, it evaluates to no value at all. \r\n\r\n    $ jq -n &#39;{a:1}.v?&#39;\r\n    null\r\n    $ jq -n &#39;&quot;foo&quot;.v?&#39;\r\n    $\r\n    \r\nWith nothing to test, the `if-then-else` expression *also* has no value at all, which results in `.value` being removed from the input to `with_entries`.\r\n\r\nLikewise, `.|strings` filters out non-string values entirely; it doesn&#39;t provide a false or null for each element of `.` that *isn&#39;t* a string. Any array is true, so the `then` value is always returned, but only for string-valued values. Otherwise, *no* value is returned, and `.value` is again removed.\r\n\r\n`objects` can be used, but on the *left* of `|=`, not the right. You want to disregard non-objects from even being updated, rather than trying to replace it with itself if it isn&#39;t an object with `v`.\r\n\r\n    jq -n &#39;\r\n      {a:&quot;string&quot;,b:{k:&quot;k&quot;,v:1},c:12} |\r\n      with_entries((.value|objects) |= if .v then .v else . end)\r\n    &#39;\r\n\r\nThere&#39;s no further need for `.v?`; if you are sure that all objects *will* have a `v` key, you can dispense with the `if-then-else` expression as well.\r\n",
                "title": "Why is jq modify and if-then-else not working"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1631830438,
        "creation_date": 1631824900,
        "question_id": 69214919,
        "body_markdown": "I want to modify values within a hash.  Sometimes the values are simple strings or numbers, and other times they are objects.\r\n\r\nI can start with a simple example:\r\n\r\n```\r\njq -n &#39;{a:&quot;string&quot;,b:{k:&quot;k&quot;,v:1},c:12}&#39;\r\n```\r\n\r\nwhich results in\r\n```\r\n{\r\n  &quot;a&quot;: &quot;string&quot;,\r\n  &quot;b&quot;: {\r\n    &quot;k&quot;: &quot;k&quot;,\r\n    &quot;v&quot;: 1\r\n  },\r\n  &quot;c&quot;: 12\r\n}\r\n```\r\n\r\nI want the value of the `b` key in the hash to get the value of `.v` below it (I actually want to do things more complex but it works for this example).\r\n\r\nMy attempt:\r\n```\r\njq -n &#39;\r\n  {a:&quot;string&quot;,b:{k:&quot;k&quot;,v:1},c:12} |\r\n  with_entries(.value|=if .v? then .v else . end)\r\n&#39;\r\n```\r\noutputs:\r\n```\r\n{\r\n  &quot;a&quot;: null,\r\n  &quot;b&quot;: 1,\r\n  &quot;c&quot;: null\r\n}\r\n```\r\nI see the value of `b` becomes 1 as expected, but when `.v` does not exist, it causes the entire value to become null instead of `.` as I expected.\r\n\r\nThis does not appear to be specific to the `.foo?` operation either.\r\n\r\n```\r\njq -n &#39;\r\n  {a:&quot;string&quot;,b:{k:&quot;k&quot;,v:1},c:12} |\r\n  with_entries(.value|=if (.|strings) then . else . end)\r\n&#39;\r\n```\r\noutputs\r\n```\r\n{\r\n  &quot;a&quot;: &quot;string&quot;,\r\n  &quot;b&quot;: null,\r\n  &quot;c&quot;: null\r\n}\r\n```\r\n\r\nAny idea how I can have complex logic for updating .value ?",
        "link": "https://stackoverflow.com/questions/69214919/why-is-jq-modify-and-if-then-else-not-working",
        "title": "Why is jq modify and if-then-else not working"
    },
    {
        "tags": [
            "python",
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 5868390,
                    "reputation": 23877,
                    "user_id": 4621513,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/uCfJK.png?s=256",
                    "display_name": "mkrieger1",
                    "link": "https://stackoverflow.com/users/4621513/mkrieger1"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631919619,
                "post_id": 69230253,
                "comment_id": 122362358,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631919628,
                "post_id": 69230253,
                "comment_id": 122362363,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5868390,
                    "reputation": 23877,
                    "user_id": 4621513,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/uCfJK.png?s=256",
                    "display_name": "mkrieger1",
                    "link": "https://stackoverflow.com/users/4621513/mkrieger1"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631919660,
                "post_id": 69230253,
                "comment_id": 122362372,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1596663,
                    "reputation": 15,
                    "user_id": 1478613,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/94ce13f11f6d7f3af1262bdc4c31723c?s=256&d=identicon&r=PG",
                    "display_name": "Ben K",
                    "link": "https://stackoverflow.com/users/1478613/ben-k"
                },
                "reply_to_user": {
                    "account_id": 5868390,
                    "reputation": 23877,
                    "user_id": 4621513,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/uCfJK.png?s=256",
                    "display_name": "mkrieger1",
                    "link": "https://stackoverflow.com/users/4621513/mkrieger1"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631919994,
                "post_id": 69230253,
                "comment_id": 122362424,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2671330,
                    "reputation": 192705,
                    "user_id": 2308683,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/fb8f5877d244f223b4b6d29e0afb3a4e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "OneCricketeer",
                    "link": "https://stackoverflow.com/users/2308683/onecricketeer"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631920200,
                "post_id": 69230253,
                "comment_id": 122362456,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1631920052,
                "creation_date": 1631920052,
                "answer_id": 69230319,
                "question_id": 69230253,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Basically, piping and output redirection should not be done with a single `os.system` command... Python has its own piping system with `subprocess` module, however, you dont really need that. \r\n\r\nPython is capable of doing this on its own\r\n\r\nThis assumes your file contains just a JSON array\r\n\r\n    import json\r\n    \r\n    with open(&#39;_metadata.json&#39;) as f:\r\n      data = json.load(f)\r\n      for i, x in enumerate(data):\r\n        with open(str(i) + &#39;.json&#39;, &#39;w&#39;) as f_out:\r\n          json.dump(x, f_out)",
                "title": "Split a JSON file into separate files with jq and Python"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -4,
        "last_activity_date": 1631920052,
        "creation_date": 1631919299,
        "last_edit_date": 1631919871,
        "question_id": 69230253,
        "body_markdown": "I have a JSON file with 100 objects that I would like to convert into separate JSON files, one per each object.\r\n\r\nI have written a script in python to do this, but it runs endlessly in my terminal if I try and increment the values in a while loop.\r\n\r\nIt doesn&#39;t crash, it just never finishes.\r\n\r\n```\r\nimport os\r\n\r\ni = 0\r\nwhile i &lt;= 100:\r\n    os.system(f&quot;cat _metadata.json | jq &#39;.[{i}]&#39; &gt; {i}.json&quot;)\r\n    ++i\r\n```",
        "link": "https://stackoverflow.com/questions/69230253/split-a-json-file-into-separate-files-with-jq-and-python",
        "title": "Split a JSON file into separate files with jq and Python"
    },
    {
        "tags": [
            "json",
            "mongodb",
            "csv",
            "google-sheets",
            "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": 1631941486,
                "post_id": 69230818,
                "comment_id": 122364748,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 164754,
                    "reputation": 1544,
                    "user_id": 387719,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a4e134d8db4dcb849b2fad7b63ad1363?s=256&d=identicon&r=PG",
                    "display_name": "opyh",
                    "link": "https://stackoverflow.com/users/387719/opyh"
                },
                "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": 1631950806,
                "post_id": 69230818,
                "comment_id": 122366099,
                "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": 1631956965,
                "post_id": 69230818,
                "comment_id": 122367315,
                "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": 1631997383,
                "post_id": 69230818,
                "comment_id": 122376188,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 164754,
                    "reputation": 1544,
                    "user_id": 387719,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/a4e134d8db4dcb849b2fad7b63ad1363?s=256&d=identicon&r=PG",
                    "display_name": "opyh",
                    "link": "https://stackoverflow.com/users/387719/opyh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632143151,
                "post_id": 69230818,
                "comment_id": 122406201,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 7,
                "is_accepted": false,
                "score": 7,
                "last_activity_date": 1632152175,
                "last_edit_date": 1632152175,
                "creation_date": 1631927481,
                "answer_id": 69230819,
                "question_id": 69230818,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "# Solution 1, using dot notation\r\n\r\nHere is the `jq` call to convert your array of nested JSON objects to CSV:\r\n\r\n```bash\r\njq -r &#39;(. | map(leaf_paths) | unique) as $cols | map (. as $row | ($cols | map(. as $col | $row | getpath($col)))) as $rows | ([($cols | map(. | map(tostring) | join(&quot;.&quot;)))] + $rows) | map(@csv) | .[]\r\n```\r\n\r\nThe fastest way to try this solution out is to [use JQPlay](https://jqplay.org/s/48PS6AIJB1).\r\n\r\nThe CSV output will have a header row. It will contain all properties that exist anywhere in the input objects, including nested ones, in dot notation. Each input array element will be represented as a single row, properties that are missing will be represented as empty CSV fields.\r\n\r\n## Using solution 1 in `bash` or a similar shell\r\n\r\n- Create the JSON input file…\r\n\r\n  ```bash\r\n  echo &#39;[{&quot;a&quot;: {&quot;b&quot;: [{&quot;c&quot;: 123}]}},{&quot;a&quot;: {&quot;b&quot;: [{&quot;c&quot;: &quot;foo \\&quot; bar&quot;,&quot;d&quot;: &quot;qux&quot;}]}},{&quot;a&quot;: {&quot;b&quot;: [{&quot;d&quot;: 456}]}}]&#39; &gt; example.json\r\n  ```\r\n- Then use this jq command to output the CSV on the standard output:\r\n  ```bash\r\n  cat example.json | jq -r &#39;(. | map(leaf_paths) | unique) as $cols | map (. as $row | ($cols | map(. as $col | $row | getpath($col)))) as $rows | ([($cols | map(. | map(tostring) | join(&quot;.&quot;)))] + $rows) | map(@csv) | .[]&#39;\r\n  ```\r\n- …or write the output to `example.csv`:\r\n\r\n  ```bash\r\n  cat example.json | jq -r &#39;(. | map(leaf_paths) | unique) as $cols | map (. as $row | ($cols | map(. as $col | $row | getpath($col)))) as $rows | ([($cols | map(. | map(tostring) | join(&quot;.&quot;)))] + $rows) | map(@csv) | .[]&#39; &gt; example.csv\r\n  ```\r\n\r\n## Converting the data from solution 1 back to JSON\r\n\r\nHere is a [Node.js example that you can try on RunKit](https://runkit.com/opyh/load-a-nested-json-from-a-csv-with-dot-notation-headers). It converts a CSV generated with the method in solution 1 back to an array of nested JSON objects.\r\n\r\n## Explanation for solution 1\r\n\r\nHere is a longer, commented version of the `jq` filter.\r\n\r\n```bash\r\n# 1) Find all unique leaf property names of all objects in the input array. Each nested property name is an array with the components of its key path, for example [&quot;a&quot;, 0, &quot;b&quot;].\r\n(. | map(leaf_paths) | unique) as $cols |\r\n\r\n# 2) Use the found key paths to determine all (nested) property values in the given input records.\r\nmap (. as $row | ($cols | map(. as $col | $row | getpath($col)))) as $rows |\r\n\r\n  # 3) Create the raw output array of rows. Each row is represented as an array of values, one element per existing column.\r\n  (\r\n\r\n    # 3.1) This represents the header row. Key paths are generated here.\r\n    [($cols | map(. | map(tostring) | join(&quot;.&quot;)))]\r\n\r\n    + # 3.2) concatenate the header row with all other rows\r\n    $rows\r\n\r\n  )\r\n\r\n  # 4) Convert each row to a escaped CSV string.\r\n  | map(@csv)\r\n\r\n  # 5) output each array element directly. Without this, the result would be a JSON array of CSV strings.\r\n  | .[]\r\n```\r\n\r\n# Solution 2: for input that *does* have dots in property names\r\n\r\nIf you do need to support dot characters in property names, you can either use a different separator string for the key path syntax (replace the dot in `&quot;.&quot;` with something else), or replace the `map(tostring) | join(&quot;.&quot;)` part with `tostring` - this yields a JSON array of strings that you can use as key paths - no dot notation needed. Here is a [JQPlay](https://jqplay.org/s/L4WAbzED-k) with this solution variant.\r\n\r\nFull `jq` command:\r\n\r\n```bash\r\njq -r (. | map(leaf_paths) | unique) as $cols | map (. as $row | ($cols | map(. as $col | $row | getpath($col)))) as $rows | ([($cols | map(. | tostring))] + $rows) | map(@csv) | .[]\r\n```\r\n\r\nThe output CSV for the variant would look like this then – it’s less readable and not useful for cases where you want humans to intuitively understand the CSV’s header:\r\n\r\n```csv\r\n&quot;[&quot;&quot;a&quot;&quot;,&quot;&quot;b&quot;&quot;,0,&quot;&quot;c&quot;&quot;]&quot;,&quot;[&quot;&quot;a&quot;&quot;,&quot;&quot;b&quot;&quot;,0,&quot;&quot;d&quot;&quot;]&quot;\r\n123,\r\n&quot;foo &quot;&quot; bar&quot;,&quot;qux&quot;\r\n,456\r\n```\r\n\r\nSee below for an idea how to convert this format back to a representation in your programming language.\r\n\r\n## Bonus: Converting the generated CSV back to JSON\r\n\r\nIf the input&#39;s nested properties contain no `&quot;.&quot;`, it’s simple to convert the CSV back to JSON, for example with a library that supports dot notation, or with [JSONPath](https://ietf-wg-jsonpath.github.io/draft-ietf-jsonpath-base/draft-ietf-jsonpath-base.html).\r\n\r\n- JavaScript: Use [Lodash&#39;s _.set()](https://lodash.com/docs#set)\r\n- Other languages: Find a package/library that implements [JSONPath](https://ietf-wg-jsonpath.github.io/draft-ietf-jsonpath-base/draft-ietf-jsonpath-base.html) and use selectors like `$.a.b.0.c` or `$[&#39;a&#39;][&#39;b&#39;][0][&#39;c&#39;]` to set each nested property of each record.\r\n\r\nSolution 2 (with JSON arrays as headers) allows you to interpret the headers as JSON array strings. Then you can generate a JSON Path from each header, and re-create all records/objects:\r\n\r\n`&quot;[&quot;&quot;a&quot;&quot;,&quot;&quot;b&quot;&quot;,0,&quot;&quot;c&quot;&quot;]&quot;` (CSV)\r\n\r\n→ `[&quot;a&quot;,&quot;b&quot;,0,&quot;c&quot;]` (array of key-path components after unescaping and parsing as JSON)\r\n\r\n→ `$.[&quot;a&quot;][&quot;b&quot;][0][&quot;c&quot;]` (JSONPath)\r\n\r\n→ `{ a: { b: [{c: … }] } }` (Nested regenerated object)\r\n\r\nI&#39;ve written an example Node.js script to convert a CSV like this back to JSON. You can [try solution 2 in RunKit](https://runkit.com/opyh/614899a33b003f00084c670b).",
                "title": "How to convert arbitrary nested JSON to CSV with jq – so you can convert it back?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632149770,
                "last_edit_date": 1632149770,
                "creation_date": 1631958025,
                "answer_id": 69233436,
                "question_id": 69230818,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The following `tocsv` and `fromcsv` functions provide a solution to the stated problem except for one complication regarding requirement (6) concerning the headers.  Essentially, this requirement can be met using the functions given here by adding a matrix transposition step.\r\n\r\nWhether or not a transposition step is added, the advantage of the approach taken here is that there are no restrictions on the JSON keys or values. In particular, they may\r\ncontain periods (dots), newlines and/or NUL characters.\r\n\r\nIn the example, an array of objects is given, but in fact any stream of valid JSON documents could be used as input to `tocsv`; thanks to the magic of jq, the original stream will be recreated by `fromcsv` (in the sense of entity-by-entity equality).\r\n\r\nOf course, since there is no CSV standard, the CSV produced by the\r\n`tocsv` function might not be understood by all CSV processors.  In\r\nparticular, please note that the `tocsv` function defined here maps\r\nembedded newlines in JSON strings or key names to the two-character\r\nstring &quot;\\n&quot; (i.e., a literal backslash followed by the letter &quot;n&quot;);\r\nthe inverse operation performs the inverse translation to meet the\r\n&quot;round-trip&quot; requirement.\r\n\r\n(The use of `tail` is just to simplify the presentation; it would be\r\ntrivial to modify the solution to make it an only-jq one.)\r\n\r\nThe CSV is generated on the assumption that any value can be\r\nincluded in a field so long as (a) the field is quoted, and (b)\r\ndouble-quotes within the field are doubled.\r\n\r\nAny generic solution that supports &quot;round-trips&quot; is bound to be\r\nsomewhat complicated.  The main reason why the solution presented here is\r\nmore complex than one might expect is because a third column is\r\nadded, partly to make it easy to distinguish between integers and\r\ninteger-valued strings, but mainly because it makes it easy to\r\ndistinguish between the size-1 and size-2 arrays produced by jq&#39;s\r\n`--stream` option.  Needless to say, there are other ways\r\nthese issues could be addressed; the number of calls to jq could\r\nalso be reduced.\r\n\r\nThe solution is presented as a test script that checks the round-trip requirement on a telling test case:\r\n```\r\n#!/bin/bash\r\n\r\nfunction json {\r\n    cat&lt;&lt;EOF\r\n[\r\n  {\r\n    &quot;a&quot;: 1,\r\n    &quot;b&quot;: [\r\n      1,\r\n      2,\r\n      &quot;1&quot;\r\n    ],\r\n    &quot;c&quot;: &quot;d\\&quot;,ef&quot;,\r\n    &quot;embed\\&quot;ed&quot;: &quot;quote&quot;,\r\n    &quot;null&quot;: null,\r\n    &quot;string&quot;: &quot;null&quot;,\r\n    &quot;control characters&quot;: &quot;a\\u0000c&quot;,\r\n    &quot;newline&quot;: &quot;a\\nb&quot;\r\n  },\r\n  {\r\n    &quot;x&quot;: 1\r\n  }\r\n]\r\nEOF\r\n}\r\n\r\nfunction tocsv {\r\n jq -ncr --stream &#39;\r\n   ([&quot;path&quot;, &quot;value&quot;, &quot;stringp&quot;],\r\n    (inputs | . + [.[1]|type==&quot;string&quot;]))\r\n   | map( tostring|gsub(&quot;\\&quot;&quot;;&quot;\\&quot;\\&quot;&quot;) | gsub(&quot;\\n&quot;; &quot;\\\\n&quot;))\r\n   | &quot;\\&quot;\\(.[0])\\&quot;,\\&quot;\\(.[1])\\&quot;,\\(.[2])&quot; \r\n&#39;\r\n}\r\n\r\nfunction fromcsv { \r\n    tail -n +2 | # first duplicate backslashes and deduplicate double-quotes\r\n    jq -rR &#39;&quot;[\\(gsub(&quot;\\\\\\\\&quot;;&quot;\\\\\\\\&quot;) | gsub(&quot;\\&quot;\\&quot;&quot;;&quot;\\\\\\&quot;&quot;) ) ]&quot;&#39; |\r\n    jq -c &#39;.[2] as $s \r\n           | .[0] |= fromjson \r\n           | .[1] |= if $s then . else fromjson end \r\n           | if $s == null then [.[0]] else .[:-1] end\r\n             # handle newlines\r\n           | map(if type == &quot;string&quot; then gsub(&quot;\\\\\\\\n&quot;;&quot;\\n&quot;) else . end)&#39; |\r\n    jq -n &#39;fromstream(inputs)&#39;\r\n}    \r\n\r\n# Check the roundtrip:\r\njson | tocsv | fromcsv | jq -s &#39;.[0] == .[1]&#39; - &lt;(json)\r\n```\r\n\r\nHere is the CSV that would be produced by `json | tocsv`, except that SO seems to disallow literal NULs, so I have replaced that by `\\0`:\r\n```\r\n&quot;path&quot;,&quot;value&quot;,stringp\r\n&quot;[0,&quot;&quot;a&quot;&quot;]&quot;,&quot;1&quot;,false\r\n&quot;[0,&quot;&quot;b&quot;&quot;,0]&quot;,&quot;1&quot;,false\r\n&quot;[0,&quot;&quot;b&quot;&quot;,1]&quot;,&quot;2&quot;,false\r\n&quot;[0,&quot;&quot;b&quot;&quot;,2]&quot;,&quot;1&quot;,true\r\n&quot;[0,&quot;&quot;b&quot;&quot;,2]&quot;,&quot;false&quot;,null\r\n&quot;[0,&quot;&quot;c&quot;&quot;]&quot;,&quot;d&quot;&quot;,ef&quot;,true\r\n&quot;[0,&quot;&quot;embed\\&quot;&quot;ed&quot;&quot;]&quot;,&quot;quote&quot;,true\r\n&quot;[0,&quot;&quot;null&quot;&quot;]&quot;,&quot;null&quot;,false\r\n&quot;[0,&quot;&quot;string&quot;&quot;]&quot;,&quot;null&quot;,true\r\n&quot;[0,&quot;&quot;control characters&quot;&quot;]&quot;,&quot;a\\0c&quot;,true\r\n&quot;[0,&quot;&quot;newline&quot;&quot;]&quot;,&quot;a\\nb&quot;,true\r\n&quot;[0,&quot;&quot;newline&quot;&quot;]&quot;,&quot;false&quot;,null\r\n&quot;[1,&quot;&quot;x&quot;&quot;]&quot;,&quot;1&quot;,false\r\n&quot;[1,&quot;&quot;x&quot;&quot;]&quot;,&quot;false&quot;,null\r\n&quot;[1]&quot;,&quot;false&quot;,null\r\n```\r\n",
                "title": "How to convert arbitrary nested JSON to CSV with jq – so you can convert it back?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 7,
        "last_activity_date": 1632152175,
        "creation_date": 1631927481,
        "last_edit_date": 1632143749,
        "question_id": 69230818,
        "body_markdown": "How do I use [jq](https://stedolan.github.io/jq/) to convert an **arbitrary** JSON array of objects to CSV, while objects in this array are **nested**?\r\n\r\nStackOverflow has a sea of questions/answers where *specific* input or output fields are referenced, but I&#39;d like to have a generic solution that\r\n\r\n1) includes a header row,\r\n2) works for any JSON input including nested arrays + objects,\r\n3) allows records that have missing values for keys that are present in other records\r\n4) does not hard-code any field names,\r\n5) allows converting the CSV back into the nested JSON structure if needed, and\r\n6) uses key paths as header names (see the following description).\r\n\r\n## Dot notation\r\n\r\nMany JSON-using products (like [CouchDB](https://docs.couchdb.org/en/stable/api/database/find.html#subfields), [MongoDB](https://docs.mongodb.com/manual/core/document/#dot-notation), …) and libraries (like [Lodash](https://docs-lodash.com/v4/get/), …) use variations of syntax that allows access to nested property values / subfields by joining key fragments with a character, often a dot (‘dot notation’).\r\n\r\nAn example of a key path like this would be `&quot;a.b.0.c&quot;` to refer to the deeply nested property in this JSON snippet:\r\n\r\n```json\r\n{\r\n  &quot;a&quot;: {\r\n    &quot;b&quot;: [\r\n      {\r\n        &quot;c&quot;: 123,\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\n**Caveat**: Using this method is a pragmatic solution for most cases, but means that either dot characters have to be banned in property names, or a more complex (and definitely never used property name) has to be invented for escaping dots in property names / accessing nested fields. MongoDB simply [banned usage of `&quot;.&quot;` in documents until v5.0](https://docs.mongodb.com/manual/core/dot-dollar-considerations/#std-label-crud-concepts-dot-dollar-considerations), some libraries have workarounds for field access ([Lodash example](https://github.com/lodash/lodash/issues/1637)).\r\n\r\n**Despite this**, for simplicity, a solution should use the described dot syntax in the CSV output’s header for nested properties. Bonus if there is a solution variant that solves this problem, e.g. with [JSONPath](https://ietf-wg-jsonpath.github.io/draft-ietf-jsonpath-base/draft-ietf-jsonpath-base.html).\r\n\r\n## Example JSON array as input\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;a&quot;: {\r\n            &quot;b&quot;: [\r\n                {\r\n                    &quot;c&quot;: 123\r\n                }\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;a&quot;: {\r\n            &quot;b&quot;: [\r\n                {\r\n                    &quot;c&quot;: &quot;foo \\&quot; bar&quot;,\r\n                    &quot;d&quot;: &quot;qux&quot;\r\n                }\r\n            ]\r\n        }\r\n    },\r\n    {\r\n        &quot;a&quot;: {\r\n            &quot;b&quot;: [\r\n                {\r\n                    &quot;d&quot;: 456\r\n                }\r\n            ]\r\n        }\r\n    }\r\n]\r\n```\r\n\r\n## Example CSV output\r\n\r\nThe output should have a header that includes all fields (even if the object at the first array does not have defined values for all existing key paths).\r\n\r\nTo make the output intuitively editable by humans, each row should represent one object in the input array.\r\n\r\nThe expected output should look like this:\r\n\r\n```csv\r\n&quot;a.b.0.c&quot;,&quot;a.b.0.d&quot;\r\n123,\r\n&quot;foo &quot;&quot; bar&quot;,&quot;qux&quot;\r\n,456\r\n```\r\n\r\n## Command line\r\n\r\nThis is what I need:\r\n\r\n```\r\ncat example.json | jq &lt;MISSING CODE HERE&gt;\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69230818/how-to-convert-arbitrary-nested-json-to-csv-with-jq-so-you-can-convert-it-back",
        "title": "How to convert arbitrary nested JSON to CSV with jq – so you can convert it back?"
    },
    {
        "tags": [
            "c",
            "jq",
            "stdout",
            "ansi-escape"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 205058,
                    "reputation": 11220,
                    "user_id": 453616,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://www.gravatar.com/avatar/f5c35ad8a6275273c50d1274fd549d84?s=256&d=identicon&r=PG",
                    "display_name": "gspr",
                    "link": "https://stackoverflow.com/users/453616/gspr"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1631969873,
                "post_id": 69234860,
                "comment_id": 122370056,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4865492,
                    "reputation": 48757,
                    "user_id": 3923896,
                    "user_type": "registered",
                    "accept_rate": 69,
                    "profile_image": "https://i.sstatic.net/AcZuX.png?s=256",
                    "display_name": "Steve Summit",
                    "link": "https://stackoverflow.com/users/3923896/steve-summit"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1631970162,
                "post_id": 69234860,
                "comment_id": 122370106,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21239904,
                    "reputation": 669,
                    "user_id": 15623558,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e54c61bd96daf336fdeb91edd1a39db9?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "aszswaz",
                    "link": "https://stackoverflow.com/users/15623558/aszswaz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631971529,
                "post_id": 69234860,
                "comment_id": 122370389,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 6,
                "is_accepted": true,
                "score": 6,
                "last_activity_date": 1631972151,
                "last_edit_date": 1631972151,
                "creation_date": 1631971770,
                "answer_id": 69235116,
                "question_id": 69234860,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "On Linux and probably [POSIX][1] systems, you might use [isatty(3)][2] with `STDOUT_FILENO`. See also [stdio(3)][3] and [fileno(3)][4].\r\n\r\nSo your code would be\r\n\r\n    if (isatty(STDOUT_FILENO)) {\r\n       // standard output is a tty\r\n       ...\r\n    }\r\n\r\nand you have to bet that in 2021 most terminal emulators support [ANSI TTY escapes][5].\r\n\r\nBy the way, [jq][6] is an [open source][7] software tool. You are allowed to download then study its source code.\r\n\r\n\r\nNotice that the C programming language standard (read [n1570][8] or better) does not know about ttys. Read the [TTY demystified][9] web page.\r\n\r\n\r\n  [1]: https://en.wikipedia.org/wiki/POSIX\r\n  [2]: https://man7.org/linux/man-pages/man3/isatty.3.html\r\n  [3]: https://man7.org/linux/man-pages/man3/stdio.3.html\r\n  [4]: https://man7.org/linux/man-pages/man3/fileno.3.html\r\n  [5]: https://en.wikipedia.org/wiki/ANSI_escape_code\r\n  [6]: https://stedolan.github.io/jq/\r\n  [7]: https://en.wikipedia.org/wiki/Open_source\r\n  [8]: http://www.open-std.org/jtc1/sc22/wg14/www/docs/n1570.pdf\r\n  [9]: https://www.linusakesson.net/programming/tty/",
                "title": "How to judge whether stdout supports ANSI escape code"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1679039980,
        "creation_date": 1631969811,
        "last_edit_date": 1679039980,
        "question_id": 69234860,
        "body_markdown": "In a terminal that does not support ANSI escape code, outputting a color control code like \\033[0m will not only have no effect, but will also disturb the terminal.\r\n\r\nI know a json formatting tool called jq, which judges whether the terminal can use ANSI escape code.\r\n\r\nI want to know, how to realize this function through C programming language?",
        "link": "https://stackoverflow.com/questions/69234860/how-to-judge-whether-stdout-supports-ansi-escape-code",
        "title": "How to judge whether stdout supports ANSI escape code"
    },
    {
        "tags": [
            "json",
            "group-by",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 21188657,
                    "reputation": 15,
                    "user_id": 15581529,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f57b0c83ba1f13d31c1bbbd9c438dcf7?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Pranali",
                    "link": "https://stackoverflow.com/users/15581529/pranali"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631993974,
                "post_id": 69237892,
                "comment_id": 122375509,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1631998683,
                "post_id": 69237892,
                "comment_id": 122376429,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1632016149,
                "creation_date": 1632016149,
                "answer_id": 69239724,
                "question_id": 69237892,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming the sample JSON shown has been corrected, and that you use the -r command-line option:\r\n\r\n* Without numbering\r\n```\r\n    .[] | (.[0]|.stickyType), (.[] | .content)\r\n```\r\n* With numbering:\r\n```\r\n    .[] | (.[0]|.stickyType), (range(0;length) as $i | &quot;\\($i). \\(.[$i].content)&quot;)\r\n```\r\n\r\nYou could, for example, add either of these to your jq pipeline.",
                "title": "print group type once and all values in shell"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632104007,
        "creation_date": 1631993922,
        "last_edit_date": 1632104007,
        "question_id": 69237892,
        "body_markdown": "I grouped a curl response by `stickyType` using following command :\r\n\r\n`curl &lt;url&gt; | jq &#39;group_by(.stickyType)&#39; `\r\n which gave following output:\r\n```\r\n[\r\n  [\r\n    {\r\n      &quot;stickyType&quot;: &quot;TypeA&quot;,\r\n      &quot;content&quot;: &quot;X&quot;,\r\n    },\r\n    {\r\n      &quot;stickyType&quot;: &quot;TypeA&quot;,\r\n      &quot;content&quot;: &quot;Y&quot;,\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;stickyType&quot;: &quot;TypeB&quot;,\r\n      &quot;content&quot;: &quot;Z&quot;,\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\nNow I want to print it as:\r\n```\r\nTypeA\r\n1. X\r\n2. Y\r\n\r\nTypeB\r\n1. Z\r\n```\r\n\r\nHow can I do that ?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69237892/print-group-type-once-and-all-values-in-shell",
        "title": "print group type once and all values in shell"
    },
    {
        "tags": [
            "arrays",
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1632132473,
                "last_edit_date": 1632132473,
                "creation_date": 1632131889,
                "answer_id": 69252469,
                "question_id": 69252176,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "\r\nSince your expected output is neither valid JSON (which would be your first suggestion `jq -r &#39;.item&#39; collection.json` that includes commas AND the array brackets) nor the plain raw content of the elements (which would be your second suggestion `jq -r &#39;.item[]&#39; collection.json` that removes all the surrounding JSON syntax), you will have to build the desired syntax yourself which may depend on what the `.item` array elements actually are.\r\n\r\nFor instance, convert them into strings using `tostring` and glue them together with the `join` builtin:\r\n\r\n    jq -r &#39;.item | map(tostring) | join(&quot;,\\n&quot;)&#39; collection.json\r\n",
                "title": "Extract all fields from array with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632134118,
        "creation_date": 1632130586,
        "last_edit_date": 1632134118,
        "question_id": 69252176,
        "body_markdown": "I have a json file named `collection.json`such as :\r\n\r\n```\r\n{\r\n    &quot;info&quot; : {\r\n        ...\r\n    },\r\n    &quot;item&quot; : [\r\n        {...}, # A\r\n        {...}, # B\r\n        {...}  # C\r\n    ]\r\n\r\n}\r\n```\r\n\r\nI want all the fields from the array `item`, like below:\r\n\r\n```\r\n{...}, # A\r\n{...}, # B\r\n{...}  # C\r\n```\r\n\r\n______ \r\n### What I have tried:\r\n\r\n&gt; jq -r &#39;.item&#39; collection.json \r\n\r\nWith this, I still avec the squares brackets, at the beginning and the end.\r\n\r\n&gt; jq -r &#39;.item[]&#39; collection.json\r\n\r\nWith this, the comma between the fields is removed.\r\n",
        "link": "https://stackoverflow.com/questions/69252176/extract-all-fields-from-array-with-jq",
        "title": "Extract all fields from array with jq"
    },
    {
        "tags": [
            "json",
            "kubernetes",
            "select",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1632171079,
                "creation_date": 1632171079,
                "answer_id": 69260669,
                "question_id": 69260360,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For this approch, we introduce a variable `$pattern`. You may set it with `--arg pattern` to your regex, e.g. `&quot;Jeff&quot;` or `&quot;^Al&quot;` or `&quot;e$&quot;` to have the student list filtered by `test`, or leave it empty to see all students.\r\n\r\nNow, we iterate over all `.item[]` elements (i.e. over &quot;all deployments&quot;). For each found, we output the content of `.metadata.name` followed by a literal colon and a space. Then we iterate again over all `.spec.template.spec.containers[].students[]`, perform the pattern `test` and concatenate the outcome.\r\n\r\nTo print out raw strings instead of JSON, we use the `-r` option when calling `jq`.\r\n\r\n    kubectl get deployments -o json \\\r\n    | jq --arg pattern &quot;Jeff&quot; -r &#39;\r\n        .items[]\r\n        | .metadata.name + &quot;: &quot; + (\r\n            .spec.template.spec.containers[].students[]\r\n            | select(test($pattern))\r\n          )\r\n      &#39;\r\n",
                "title": "How do I print a specific value of an array given a condition in jq if there is no key specified"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632174390,
                "last_edit_date": 1632174390,
                "creation_date": 1632174075,
                "answer_id": 69261154,
                "question_id": 69260360,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To retrieve the &quot;students&quot; array(s) in the input, you could use this filter:\r\n```\r\n.items[]\r\n| paths(objects) as $p\r\n| getpath($p)\r\n| select( objects | has(&quot;students&quot;) )\r\n| .students\r\n```\r\n\r\nYou can then add additional filters to select the particular student(s) of interest, e.g.\r\n```\r\n| .[]\r\n| select(test(&quot;Jeff&quot;))\r\n```\r\n\r\nAnd then add any postprocessing filters, e.g.\r\n```\r\n| &quot;student-deployment: \\(.)&quot;\r\n```\r\n\r\nOf course you can obtain the `students` array in numerous other ways.",
                "title": "How do I print a specific value of an array given a condition in jq if there is no key specified"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1632205946,
        "creation_date": 1632169257,
        "last_edit_date": 1632205946,
        "question_id": 69260360,
        "body_markdown": "I am trying to output the value for .metadata.name followed by the student&#39;s name in .spec.template.spec.containers[].students[] array using the regex test() function in jq.\r\n\r\nI am having trouble to retrieve the individual array value since there is no key specified for the students[] array. \r\n\r\nFor example, if I check the students[] array if it contains the word &quot;Jeff&quot;, I would like the output to display as below:\r\n\r\n    student-deployment:    Jefferson\r\n\r\n**What i have tried:**\r\n\r\nI&#39;ve tried the command below which somewhat works but I am not sure how to get only the &quot;Jefferson&quot; value. The command below would print out all of the students[] array values which is not what I want. I am using Powershell to run the command below.\r\n\r\n    kubectl get deployments -o json | jq -r &#39;.items[] | select(.spec.template.spec.containers[].students[]?|test(&quot;\\&quot;^Jeff.\\&quot;&quot;)) | .metadata.name, &quot;\\&quot;:\\t\\&quot;&quot;, .spec.template.spec.containers[].students&#39;\r\n\r\nIs there a way to print a specific value of an array given a condition in jq if there is no key specified? Also, would the solution work if there are multiple deployments?\r\n\r\nThe deployment template below is in json and I shortened it to only the relevant parts.\r\n\r\n    {\r\n        &quot;apiVersion&quot;: &quot;v1&quot;,\r\n        &quot;items&quot;: [\r\n            {\r\n                &quot;apiVersion&quot;: &quot;apps/v1&quot;,\r\n                &quot;kind&quot;: &quot;Deployment&quot;,\r\n                &quot;metadata&quot;: {\r\n                    &quot;name&quot;: &quot;student-deployment&quot;,\r\n                    &quot;namespace&quot;: &quot;default&quot;\r\n                },\r\n                &quot;spec&quot;: {\r\n                    &quot;template&quot;: {\r\n                        &quot;spec&quot;: {\r\n                            &quot;containers&quot;: [\r\n                                {\r\n                                    &quot;students&quot;: [\r\n                                            &quot;Alice&quot;,\r\n                                            &quot;Bob&quot;,\r\n                                            &quot;Peter&quot;,\r\n                                            &quot;Sally&quot;,\r\n                                            &quot;Jefferson&quot;\r\n                                    ]\r\n                                }\r\n                            ]\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        ]\r\n    }",
        "link": "https://stackoverflow.com/questions/69260360/how-do-i-print-a-specific-value-of-an-array-given-a-condition-in-jq-if-there-is",
        "title": "How do I print a specific value of an array given a condition in jq if there is no key specified"
    },
    {
        "tags": [
            "json",
            "bash",
            "shell",
            "scripting",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 173557,
                    "reputation": 24077,
                    "user_id": 402322,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/GWEWt.gif?s=256",
                    "display_name": "ceving",
                    "link": "https://stackoverflow.com/users/402322/ceving"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1632224803,
                "post_id": 69268321,
                "comment_id": 122429703,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632225077,
                "post_id": 69268321,
                "comment_id": 122429799,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11728572,
                    "reputation": 2848,
                    "user_id": 8584929,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c8e5fc4edbdeb17c6898c33b742e5878?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Andrej Podzimek",
                    "link": "https://stackoverflow.com/users/8584929/andrej-podzimek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632229049,
                "post_id": 69268321,
                "comment_id": 122431587,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 11728572,
                    "reputation": 2848,
                    "user_id": 8584929,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c8e5fc4edbdeb17c6898c33b742e5878?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Andrej Podzimek",
                    "link": "https://stackoverflow.com/users/8584929/andrej-podzimek"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632229085,
                "post_id": 69268321,
                "comment_id": 122431603,
                "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"
                },
                "reply_to_user": {
                    "account_id": 173557,
                    "reputation": 24077,
                    "user_id": 402322,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://i.sstatic.net/GWEWt.gif?s=256",
                    "display_name": "ceving",
                    "link": "https://stackoverflow.com/users/402322/ceving"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632234040,
                "post_id": 69268321,
                "comment_id": 122433859,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5203734,
                    "reputation": 37594,
                    "user_id": 4162356,
                    "user_type": "registered",
                    "accept_rate": 92,
                    "profile_image": "https://i.sstatic.net/dGhuV.png?s=256",
                    "display_name": "James Brown",
                    "link": "https://stackoverflow.com/users/4162356/james-brown"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632238846,
                "post_id": 69268321,
                "comment_id": 122436078,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1632272760,
                "creation_date": 1632272760,
                "answer_id": 69277057,
                "question_id": 69268321,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I am still missing certain constraints, such as\r\n* Are there always exactly two Products or could there be also, say, three or even zero?\r\n* Does a Product always have ADD, REMOVE and RETURN or could any of them be there twice or even missing?\r\n* Are ADD, REMOVE and RETURN always in the same order? If not, how to distinguish between Products?\r\n\r\nHowever, if all of them were static as provided in your example, I&#39;d simply go with reading the raw input into an array of lines, split them further into arrays of values, then align them with a static ordered set of paths pointing into the output object, and build them setting the paths to those values accordingly.\r\n\r\n    jq -Rn &#39;[inputs / &quot;|&quot; | [[\r\n      \r\n      [&quot;ProductId&quot;],[&quot;PIDT&quot;],[&quot;RPID&quot;],[&quot;OfferId&quot;],\r\n      ((&quot;Product1&quot;, &quot;Product2&quot;) as $p |\r\n        [$p, 0] + ([&quot;Action&quot;], [&quot;ProductOfferId&quot;]),\r\n        [$p, 1] + ([&quot;Action&quot;], [&quot;ProductOfferId&quot;], [&quot;RemoveProduct1Instance&quot;]),\r\n        [$p, 2] + ([&quot;Action&quot;], [&quot;RemoveProduct1Instance&quot;], [&quot;ProductOfferId&quot;])\r\n      )\r\n    \r\n    ],.] | transpose | reduce .[] as $k ({}; setpath($k[0];$k[1]))]&#39; data.txt\r\n",
                "title": "Convert .txt file to json using shell script or jq command"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -2,
        "last_activity_date": 1632272760,
        "creation_date": 1632224642,
        "last_edit_date": 1632224727,
        "question_id": 69268321,
        "body_markdown": "I have the **data.txt** file containing below information:\r\n\r\n~~~\r\n611111|22|53|200003|ADD|234566|REMOVE|546768|647|Return|5647|746927|ADD|345677858|REMOVE|546768|64774|Return|5647|2134\r\n611112|24|53|200043|ADD|234576|REMOVE|5467658|647|Return|5687|746927|ADD|445677858|REMOVE|546768|64774|Return|5647|2334\r\n~~~\r\n\r\nHow can I convert into **.json** file like below :\r\n\r\n**Output required :**\r\n~~~\r\n[\r\n  {\r\n    &quot;ProductId&quot;: &quot;611111&quot;,\r\n    &quot;PIDT&quot;: &quot;22&quot;,\r\n    &quot;RPID&quot;: &quot;53&quot;,\r\n    &quot;OfferId&quot;: &quot;20003&quot;,\r\n    &quot;Product1&quot;: \r\n\t[\r\n      {\r\n        &quot;Action&quot;: &quot;ADD&quot;,\r\n        &quot;ProductOfferId&quot;: &quot;234566&quot;,\r\n      },\r\n\t  {\r\n        &quot;Action&quot;: &quot;REMOVE&quot;,\r\n\t   &quot;ProductOfferId&quot;: &quot;546768&quot;,\r\n        &quot;RemoveProduct1Instance&quot;: &quot;647&quot;,\r\n      },\r\n\t  {\r\n        &quot;Action&quot;: &quot;RETURN&quot;,\r\n\t   &quot;RemoveProduct1Instance&quot;: &quot;5647&quot;,\r\n        &quot;ProductOfferId&quot;: &quot;746927&quot;,\r\n      }   \r\n\t]\r\n\t&quot;Product2&quot;: \r\n\t[\r\n      {\r\n        &quot;Action&quot;: &quot;ADD&quot;,\r\n        &quot;NewComponentOfferId&quot;: &quot;345677858&quot;,\r\n      },\r\n\t  {\r\n        &quot;Action&quot;: &quot;REMOVE&quot;,\r\n\t   &quot;ComponentOfferId&quot;: &quot;546768&quot;,\r\n        &quot;RemoveProduct2Instance&quot;: &quot;64774&quot;,\r\n      },\r\n\t  {\r\n        &quot;Action&quot;: &quot;RETURN&quot;,\r\n\t   &quot;RemoveProduct2Instance&quot;: &quot;5647&quot;,\r\n\t   &quot;ProductOfferId&quot;: &quot;2134&quot;\r\n      }   \r\n\t]\r\n  }\r\n]    \r\n~~~\r\n\r\nAnd like wise for every line.\r\nPlease suggest how we can obtain this using **jq command** or **shell scripting**?\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69268321/convert-txt-file-to-json-using-shell-script-or-jq-command",
        "title": "Convert .txt file to json using shell script or jq command"
    },
    {
        "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": 1632231247,
                "post_id": 69269719,
                "comment_id": 122432546,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632247519,
                "post_id": 69269719,
                "comment_id": 122439373,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1632236529,
        "creation_date": 1632230886,
        "last_edit_date": 1632236529,
        "question_id": 69269719,
        "body_markdown": "I have quite long input with the following structure:\r\n\r\n```json\r\n{\r\n    &quot;name&quot;: &quot;test1&quot;,\r\n    &quot;selfLink&quot;: &quot;https://1.2.3.4&quot;,\r\n    &quot;items&quot;: [\r\n        {\r\n           &quot;name&quot;: &quot;test1&quot;,\r\n           &quot;rules&quot;: [\r\n                {\r\n                   &quot;expression&quot;: &quot;expresFOOsion1&quot;\r\n                }\r\n            ]\r\n        }\r\n    ],\r\n    ....next similar item, \r\n    ....next similar item, \r\n    ....next similar item\r\n}\r\n```\r\n\r\nthis finds the correct item(s):\r\n\r\n```sh\r\njq &#39;.items[].rules[]|select(.expression|test(&quot;.*FOO.*&quot;))&#39; testfile.json\r\n```\r\n\r\nbut i need to get the &quot;name&quot; : &quot;test1&quot; to the output.",
        "link": "https://stackoverflow.com/questions/69269719/jq-how-do-i-extract-item-which-has-part-of-subitem-value-of-foo",
        "title": "JQ: How do I extract item which has part of subitem value of &quot;FOO&quot;"
    },
    {
        "tags": [
            "bash",
            "shell",
            "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": 1632261529,
                "post_id": 69275915,
                "comment_id": 122443754,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14062568,
                    "reputation": 33,
                    "user_id": 10158223,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/s2uFa.jpg?s=256",
                    "display_name": "Kevin",
                    "link": "https://stackoverflow.com/users/10158223/kevin"
                },
                "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": 1632288067,
                "post_id": 69275915,
                "comment_id": 122447922,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 14062568,
                    "reputation": 33,
                    "user_id": 10158223,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/s2uFa.jpg?s=256",
                    "display_name": "Kevin",
                    "link": "https://stackoverflow.com/users/10158223/kevin"
                },
                "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": 1632288397,
                "post_id": 69275915,
                "comment_id": 122447990,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632296122,
                "post_id": 69275915,
                "comment_id": 122450521,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13789219,
                    "reputation": 53538,
                    "user_id": 9952196,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/cd1a3f93172eb89e221c98e35e6e22b3?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Shawn",
                    "link": "https://stackoverflow.com/users/9952196/shawn"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1632296303,
                "post_id": 69275915,
                "comment_id": 122450596,
                "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": 1632319477,
                "post_id": 69275915,
                "comment_id": 122460416,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1638205805,
                "creation_date": 1638205805,
                "answer_id": 70158585,
                "question_id": 69275915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is a comma missing between the fields &quot;description&quot; and &quot;timeWindow&quot;.  The `jq` error msg reflects the typo:\r\n\r\n    jq: error: syntax error, unexpected IDENT, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    split(&quot;?&quot;)|{ deviceName:.[0], ProcessId:.[1], processName:.[2], description:.[3] timeWindow:.[4], numberOfOccurrence:.[5] }                                                                                 \r\n    jq: error: May need parentheses around object key expression at &lt;top-level&gt;, line 1:\r\n    split(&quot;?&quot;)|{ deviceName:.[0], ProcessId:.[1], processName:.[2], description:.[3] timeWindow:.[4], numberOfOccurrence:.[5] }\r\n\r\nYour code example has the comma &amp; works for us!",
                "title": "convert output to json in shell"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1638205805,
        "creation_date": 1632260985,
        "question_id": 69275915,
        "body_markdown": "input:\r\n\r\n    BBAOMACBOOKAIR2?976?AMPDeviceDiscoveryAgent[976]:?      - Can&#39;t handle disconnect with invalid ecid?0700-0800?8\r\n    BBAOMACBOOKAIR2?976?AMPDeviceDiscoveryAgent[976]:?      - Can&#39;t handle disconnect with invalid ecid?0800-0900?40\r\n    BBAOMACBOOKAIR2?976?AMPDeviceDiscoveryAgent[976]:?      - Can&#39;t handle disconnect with invalid ecid?0900-1000?18\r\n    BBAOMACBOOKAIR2?976?AMPDeviceDiscoveryAgent[976]:?      - Can&#39;t handle disconnect with invalid ecid?1000-1100?14\r\n    BBAOMACBOOKAIR2?976?AMPDeviceDiscoveryAgent[976]:?      - Can&#39;t handle disconnect with invalid ecid?1100-1200?2\r\n\r\ncode:\r\n\r\n`input | jq -R &#39;split(&quot;?&quot;)|{ deviceName:.[0], ProcessId:.[1], processName:.[2], description:.[3], timeWindow:.[4], numberOfOccurrence:.[5] }`&#39;\r\n\r\nerror: I tried to solve it by searching Google results overnight, but I found nothing. Can you tell me where I went wrong?\r\n\r\n    jq: error: syntax error, unexpected IDENT, expecting &#39;}&#39; (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    split(&quot;?&quot;)|{ deviceName:.[0], ProcessId:.[1], processName:.[2], description:.[3] timeWindow:.[4], numberOfOccurrence:.[5] }                                                                                 \r\n    jq: error: May need parentheses around object key expression at &lt;top-level&gt;, line 1:\r\n    split(&quot;?&quot;)|{ deviceName:.[0], ProcessId:.[1], processName:.[2], description:.[3] timeWindow:.[4], numberOfOccurrence:.[5] } \r\n\r\n",
        "link": "https://stackoverflow.com/questions/69275915/convert-output-to-json-in-shell",
        "title": "convert output to json in shell"
    },
    {
        "tags": [
            "json",
            "unicode",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 378,
                    "reputation": 523921,
                    "user_id": 476,
                    "user_type": "moderator",
                    "accept_rate": 70,
                    "profile_image": "https://www.gravatar.com/avatar/a235706e3d81b614acaec3368edfea4b?s=256&d=identicon&r=PG",
                    "display_name": "deceze",
                    "link": "https://stackoverflow.com/users/476/deceze"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632319096,
                "post_id": 69285688,
                "comment_id": 122460241,
                "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": 1,
                "creation_date": 1632319876,
                "post_id": 69285688,
                "comment_id": 122460606,
                "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": 1632320031,
                "post_id": 69285688,
                "comment_id": 122460675,
                "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": 1632320171,
                "post_id": 69285688,
                "comment_id": 122460734,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 34424,
                    "reputation": 300619,
                    "user_id": 97337,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/ed9a0d8cd44b62539b141f6c10405db1?s=256&d=identicon&r=PG",
                    "display_name": "Rob Napier",
                    "link": "https://stackoverflow.com/users/97337/rob-napier"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1632320734,
                "post_id": 69285688,
                "comment_id": 122461002,
                "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": 1,
                "creation_date": 1632320960,
                "post_id": 69285688,
                "comment_id": 122461123,
                "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": 1632321028,
                "post_id": 69285688,
                "comment_id": 122461167,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 180181,
                    "reputation": 79427,
                    "user_id": 413337,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/783783f968e84cf5047544e9a0f3ccf4?s=256&d=identicon&r=PG",
                    "display_name": "Codo",
                    "link": "https://stackoverflow.com/users/413337/codo"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1632370421,
                "post_id": 69285688,
                "comment_id": 122474692,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8216,
                    "reputation": 152928,
                    "user_id": 1269037,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://i.sstatic.net/R0r8D.jpg?s=256",
                    "display_name": "Dan Dascalescu",
                    "link": "https://stackoverflow.com/users/1269037/dan-dascalescu"
                },
                "reply_to_user": {
                    "account_id": 180181,
                    "reputation": 79427,
                    "user_id": 413337,
                    "user_type": "registered",
                    "accept_rate": 64,
                    "profile_image": "https://www.gravatar.com/avatar/783783f968e84cf5047544e9a0f3ccf4?s=256&d=identicon&r=PG",
                    "display_name": "Codo",
                    "link": "https://stackoverflow.com/users/413337/codo"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633573320,
                "post_id": 69285688,
                "comment_id": 122797584,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1632319375,
                "creation_date": 1632319375,
                "answer_id": 69285830,
                "question_id": 69285688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "First of all, you need a font which supports this.\r\n\r\nYou are confusing Unicode composed chars with UTF-8 encoding. It has to be either:\r\n```\r\n$ echo &#39;{&quot;content&quot;:&quot;\\u1F937\\u200D\\u2642&quot;}&#39; | jq -c &#39;.&#39;\r\n```\r\nor\r\n```\r\n$ echo &#39;{&quot;content&quot;:&quot;\\u1F937\\u200D\\u2642\\uFE0F&quot;}&#39; | jq -c &#39;.&#39;\r\n```",
                "title": "Convert emoji Unicode byte sequences to Unicode characters with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632322112,
                "creation_date": 1632322112,
                "answer_id": 69286575,
                "question_id": 69285688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The problem is that the response contains the UTF-8 encoding of the Unicode code points, not the code points themselves. `jq` cannot decode this itself. You could use another language; for example, in Python\r\n\r\n    &gt;&gt;&gt; x = json.load(open(&quot;response.json&quot;))[&#39;content&#39;]\r\n    &gt;&gt;&gt; x\r\n    &#39;&#240;\\x9f&#164;&#183;&#240;\\x9f\\x8f&#191;&#226;\\x80\\x8d&#226;\\x99\\x82&#239;&#184;\\x8f&#39;\r\n    &gt;&gt;&gt; x.encode(&#39;latin1&#39;).decode()\r\n    &#39;&#129335;&#127999;\\u200d♂️&#39;\r\n\r\nIt&#39;s not *exact*, but I&#39;m not sure the encoding is unambiguous. For example,\r\n\r\n    &gt;&gt;&gt; x.encode(&#39;latin1&#39;)\r\n    b&#39;\\xf0\\x9f\\xa4\\xb7\\xf0\\x9f\\x8f\\xbf\\xe2\\x80\\x8d\\xe2\\x99\\x82\\xef\\xb8\\x8f&#39;\r\n    &gt;&gt;&gt; &#39;&#129335;&#127999;‍♂️&#39;.encode()\r\n    b&#39;\\xf0\\x9f\\xa4\\xb7\\xf0\\x9f\\x8f\\xbf\\xe2\\x80\\x8d\\xe2\\x99\\x82\\xef\\xb8\\x8f&#39;\r\n    &gt;&gt;&gt; &#39;&#129335;&#127999;‍♂️&#39;.encode().decode()\r\n    &#39;&#129335;&#127999;\\u200d♂️&#39;\r\n\r\nThe result of re-encoding the response using Latin-1 is identical to encoding the desired emoji as UTF-8, but decoding doesn&#39;t not give back precisely the same emoji (or at least, Python isn&#39;t rendering it identically.)",
                "title": "Convert emoji Unicode byte sequences to Unicode characters with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1632326106,
                "last_edit_date": 1632326106,
                "creation_date": 1632325057,
                "answer_id": 69287352,
                "question_id": 69285688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "@chepner&#39;s use of Latin1 in Python finally shook free in my head how to do with jq almost directly. You&#39;ll need to pipe through iconv:\r\n\r\n```\r\n$ echo &#39;{&quot;content&quot;:&quot;\\u00f0\\u...&quot;}&#39; | jq -c . | iconv -t latin1\r\n{&quot;content&quot;:&quot;&#129335;&#127999;‍♂️&quot;}\r\n```\r\n\r\nIn JSON, the string `\\u00f0` does not mean &quot;the byte 0xF0, as part of a UTF-8 encoded sequence.&quot; It means &quot;Unicode code point 0x00F0.&quot; That&#39;s &#240;, and jq is displaying it correctly as the UTF-8 encoding 0xc3 0xb0.\r\n\r\nThe iconv call reinterprets the UTF-8 string for &#240; (0xc3 0xb0) back into Latin1 as 0xf0 (Latin1 exactly matches the first 255 Unicode code points). Your UTF-8 capable terminal then interprets *that* as the first byte of a UTF-8 sequence.\r\n",
                "title": "Convert emoji Unicode byte sequences to Unicode characters with jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632720584,
                "creation_date": 1632720584,
                "answer_id": 69341616,
                "question_id": 69285688,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a jq-only solution.  It works with both the C and Go implementations of jq.\r\n```\r\n# input: a decimal integer\r\n# output: the corresponding binary array, most significant bit first\r\ndef binary_digits:\r\n  if . == 0 then 0\r\n  else [recurse( if . == 0 then empty else ./2 | floor end ) % 2]\r\n    | reverse\r\n    | .[1:] # remove the leading 0\r\n  end ;\r\n\r\ndef binary_to_decimal:\r\n  reduce reverse[] as $b ({power:1, result:0};\r\n       .result += .power * $b\r\n       | .power *= 2)\r\n  | .result;\r\n\r\n# input: an array of decimal integers representing the utf-8 bytes of a Unicode codepoint.\r\n# output: the corresponding decimal number of that codepoint.\r\ndef utf8_decode:\r\n   # Magic numbers:\r\n   # x80: 128,       # 10000000\r\n   # xe0: 224,       # 11100000\r\n   # xf0: 240        # 11110000\r\n     (-6) as $mb     # non-first bytes start 10 and carry 6 bits of data\r\n                     # first byte of a 2-byte encoding starts 110 and carries 5 bits of data\r\n                     # first byte of a 3-byte encoding starts 1110 and carries 4 bits of data\r\n                     # first byte of a 4-byte encoding starts 11110 and carries 3 bits of data\r\n   | map(binary_digits) as $d\r\n   | .[0]\r\n   | if   . &lt; 128 then $d[0]\r\n     elif . &lt; 224 then [$d[0][-5:][], $d[1][$mb:][]]\r\n     elif . &lt; 240 then [$d[0][-4:][], $d[1][$mb:][], $d[2][$mb:][]]\r\n     else              [$d[0][-3:][], $d[1][$mb:][], $d[2][$mb:][], $d[3][$mb:][]]\r\n     end\r\n   | binary_to_decimal ;\r\n```\r\n```\r\n{&quot;content&quot;:&quot;\\u00f0\\u009f\\u00a4\\u00b7\\u00f0\\u009f\\u008f\\u00bf\\u00e2\\u0080\\u008d\\u00e2\\u0099\\u0082\\u00ef\\u00b8\\u008f&quot;}\r\n| .content|= (explode| [utf8_decode] | implode)\r\n```\r\n\r\nTranscript:\r\n\r\n```\r\n$ jq -nM -f program.jq\r\n{\r\n  &quot;content&quot;: &quot;&#129335;&quot;\r\n}\r\n```\r\n\r\n",
                "title": "Convert emoji Unicode byte sequences to Unicode characters with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 4,
        "score": 0,
        "last_activity_date": 1632720584,
        "creation_date": 1632318853,
        "question_id": 69285688,
        "body_markdown": "I&#39;m [filtering Facebook Messenger JSON dumps](https://dev.to/dandv/how-to-extract-your-facebook-messenger-messages-from-a-conversation-2nik) with `jq`. The source JSON contains emojis as Unicode sequences. How can I output these back as emojis?\r\n\r\n    echo &#39;{&quot;content&quot;:&quot;\\u00f0\\u009f\\u00a4\\u00b7\\u00f0\\u009f\\u008f\\u00bf\\u00e2\\u0080\\u008d\\u00e2\\u0099\\u0082\\u00ef\\u00b8\\u008f&quot;}&#39; | jq -c &#39;.&#39;\r\n\r\nActual result:\r\n\r\n    {&quot;content&quot;:&quot;&#240;&#164;&#183;&#240;&#191;&#226;&#226;&#239;&#184;&quot;}\r\n\r\nDesired result:\r\n\r\n    {&quot;content&quot;:&quot;&#129335;&#127999;‍♂️&quot;}",
        "link": "https://stackoverflow.com/questions/69285688/convert-emoji-unicode-byte-sequences-to-unicode-characters-with-jq",
        "title": "Convert emoji Unicode byte sequences to Unicode characters with jq"
    },
    {
        "tags": [
            "json",
            "azure",
            "azure-devops",
            "jq",
            "azure-powershell"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1662221516,
                "post_id": 69288043,
                "comment_id": 129958389,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662221815,
                "creation_date": 1662221815,
                "answer_id": 73593729,
                "question_id": 69288043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The output you have shown is invalid JSON and cannot be transformed with JSON. Assuming that it were valid JSON:\r\n\r\n```\r\n{\r\n  &quot;build.sourceBranchName&quot;: &quot;master&quot;,\r\n  &quot;build.reason&quot;: &quot;Manual&quot;,\r\n  &quot;system.pullRequest.isFork&quot;: &quot;False&quot;,\r\n  &quot;system.jobParallelismTag&quot;: &quot;Public&quot;,\r\n  &quot;system.enableAccessToken&quot;: &quot;SecretVariable&quot;,\r\n  &quot;TEST_DB_HOSTNAME&quot;: &quot;10.123.56.222&quot;,\r\n  &quot;TEST_DB_PORTNUMBER&quot;: 1521,\r\n  &quot;TEST_USERNAME&quot;: &quot;TEST&quot;,\r\n  &quot;TEST_PASSWORD&quot;: &quot;TEST&quot;,\r\n  &quot;TEST_SCHEMANAME&quot;: &quot;SCHEMA&quot;,\r\n  &quot;TEST_ACTIVEMQNAME&quot;: &quot;10.123.56.223&quot;,\r\n  &quot;TEST_ACTIVEMQPORT&quot;: 8161\r\n}\r\n```\r\n\r\nthen you can use the `to_entries` or `with_entries` filters of jq to get an object containing only those keys which start with `&quot;TEST_&quot;`:\r\n\r\n```\r\nwith_entries(select(.key|startswith(&quot;TEST_&quot;)))\r\n```\r\n\r\nThis will give you a new object as output:\r\n\r\n```\r\n{\r\n  &quot;TEST_DB_HOSTNAME&quot;: &quot;10.123.56.222&quot;,\r\n  &quot;TEST_DB_PORTNUMBER&quot;: 1521,\r\n  &quot;TEST_USERNAME&quot;: &quot;TEST&quot;,\r\n  &quot;TEST_PASSWORD&quot;: &quot;TEST&quot;,\r\n  &quot;TEST_SCHEMANAME&quot;: &quot;SCHEMA&quot;,\r\n  &quot;TEST_ACTIVEMQNAME&quot;: &quot;10.123.56.223&quot;,\r\n  &quot;TEST_ACTIVEMQPORT&quot;: 8161\r\n}\r\n```",
                "title": "How to store the variable key and value that has been extracted from json into another variable with same format in azure pipeline?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1662380128,
                "creation_date": 1662380128,
                "answer_id": 73609214,
                "question_id": 69288043,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `convertToJson()` function is a bit messy, as the &quot;json&quot; it creates is not, in fact, a valid json. \r\n\r\nThere are several possible approaches I can think of:\r\n\r\n1. Use `convertToJson()` to pass the non-valid json to a script-step, convert it to a valid json and then extract the relevant values. I have done this before and it typically works, if you have control over the data in the variables. The downside is that there is risk that the conversion to valid json can fail.\r\n2. Create a yaml-loop that iterates the variables and extract the ones that begins with `Test_`. You can find examples of how to write a loop [here][1], but basically, it would look like this:\r\n\r\n```yaml\r\n- stage:\r\n  variables:\r\n    firstVar: 1\r\n    secondVar: 2\r\n    Test_thirdVar: 3\r\n    Test_forthVar: 4\r\n  jobs:\r\n  - job: loopVars\r\n    steps:\r\n    - ${{ each var in variables }}:\r\n      - script: |\r\n          echo ${{ var.key }}\r\n          echo ${{ var.value }}\r\n        displayName: handling ${{ var.key }}\r\n```\r\n\r\n3. If applicable to your use case, you can create complex parameters (instead of variables) for only the `Test_` variables. Using this, you could use the relevant values directly and would not need to extract a subset from your variable list. Note however, that parameters are inputs to a pipeline and can be adjusted before execution. Example:\r\n\r\n```yaml\r\nparameters:\r\n- name: non-test-variables\r\n  type: object\r\n  default:\r\n    firstVar: 1\r\n    secondVar: 2\r\n- name: test-variables\r\n  type: object\r\n  default:\r\n    Test_thirdVar: 3\r\n    Test_forthVar: 4\r\n```\r\nYou can use these by referencing `${{ parameters.Test_thirdVar }}` in the pipeline.\r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/69756083/how-to-loop-through-user-defined-variables-in-a-yaml-pipeline",
                "title": "How to store the variable key and value that has been extracted from json into another variable with same format in azure pipeline?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1662380128,
        "creation_date": 1632328351,
        "last_edit_date": 1632377305,
        "question_id": 69288043,
        "body_markdown": "I have a variable template \r\n\r\n    var1.yml\r\n    variables:\r\n    - name: TEST_DB_HOSTNAME\r\n      value: 10.123.56.222\r\n    - name: TEST_DB_PORTNUMBER\r\n      value: 1521\r\n    - name: TEST_USERNAME\r\n      value: TEST\r\n    - name: TEST_PASSWORD\r\n      value: TEST\r\n    - name: TEST_SCHEMANAME\r\n      value: SCHEMA  \r\n    - name: TEST_ACTIVEMQNAME\r\n      value: 10.123.56.223\r\n    - name: TEST_ACTIVEMQPORT\r\n      value: 8161\r\n \r\nWhen I run the below pipeline \r\n    \r\n    resources:\r\n      repositories:\r\n      - repository: templates\r\n        type: git\r\n        name: pipeline_templates\r\n        ref: refs/heads/master\r\n    \r\n    \r\n    trigger:\r\n    - none\r\n    variables:\r\n      - template: templates/var1.yml@templates\r\n    pool:\r\n      name: PoolA\r\n    steps:\r\n    - pwsh: |\r\n        Write-Host &quot;${{ convertToJson(variables) }}&quot;\r\n\r\nI get the output \r\n\r\n    {\r\n      build.sourceBranchName: master,\r\n      build.reason: Manual,\r\n      system.pullRequest.isFork: False,\r\n      system.jobParallelismTag: Public,\r\n      system.enableAccessToken: SecretVariable,\r\n      TEST_DB_HOSTNAME: 10.123.56.222,\r\n      TEST_DB_PORTNUMBER: 1521,\r\n      TEST_USERNAME: TEST,\r\n      TEST_PASSWORD: TEST,\r\n      TEST_SCHEMANAME: SCHEMA,\r\n      TEST_ACTIVEMQNAME: 10.123.56.223,\r\n      TEST_ACTIVEMQPORT: 8161\r\n    }\r\n\r\nHow can I modify the pipeline to extract only the key value from the result set that starts with `&quot;Test_&quot;` and store into another variable in the same format so that I could be used in other tasks in the same pipeline ? \r\nOR iterate through the objects that has keys &quot;Test_&quot; and get the value for the same ?",
        "link": "https://stackoverflow.com/questions/69288043/how-to-store-the-variable-key-and-value-that-has-been-extracted-from-json-into-a",
        "title": "How to store the variable key and value that has been extracted from json into another variable with same format in azure pipeline?"
    },
    {
        "tags": [
            "arrays",
            "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": 1632334215,
                "post_id": 69288526,
                "comment_id": 122466896,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632338725,
                "post_id": 69288526,
                "comment_id": 122468470,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632338760,
                "post_id": 69288526,
                "comment_id": 122468489,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 289134,
                    "reputation": 389369,
                    "user_id": 589924,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/b2cf53d5a3d25f95c0db4e025aed4153?s=256&d=identicon&r=PG",
                    "display_name": "ikegami",
                    "link": "https://stackoverflow.com/users/589924/ikegami"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632338800,
                "post_id": 69288526,
                "comment_id": 122468508,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 986543,
                    "reputation": 22837,
                    "user_id": 1004889,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://i.sstatic.net/bI4Hk.jpg?s=256",
                    "display_name": "pje",
                    "link": "https://stackoverflow.com/users/1004889/pje"
                },
                "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": 1632500103,
                "post_id": 69288526,
                "comment_id": 122518065,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1632340743,
                "last_edit_date": 1632340743,
                "creation_date": 1632339800,
                "answer_id": 69290384,
                "question_id": 69288526,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Perhaps the key concept you have not grasped is that of a &quot;stream&quot;.  jq can be thought of as a stream-oriented language so you might find the following helpful:\r\n\r\nhttps://github.com/pkoppstein/jq/wiki/A-Stream-oriented-Introduction-to-jq\r\n\r\nDisclosure: I am the author.",
                "title": "In jq, what&#39;s the difference between `.my_array` and `.my_array[]`?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632340824,
                "creation_date": 1632340824,
                "answer_id": 69290563,
                "question_id": 69288526,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Consider a filter that would do something with the result of each of your two filters. This might make it clearer than simply seeing the value(s) written to standard output.\r\n\r\nFirst, we create an object from the single array value produced by `.my_array`. The entire array becomes the value of the key `x`.\r\n\r\n    % echo &#39;{&quot;my_array&quot;:[{&quot;id&quot;:1},{&quot;id&quot;:2}]}&#39; | jq &#39;{x: .my_array}&#39;\r\n    {\r\n      &quot;x&quot;: [\r\n        {\r\n          &quot;id&quot;: 1\r\n        },\r\n        {\r\n          &quot;id&quot;: 2\r\n        }\r\n      ]\r\n    }\r\n\r\nNext, we create *two* objects, one for each object value produced by `.my_array[]`.\r\n\r\n    % echo &#39;{&quot;my_array&quot;:[{&quot;id&quot;:1},{&quot;id&quot;:2}]}&#39; | jq &#39;{x: .my_array[]}&#39;\r\n    {\r\n      &quot;x&quot;: {\r\n        &quot;id&quot;: 1\r\n      }\r\n    }\r\n    {\r\n      &quot;x&quot;: {\r\n        &quot;id&quot;: 2\r\n      }\r\n    }\r\n\r\n\r\n\r\n",
                "title": "In jq, what&#39;s the difference between `.my_array` and `.my_array[]`?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632414457,
                "last_edit_date": 1632414457,
                "creation_date": 1632413942,
                "answer_id": 69303619,
                "question_id": 69288526,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The point to understand is that all filters emit a _stream_ of zero or more JSON entities. When your first example reads in one JSON object, it places _one_ JSON _array_ onto its output stream:\r\n\r\n```\r\necho &#39;{&quot;my_array&quot;:[{&quot;id&quot;:1},{&quot;id&quot;:2}]}&#39; | jq &#39;.my_array&#39;\r\n[\r\n  {\r\n    &quot;id&quot;: 1\r\n  },\r\n  {\r\n    &quot;id&quot;: 2\r\n  }\r\n]\r\n\r\n```\r\nWhen your second example reads in one JSON object it emits _two_ JSON _objects_ onto its output stream:\r\n```\r\n$ echo &#39;{&quot;my_array&quot;:[{&quot;id&quot;:1},{&quot;id&quot;:2}]}&#39; | jq &#39;.my_array[]&#39;\r\n{\r\n  &quot;id&quot;: 1\r\n}\r\n{\r\n  &quot;id&quot;: 2\r\n}\r\n```\r\nA lot of `jq` will make more sense once you understand that filters can be composed together and all filters output streams. The filter `.my_array[]` can be seen as two filters composed together, `.myarray` and `.[]`. We&#39;ve already seen what `.myarray` does on its own: every time it reads in an object, it places one entity on its output stream, either the value of that field or `null` if it was missing. When the two filters are composed together, each output from the first is fed into the second. Every time `.[]` reads in an array, it places all of that array&#39;s contents, one at a time, on its output stream.",
                "title": "In jq, what&#39;s the difference between `.my_array` and `.my_array[]`?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 0,
        "last_activity_date": 1632414457,
        "creation_date": 1632330558,
        "last_edit_date": 1632355970,
        "question_id": 69288526,
        "body_markdown": "I&#39;m new to JQ and I&#39;m having trouble wrapping my head around the return types of JQ&#39;s filters when applied to arrays.\r\n\r\n**Specifically: What&#39;s the difference between `.my_array` and `my_array[]`?**\r\n\r\nThe first example returns an array:\r\n\r\n```shell\r\n$ echo &#39;{&quot;my_array&quot;:[{&quot;id&quot;:1},{&quot;id&quot;:2}]}&#39; | jq &#39;.my_array&#39;\r\n[\r\n  {\r\n    &quot;id&quot;: 1\r\n  },\r\n  {\r\n    &quot;id&quot;: 2\r\n  }\r\n]\r\n\r\n```\r\n\r\nWhile the second example seems to return _each element of the array_:\r\n\r\n\r\n```shell\r\n$ echo &#39;{&quot;my_array&quot;:[{&quot;id&quot;:1},{&quot;id&quot;:2}]}&#39; | jq &#39;.my_array[]&#39;\r\n{\r\n  &quot;id&quot;: 1\r\n}\r\n{\r\n  &quot;id&quot;: 2\r\n}\r\n```\r\n\r\nWhat&#39;s the precise difference between &quot;filter that returns an array&quot; and &quot;filter that returns each element of the array&quot;, and why does JQ consider them different?\r\n",
        "link": "https://stackoverflow.com/questions/69288526/in-jq-whats-the-difference-between-my-array-and-my-array",
        "title": "In jq, what&#39;s the difference between `.my_array` and `.my_array[]`?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1632336444,
                "last_edit_date": 1632336444,
                "creation_date": 1632334974,
                "answer_id": 69289464,
                "question_id": 69289006,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You don&#39;t need the `*` operator there. Something like this should work just fine:\r\n```\r\nreduce to_entries[] as {$key, $value} ({};\r\n  .[$value] += [$key]\r\n)\r\n```\r\n&lt;sup&gt;[Online demo](https://jqplay.org/s/N6QO4v2lYT)&lt;/sup&gt;",
                "title": "jq: idiomatically aggregate object keys by value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1664763803,
        "creation_date": 1632332778,
        "last_edit_date": 1664763803,
        "question_id": 69289006,
        "body_markdown": "Let&#39;s say I have a JSON object that looks like:\r\n\r\n    {\r\n        &quot;Person A&quot;: &quot;Accounting&quot;,\r\n        &quot;Person B&quot;: &quot;Accounting&quot;,\r\n        &quot;Person C&quot;: &quot;Production&quot;,\r\n        &quot;Person D&quot;: &quot;Production&quot;,\r\n        &quot;Person E&quot;: &quot;Marketing&quot;\r\n    }\r\n\r\nAnd I&#39;d like to flip it inside out so that for each Department, I have a list of people in it, a la:\r\n\r\n    {\r\n        &quot;Accounting&quot;: [\r\n            &quot;Person A&quot;,\r\n            &quot;Person B&quot;\r\n        ],\r\n        &quot;Production&quot;: [\r\n            &quot;Person C&quot;,\r\n            &quot;Person D&quot;\r\n        ],\r\n        &quot;Marketing&quot;: [\r\n            &quot;Person E&quot;\r\n        ]\r\n    }\r\n\r\nI&#39;m still pretty new to `jq` and have come up with a couple of functional solutions, but each has their own issues and I&#39;m hoping there&#39;s a better, more idiomatic way to do it that I just haven&#39;t figured out yet.\r\n\r\n### jq program 1 ([jqplay](https://jqplay.org/s/vgTZ--5jl_)):\r\n\r\n    to_entries\r\n    | group_by(.value)\r\n    | map( { &quot;key&quot;: .[0].value, &quot;value&quot;: [ .[].key ] } )\r\n    | from_entries\r\n\r\nThe inefficiency here is that the structure created by `group_by` creates a structure that needs to be further manipulated, so for each entry in the resulting list, we build our own by taking the first subentry&#39;s value (ignoring every other subentry&#39;s value), and then taking every subentry&#39;s key.\r\n\r\n### jq program 2 ([jqplay](https://jqplay.org/s/N6n04lq1DS))\r\n\r\n    to_entries | reduce .[] as $x (\r\n        {};\r\n        . * {\r\n            ($x.value): (\r\n                (.[$x.value]//[]) + [ $x.key ]\r\n            )\r\n        }\r\n    )\r\n\r\nHere we&#39;re using `reduce` to efficiently build the thing we want to build which is nice. However, the `*` doesn&#39;t recursively `+` arrays, so we have to handle that part ourselves, and that makes for some pretty hairy reading (at least from my perspective).\r\n\r\nCan you think of a more elegant and/or idiomatic way to aggregate an object&#39;s values by key in `jq`?",
        "link": "https://stackoverflow.com/questions/69289006/jq-idiomatically-aggregate-object-keys-by-value",
        "title": "jq: idiomatically aggregate object keys by value"
    },
    {
        "tags": [
            "bash",
            "amazon-web-services",
            "jq"
        ],
        "comments": [
            {
                "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": 1632396468,
                "post_id": 69298128,
                "comment_id": 122483616,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632720501,
                "last_edit_date": 1632720501,
                "creation_date": 1632399912,
                "answer_id": 69299954,
                "question_id": 69298128,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Implemented as Bash logic:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\njq -s -j &#39;.[]|(.InstanceId + &quot;\\u001f&quot; + .HealthStatus + &quot;\\u001f&quot; + .LifecycleState, &quot;\\u0000&quot;)&#39; a.json |\r\nwhile IFS=$&#39;\\37&#39; read -r -d &#39;&#39; InstanceId HealthStatus LifecycleState; do\r\n  if [ &quot;$HealthStatus&quot; == &#39;Healthy&#39; ] &amp;&amp; [ &quot;$LifecycleState&quot; == &#39;InService&#39; ]; then\r\n    echo do_something &quot;$InstanceId&quot;\r\n  fi\r\ndone\r\n```\r\n\r\nImplemented as `jq` logic:\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\njq -sj &#39;.[]|if .HealthStatus==&quot;Healthy&quot; and .LifecycleState==&quot;InService&quot; then .InstanceId + &quot;\\u0000&quot; else empty end&#39; a.json |\r\nwhile IFS= read -r -d &#39;&#39; InstanceID; do\r\n  echo do_something &quot;$InstanceID&quot;\r\ndone\r\n```\r\n\r\n**EDIT**\r\nForgot about `jq` `select` which is even more appropriate here than an `if then else empty end`:\r\n\r\n```sh\r\n#!/usr/bin/env bash\r\n\r\njq -sj &#39;.[] | select(.HealthStatus == &quot;Healthy&quot; and .LifecycleState == &quot;InService&quot;) | .InstanceId + &quot;\\u0000&quot;&#39; a.json |\r\nwhile IFS= read -r -d &#39;&#39; InstanceID; do\r\n  echo do_something &quot;$InstanceID&quot;\r\ndone\r\n```",
                "title": "BASH and jq to access JSON key-value pair"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632720501,
        "creation_date": 1632392230,
        "question_id": 69298128,
        "body_markdown": "How can I access the key and value in BASH and/or jq?\r\n\r\nI have a command shown below:\r\n\r\n    asg_name=&quot;bleh&quot;\r\n    aws autoscaling describe-auto-scaling-groups \\\r\n        --auto-scaling-group-names $asg_name | \r\n        jq -r &#39;.AutoScalingGroups[].Instances[] | \r\n               {InstanceId: .InstanceId, HealthStatus: .HealthStatus, LifecycleState: .LifecycleState}&#39;\r\n\r\nwhich produces the following format:\r\n\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-jibberish&quot;,\r\n      &quot;HealthStatus&quot;: &quot;Healthy&quot;,\r\n      &quot;LifecycleState&quot;: &quot;InService&quot;\r\n    }\r\n    {\r\n      &quot;InstanceId&quot;: &quot;i-jibberish&quot;,\r\n      &quot;HealthStatus&quot;: &quot;Healthy&quot;,\r\n      &quot;LifecycleState&quot;: &quot;InService&quot;\r\n    }\r\n\r\nHow can I extract the value of each key in each JSON block (as the same row) so that I can use it in another process? Similar to the following effect:\r\n\r\n    for obj in $results\r\n    do\r\n       if [ obj[ValueOfHealthStatus] = &quot;Healthy&quot; ] &amp;&amp; [ obj[ValueLifeCycleState] = &quot;InService&quot; ]; then\r\n          do_something(obj[ValueOfInstanceId])   \r\n       fi\r\n    done\r\n\r\nIs it possible at all?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/69298128/bash-and-jq-to-access-json-key-value-pair",
        "title": "BASH and jq to access JSON key-value pair"
    },
    {
        "tags": [
            "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": 1632446887,
                "post_id": 69300195,
                "comment_id": 122500833,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632402203,
                "creation_date": 1632402203,
                "answer_id": 69300605,
                "question_id": 69300195,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` does not implement hash functions, you have to export the data, apply an external tool and re-import the hash.\r\n\r\nFor instance, if your JSON lived in a file called `input.json` and you were using `bash` to call `jq`, you could do:\r\n\r\n    # Export the data\r\n    data=&quot;$(jq -r &#39;.a&#39; input.json)&quot;\r\n\r\n    # Apply an external tool\r\n    md5sum=&quot;$(printf &#39;%.32s&#39; &quot;$(md5sum &lt;&lt;&lt; &quot;${data}&quot;)&quot;)&quot;\r\n\r\n    # Re-import the hash\r\n    jq --arg md5sum &quot;${md5sum}&quot; &#39;.a_md5 = $md5sum&#39; input.json\r\n\r\nor without using variables\r\n\r\n    jq --arg md5sum &quot;$(\r\n      printf &#39;%.32s&#39; &quot;$(\r\n        md5sum &lt;&lt;&lt; &quot;$(\r\n          jq -r &#39;.a&#39; input.json\r\n        )&quot;\r\n      )&quot;\r\n    )&quot; &#39;.a_md5 = $md5sum&#39; input.json",
                "title": "How to compute mod hash of a field using JQ?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1632402203,
        "creation_date": 1632400772,
        "question_id": 69300195,
        "body_markdown": "```\r\n{\r\n  &quot;a&quot;: &quot;jdsdjhsandks&quot;\r\n}\r\n```\r\n\r\nHow can I compute modular hash of `a` field using JQ expression?",
        "link": "https://stackoverflow.com/questions/69300195/how-to-compute-mod-hash-of-a-field-using-jq",
        "title": "How to compute mod hash of a field using JQ?"
    },
    {
        "tags": [
            "jq",
            "openapi"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632440596,
                "last_edit_date": 1632440596,
                "creation_date": 1632440077,
                "answer_id": 69307960,
                "question_id": 69307846,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I prefer building a lookup table.\r\n\r\n```sh\r\njq &#39;\r\n   ( [&quot;/pets&quot;] | map({ (.): true }) | add ) as $whitelist |\r\n   .paths |= with_entries(select( $whitelist[.key] ))\r\n&#39;\r\n```\r\n\r\n[jqplay](https://jqplay.org/s/AF5mQB03ns)",
                "title": "Filter openapi spec by routes"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632440596,
        "creation_date": 1632438808,
        "last_edit_date": 1632440121,
        "question_id": 69307846,
        "body_markdown": "I have an openapi spec on which I&#39;d like to select a subset of paths (thus, filter by key). I&#39;m having trouble getting the with_entries command to work to filter a list of paths.\r\n\r\nSample JSON:\r\n\r\n```json\r\n{\r\n  &quot;swagger&quot;: &quot;2.0&quot;,\r\n  &quot;info&quot;: {},\r\n  &quot;host&quot;: &quot;petstore.swagger.io&quot;,\r\n  &quot;basePath&quot;: &quot;/api&quot;,\r\n  &quot;schemes&quot;: [],\r\n  &quot;consumes&quot;: [],\r\n  &quot;produces&quot;: [],\r\n  &quot;paths&quot;: {\r\n    &quot;/pets&quot;: {},\r\n    &quot;/pets/{id}&quot;: {}\r\n  },\r\n  &quot;definitions&quot;: {}\r\n}\r\n```\r\n\r\nThe input is the json, the output should be the same json, but only the &#39;/pets&#39; route left in (filtering the &quot;/pets/{id}&quot; route out).\r\n\r\nWe will have a list of probably 20 routes, so would like a solution that is clean and allows me to specify the ~20 routes separately as a variable.\r\n\r\nI tried some of the answers [here](https://stackoverflow.com/questions/44704404/select-entries-based-on-multiple-values-in-jq) and came up with this: (We also need to capture and keep other top-level keys, but I&#39;m focused on path filtering for now, but an answer for that would be most welcome!)\r\n\r\n    .paths\r\n    [&quot;/pets&quot;] as $whitelist\r\n    | with_entries( select( .key as $k | any( $whitelist[]; . == $k) ) ) \r\n\r\nHowever, this gives an error (`jq: error (at file.json:xx): Cannot iterate over null (null)`\r\n\r\nSo there are two problems to solve:\r\n1) How to keep all of the elements in the original json, but filter out some of the paths\r\n2) How to make the script &#39;clean&#39; so that the list of paths to keep can be easily maintained",
        "link": "https://stackoverflow.com/questions/69307846/filter-openapi-spec-by-routes",
        "title": "Filter openapi spec by routes"
    },
    {
        "tags": [
            "json",
            "jenkins",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": -1,
                    "reputation": 1,
                    "user_id": -1,
                    "user_type": "moderator",
                    "profile_image": "https://www.gravatar.com/avatar/a007be5a61f6aa8f3e85ae2fc18dd66e?s=256&d=identicon&r=PG",
                    "display_name": "Community",
                    "link": "https://stackoverflow.com/users/-1/community"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1633256579,
                "post_id": 69311166,
                "comment_id": 122706648,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1632470570,
                "last_edit_date": 1632470570,
                "creation_date": 1632469941,
                "answer_id": 69311443,
                "question_id": 69311166,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `jq -Rs . &lt;&lt;&lt; &quot;${projectContent}&quot;` to convert the variable content into a JSON string (you may even use `curl` directly, like so: `curl … | jq -Rs`), then import that string into a jq variable using `--slurpfile` with [Process Substitution][1]\r\n\r\n    jq --slurpfile projectContent &lt;(\r\n      jq -Rs . &lt;&lt;&lt; &quot;${projectContent}&quot;\r\n    ) &#39;...&#39; # your jq code here using variable $projectContent\r\n\r\nDon&#39;t forget to also add either `-n` or an input file.\r\n\r\n  [1]: https://tldp.org/LDP/abs/html/process-sub.html",
                "title": "/bin/jq: Argument list too long"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1632470570,
        "creation_date": 1632468613,
        "question_id": 69311166,
        "body_markdown": "I&#39;m using groovy script and write this line \r\nVersion_List=\\$(`jq -r  &#39;.items[] .version&#39; &quot;${projectContent}&quot;`)\r\n\r\nthe ${projectContent} is another variable which is result of curl command \r\nwhen i run the pipeline this is the error /bin/jq: Argument list too long",
        "link": "https://stackoverflow.com/questions/69311166/bin-jq-argument-list-too-long",
        "title": "/bin/jq: Argument list too long"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632483617,
                "post_id": 69314397,
                "comment_id": 122511233,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 21207614,
                    "reputation": 45,
                    "user_id": 15596906,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a-/AOh14GgV43iiYYmURHD6XpSzxNr3eiQAw2lSOYz9yP0i=k-s256",
                    "display_name": "zexapod",
                    "link": "https://stackoverflow.com/users/15596906/zexapod"
                },
                "reply_to_user": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632483739,
                "post_id": 69314397,
                "comment_id": 122511285,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 3959308,
                    "reputation": 53394,
                    "user_id": 3266847,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/U0oyt.png?s=256",
                    "display_name": "Benjamin W.",
                    "link": "https://stackoverflow.com/users/3266847/benjamin-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632484317,
                "post_id": 69314397,
                "comment_id": 122511504,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1632483805,
                "creation_date": 1632483805,
                "answer_id": 69314467,
                "question_id": 69314397,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `--argjson` instead of `--arg`. That way your variable `v` becomes a number in `jq`, not a string.\r\n\r\n    jq --raw-output --argjson v $i &#39;.items.item[$v].request.text&#39; try4.json | base64 --decode | sed &#39;1q;d&#39; | awk &#39;{print $2}&#39;",
                "title": "Bash loop through json array using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1632489391,
                "creation_date": 1632489391,
                "answer_id": 69315673,
                "question_id": 69314397,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Doing it entirely in `jq` without needing bash:\r\n\r\n```sh\r\njq -r &#39;.items[].item.request.text| @base64d | split(&quot;\\n&quot;)[0] | split(&quot; &quot;)[1]&#39;\r\n```\r\n\r\nThe same commented `jq` script as a stand-alone version:\r\n\r\n```jq\r\n#!/usr/bin/env -S jq -rf\r\n\r\n.items[].item.request.text |\r\n# Base64 decode item request text\r\n@base64d |\r\n\r\n# Split decoded text lines and use first line\r\nsplit(&quot;\\n&quot;)[0] |\r\n\r\n# Split line on space and get second element\r\nsplit(&quot; &quot;)[1]\r\n```",
                "title": "Bash loop through json array using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1632489391,
        "creation_date": 1632483483,
        "question_id": 69314397,
        "body_markdown": "I wanted to loop through json array, I wrote this simple script but I am getting this error\r\n\r\n```\r\n#! /bin/bash\r\n\r\n\r\nm=$(jq &#39;.items.item | length&#39; try4.json)\r\n\r\nfor i in $(seq 1 10);\r\ndo\r\n    jq --raw-output --arg v $i &#39;.items.item[$v].request.text&#39; try4.json | base64 --decode | sed &#39;1q;d&#39; | awk &#39;{print $2}&#39;\r\ndone\r\n```\r\n\r\nError\r\n```\r\njq: error (at try4.json:58): Cannot index array with string &quot;1&quot;\r\njq: error (at try4.json:58): Cannot index array with string &quot;2&quot;\r\njq: error (at try4.json:58): Cannot index array with string &quot;3&quot;\r\njq: error (at try4.json:58): Cannot index array with string &quot;4&quot;\r\njq: error (at try4.json:58): Cannot index array with string &quot;5&quot;\r\njq: error (at try4.json:58): Cannot index array with string &quot;6&quot;\r\njq: error (at try4.json:58): Cannot index array with string &quot;7&quot;\r\njq: error (at try4.json:58): Cannot index array with string &quot;8&quot;\r\njq: error (at try4.json:58): Cannot index array with string &quot;9&quot;\r\njq: error (at try4.json:58): Cannot index array with string &quot;10&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/69314397/bash-loop-through-json-array-using-jq",
        "title": "Bash loop through json array using jq"
    },
    {
        "tags": [
            "bash",
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632492802,
                "post_id": 69316366,
                "comment_id": 122515001,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1632492711,
                "creation_date": 1632492711,
                "answer_id": 69316449,
                "question_id": 69316366,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Construct a new object rather than simply returning the value associated with the key.\r\n\r\n    jq &#39;{popup: .menu.popup}&#39; tmp.json\r\n\r\nIf you want to pass the key as an argument, you can.\r\n\r\n    jq --arg key popup &#39;{($key): .menu|.[$key])}&#39; tmp.json",
                "title": "Bash jq include search key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632492779,
        "creation_date": 1632492376,
        "last_edit_date": 1632492779,
        "question_id": 69316366,
        "body_markdown": "When searching in a json by key i want also to print the key I search by:\r\n\r\nInput:\r\n```\r\n{&quot;menu&quot;: {\r\n  &quot;id&quot;: &quot;file&quot;,\r\n  &quot;value&quot;: &quot;File&quot;,\r\n  &quot;popup&quot;: {\r\n    &quot;menuitem&quot;: [\r\n      {&quot;value&quot;: &quot;New&quot;, &quot;onclick&quot;: &quot;CreateNewDoc()&quot;},\r\n      {&quot;value&quot;: &quot;Open&quot;, &quot;onclick&quot;: &quot;OpenDoc()&quot;},\r\n      {&quot;value&quot;: &quot;Close&quot;, &quot;onclick&quot;: &quot;CloseDoc()&quot;}\r\n    ]\r\n  }\r\n}}\r\n```\r\n\r\nWhen search by &quot;.menu.popup&quot;, actual result:\r\n```\r\n$ jq &quot;.menu.popup&quot; test.json \r\n{\r\n  &quot;menuitem&quot;: [\r\n    {\r\n      &quot;value&quot;: &quot;New&quot;,\r\n      &quot;onclick&quot;: &quot;CreateNewDoc()&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: &quot;Open&quot;,\r\n      &quot;onclick&quot;: &quot;OpenDoc()&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: &quot;Close&quot;,\r\n      &quot;onclick&quot;: &quot;CloseDoc()&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nexpected output:\r\n```\r\n{\r\n  &quot;popup&quot;: {\r\n    &quot;menuitem&quot;: [\r\n      {\r\n        &quot;value&quot;: &quot;New&quot;,\r\n        &quot;onclick&quot;: &quot;CreateNewDoc()&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: &quot;Open&quot;,\r\n        &quot;onclick&quot;: &quot;OpenDoc()&quot;\r\n      },\r\n      {\r\n        &quot;value&quot;: &quot;Close&quot;,\r\n        &quot;onclick&quot;: &quot;CloseDoc()&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n\r\nAn obvious solution is to prefix output with search key, but I wonder if it is possible to include parent key natively for jq.\r\n",
        "link": "https://stackoverflow.com/questions/69316366/bash-jq-include-search-key",
        "title": "Bash jq include search key"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632493963,
                "post_id": 69316726,
                "comment_id": 122515514,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22256162,
                    "reputation": 3,
                    "user_id": 16488304,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJz1O8bO9mb_9nqk0zx_6iJrikqM8WyYJCdR5bZe=k-s256",
                    "display_name": "Tim Goodman",
                    "link": "https://stackoverflow.com/users/16488304/tim-goodman"
                },
                "reply_to_user": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632494489,
                "post_id": 69316726,
                "comment_id": 122515761,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632494577,
                "post_id": 69316726,
                "comment_id": 122515800,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22256162,
                    "reputation": 3,
                    "user_id": 16488304,
                    "user_type": "registered",
                    "profile_image": "https://lh3.googleusercontent.com/a/AATXAJz1O8bO9mb_9nqk0zx_6iJrikqM8WyYJCdR5bZe=k-s256",
                    "display_name": "Tim Goodman",
                    "link": "https://stackoverflow.com/users/16488304/tim-goodman"
                },
                "reply_to_user": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632495768,
                "post_id": 69316726,
                "comment_id": 122516309,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 51201,
                    "reputation": 243376,
                    "user_id": 152948,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/194ef8f807c34a9d7aab0e11a8674768?s=256&d=identicon&r=PG",
                    "display_name": "hobbs",
                    "link": "https://stackoverflow.com/users/152948/hobbs"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632500379,
                "post_id": 69316726,
                "comment_id": 122518165,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632496023,
                "creation_date": 1632496023,
                "answer_id": 69317292,
                "question_id": 69316726,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your JSON starts with:\r\n```json\r\n{\r\n  &quot;value&quot;: [\r\n    {\r\n```\r\n\r\nThis indicates that you&#39;re dealing with an object.\r\n\r\nYour command, `&#39;.[].value.health&#39;` tries to loop over an array.\r\n\r\nTo do so, you&#39;ll need to select the first `value` key, then use that as an array.\r\n\r\n```none\r\njq &#39;.value[].value.health&#39; tst.input\r\n```\r\n\r\nWill produce:\r\n```none\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\nnull\r\nnull\r\nnull\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\nnull\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\nnull\r\nnull\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\nnull\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n&quot;HEALTHY&quot;\r\n```",
                "title": "Need help parsing json output with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632549453,
        "creation_date": 1632493783,
        "last_edit_date": 1632549453,
        "question_id": 69316726,
        "body_markdown": "I have the below json file and I&#39;m trying to parse a particular field from it using jq\r\n```\r\n{\r\n  &quot;value&quot;: [\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.analytics.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.analytics.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;analytics&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.applmgmt.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.applmgmt.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;applmgmt&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.certificatemanagement.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [\r\n              &quot;GREEN&quot;\r\n            ],\r\n            &quot;default_message&quot;: &quot;Health is GREEN&quot;,\r\n            &quot;id&quot;: &quot;certificatemanagement.health.statuscode&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.certificatemanagement.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;certificatemanagement&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.cis-license.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [],\r\n            &quot;default_message&quot;: &quot;The License Service is operational.&quot;,\r\n            &quot;id&quot;: &quot;cis.license.health.ok&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.cis-license.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;cis-license&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.cm.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.cm.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;cm&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.content-library.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [],\r\n            &quot;default_message&quot;: &quot;Database server connection is GREEN.&quot;,\r\n            &quot;id&quot;: &quot;com.vmware.vdcs.vsphere-cs-lib.db_health_green&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.content-library.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;content-library&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.eam.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [],\r\n            &quot;default_message&quot;: &quot;&quot;,\r\n            &quot;id&quot;: &quot;cis.eam.statusOK&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.eam.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;eam&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.imagebuilder.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;MANUAL&quot;,\r\n        &quot;description_key&quot;: &quot;cis.imagebuilder.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STOPPED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;imagebuilder&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.mbcs.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;MANUAL&quot;,\r\n        &quot;description_key&quot;: &quot;cis.mbcs.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STOPPED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;mbcs&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.netdumper.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;MANUAL&quot;,\r\n        &quot;description_key&quot;: &quot;cis.netdumper.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STOPPED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;netdumper&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.perfcharts.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [],\r\n            &quot;default_message&quot;: &quot;health.statsReoptInitalizer.green&quot;,\r\n            &quot;id&quot;: &quot;health.statsReoptInitalizer.green&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.perfcharts.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;perfcharts&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.pschealth.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.pschealth.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;pschealth&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.rbd.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;MANUAL&quot;,\r\n        &quot;description_key&quot;: &quot;cis.rbd.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STOPPED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;rbd&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.rhttpproxy.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.rhttpproxy.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;rhttpproxy&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.sca.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.sca.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;sca&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.sps.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.sps.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;sps&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.statsmonitor.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [],\r\n            &quot;default_message&quot;: &quot;Appliance monitoring service is healthy.&quot;,\r\n            &quot;id&quot;: &quot;com.vmware.applmgmt.mon.health.healthy&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.statsmonitor.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;statsmonitor&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.topologysvc.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [\r\n              &quot;GREEN&quot;\r\n            ],\r\n            &quot;default_message&quot;: &quot;Health is GREEN&quot;,\r\n            &quot;id&quot;: &quot;topologysvc.health.statuscode&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.topologysvc.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;topologysvc&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.updatemgr.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.updatemgr.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;updatemgr&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vapi-endpoint.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [\r\n              &quot;2021-09-24T14:56:06UTC&quot;,\r\n              &quot;2021-09-24T14:56:07UTC&quot;\r\n            ],\r\n            &quot;default_message&quot;: &quot;Current vApi Endpoint health status is created between 2021-09-24T14:56:06UTC and 2021-09-24T14:56:07UTC.&quot;,\r\n            &quot;id&quot;: &quot;com.vmware.vapi.endpoint.healthStatusProducedTimes&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vapi-endpoint.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vapi-endpoint&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vcha.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;DISABLED&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vcha.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STOPPED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vcha&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vmcam.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;MANUAL&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vmcam.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STOPPED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vmcam&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vmonapi.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vmonapi.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vmonapi&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vmware-postgres-archiver.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [],\r\n            &quot;default_message&quot;: &quot;VMware Archiver service is healthy.&quot;,\r\n            &quot;id&quot;: &quot;cis.vmware-postgres-archiver.health.healthy&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vmware-postgres-archiver.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vmware-postgres-archiver&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vmware-vpostgres.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [],\r\n            &quot;default_message&quot;: &quot;VMware Postgres service is healthy.&quot;,\r\n            &quot;id&quot;: &quot;cis.vmware-vpostgres.health.healthy&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vmware-vpostgres.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vmware-vpostgres&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vpxd.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [\r\n              &quot;vCenter Server&quot;,\r\n              &quot;GREEN&quot;\r\n            ],\r\n            &quot;default_message&quot;: &quot;{0} health is {1}&quot;,\r\n            &quot;id&quot;: &quot;vc.health.statuscode&quot;\r\n          },\r\n          {\r\n            &quot;args&quot;: [\r\n              &quot;VirtualCenter Database&quot;,\r\n              &quot;GREEN&quot;\r\n            ],\r\n            &quot;default_message&quot;: &quot;{0} health is {1}&quot;,\r\n            &quot;id&quot;: &quot;vc.health.statuscode&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vpxd.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vpxd&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vpxd-svcs.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [\r\n          {\r\n            &quot;args&quot;: [],\r\n            &quot;default_message&quot;: &quot;Tagging service is in a healthy state&quot;,\r\n            &quot;id&quot;: &quot;cis.tagging.health.status&quot;\r\n          }\r\n        ],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vpxd-svcs.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vpxd-svcs&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vsan-dps.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;MANUAL&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vsan-dps.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STOPPED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vsan-dps&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vsan-health.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vsan-health.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vsan-health&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vsm.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vsm.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vsm&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vsphere-client.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vsphere-client.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vsphere-client&quot;\r\n    },\r\n    {\r\n      &quot;value&quot;: {\r\n        &quot;name_key&quot;: &quot;cis.vsphere-ui.ServiceName&quot;,\r\n        &quot;startup_type&quot;: &quot;AUTOMATIC&quot;,\r\n        &quot;health_messages&quot;: [],\r\n        &quot;health&quot;: &quot;HEALTHY&quot;,\r\n        &quot;description_key&quot;: &quot;cis.vsphere-ui.ServiceDescription&quot;,\r\n        &quot;state&quot;: &quot;STARTED&quot;\r\n      },\r\n      &quot;key&quot;: &quot;vsphere-ui&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;ve tried different combinations that I felt should work and can&#39;t get it\r\n\r\n```jq &#39;.[].value.health&#39; vm_services.json```       \r\njq: error (at vm_services.json:432): Cannot index array with string &quot;value&quot;\r\n\r\n```jq &#39;.[] | .value.health&#39; vm_services.json```     \r\njq: error (at vm_services.json:432): Cannot index array with string &quot;value&quot;",
        "link": "https://stackoverflow.com/questions/69316726/need-help-parsing-json-output-with-jq",
        "title": "Need help parsing json output with jq"
    },
    {
        "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": 1632563872,
                "post_id": 69324998,
                "comment_id": 122530474,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632564950,
                "post_id": 69324998,
                "comment_id": 122530681,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 22553865,
                    "reputation": 79,
                    "user_id": 16742581,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e417ad09ffa39504955a1aeca59bfc2f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "dogman",
                    "link": "https://stackoverflow.com/users/16742581/dogman"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632565035,
                "post_id": 69324998,
                "comment_id": 122530694,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1632563655,
        "creation_date": 1632563509,
        "last_edit_date": 1632563655,
        "question_id": 69324998,
        "body_markdown": "If I have a list like:\r\n\r\n```json\r\n{\r\n  &quot;animals&quot;: [\r\n    &quot;wolf&quot;,\r\n    &quot;bear&quot;,\r\n    &quot;cat&quot;,\r\n    &quot;lion&quot;,\r\n    &quot;snake&quot;,\r\n    &quot;tortise&quot;,\r\n    &quot;squirrel&quot;\r\n  ]\r\n}\r\n```\r\n\r\nand I want to remove &quot;bear&quot; from the list. I found I can use:\r\n\r\n```\r\njq &#39;del( .animals[1] )&#39; animals.json\r\n```\r\n\r\nWhat if I want to remove a value by it&#39;s value name ie &quot;bear&quot;?",
        "link": "https://stackoverflow.com/questions/69324998/remove-a-value-in-a-list-with-jq",
        "title": "Remove a value in a list with jq"
    },
    {
        "tags": [
            "json",
            "bash",
            "curl",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 31164,
                    "reputation": 398080,
                    "user_id": 85371,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/6d52c235ec6dd15f30bab444103e7af2?s=256&d=identicon&r=PG",
                    "display_name": "sehe",
                    "link": "https://stackoverflow.com/users/85371/sehe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632570809,
                "post_id": 69325868,
                "comment_id": 122531820,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9023324,
                    "reputation": 3225,
                    "user_id": 6737245,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47c5207e6297e9ddc5f5c65cc1424664?s=256&d=identicon&r=PG",
                    "display_name": "user630702",
                    "link": "https://stackoverflow.com/users/6737245/user630702"
                },
                "reply_to_user": {
                    "account_id": 31164,
                    "reputation": 398080,
                    "user_id": 85371,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/6d52c235ec6dd15f30bab444103e7af2?s=256&d=identicon&r=PG",
                    "display_name": "sehe",
                    "link": "https://stackoverflow.com/users/85371/sehe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632571056,
                "post_id": 69325868,
                "comment_id": 122531872,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9023324,
                    "reputation": 3225,
                    "user_id": 6737245,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47c5207e6297e9ddc5f5c65cc1424664?s=256&d=identicon&r=PG",
                    "display_name": "user630702",
                    "link": "https://stackoverflow.com/users/6737245/user630702"
                },
                "reply_to_user": {
                    "account_id": 31164,
                    "reputation": 398080,
                    "user_id": 85371,
                    "user_type": "registered",
                    "accept_rate": 43,
                    "profile_image": "https://www.gravatar.com/avatar/6d52c235ec6dd15f30bab444103e7af2?s=256&d=identicon&r=PG",
                    "display_name": "sehe",
                    "link": "https://stackoverflow.com/users/85371/sehe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632571086,
                "post_id": 69325868,
                "comment_id": 122531876,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 49492,
                    "reputation": 316217,
                    "user_id": 147356,
                    "user_type": "registered",
                    "accept_rate": 54,
                    "profile_image": "https://www.gravatar.com/avatar/b9506717d24256a090524dd5505d3207?s=256&d=identicon&r=PG",
                    "display_name": "larsks",
                    "link": "https://stackoverflow.com/users/147356/larsks"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1632571528,
                "post_id": 69325868,
                "comment_id": 122531952,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9023324,
                    "reputation": 3225,
                    "user_id": 6737245,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47c5207e6297e9ddc5f5c65cc1424664?s=256&d=identicon&r=PG",
                    "display_name": "user630702",
                    "link": "https://stackoverflow.com/users/6737245/user630702"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632571611,
                "post_id": 69325868,
                "comment_id": 122531965,
                "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": 1632571861,
                "post_id": 69325868,
                "comment_id": 122532018,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9023324,
                    "reputation": 3225,
                    "user_id": 6737245,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/47c5207e6297e9ddc5f5c65cc1424664?s=256&d=identicon&r=PG",
                    "display_name": "user630702",
                    "link": "https://stackoverflow.com/users/6737245/user630702"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632572077,
                "post_id": 69325868,
                "comment_id": 122532073,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1632571285,
        "creation_date": 1632570617,
        "last_edit_date": 1632571285,
        "question_id": 69325868,
        "body_markdown": "I have a bash variable `FPR_LOW` which is a multiline content. I want to convert this variable into JSON string so it can be used with curl.\r\n\r\noutput of variable: echo $FPR_LOW \r\n\r\n    Issue counts by category:\r\n    \r\n     &quot;J2EE Bad Practices: Leftover Debug Code&quot; =&gt; 1 Issues\r\n         ApiApplication.java:23 (Structural)\r\n     &quot;Poor Error Handling: Overly Broad Throws&quot; =&gt; 3 Issues\r\n         controller/BanksController.java:27 (Structural)\r\n         controller/BanksController.java:40 (Structural)\r\n         controller/BanksController.java:51 (Structural)\r\n\r\nHow can I convert this variable into a JSON string using jq so there is no issue when uploading through curl body?\r\n\r\n`curl ....  -d &#39;{ &quot;body&quot;: \\&#39;${JSON_FPR_LOW}\\&#39; }&#39;`",
        "link": "https://stackoverflow.com/questions/69325868/convert-bash-variable-into-json-string-using-jq",
        "title": "Convert bash variable into JSON string using JQ"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 294314,
                    "reputation": 4853,
                    "user_id": 598141,
                    "user_type": "registered",
                    "accept_rate": 44,
                    "profile_image": "https://www.gravatar.com/avatar/3364694d6c19de60221616ab2ba3cb22?s=256&d=identicon&r=PG",
                    "display_name": "Ian W",
                    "link": "https://stackoverflow.com/users/598141/ian-w"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632715404,
                "post_id": 69327062,
                "comment_id": 122558333,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1632632693,
                "last_edit_date": 1632632693,
                "creation_date": 1632595389,
                "answer_id": 69329053,
                "question_id": 69327062,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Pass the value as a `jq` variable (and tell it not to expect input):\r\n\r\n```sh\r\njq -n --arg fpr &quot;$FPR_LOW&quot; &#39;$fpr&#39;\r\n```",
                "title": "Convert mutliline shell variable to JSON string"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632632693,
        "creation_date": 1632579956,
        "last_edit_date": 1632589027,
        "question_id": 69327062,
        "body_markdown": "How can I convert a multiline variable with special characters into a JSON string using JQ?\r\n```\r\n$ echo $FPR_LOW\r\n4 issues of 4 matched search query.\r\n\r\nIssue counts by category:\r\n\r\n J2EE Bad Practices: Leftover Debug Code =&gt; 1 Issues\r\n     ApiApplication.java:23 (Structural)\r\n Poor Error Handling: Overly Broad Throws =&gt; 3 Issues\r\n     controller/BanksController.java:27 (Structural)\r\n     controller/BanksController.java:40 (Structural)\r\n     controller/BanksController.java:51 (Structural)\r\n```\r\nThe above string variable should be a single JSON string.",
        "link": "https://stackoverflow.com/questions/69327062/convert-mutliline-shell-variable-to-json-string",
        "title": "Convert mutliline shell variable to JSON string"
    },
    {
        "tags": [
            "json",
            "logging",
            "error-handling",
            "command-line-interface",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 8,
                "is_accepted": false,
                "score": 8,
                "last_activity_date": 1632651963,
                "last_edit_date": 1632651963,
                "creation_date": 1632650285,
                "answer_id": 69333773,
                "question_id": 69333650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To skip the broken lines you could use:\r\n\r\n    jq -Rr &#39;fromjson? | .message&#39;\r\n\r\n\r\nIf you want to do something else with them, you could start with something like:\r\n\r\n    jq -R &#39;. as $line | try fromjson catch $line&#39;\r\n\r\nFor other options, see:\r\n\r\n&gt; &#119928;: Is there a way to have jq keep going after it hits an error in the input file? Can jq handle broken JSON?\r\n\r\nin the [jq FAQ][1].\r\n\r\n\r\n  [1]: https://github.com/stedolan/jq/wiki/FAQ",
                "title": "How to ignore broken JSON line in jq?"
            },
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1632652238,
                "last_edit_date": 1632652238,
                "creation_date": 1632651957,
                "answer_id": 69333974,
                "question_id": 69333650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A few more explanations to peak&#39;s answer. (Credits go to peak)\r\n\r\nSolution #1:\r\n\r\n```bash\r\n❯ cat bad.json | jq -r -R &#39;fromjson? | .message&#39;\r\nsent send binary to ws server1\r\nsent send binary to ws server2\r\nsent send binary to ws server4\r\nsent send binary to ws server5\r\n```\r\n\r\nSolution #2:\r\n\r\n```bash\r\n❯ cat bad.json | jq -r -R &#39;. as $line | try fromjson catch $line | .message&#39;\r\nsent send binary to ws server1\r\nsent send binary to ws server2\r\njq: error (at &lt;stdin&gt;:3): Cannot index string with string &quot;message&quot;\r\nsent send binary to ws server4\r\nsent send binary to ws server5\r\n```\r\n\r\njq still output errors, but it&#39;s on stderr, and you can redirect it:\r\n\r\n```bash\r\n❯ cat bad.json | jq -r -R &#39;. as $line | try fromjson catch $line | .message&#39; 2&gt;/dev/null\r\nsent send binary to ws server1\r\nsent send binary to ws server2\r\nsent send binary to ws server4\r\nsent send binary to ws server5\r\n```\r\n\r\nIt&#39;s notable that it `-R` and`-r` can be used together. (Thanks for @peak !)",
                "title": "How to ignore broken JSON line in jq?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -1,
                "last_activity_date": 1680553639,
                "creation_date": 1680553639,
                "answer_id": 75923522,
                "question_id": 69333650,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I also came across this issue. Briefly, here&#39;s our setup:\r\n\r\n- Kubernets / AKS\r\n- Datadog for log collection \r\n- Maven for Java Spring Boot with `logstash-logback-encoder` dependency\r\n\r\nNow `kubectl` logs become pretty unreadable on the commandline. However, I think debugging in the terminal still has its advantages. So here&#39;s my most loved one-line solution for more or less resilient live tailing from a kubernetes pod and quick debugging:\r\n\r\n`kubectl logs -f --tail 200 &lt;podname&gt; | jq -R &#39;fromjson? | . | &quot;\\(.[&quot;@timestamp&quot;]) -- \\(.level) -- \\(.logger_name) -- \\(.message) \\(.stack_trace)&quot;&#39; -r`\r\n\r\nThis will ignore/hide lines with parse errors and show some of the JSON fields of each log line using the format string above.\r\n\r\nIt&#39;s not perfect, but will serve as a starting point I guess. Adapt to your needs :-)",
                "title": "How to ignore broken JSON line in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 6,
        "last_activity_date": 1680553639,
        "creation_date": 1632649509,
        "last_edit_date": 1632650916,
        "question_id": 69333650,
        "body_markdown": "When using `jq` to handle log files, some lines might be broken, therefore `jq` throws errors and stop processing.\r\n\r\ne.g. the complete log:\r\n\r\n```json\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.140+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server1&quot;,&quot;pid&quot;:41491,&quot;cid&quot;:&quot;32likw&quot;,&quot;num&quot;:1,&quot;count&quot;:5120}\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.305+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server2&quot;,&quot;pid&quot;:41491,&quot;cid&quot;:&quot;32likw&quot;,&quot;num&quot;:1,&quot;count&quot;:5120}\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.469+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server3&quot;,&quot;pid&quot;:41491,&quot;cid&quot;:&quot;32likw&quot;,&quot;num&quot;:1,&quot;count&quot;:5120}\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.499+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server4&quot;,&quot;pid&quot;:41491,&quot;cid&quot;:&quot;32likw&quot;,&quot;num&quot;:1,&quot;count&quot;:5120}\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.581+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server5&quot;,&quot;pid&quot;:41491,&quot;cid&quot;:&quot;32likw&quot;,&quot;num&quot;:1,&quot;count&quot;:5120}\r\n```\r\n\r\njq handles it well:\r\n\r\n```bash\r\n&lt; snippet1.json jq -C -r &#39;.message&#39;\r\nsent send binary to ws server1\r\nsent send binary to ws server2\r\nsent send binary to ws server3\r\nsent send binary to ws server4\r\nsent send binary to ws server5\r\n```\r\n\r\nthe broken one (last part of line 3 is missing):\r\n```json\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.140+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server1&quot;,&quot;pid&quot;:41491,&quot;cid&quot;:&quot;32likw&quot;,&quot;num&quot;:1,&quot;count&quot;:5120}\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.305+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server2&quot;,&quot;pid&quot;:41491,&quot;cid&quot;:&quot;32likw&quot;,&quot;num&quot;:1,&quot;count&quot;:5120}\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.469+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server3&quot;,&quot;pi\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.499+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server4&quot;,&quot;pid&quot;:41491,&quot;cid&quot;:&quot;32likw&quot;,&quot;num&quot;:1,&quot;count&quot;:5120}\r\n{&quot;level&quot;:&quot;debug&quot;,&quot;time&quot;:&quot;2021-09-24T19:42:47.581+0800&quot;,&quot;message&quot;:&quot;sent send binary to ws server5&quot;,&quot;pid&quot;:41491,&quot;cid&quot;:&quot;32likw&quot;,&quot;num&quot;:1,&quot;count&quot;:5120}\r\n```\r\n\r\n`jq` stops at the broken line:\r\n\r\n```bash\r\n&lt; snippet2.json jq -C -r &#39;.message&#39;\r\nsent send binary to ws server1\r\nsent send binary to ws server2\r\nparse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 4, column 2\r\n```\r\n\r\nAnd I hope `jq` can ignore the 3rd line and continue, just like this:\r\n\r\n```bash\r\n&lt; snippet2.json jq -C -r &#39;.message&#39;\r\nsent send binary to ws server1\r\nsent send binary to ws server2\r\nsent send binary to ws server4\r\nsent send binary to ws server5\r\n```\r\n\r\nI tried to use `-R` mentioned in [another post](https://stackoverflow.com/questions/41599314/ignore-unparseable-json-with-jq), it didn&#39;t help with this case.\r\n\r\n```bash\r\n&lt; snippet2.json jq -C -R -r &#39;.message&#39;\r\njq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;message&quot;\r\njq: error (at &lt;stdin&gt;:2): Cannot index string with string &quot;message&quot;\r\njq: error (at &lt;stdin&gt;:3): Cannot index string with string &quot;message&quot;\r\njq: error (at &lt;stdin&gt;:4): Cannot index string with string &quot;message&quot;\r\njq: error (at &lt;stdin&gt;:5): Cannot index string with string &quot;message&quot;\r\n```\r\n\r\nCan you please let me know if there is any solutions/skills to ignore/skip/suppress errors like this and get result of the rest?\r\n",
        "link": "https://stackoverflow.com/questions/69333650/how-to-ignore-broken-json-line-in-jq",
        "title": "How to ignore broken JSON line in jq?"
    },
    {
        "tags": [
            "json",
            "list",
            "insert",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1632738625,
                "creation_date": 1632738625,
                "answer_id": 69345110,
                "question_id": 69344994,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `|=` instead of `|`. It updates the object rather than just taking it as next input (just like you used `+=` not just `+` later on).\r\n\r\n    jq &#39;.parent.&quot;child-list&quot; |= map(select(.&quot;usecase&quot;==&quot;second&quot;) += { &quot;result&quot;: &quot;SUCCESS&quot; })&#39; base.json",
                "title": "Add new element to existing JSON to a specific list element with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632738625,
        "creation_date": 1632738065,
        "question_id": 69344994,
        "body_markdown": "I have an already existing json, in which I have to add a new element to a list element which has a specific key-value pair. For example:\r\n```\r\n{\r\n  &quot;parent&quot;: {\r\n    &quot;child-list&quot;: [\r\n      {\r\n        &quot;usecase&quot;: &quot;first&quot;\r\n      },\r\n      {\r\n        &quot;usecase&quot;: &quot;second&quot;\r\n      },\r\n      {\r\n        &quot;usecase&quot;: &quot;third&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nSo I would like to have this as result:\r\n```\r\n{\r\n  &quot;parent&quot;: {\r\n    &quot;child-list&quot;: [\r\n      {\r\n        &quot;usecase&quot;: &quot;first&quot;\r\n      },\r\n      {\r\n        &quot;usecase&quot;: &quot;second&quot;,\r\n        &quot;result&quot;: &quot;SUCCESS&quot;\r\n      },\r\n      {\r\n        &quot;usecase&quot;: &quot;third&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nI&#39;ve tried this:\r\n```\r\njq &#39;.parent.&quot;child-list&quot; | map(select(.&quot;usecase&quot;==&quot;second&quot;) += { &quot;result&quot;: &quot;SUCCESS&quot; })&#39; base.json\r\n```\r\nBut it prints only the &#39;child-list&#39; not the whole json.",
        "link": "https://stackoverflow.com/questions/69344994/add-new-element-to-existing-json-to-a-specific-list-element-with-jq",
        "title": "Add new element to existing JSON to a specific list element with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632761523,
                "last_edit_date": 1632761523,
                "creation_date": 1632760323,
                "answer_id": 69350181,
                "question_id": 69349328,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This implements the requirements as I understand them:\r\n```\r\njq  --arg updateName &quot;user4&quot; --arg updateVal &quot;root&quot; &#39;\r\n  .environment |= \r\n       if any(.[]; .name == $updateName)\r\n       then map(if .name == $updateName then .value = $updateVal else . end)\r\n       else (. + [{&quot;name&quot;: $updateName, &quot;value&quot;: $updateVal}] )\r\n       end&#39; input.json\r\n       \r\n```",
                "title": "Adding new JSON fields using jq when value not matched"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1632823780,
                "last_edit_date": 1632823780,
                "creation_date": 1632762876,
                "answer_id": 69350737,
                "question_id": 69349328,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Do you care about the order of the elements in the array to be modified?\r\n\r\n## No, the array is unordered ##\r\n\r\nTake an array of only those elements that do not match (`map(select(.name != $name))`) and unconditionally add an element with the new data to it (`+ [{$name,$value}]`). That way, an existing element gets deleted if and only if it matches, and a new one is added in any case. The one added (or updated) will always be at the array&#39;s final position, not at any &#39;deleted position&#39;.\r\n\r\n    jq --arg name &quot;user4&quot; --arg value &quot;root&quot;  &#39;\r\n      \r\n      .environment |= map(select(.name != $name)) + [{$name,$value}]\r\n    \r\n    &#39; envt.json\r\n\r\n## Yes, the array is ordered ##\r\n\r\nIf the array is ordered, only a truly new element should be added at the end of the array, while updated elements should be replaced at their original positions within the array.\r\n\r\nFor this, we don&#39;t update the whole array as before (`.environment |= …`), just certain elements that matter (`(.environment | …) |= …`). If there are elements matching the condition (`(.[] | select(.name == $name))`), they matter, otherwise (`//`) the element at position `length` (past the end of the array, thus new, as indices go from `0` to only `length-1`) is the one that matters. Whichever elements get through, they will be updated with the data provided (`|= {$name,$value}`):\r\n\r\n    jq --arg name &quot;user4&quot; --arg value &quot;root&quot;  &#39;\r\n      \r\n      (.environment | ((.[] | select(.name == $name)) // .[length])) |= {$name,$value}\r\n    \r\n    &#39; envt.json\r\n\r\n----------\r\n\r\nSidenote: I also renamed the input variables to `$name` and `$value` (according to the future field names) in order to simplify creating the new object as `{$name,$value}`.\r\n\r\n",
                "title": "Adding new JSON fields using jq when value not matched"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1632837185,
        "creation_date": 1632756731,
        "last_edit_date": 1632837185,
        "question_id": 69349328,
        "body_markdown": "I have below sample json \r\n```\r\n{\r\n  &quot;environment&quot;: [\r\n        {\r\n      &quot;name&quot;: &quot;user1&quot;,\r\n      &quot;value&quot;: &quot;app&quot;\r\n    },\r\n            {\r\n      &quot;name&quot;: &quot;user2&quot;,\r\n      &quot;value&quot;: &quot;admin&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;user3&quot;,\r\n      &quot;value&quot;: &quot;db&quot;\r\n    }\r\n\r\n\r\n  ]\r\n}\r\n```\r\nI need to update the value with new value (passed as an input argument to the script) when name exists. If different name and value are given, need to append them as new fields in the end.\r\nFor example, if name=user4 and value=root then my new json should look like this \r\n```\r\n{\r\n  &quot;environment&quot;: [\r\n        {\r\n      &quot;name&quot;: &quot;user1&quot;,\r\n      &quot;value&quot;: &quot;app&quot;\r\n    },\r\n            {\r\n      &quot;name&quot;: &quot;user2&quot;,\r\n      &quot;value&quot;: &quot;admin&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;user3&quot;,\r\n      &quot;value&quot;: &quot;db&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;user4&quot;,\r\n      &quot;value&quot;: &quot;root&quot;\r\n    }\r\n\r\n  ]\r\n}\r\n```\r\nIf existing values given as user3, aws then it has to update the value of user3 as follows\r\n```\r\n{\r\n  &quot;environment&quot;: [\r\n        {\r\n      &quot;name&quot;: &quot;user1&quot;,\r\n      &quot;value&quot;: &quot;app&quot;\r\n    },\r\n            {\r\n      &quot;name&quot;: &quot;user2&quot;,\r\n      &quot;value&quot;: &quot;admin&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;user3&quot;,\r\n      &quot;value&quot;: &quot;aws&quot;\r\n    }\r\n\r\n\r\n  ]\r\n}\r\n```\r\nIts working as expected but only has the below problem.\r\nWhen my JSON has any extra tags before environment tag, after execution of command, those are getting trimmed off and next time when I run same command with different inputs, It won&#39;t find the previous existing tag and giving this error ``` Cannot iterate over null (null)``` \r\nWith the below command that is given by peak, taskDefinition &amp; containerDefinitions tags are getting trimmed off. Hence please help me to have these tags in place.\r\n\r\n```\r\n jq  --arg updateName &quot;user5&quot; --arg updateVal &quot;admin&quot; &#39;\r\n  .taskDefinition | .containerDefinitions[] | .environment |=\r\n       if any(.[]; .name == $updateName)\r\n       then map(if .name == $updateName then .value = $updateVal else . end)\r\n       else (. + [{&quot;name&quot;: $updateName, &quot;value&quot;: $updateVal}] )\r\n       end&#39; envt_values1.json\r\n```\r\n```\r\n{\r\n\t&quot;taskDefinition&quot;: {\r\n\t\t&quot;containerDefinitions&quot;: [\r\n\t\t\t{\r\n\t\t\t  &quot;environment&quot;: [\r\n\t\t\t\t{\r\n\t\t\t\t  &quot;name&quot;: &quot;user1&quot;,\r\n\t\t\t\t  &quot;value&quot;: &quot;app&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t  &quot;name&quot;: &quot;user2&quot;,\r\n\t\t\t\t  &quot;value&quot;: &quot;admin&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t  &quot;name&quot;: &quot;user3&quot;,\r\n\t\t\t\t  &quot;value&quot;: &quot;aws&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{\r\n\t\t\t\t  &quot;name&quot;: &quot;user4&quot;,\r\n\t\t\t\t  &quot;value&quot;: &quot;root&quot;\r\n\t\t\t\t},\r\n\t\t\t\t{}\r\n\t\t\t  ],\r\n\t\t\t  &quot;configuration&quot;: []\r\n\t\t\t}\r\n\t\t]\r\n\t}\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/69349328/adding-new-json-fields-using-jq-when-value-not-matched",
        "title": "Adding new JSON fields using jq when value not matched"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1632812893,
                "creation_date": 1632812893,
                "answer_id": 69357212,
                "question_id": 69356930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With your input, the following jq program produces results which are very similar to what you indicated is expected:\r\n```\r\n.result[0]\r\n| [&quot;COMMENT&quot;, .name, .dbno],\r\n  ([&quot;SPOT&quot;, &quot;addr&quot;, &quot;\\\\@lbl&quot;] + .address),\r\n  ( .segments[].lines[].products[] as $p\r\n   | (([&quot;TABLE&quot;] + [$p[]]),\r\n      [&quot;BREAK&quot;])),\r\n  [&quot;FLUSH&quot;]\r\n\r\n| join(&quot;|&quot;)\r\n```\r\n\r\nNamely:\r\n```\r\nCOMMENT|Petes corner store|201449\r\nSPOT|addr|\\@lbl|LOCKED BAY 222|Sydney|9876\r\nTABLE|Product 1|2|4.62|9.24\r\nBREAK\r\nTABLE|Prod desc 2|18|0.12|2.16\r\nBREAK\r\nTABLE|Product 3|3|4.00|12.00\r\nBREAK\r\nFLUSH\r\n```\r\n\r\nIf the ordering of the keys in the product detail objects might not be the same, then you will probably want to specify the order rather than using `[$p[]]`.\r\n\r\n",
                "title": "Using jq as a non json formatter"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1632888734,
                "creation_date": 1632888734,
                "answer_id": 69370315,
                "question_id": 69356930,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Many thanks for taking the time to reply.\r\n\r\nWith the syntax tips given I was able to create a script that is doing exactly what I require. It has the BREAK lines correctly set only after each line array and it will work with multiple .result records in the array. \r\n```\r\n.result\r\n| keys[] as $c\r\n|\r\n  [&quot;COMMENT&quot;, (.[$c] | &quot;\\(.name), \\(.dbno)&quot; )],\r\n  [&quot;SPOT&quot;, &quot;addr&quot;,&quot;\\\\@lbl&quot;] + (.[$c].address),\r\n  (\r\n    (.[$c].segments | keys[]) as $s |\r\n\t  (.[$c].segments[$s].lines | keys[]) as $l |\r\n \t    (.[$c].segments[$s].lines[$l].products | keys[]) as $p |\r\n\t\t  (if $p &gt; 0 then [&quot;BREAK&quot;] else empty end),\r\n \t\t  [\r\n\t\t    &quot;TABLE&quot;,\r\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].name,\r\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].qty,\r\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].price_ea,\r\n\t\t\t.[$c].segments[$s].lines[$l].products[$p].extended\r\n\t\t\t]\r\n  ),\r\n[&quot;FLUSH&quot;]\r\n| join(&quot;|&quot;)\r\n```\r\nThere may be some optimizing that could be performed but this gives me a good foothold to work off.\r\n",
                "title": "Using jq as a non json formatter"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1632901767,
        "creation_date": 1632811444,
        "last_edit_date": 1632901767,
        "question_id": 69356930,
        "body_markdown": "I have some json input that looks like:\r\n```\r\n{\r\n  &quot;vers&quot;: &quot;2.0&quot;,\r\n  &quot;result&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;Petes corner store&quot;,\r\n      &quot;address&quot;: [\r\n        &quot;LOCKED BAY 222&quot;,\r\n        &quot;Sydney&quot;,\r\n        &quot;9876&quot;\r\n      ],\r\n      &quot;dbno&quot;: &quot;201449&quot;,\r\n      &quot;segments&quot;: [\r\n        {\r\n          &quot;val&quot;: &quot;23.40&quot;,\r\n          &quot;lines&quot;: [\r\n            {\r\n              &quot;val&quot;: &quot;11.40&quot;,\r\n              &quot;products&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Product 1&quot;,\r\n                  &quot;qty&quot;: &quot;2&quot;,\r\n                  &quot;price_ea&quot;: &quot;4.62&quot;,\r\n                  &quot;extended&quot;: &quot;9.24&quot;\r\n                },\r\n                {\r\n                  &quot;name&quot;: &quot;Prod desc 2&quot;,\r\n                  &quot;qty&quot;: &quot;18&quot;,\r\n                  &quot;price_ea&quot;: &quot;0.12&quot;,\r\n                  &quot;extended&quot;: &quot;2.16&quot;\r\n                }\r\n              ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;val&quot;: &quot;16.00&quot;,\r\n          &quot;lines&quot;: [\r\n            {\r\n              &quot;val&quot;: &quot;16.00&quot;,\r\n              &quot;products&quot;: [\r\n                {\r\n                  &quot;name&quot;: &quot;Product 3&quot;,\r\n                  &quot;qty&quot;: &quot;3&quot;,\r\n                  &quot;price_ea&quot;: &quot;4.00&quot;,\r\n                  &quot;extended&quot;: &quot;12.00&quot;\r\n                }\r\n              ]\r\n            }\r\n\t\t  ]\r\n\t\t}  \r\n      ]\r\n    }\r\n  ],\r\n  &quot;id&quot;: 1\r\n}\r\n```\r\nThe data has a variable length of result, segments and lines arrays. I am trying to format the non json output to look something like:\r\n```\r\nCOMMENT|Petes corner store|201449\r\nSPOT|addr|\\@lbl|LOCKED BAY 222|Sydney|9876\r\nTABLE|Product 1|2|4.62|9.24\r\nTABLE|Prod desc 2|18|0.12|2.16\r\nBREAK\r\nTABLE|Product 3|3|4.00|12.00\r\nBREAK\r\nFLUSH\r\n```\r\nWhere the TABLE entries are a list of the extracted segments[].lines[].products[] kept in the same order with a divider between each segment. I was trying to use a single jq script to do the whole job that is basically:\r\n```\r\n.result |\r\nkeys[] as $k |\r\n&quot;COMMENT|\\(.[$k] | &quot;\\(.name)|\\(.dbno)&quot;  )\r\nSPOT|addr|\\\\@lbl|\\(.[$k].address  | join(&quot;|&quot;) )\r\nTABLE|Cant figure this out...\r\nFLUSH\r\n&quot;\r\n```\r\nI thought this would be a good time to learn jq as I have written this in bourne shell and it works but its not very elegant. \r\nSo, any pointers on getting my TABLE entries working??",
        "link": "https://stackoverflow.com/questions/69356930/using-jq-as-a-non-json-formatter",
        "title": "Using jq as a non json formatter"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632829417,
                "creation_date": 1632829417,
                "answer_id": 69361113,
                "question_id": 69360712,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `transpose` to generate an array of arrays with one element of each input array.\r\n\r\n    [.title,.link] | transpose | map({title:.[0],link:.[1]})",
                "title": "jq: combine multi array in dict without permutate"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632829417,
        "creation_date": 1632827786,
        "question_id": 69360712,
        "body_markdown": "&gt; are there have any way to achieve simply as expected?\r\n&gt; \r\n&gt; it using combine with permutate in default.\r\n\r\nThe Following Case\r\n\r\n**source**\r\n```json\r\n{\r\n    &quot;title&quot;:[&quot;title1&quot;,&quot;title2&quot;],\r\n    &quot;link&quot;:[&quot;http://testapi.cn&quot;,&quot;http://testapi.org&quot;]\r\n}\r\n```\r\n\r\n**expression** `[{title:.title[],link:.link[]}]`\r\n\r\n**console**\r\n```json\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;title1&quot;,\r\n    &quot;link&quot;: &quot;http://testapi.cn&quot;\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;title1&quot;,\r\n    &quot;link&quot;: &quot;http://testapi.org&quot;\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;title2&quot;,\r\n    &quot;link&quot;: &quot;http://testapi.cn&quot;\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;title2&quot;,\r\n    &quot;link&quot;: &quot;http://testapi.org&quot;\r\n  }\r\n]\r\n```\r\n**expected**\r\n```json\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;title1&quot;,\r\n    &quot;link&quot;: &quot;http://testapi.cn&quot;\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;title2&quot;,\r\n    &quot;link&quot;: &quot;http://testapi.org&quot;\r\n  }\r\n]\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/69360712/jq-combine-multi-array-in-dict-without-permutate",
        "title": "jq: combine multi array in dict without permutate"
    },
    {
        "tags": [
            "arrays",
            "json",
            "object",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1632834893,
                "creation_date": 1632834893,
                "answer_id": 69362444,
                "question_id": 69362205,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want full control over the output, I&#39;d just re-create the desired format.\r\n\r\nIt sounds like you&#39;re trying to accieve the following format:\r\n```json\r\n{\r\n  &quot;entries&quot;: [\r\n    {\r\n      &quot;sys&quot;: {\r\n        &quot;id&quot;: ...\r\n      },\r\n      &quot;contentType&quot;: {\r\n        &quot;sys&quot;: {\r\n          &quot;id&quot;: ...\r\n        }\r\n      },\r\n      &quot;fields&quot;: ...\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nWe can achieve this by using the following JQ selector:\r\n```none\r\n.entries |= map({ &quot;sys&quot;: { &quot;id&quot;: .sys.id }, &quot;contentType&quot;: { &quot;sys&quot;: { &quot;id&quot;: .sys.contentType.sys.id } }, fields })\r\n```\r\n\r\n##### [Try it online](https://jqplay.org/s/ljQeBL-eJp)!",
                "title": "JQ: Remove json objects from array"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632834893,
        "creation_date": 1632833904,
        "question_id": 69362205,
        "body_markdown": "I have this json file with hundreds of entries that I need to strip from data I do not need. \r\nSnippet:\r\n\r\n    {\r\n      &quot;entries&quot;: [\r\n        {\r\n          &quot;metadata&quot;: {\r\n            &quot;tags&quot;: [\r\n            ]\r\n          },\r\n          &quot;sys&quot;: {\r\n            &quot;space&quot;: {\r\n              &quot;sys&quot;: {\r\n                &quot;type&quot;: &quot;Link&quot;,\r\n                &quot;linkType&quot;: &quot;Space&quot;,\r\n                &quot;id&quot;: &quot;9kn72w8zc6fh&quot;\r\n              }\r\n            },\r\n            &quot;id&quot;: &quot;vcLKKhJ3mZNfGMvVZZi07&quot;,\r\n            &quot;type&quot;: &quot;Entry&quot;,\r\n            &quot;createdAt&quot;: &quot;2021-05-20T15:14:01.358Z&quot;,\r\n            &quot;updatedAt&quot;: &quot;2021-09-20T15:28:30.799Z&quot;,\r\n            &quot;environment&quot;: {\r\n              &quot;sys&quot;: {\r\n                &quot;id&quot;: &quot;production&quot;,\r\n                &quot;type&quot;: &quot;Link&quot;,\r\n                &quot;linkType&quot;: &quot;Environment&quot;\r\n              }\r\n            },\r\n            &quot;publishedVersion&quot;: 47,\r\n            &quot;publishedAt&quot;: &quot;2021-09-20T15:28:30.799Z&quot;,\r\n            &quot;firstPublishedAt&quot;: &quot;2021-05-25T10:26:56.722Z&quot;,\r\n            &quot;createdBy&quot;: {\r\n              &quot;sys&quot;: {\r\n                &quot;type&quot;: &quot;Link&quot;,\r\n                &quot;linkType&quot;: &quot;User&quot;,\r\n                &quot;id&quot;: &quot;6F84RwUIY9cXNNXBoQemqX&quot;\r\n              }\r\n            },\r\n            &quot;updatedBy&quot;: {\r\n              &quot;sys&quot;: {\r\n                &quot;type&quot;: &quot;Link&quot;,\r\n                &quot;linkType&quot;: &quot;User&quot;,\r\n                &quot;id&quot;: &quot;6F84RwUIY9cXNNXBoQemqX&quot;\r\n              }\r\n            },\r\n            &quot;publishedCounter&quot;: 4,\r\n            &quot;version&quot;: 48,\r\n            &quot;publishedBy&quot;: {\r\n              &quot;sys&quot;: {\r\n                &quot;type&quot;: &quot;Link&quot;,\r\n                &quot;linkType&quot;: &quot;User&quot;,\r\n                &quot;id&quot;: &quot;6F84RwUIY9cXNNXBoQemqX&quot;\r\n              }\r\n            },\r\n            &quot;contentType&quot;: {\r\n              &quot;sys&quot;: {\r\n                &quot;type&quot;: &quot;Link&quot;,\r\n                &quot;linkType&quot;: &quot;ContentType&quot;,\r\n                &quot;id&quot;: &quot;page&quot;\r\n              }\r\n            }\r\n          },\r\n          &quot;fields&quot;: {\r\n            &quot;title&quot;: {\r\n              &quot;de-DE&quot;: &quot;Startseite&quot;,\r\n              &quot;en-US&quot;: &quot;Home&quot;\r\n            },\r\n            &quot;description&quot;: {\r\n              &quot;en-US&quot;: &quot;foo&quot;\r\n            },\r\n            &quot;keywords&quot;: {\r\n              &quot;en-US&quot;: &quot;bar&quot;\r\n            },\r\n            &quot;stageModules&quot;: {\r\n              &quot;en-US&quot;: [\r\n                {\r\n                  &quot;sys&quot;: {\r\n                    &quot;type&quot;: &quot;Link&quot;,\r\n                    &quot;linkType&quot;: &quot;Entry&quot;,\r\n                    &quot;id&quot;: &quot;11AfBBuNK8bx3EygAS3WTY&quot;\r\n                  }\r\n                }\r\n              ]\r\n            },\r\n            &quot;contentModules&quot;: {\r\n              &quot;en-US&quot;: [\r\n                {\r\n                  &quot;sys&quot;: {\r\n                    &quot;type&quot;: &quot;Link&quot;,\r\n                    &quot;linkType&quot;: &quot;Entry&quot;,\r\n                    &quot;id&quot;: &quot;7uyuyIBsXWApHqpR7Pgkac&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;sys&quot;: {\r\n                    &quot;type&quot;: &quot;Link&quot;,\r\n                    &quot;linkType&quot;: &quot;Entry&quot;,\r\n                    &quot;id&quot;: &quot;4HILHPLjqQkP2H1hA2FeBG&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;sys&quot;: {\r\n                    &quot;type&quot;: &quot;Link&quot;,\r\n                    &quot;linkType&quot;: &quot;Entry&quot;,\r\n                    &quot;id&quot;: &quot;QuwRHL3XMSkguqrL1hUzC&quot;\r\n                  }\r\n                },\r\n                {\r\n                  &quot;sys&quot;: {\r\n                    &quot;type&quot;: &quot;Link&quot;,\r\n                    &quot;linkType&quot;: &quot;Entry&quot;,\r\n                    &quot;id&quot;: &quot;4ZyVef5oWhQWXK9V1lr3vz&quot;\r\n                  }\r\n                }\r\n              ]\r\n            },\r\n            &quot;layout&quot;: {\r\n              &quot;en-US&quot;: &quot;Wide&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\nFrom the entries array, I actually only need:\r\n\r\n - entries.sys.id \r\n - entries.sys.contentType.sys.id\r\n - entries.fields\r\n\r\nI came up with:\r\n\r\n    jq \\\r\n      &#39;.entries | .[] .sys, .[] .fields | del(.createdAt, .createdBy, .environment, .firstPublishedAt, .metadata, .publishedAt, .publishedBy, .publishedCounter, .publishedVersion, .space, .type, .updatedAt, .updatedBy, .version)&#39; \\\r\n      $infile &gt;| $outfile\r\n\r\nHowever, this changes the structure of the document. The entries node is missing (due to the `.entries filter`):\r\n\r\n    {\r\n      &quot;id&quot;: &quot;vcLKKhJ3mZNfGMvVZZi07&quot;,\r\n      &quot;contentType&quot;: {\r\n        &quot;sys&quot;: {\r\n          &quot;type&quot;: &quot;Link&quot;,\r\n          &quot;linkType&quot;: &quot;ContentType&quot;,\r\n          &quot;id&quot;: &quot;page&quot;\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;id&quot;: &quot;1UgOmHIvsWrFEf1VCa84kz&quot;,\r\n      &quot;contentType&quot;: {\r\n        &quot;sys&quot;: {\r\n          &quot;type&quot;: &quot;Link&quot;,\r\n          &quot;linkType&quot;: &quot;ContentType&quot;,\r\n          &quot;id&quot;: &quot;moduleText&quot;\r\n        }\r\n      }\r\n    }\r\n    {\r\n      &quot;title&quot;: {\r\n        &quot;de-DE&quot;: &quot;Startseite&quot;,\r\n        &quot;en-US&quot;: &quot;Home&quot;\r\n      },\r\n      &quot;description&quot;: {\r\n        &quot;en-US&quot;: &quot;Foo&quot;\r\n      },\r\n      &quot;keywords&quot;: {\r\n        &quot;en-US&quot;: &quot;Bar&quot;\r\n      },\r\n      &quot;stageModules&quot;: {\r\n        &quot;en-US&quot;: [\r\n          {\r\n            &quot;sys&quot;: {\r\n              &quot;type&quot;: &quot;Link&quot;,\r\n              &quot;linkType&quot;: &quot;Entry&quot;,\r\n              &quot;id&quot;: &quot;11AfBBuNK8bx3EygAS3WTY&quot;\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;contentModules&quot;: {\r\n        &quot;en-US&quot;: [\r\n          {\r\n            &quot;sys&quot;: {\r\n              &quot;type&quot;: &quot;Link&quot;,\r\n              &quot;linkType&quot;: &quot;Entry&quot;,\r\n              &quot;id&quot;: &quot;7uyuyIBsXWApHqpR7Pgkac&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;sys&quot;: {\r\n              &quot;type&quot;: &quot;Link&quot;,\r\n              &quot;linkType&quot;: &quot;Entry&quot;,\r\n              &quot;id&quot;: &quot;4HILHPLjqQkP2H1hA2FeBG&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;sys&quot;: {\r\n              &quot;type&quot;: &quot;Link&quot;,\r\n              &quot;linkType&quot;: &quot;Entry&quot;,\r\n              &quot;id&quot;: &quot;QuwRHL3XMSkguqrL1hUzC&quot;\r\n            }\r\n          },\r\n          {\r\n            &quot;sys&quot;: {\r\n              &quot;type&quot;: &quot;Link&quot;,\r\n              &quot;linkType&quot;: &quot;Entry&quot;,\r\n              &quot;id&quot;: &quot;4ZyVef5oWhQWXK9V1lr3vz&quot;\r\n            }\r\n          }\r\n        ]\r\n      },\r\n      &quot;layout&quot;: {\r\n        &quot;en-US&quot;: &quot;Wide&quot;\r\n      }\r\n    }\r\n\r\n\r\nI have 2 questions: \r\n\r\n 1. How can I delete deeper objects, eg. `.entries.sys.space.sys.linkType`?\r\n 2. How can I keep the .entries node in the outfile?\r\n\r\nThank you for your help.",
        "link": "https://stackoverflow.com/questions/69362205/jq-remove-json-objects-from-array",
        "title": "JQ: Remove json objects from array"
    },
    {
        "tags": [
            "json",
            "object",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6313442,
                    "reputation": 45115,
                    "user_id": 5625547,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/oqCND.jpg?s=256",
                    "display_name": "0stone0",
                    "link": "https://stackoverflow.com/users/5625547/0stone0"
                },
                "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": 1632837780,
                "post_id": 69362748,
                "comment_id": 122598148,
                "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": 1632841759,
                "post_id": 69362748,
                "comment_id": 122600174,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632839278,
                "last_edit_date": 1632839278,
                "creation_date": 1632836827,
                "answer_id": 69362964,
                "question_id": 69362748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Not exactly a short-cut alternative, but the path functions can be used for this. This assumes you know the names of the paths beforehand and know they exist\r\n\r\n```none\r\njq -n &#39;setpath( [&quot;foo&quot;, &quot;bar&quot;] ; ( inputs | getpath([&quot;foo&quot;, &quot;bar&quot;]) ) )&#39;\r\n```\r\nThe `setpath/2` function sets the value on the assigned path indicated in the first argument. The value  for the path is set from the original input using `getpath/1`\r\n\r\nYou could use the `--argjson` to pass the path as an array and use it directly as well.\r\n\r\n```none\r\njq -n --argjson p &#39;[&quot;foo&quot;, &quot;bar&quot;]&#39; &#39;setpath( $p ; ( inputs | getpath($p) ) )&#39;\r\n```\r\n\r\n  [1]: https://stedolan.github.io/jq/manual/v1.6/#getpath(PATHS)",
                "title": "Nested Object Construction JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632841927,
                "creation_date": 1632841927,
                "answer_id": 69364308,
                "question_id": 69362748,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is (quite literally) a shorter alternative that&#39;s also DRYer, though I don&#39;t think it&#39;s any clearer:\r\n\r\n    {foo} | .foo |= {bar}",
                "title": "Nested Object Construction JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1632841927,
        "creation_date": 1632836025,
        "last_edit_date": 1632837757,
        "question_id": 69362748,
        "body_markdown": "From [tag:jq]&#39;s [Types And Values Documentation](https://stedolan.github.io/jq/manual/#TypesandValues):\r\n\r\n&gt; #### Object Construction\r\n&gt; The value can be any expression (although you may need to wrap it in parentheses if, for example, it contains colons), which gets applied to the `{}` expression&#39;s input (remember, all filters have an input and an output).\r\n&gt;\r\n&gt; ```json\r\n&gt; {foo: .bar}\r\n&gt; ```\r\n&gt; [ ... ]\r\n&gt; \r\n&gt; Because that is so common, there&#39;s a **shortcut syntax** for it: `{user, title}`.\r\n\r\nSo given the following example json\r\n```json\r\n{\r\n    &quot;foo&quot;: {\r\n        &quot;bar&quot;: {\r\n            &quot;value&quot;: 42,\r\n            &quot;valid&quot;: true\r\n        },\r\n        &quot;valid&quot;: false\r\n    },\r\n    &quot;valid&quot;: false\r\n}\r\n```\r\n\r\nIf I *only* want the *complete* `foo` object (removing the outer `valid` key), I can get the desired output by using\r\n```\r\n{ foo }\r\n```\r\n&lt;sup&gt;[Demo](https://jqplay.org/s/1WJ_k3UkmG)&lt;/sup&gt;\r\n\r\n----------\r\n\r\nUnfortunately, the documentation doesn&#39;t mention any way to get the same behaviour, but for **deeper** keys, using the example above, getting an output object with just the `.foo.bar` object would look something like:  \r\n\r\n```\r\n{ &quot;foo&quot;: { &quot;bar&quot;: .foo.bar } }\r\n```\r\n&lt;sup&gt;[Demo](https://jqplay.org/s/33H-QnEiR8)&lt;/sup&gt;\r\n\r\nWhich will generate the following (desired) json output:\r\n```json\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;bar&quot;: {\r\n      &quot;value&quot;: 42,\r\n      &quot;valid&quot;: true\r\n    }\r\n  }\r\n}\r\n``` \r\n\r\n**Note** both the outer `valid` and the `.foo.valid` are missing.\r\n\r\n----------\r\n\r\nIs there any short-cut alternative for the above selector to get the same result?\r\n\r\nIdeally I&#39;d use something like:\r\n```\r\n{ foo.bar }\r\n```\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/69362748/nested-object-construction-jq",
        "title": "Nested Object Construction JQ"
    },
    {
        "tags": [
            "json",
            "twitter",
            "jq",
            "fastapi",
            "httpie"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 160509,
                    "reputation": 16272,
                    "user_id": 380625,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/OZRxx.jpg?s=256",
                    "display_name": "Jakub Roztocil",
                    "link": "https://stackoverflow.com/users/380625/jakub-roztocil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632848201,
                "post_id": 69364553,
                "comment_id": 122602783,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632852140,
                "post_id": 69364553,
                "comment_id": 122604193,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2478374,
                    "reputation": 37641,
                    "user_id": 2158479,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b5f80e7aa8246b07b48602dfa049281c?s=256&d=identicon&r=PG",
                    "display_name": "pmf",
                    "link": "https://stackoverflow.com/users/2158479/pmf"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1632852306,
                "post_id": 69364553,
                "comment_id": 122604259,
                "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": 1632858828,
                "post_id": 69364553,
                "comment_id": 122606712,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1693,
                    "reputation": 18059,
                    "user_id": 2283,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/3ac5db3768c09788ed9fe03c5f4ff171?s=256&d=identicon&r=PG",
                    "display_name": "Weeble",
                    "link": "https://stackoverflow.com/users/2283/weeble"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1632920519,
                "post_id": 69364553,
                "comment_id": 122622990,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 39208,
                    "reputation": 267964,
                    "user_id": 112968,
                    "user_type": "registered",
                    "accept_rate": 68,
                    "profile_image": "https://i.sstatic.net/zHTaT.png?s=256",
                    "display_name": "knittl",
                    "link": "https://stackoverflow.com/users/112968/knittl"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1663758664,
                "post_id": 69364553,
                "comment_id": 130313511,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1632843118,
        "creation_date": 1632843118,
        "question_id": 69364553,
        "body_markdown": "Here is a minimum example of how to catch the output of the [Twitter API Filtered Stream][1] and to send it to another API, in this case a [FastAPI] project, using `httpie` according to [an example use case in the docs][2]:\r\n\r\n    http --stream get \\\r\n        &quot;https://api.twitter.com/2/tweets/search/stream&quot; \\\r\n        &quot;Authorization: Bearer $BEARER_TOKEN&quot; |\r\n        while read -r line; do\r\n            echo &quot;$line&quot; | http post localhost:8888/posts\r\n        done\r\n\r\nThis works fine, but now I am trying to alter the output of the Twitter stream using the [command line JSON processor `jq`][3]:\r\n\r\n    http --stream get \\\r\n        &quot;https://api.twitter.com/2/tweets/search/stream&quot; \\\r\n        &quot;Authorization: Bearer $BEARER_TOKEN&quot; |\r\n        jq --compact-output --monochrome-output &#39;. | {id: .data.id, rules: .matching_rules}&#39; |\r\n        while read -r line; do\r\n            echo &quot;$line&quot; | http post localhost:8888/posts\r\n        done\r\n\r\nThis does not work, unfortunately. It does work while doing `http … | jq …` but it stops working after adding `| while …` so even when omitting the following `| http …` this does not output anything.\r\n\r\nSo I assume that `jq` somehow breaks that streaming behavior, even when using `--compact-output` to have the entire JSON string in one line and `--monochrome-output` to prevent any color issues with the shell. Why is that? How can I fix this?\r\n\r\nHow could I filter the Twitter stream otherwise?\r\n\r\n[1]: https://developer.twitter.com/en/docs/twitter-api/tweets/filtered-stream/api-reference/get-tweets-search-stream\r\n[2]: https://httpie.io/docs#example-use-cases\r\n[FastAPI]: https://fastapi.tiangolo.com\r\n[3]: https://stedolan.github.io/jq/",
        "link": "https://stackoverflow.com/questions/69364553/how-to-use-jq-between-two-httpie-calls-to-filter-a-stream-of-json-objects",
        "title": "How to use jq between two httpie calls to filter a stream of JSON objects"
    },
    {
        "tags": [
            "json",
            "sorting",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632851635,
                "creation_date": 1632851635,
                "answer_id": 69366385,
                "question_id": 69364864,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You are trying to sort the `time` object which, of course, is not possible. Sort the array instead:\r\n\r\n    jq &#39;.results |= sort_by(.request.path.time.seconds)&#39; output.json",
                "title": "How can I use jq to sort this json file by the seconds value?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632851635,
        "creation_date": 1632844292,
        "question_id": 69364864,
        "body_markdown": "I have this json data:\r\n```\r\n{\r\n    &quot;results&quot;: [\r\n        {\r\n            &quot;request&quot;: {\r\n                &quot;metric&quot;: &quot;CLOUDFREE_TIME_PERCENT&quot;, \r\n                &quot;path&quot;: {\r\n                    &quot;fromPoint&quot;: {\r\n                        &quot;pointX&quot;: -94.2802, \r\n                        &quot;pointY&quot;: 23.6687, \r\n                        &quot;pointZ&quot;: 564843.0\r\n                    }, \r\n                    &quot;time&quot;: {\r\n                        &quot;seconds&quot;: 1582074350\r\n                    }, \r\n                    &quot;toPoint&quot;: {\r\n                        &quot;pointX&quot;: -118.2258, \r\n                        &quot;pointY&quot;: 33.7501, \r\n                        &quot;pointZ&quot;: -2.6077032e-08\r\n                    }\r\n                }, \r\n                &quot;waveLength&quot;: 0\r\n            }, \r\n            &quot;response&quot;: {\r\n                &quot;dataSources&quot;: [], \r\n                &quot;metricValue&quot;: 0.0, \r\n                &quot;success&quot;: false\r\n            }\r\n        },\r\n        {\r\n            &quot;request&quot;: {\r\n                &quot;metric&quot;: &quot;CLOUDFREE_TIME_PERCENT&quot;, \r\n                &quot;path&quot;: {\r\n                    &quot;fromPoint&quot;: {\r\n                        &quot;pointX&quot;: -20.6361, \r\n                        &quot;pointY&quot;: 16.1509, \r\n                        &quot;pointZ&quot;: 563070.9\r\n                    }, \r\n                    &quot;time&quot;: {\r\n                        &quot;seconds&quot;: 1582056949\r\n                    }, \r\n                    &quot;toPoint&quot;: {\r\n                        &quot;pointX&quot;: -20.6361, \r\n                        &quot;pointY&quot;: 16.1509, \r\n                        &quot;pointZ&quot;: 563070.9\r\n                    }\r\n                }, \r\n                &quot;waveLength&quot;: 0\r\n            }, \r\n            &quot;response&quot;: {\r\n                &quot;dataSources&quot;: [], \r\n                &quot;metricValue&quot;: 0.0, \r\n                &quot;success&quot;: false\r\n            }\r\n        }, \r\n        {\r\n            &quot;request&quot;: {\r\n                &quot;metric&quot;: &quot;CLOUDFREE_TIME_PERCENT&quot;, \r\n                &quot;path&quot;: {\r\n                    &quot;fromPoint&quot;: {\r\n                        &quot;pointX&quot;: -94.2661, \r\n                        &quot;pointY&quot;: 23.6066, \r\n                        &quot;pointZ&quot;: 564826.16\r\n                    }, \r\n                    &quot;time&quot;: {\r\n                        &quot;seconds&quot;: 1582064349\r\n                    }, \r\n                    &quot;toPoint&quot;: {\r\n                        &quot;pointX&quot;: -118.2258, \r\n                        &quot;pointY&quot;: 33.7501, \r\n                        &quot;pointZ&quot;: -2.6077032e-08\r\n                    }\r\n                }, \r\n                &quot;waveLength&quot;: 0\r\n            }, \r\n            &quot;response&quot;: {\r\n                &quot;dataSources&quot;: [], \r\n                &quot;metricValue&quot;: 0.0, \r\n                &quot;success&quot;: false\r\n            }\r\n        } \r\n    ]\r\n}\r\n```\r\nI have been trying (but failing) to sort this by the &quot;seconds&quot; value. I&#39;ve tried `jq &#39;.results[].request.path.time|=sort_by(.seconds)&#39; output.json` and it gives me the error `Cannot index number with string &quot;seconds&quot;`. I&#39;ve tried all sorts of rearrangements of that command (and things like wrapping it with `map()`) as well to no avail. I&#39;m starting to doubt if it&#39;s possible. Any help would be appreciated!",
        "link": "https://stackoverflow.com/questions/69364864/how-can-i-use-jq-to-sort-this-json-file-by-the-seconds-value",
        "title": "How can I use jq to sort this json file by the seconds value?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1632863942,
                "creation_date": 1632863942,
                "answer_id": 69368592,
                "question_id": 69368460,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.[] |= add&#39;\r\n```\r\n\r\nWill generate\r\n```json\r\n{\r\n  &quot;service1&quot;: [\r\n    &quot;example1&quot;,\r\n    &quot;example2&quot;,\r\n    &quot;example3&quot;,\r\n    &quot;example4&quot;\r\n  ],\r\n  &quot;service2&quot;: [\r\n    &quot;example5&quot;,\r\n    &quot;example6&quot;,\r\n    &quot;example7&quot;,\r\n    &quot;example8&quot;\r\n  ]\r\n}\r\n```\r\n\r\nAs you can try in this [only demo](https://jqplay.org/s/oGdL6lb9Sz)\r\n\r\n\r\n----------\r\n\r\nFor `add`, please take a look at [jq&#39;s documentation](https://stedolan.github.io/jq/manual/#example33).",
                "title": "Way to remove parent and preserve children jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632863942,
        "creation_date": 1632863038,
        "question_id": 69368460,
        "body_markdown": "I have this input json as example:\r\n\r\n**INPUT**\r\n```\r\n{\r\n  &quot;service1&quot;: {\r\n    &quot;action1&quot;: [\r\n      &quot;example1&quot;\r\n    ],\r\n    &quot;action2&quot;: [\r\n      &quot;example2&quot;,\r\n      &quot;example3&quot;,\r\n      &quot;example4&quot;\r\n    ]\r\n    },\r\n  &quot;service2&quot;: {\r\n    &quot;action3&quot;: [\r\n      &quot;example5&quot;\r\n    ],\r\n    &quot;action4&quot;: [\r\n      &quot;example6&quot;,\r\n      &quot;example7&quot;,\r\n      &quot;example8&quot;\r\n    ]\r\n    }\r\n}\r\n```\r\n\r\nI need to remove parents: action1, action2, action3, action4 and preserve their children as join, is there a way to do that in jq ?\r\n\r\n**DESIRED OUTPUT**\r\n```\r\n{\r\n  &quot;service1&quot;: [\r\n      &quot;example1&quot;,\r\n      &quot;example2&quot;,\r\n      &quot;example3&quot;,\r\n      &quot;example4&quot;\r\n    ],\r\n  &quot;service2&quot;: [\r\n      &quot;example5&quot;,\r\n      &quot;example6&quot;,\r\n      &quot;example7&quot;,\r\n      &quot;example8&quot;\r\n    ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/69368460/way-to-remove-parent-and-preserve-children-jq",
        "title": "Way to remove parent and preserve children jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1632867284,
                "last_edit_date": 1632867284,
                "creation_date": 1632866984,
                "answer_id": 69368999,
                "question_id": 69368874,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Convert all entries to an object with key/value fields using `to_entries`, retain only those objects that do match your conditions (in the `.value`&#39;s object `.language` the value of a field `$lang` provided as input variable using `--arg` equals `any` one of `&quot;spoken&quot;` or `&quot;perhaps&quot;`) and output the original entry&#39;s `.key`.\r\n\r\n    jq -r --arg lang &quot;fr&quot; &#39;\r\n      \r\n      to_entries[]\r\n      | select([.value.language[$lang] == (&quot;spoken&quot;,&quot;perhaps&quot;)] | any)\r\n      | .key\r\n    \r\n    &#39; input.json\r\n\r\nTry it at [jqplay.org][1]\r\n\r\n\r\n  [1]: https://jqplay.org/s/VdQWz1ZTxU",
                "title": "JQ: Selection with conditions in a nested hash"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1632867284,
        "creation_date": 1632865907,
        "question_id": 69368874,
        "body_markdown": "How to get a city name specifying the name of a language with the additional condition of &quot;spoken&quot; or &quot;perhaps&quot;?\r\n\r\n    {\r\n      &quot;Paris&quot;: {\r\n        &quot;language&quot;: {\r\n          &quot;fr&quot;: &quot;spoken&quot;,\r\n          &quot;en&quot;: &quot;perhaps&quot;\r\n         }\r\n       },\r\n       &quot;London&quot;: {\r\n         &quot;language&quot;: {\r\n           &quot;en&quot;: &quot;spoken&quot;,\r\n           &quot;fr&quot;: &quot;perhaps&quot;,\r\n           &quot;ru&quot;: &quot;unused&quot;\r\n         }\r\n       },\r\n       &quot;Moscow&quot;: {\r\n         &quot;language&quot;: {\r\n           &quot;ru&quot;: &quot;spoken&quot;,\r\n           &quot;en&quot;: &quot;perhaps&quot;,\r\n           &quot;fr&quot;: &quot;unused&quot;\r\n         } \r\n       }\r\n     }\r\n\r\n\r\nE.g:\r\n\r\nInput: en;\r\nOutput: Paris, London, Moscow\r\n\r\nInput: fr;\r\nOutput: Paris, London\r\n\r\nInput: ru;\r\nOutput: Moscow\r\n",
        "link": "https://stackoverflow.com/questions/69368874/jq-selection-with-conditions-in-a-nested-hash",
        "title": "JQ: Selection with conditions in a nested hash"
    }
]