[
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1729172494,
                "post_id": 79098307,
                "comment_id": 139473017,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1729173477,
                "creation_date": 1729173477,
                "answer_id": 79098429,
                "question_id": 79098307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can add the new element everywhere and then delete the old prod release if it existed:\r\n```\r\njq --arg release 1.2 &#39;.environments += [{&quot;name&quot;:&quot;prod&quot;,&quot;release&quot;:$release}]\r\n                      | del(.environments[]\r\n                            | select(.name == &quot;prod&quot; and .release != $release))&#39; file.json\r\n```\r\nTested on the following 4 files:\r\n\r\n```bash\r\necho &#39;{}&#39; &gt; 1.in\r\necho &#39;{&quot;environments&quot;:[]}&#39; &gt; 2.in\r\necho &#39;{&quot;environments&quot;:[{&quot;name&quot;:&quot;test&quot;,&quot;release&quot;:&quot;2.0&quot;}]}&#39; &gt; 3.in\r\necho &#39;{&quot;environments&quot;:[{&quot;name&quot;:&quot;test&quot;,&quot;release&quot;:&quot;2.0&quot;},{&quot;name&quot;:&quot;prod&quot;,&quot;release&quot;:&quot;1.0&quot;}]}&#39; &gt; 4.in\r\n```",
                "title": "Using JQ how to append entry to dictionary type array in JSON or create it if array doesn&#39;t exist?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1729174610,
                "last_edit_date": 1729174610,
                "creation_date": 1729173504,
                "answer_id": 79098431,
                "question_id": 79098307,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could create an `INDEX`, then update the `.prod` field. This way, it is either updated if it existed, or created if it didn&#39;t. Afterwards, iterate over the items to restore the array. Using the `?` operator when creating the stream takes care of the empty object case.\r\n```sh\r\n.environments |= [\r\n  INDEX(.[]?; .name) | .prod = {name: &quot;prod&quot;, release: &quot;2.0&quot;} | .[]\r\n]\r\n```\r\n\r\nThis turns both `{}` and `{&quot;environments&quot;: []}` into:\r\n```json\r\n{\r\n  &quot;environments&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;prod&quot;,\r\n      &quot;release&quot;: &quot;2.0&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nAnd updates the given sample (after removing the abundant comma) into:\r\n```json\r\n{\r\n  &quot;environments&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;release&quot;: &quot;2.0&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;prod&quot;,\r\n      &quot;release&quot;: &quot;2.0&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/6bWdjxpRUT9Dn40)",
                "title": "Using JQ how to append entry to dictionary type array in JSON or create it if array doesn&#39;t exist?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1729174610,
        "creation_date": 1729171520,
        "last_edit_date": 1729172325,
        "question_id": 79098307,
        "body_markdown": "I have ideal JSON:\r\n\r\n    {\r\n        &quot;environments&quot;:[\r\n            {\r\n                &quot;name&quot;:&quot;test&quot;,\r\n                &quot;release&quot;:&quot;2.0&quot;\r\n            },\r\n            {\r\n                &quot;name&quot;:&quot;prod&quot;,\r\n                &quot;release&quot;:&quot;1.0&quot;\r\n            },\r\n        ]\r\n    }\r\n\r\nThis file could be in any state:\r\n\r\n 1. It can be empty file with just empty object { }\r\n 2. It can have empty &quot;environemnts&quot; array\r\n 3. It can have some entries in environment array but not the one we want to update\r\n\r\n**I need to update or create the &quot;release&quot; tag with given version under given environment.**\r\n\r\nI tried variations of: \r\n\r\n    (.environments[] | select(.name == &quot;prod&quot;) | .release) = &quot;3.0&quot; // .environments += [{&quot;name&quot;: &quot;prod&quot;, &quot;release&quot;: &quot;3.0&quot;}]\r\n\r\n\r\nI also tried:\r\n\r\n    .environments\r\n    |=  (map(.name) | index(&quot;prod&quot;)) as $ix\r\n        | if $ix \r\n          then .[$ix][&quot;release&quot;] = &quot;2.0&quot; \r\n          else . + [{name: &quot;release&quot;, value: &quot;2.0&quot;}]\r\n          end\r\n\r\nBut it either fails on empty file. Or doesn&#39;t create new entry.\r\nI&#39;m lost here.",
        "link": "https://stackoverflow.com/questions/79098307/using-jq-how-to-append-entry-to-dictionary-type-array-in-json-or-create-it-if-ar",
        "title": "Using JQ how to append entry to dictionary type array in JSON or create it if array doesn&#39;t exist?"
    },
    {
        "tags": [
            "json",
            "jq",
            "reduce"
        ],
        "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": 1729199709,
                "post_id": 79099839,
                "comment_id": 139475915,
                "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": 1,
                "creation_date": 1729199929,
                "post_id": 79099839,
                "comment_id": 139475932,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1729206400,
                "last_edit_date": 1729206400,
                "creation_date": 1729205687,
                "answer_id": 79100063,
                "question_id": 79099839,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The error you are encountering is related to referencing the top level schema object while iterating through the contents of inputArray without having a proper reference back to it.\r\n\r\nSo, you need to be able to get the value of the current item with the key (item[ that maps to the key in the schema.\r\n\r\nTry this:\r\n\r\n    {\r\n      transformedArray: (\r\n        [.inputArray[] as $item |\r\n          reduce .schema[] as $s (\r\n            {}; \r\n            . + { ($s.new): $item[$s.input] }\r\n          )\r\n        ]\r\n      )\r\n    }\r\n\r\n\r\n`$item` is the current item being iterated over in `inputArray`.   \r\n`$s` is the `schema`, then `$s.new` is the new key that replaces the old key `$s.input`.  \r\nThe value is then obtained with `$item[$s.input]`\r\n\r\n\r\n[![enter image description here][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/19Cenv53.png",
                "title": "JQ Cannot iterate over null"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1729206400,
        "creation_date": 1729199487,
        "question_id": 79099839,
        "body_markdown": "I am trying to create a jq that is dynamic in returning data.\r\nUser Story: I have data with many fields and not named like I want. I want to be able to based on the data and schema transform the data.\r\n\r\nExample:\r\nJSON\r\n```{\r\n  &quot;inputArray&quot;: [\r\n    {\r\n      &quot;objective_id&quot;: &quot;ac-1_obj.a-1&quot;,\r\n      &quot;description&quot;: &quot;an access control policy is developed and documented;&quot;,\r\n      &quot;framework_id&quot;: 1,\r\n      &quot;domain_id&quot;: &quot;ac&quot;,\r\n      &quot;domaintitle&quot;: &quot;Access Control&quot;,\r\n      &quot;id&quot;: 0,\r\n      &quot;control_id&quot;: &quot;ac-1&quot;,\r\n      &quot;controltitle&quot;: &quot;Policy and Procedures&quot;\r\n    },\r\n    {\r\n      &quot;objective_id&quot;: &quot;ac-1_obj.a-2&quot;,\r\n      &quot;description&quot;: &quot;the access control policy is disseminated to {{ insert: param, ac-01_odp.01 }};&quot;,\r\n      &quot;framework_id&quot;: 1,\r\n      &quot;domain_id&quot;: &quot;ac&quot;,\r\n      &quot;domaintitle&quot;: &quot;Access Control&quot;,\r\n      &quot;id&quot;: 0,\r\n      &quot;control_id&quot;: &quot;ac-1&quot;,\r\n      &quot;controltitle&quot;: &quot;Policy and Procedures&quot;\r\n    },\r\n    {\r\n      &quot;objective_id&quot;: &quot;ac-1_obj.a-3&quot;,\r\n      &quot;description&quot;: &quot;access control procedures to facilitate the implementation of the access control policy and associated controls are developed and documented;&quot;,\r\n      &quot;framework_id&quot;: 1,\r\n      &quot;domain_id&quot;: &quot;ac&quot;,\r\n      &quot;domaintitle&quot;: &quot;Access Control&quot;,\r\n      &quot;id&quot;: 0,\r\n      &quot;control_id&quot;: &quot;ac-1&quot;,\r\n      &quot;controltitle&quot;: &quot;Policy and Procedures&quot;\r\n    }\r\n  ],\r\n  &quot;schema&quot;: [\r\n    { &quot;new&quot;: &quot;objective&quot;, &quot;input&quot;: &quot;objective_id&quot; },\r\n    { &quot;new&quot;: &quot;framework&quot;, &quot;input&quot;: &quot;framework_id&quot; },\r\n    { &quot;new&quot;: &quot;control&quot;, &quot;input&quot;: &quot;control_id&quot; },\r\n    { &quot;new&quot;: &quot;title&quot;, &quot;input&quot;: &quot;controltitle&quot; },\r\n    { &quot;new&quot;: &quot;description&quot;, &quot;input&quot;: &quot;description&quot; }\r\n  ]\r\n}\r\n```\r\nJQ\r\n```{\r\n  inputArray: [\r\n    .inputArray[] |\r\n    reduce (.schema[] | {new: .new, input: .input}) as $map (\r\n      {}; \r\n      .[$map.new] = .[$map.input]\r\n    )\r\n  ]\r\n}\r\n```\r\nError\r\n```\r\njq: error (at /tmp/data.json:40): Cannot iterate over null (null) undefined\r\n```\r\n\r\n - schema is what it seems to be mad about.\r\n - I have tested that .schema is available\r\n - I have added ? to the end of .schema and values are empty\r\n[![jq kung fu playground][1]][1]\r\n\r\n\r\n  [1]: https://i.sstatic.net/rU5DW3Ak.png",
        "link": "https://stackoverflow.com/questions/79099839/jq-cannot-iterate-over-null",
        "title": "JQ Cannot iterate over null"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16657153,
                    "reputation": 325,
                    "user_id": 12038199,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/afe51bbc140e097b13e5cfcbd2268141?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sloppy",
                    "link": "https://stackoverflow.com/users/12038199/sloppy"
                },
                "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": 1729239328,
                "post_id": 79101157,
                "comment_id": 139478177,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8440920,
                    "reputation": 8108,
                    "user_id": 6333444,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/2WjOT.png?s=256",
                    "display_name": "mousetail",
                    "link": "https://stackoverflow.com/users/6333444/mousetail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729239446,
                "post_id": 79101157,
                "comment_id": 139478193,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16657153,
                    "reputation": 325,
                    "user_id": 12038199,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/afe51bbc140e097b13e5cfcbd2268141?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "sloppy",
                    "link": "https://stackoverflow.com/users/12038199/sloppy"
                },
                "reply_to_user": {
                    "account_id": 8440920,
                    "reputation": 8108,
                    "user_id": 6333444,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/2WjOT.png?s=256",
                    "display_name": "mousetail",
                    "link": "https://stackoverflow.com/users/6333444/mousetail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729239707,
                "post_id": 79101157,
                "comment_id": 139478226,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1729239346,
                "last_edit_date": 1729239346,
                "creation_date": 1729239142,
                "answer_id": 79101171,
                "question_id": 79101157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Construct the array, compare it to `.size`, and use `first` to only get the first match:\r\n\r\n```sh\r\njq --argjson width 1920 --argjson height 1080 &#39;\r\n  first(.[] | select(.size == [$width, $height]).id)\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/mH7bt2MUTp75ZC7)\r\n\r\n\r\n```sh\r\njq --argjson size &#39;[1920, 1080]&#39; &#39;\r\n  first(.[] | select(.size == $size).id)\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/acv3YYmK-9NH-GN)\r\n\r\nOutput:\r\n```json\r\n366\r\n```\r\n",
                "title": "Match object with array key to exact values using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1729239416,
        "creation_date": 1729238880,
        "last_edit_date": 1729239319,
        "question_id": 79101157,
        "body_markdown": "Match first object which has an array that contains exactly same values (it&#39;s should always be length of 2)\r\n\r\nExample:\r\n\r\n```json\r\n[\r\n  { &quot;id&quot;: 242, &quot;size&quot;: [500, 500] },\r\n  { &quot;id&quot;: 234, &quot;size&quot;: [500, 1920] },\r\n  { &quot;id&quot;: 168, &quot;size&quot;: [234, 1080] },\r\n  { &quot;id&quot;: 315, &quot;size&quot;: [1080, 1920] },\r\n  { &quot;id&quot;: 366, &quot;size&quot;: [1920, 1080] },\r\n  { &quot;id&quot;: 367, &quot;size&quot;: [1920, 1080] }\r\n]\r\n```\r\n\r\n```bash\r\nwidth=1920\r\nheight=1080\r\n\r\n# Should match:\r\n# { id: 366, size: [1920, 1080] }\r\n\r\n# Then extract id (easy, got this part)\r\n\r\n```\r\n\r\nMy best attempt was to use contains, but it doesn&#39;t seems contains can take more than 1 argument:\r\n\r\n```bash\r\necho $json | jq -r &quot;.[] | select( [ .size[] | contains($width) ] | any ) | .id&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/79101157/match-object-with-array-key-to-exact-values-using-jq",
        "title": "Match object with array key to exact values using jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9531412,
                    "reputation": 2878,
                    "user_id": 7082956,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/99d1d4ee28260791f03b53f13a3bf6b2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Valerij Dobler",
                    "link": "https://stackoverflow.com/users/7082956/valerij-dobler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729244619,
                "post_id": 79101481,
                "comment_id": 139478691,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 36589682,
                    "reputation": 53,
                    "user_id": 27817057,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/QNaaz9nZ.jpg?s=256",
                    "display_name": "Vanger69",
                    "link": "https://stackoverflow.com/users/27817057/vanger69"
                },
                "reply_to_user": {
                    "account_id": 9531412,
                    "reputation": 2878,
                    "user_id": 7082956,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/99d1d4ee28260791f03b53f13a3bf6b2?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Valerij Dobler",
                    "link": "https://stackoverflow.com/users/7082956/valerij-dobler"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729247719,
                "post_id": 79101481,
                "comment_id": 139479037,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1729273864,
                "last_edit_date": 1729273864,
                "creation_date": 1729244815,
                "answer_id": 79101520,
                "question_id": 79101481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `jq` with raw input option (`-R`) and `-s` to slurp the entire file as a single string. Then you split that into array of lines. You access test lines by `$lines[1:-1]` (we skip 1-st row) and for each test line, split it by `&quot;;&quot;` and map the fields to the desired keys. Since in your data `&quot;0&quot;` represents a successful test (status `true`), you can convert the status using `(.[0] == &quot;0&quot;)`. Then deal with summary line (use `-1` index to get it regardles of line count) and you should be good. \r\n\r\nCombining the above should give you this monster:\r\n\r\n```bash\r\njq -R -s &#39;\r\n  (split(&quot;\\n&quot;) | map(select(length &gt; 0))) as $lines |\r\n  {\r\n    testName: $lines[0],\r\n    tests: ($lines[1:-1] | map(\r\n      (split(&quot;;&quot;) | {\r\n        name: .[1],\r\n        status: (.[0] == &quot;0&quot;),\r\n        duration: .[2]\r\n      })\r\n    )),\r\n    summary: ($lines[-1] | split(&quot;;&quot;) | {\r\n      success: (.[0] | tonumber),\r\n      failed: (.[1] | tonumber),\r\n      rating: (.[2] | tonumber),\r\n      duration: .[3]\r\n    })\r\n  }\r\n&#39; input.csv\r\n```\r\n\r\nOnce run on your input data output should be\r\n\r\n```json\r\n{\r\n  &quot;testName&quot;: &quot;Asserts Samples&quot;,\r\n  &quot;tests&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;expecting command finishes successfully (bash exe)&quot;,\r\n      &quot;status&quot;: false,\r\n      &quot;duration&quot;: &quot;7ms&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;expecting command finishes successfully (loading bin, execute)&quot;,\r\n      &quot;status&quot;: false,\r\n      &quot;duration&quot;: &quot;27ms&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;expecting command fails (bash exe, execute)&quot;,\r\n      &quot;status&quot;: true,\r\n      &quot;duration&quot;: &quot;23ms&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: null,\r\n      &quot;status&quot;: false,\r\n      &quot;duration&quot;: null\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;expecting command prints some message (bash exe)&quot;,\r\n      &quot;status&quot;: true,\r\n      &quot;duration&quot;: &quot;12ms&quot;\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;expecting command prints some message (loading bin, execute)&quot;,\r\n      &quot;status&quot;: true,\r\n      &quot;duration&quot;: &quot;26ms&quot;\r\n    }\r\n  ],\r\n  &quot;summary&quot;: {\r\n    &quot;success&quot;: 5,\r\n    &quot;failed&quot;: 2,\r\n    &quot;rating&quot;: 71.43,\r\n    &quot;duration&quot;: &quot;136ms&quot;\r\n  }\r\n}\r\n```",
                "title": "Converting csv to json with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1729247652,
                "last_edit_date": 1729247652,
                "creation_date": 1729246430,
                "answer_id": 79101622,
                "question_id": 79101481,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a stream (reading `inputs` line by line without storing the whole input file in memory) and regex-based (using `capture`) approach:\r\n\r\n```sh\r\njq -R &#39;reduce (inputs | capture((\r\n\r\n  &quot;^(?&lt;status&gt;0|1);(?&lt;name&gt;[^;]*)&quot;,\r\n  &quot;^(?&lt;success&gt;\\\\d+);(?&lt;failed&gt;\\\\d+);(?&lt;rating&gt;\\\\d+(\\\\.\\\\d+)?)&quot;\r\n\r\n) + &quot;;(?&lt;duration&gt;\\\\d+ms)$&quot;)) as $i ({testName: .}; if $i.name\r\n\r\n  then .tests += [$i | .status |= . == &quot;0&quot;]\r\n  else .summary = ($i | (.success, .failed, .rating) |= tonumber)\r\n\r\nend)&#39;\r\n```\r\n```json\r\n{\r\n  &quot;testName&quot;: &quot;Asserts Samples&quot;,\r\n  &quot;tests&quot;: [\r\n    {\r\n      &quot;status&quot;: false,\r\n      &quot;name&quot;: &quot;expecting command finishes successfully (bash exe)&quot;,\r\n      &quot;duration&quot;: &quot;7ms&quot;\r\n    },\r\n    {\r\n      &quot;status&quot;: false,\r\n      &quot;name&quot;: &quot;expecting command finishes successfully (loading bin, execute)&quot;,\r\n      &quot;duration&quot;: &quot;27ms&quot;\r\n    },\r\n    {\r\n      &quot;status&quot;: true,\r\n      &quot;name&quot;: &quot;expecting command fails (bash exe, execute)&quot;,\r\n      &quot;duration&quot;: &quot;23ms&quot;\r\n    },\r\n    {\r\n      &quot;status&quot;: true,\r\n      &quot;name&quot;: &quot;expecting command prints some message (bash exe)&quot;,\r\n      &quot;duration&quot;: &quot;12ms&quot;\r\n    },\r\n    {\r\n      &quot;status&quot;: true,\r\n      &quot;name&quot;: &quot;expecting command prints some message (loading bin, execute)&quot;,\r\n      &quot;duration&quot;: &quot;26ms&quot;\r\n    }\r\n  ],\r\n  &quot;summary&quot;: {\r\n    &quot;success&quot;: 5,\r\n    &quot;failed&quot;: 2,\r\n    &quot;rating&quot;: 71.43,\r\n    &quot;duration&quot;: &quot;136ms&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/-fDkD-298By2iB0)",
                "title": "Converting csv to json with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1729273864,
        "creation_date": 1729244297,
        "last_edit_date": 1729244375,
        "question_id": 79101481,
        "body_markdown": "I&#39;m currently practicing converting **plain text to csv**, and them **csv to json**. I need to do the conversion only with [jq](https://jqlang.github.io/jq/) and basic Linux commands.\r\n\r\nI didn&#39;t have any major problems converting plain text to csv, but further conversion is a bit tricky. Primarily because the **first line and the last one are out of standard**.\r\n\r\nHere is my current csv:\r\n```\r\nAsserts Samples\r\n1;expecting command finishes successfully (bash exe);7ms\r\n1;expecting command finishes successfully (loading bin, execute);27ms\r\n0;expecting command fails (bash exe, execute);23ms\r\n...\r\n0;expecting command prints some message (bash exe);12ms\r\n0;expecting command prints some message (loading bin, execute);26ms\r\n5;2;71.43;136ms\r\n```\r\nI need to convert this csv to the following format:\r\n```json\r\n{\r\n &quot;testName&quot;: &quot;Asserts Samples&quot;,\r\n &quot;tests&quot;: [\r\n   {\r\n     &quot;name&quot;: &quot;expecting command finishes successfully (bash exe)&quot;,\r\n     &quot;status&quot;: false,\r\n     &quot;duration&quot;: &quot;7ms&quot;\r\n   },\r\n...\r\n   {\r\n     &quot;name&quot;: &quot;expecting command prints some message (loading bin, execute)&quot;,\r\n     &quot;status&quot;: true,\r\n     &quot;duration&quot;: &quot;26ms&quot;\r\n   }\r\n ],\r\n &quot;summary&quot;: {\r\n   &quot;success&quot;: 5,\r\n   &quot;failed&quot;: 2,\r\n   &quot;rating&quot;: 71.43,\r\n   &quot;duration&quot;: &quot;136ms&quot;\r\n }\r\n}\r\n```\r\nSo far I have figured out:\r\n* How to add names to values. `map({&quot;name&quot;: .[1],...`\r\n* How to replace string with boolean. `select(.status == &quot;0&quot;)).status |= true`\r\n* How to make split with **one** separator. `(split(&quot;;&quot;)`\r\n\r\nLong attempts have failed to make a json structure **with a corresponding arrays and objects structure**.\r\nI would be glad for advice or guidance.",
        "link": "https://stackoverflow.com/questions/79101481/converting-csv-to-json-with-jq",
        "title": "Converting csv to json with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1729370713,
                "last_edit_date": 1729370713,
                "creation_date": 1729286056,
                "answer_id": 79103696,
                "question_id": 79103668,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given these arguments, this is the adapted, now nested approach from the [previous question](https://stackoverflow.com/questions/79098307/using-jq-how-to-append-entry-to-dictionary-type-array-in-json-or-create-it-if-ar):\r\n```sh\r\njq --arg name itemA --arg bin_id b1 --arg count 68 &#39;\r\n  .items |= [INDEX(.[]?; .name) | .[$name] |= ({$name, bins}\r\n    | .bins |= [INDEX(.[]?; .bin_id) | .[$bin_id] |= {$bin_id, $count} | .[]]\r\n  ) | .[]]\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/Z240Y1QDylYlg71)\r\n\r\nThis can be generalized by moving the repeating code into a function, and nesting the calls:\r\n```sh\r\njq --arg name itemA --arg bin_id b1 --arg count 68 &#39;\r\n  def f(a;b;c): .[a] |= [INDEX(.[]?; .[b|keys[]]) | .[b[]] |= b+c | .[]];\r\n  f(&quot;items&quot;; {$name}; f(&quot;bins&quot;; {$bin_id}; {$count}))\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/4jvAenf4h3cc-m2)\r\n\r\nFinally, making the function recursive allows for an arbitrarily deep nesting. Note the modified way providing the arguments as `(container_field index_field index_value)* field value`, which now directly includes all the field names:\r\n```sh\r\njq &#39;def f(v): .[v[0]] |= if v | length &lt; 3 then v[1] else\r\n  [INDEX(.[]?; .[v[1]]) | .[v[2]] |= {(v[1]): v[2]} + f(v[3:]) | .[]]\r\nend; f($ARGS.positional)&#39; --args items name itemA bins bin_id b1 count 68\r\n```\r\n[Demo](https://jqplay.org/s/QLPhbw39_hjeGxf)\r\n\r\nFor an empty input, all of them produce:\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;itemA&quot;,\r\n      &quot;bins&quot;: [\r\n        {\r\n          &quot;bin_id&quot;: &quot;b1&quot;,\r\n          &quot;count&quot;: &quot;68&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAnd for the sample input, they output:\r\n```json\r\n{\r\n  &quot;items&quot;: [\r\n    {\r\n      &quot;name&quot;: &quot;itemA&quot;,\r\n      &quot;bins&quot;: [\r\n        {\r\n          &quot;bin_id&quot;: &quot;b1&quot;,\r\n          &quot;count&quot;: &quot;68&quot;\r\n        },\r\n        {\r\n          &quot;bin_id&quot;: &quot;b2&quot;,\r\n          &quot;count&quot;: &quot;22&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;name&quot;: &quot;itemB&quot;,\r\n      &quot;bins&quot;: [\r\n        {\r\n          &quot;bin_id&quot;: &quot;b5&quot;,\r\n          &quot;count&quot;: &quot;55&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n",
                "title": "Using JQ query how to update propery inside two nested arrays?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1729289353,
                "creation_date": 1729289353,
                "answer_id": 79103806,
                "question_id": 79103668,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `select` to get the object to update :\r\n\r\n```\r\njq --arg i itemA --arg b b1 --arg c 68 &#39;(\r\n    .items[]? | \r\n    select(.name==$i).bins[] |\r\n    select(.bin_id==$b)\r\n    ).count=$c&#39; file.json\r\n```",
                "title": "Using JQ query how to update propery inside two nested arrays?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1729370713,
        "creation_date": 1729285314,
        "last_edit_date": 1729286061,
        "question_id": 79103668,
        "body_markdown": "I tried this for 2 days but can&#39;t figure it out in any way.\r\n\r\nThis is my JSON:\r\n\r\n    {\r\n        &quot;items&quot;: [\r\n            {\r\n                &quot;name&quot;:&quot;itemA&quot;,\r\n                &quot;bins&quot;:[\r\n                    {\r\n                        &quot;bin_id&quot;:&quot;b1&quot;,\r\n                        &quot;count&quot;:&quot;11&quot;\r\n                    },\r\n                    {\r\n                        &quot;bin_id&quot;:&quot;b2&quot;,\r\n                        &quot;count&quot;:&quot;22&quot;\r\n                    }\r\n                ]\r\n            },\r\n            {\r\n                &quot;name&quot;:&quot;itemB&quot;,\r\n                &quot;bins&quot;:[\r\n                    {\r\n                        &quot;bin_id&quot;:&quot;b5&quot;,\r\n                        &quot;count&quot;:&quot;55&quot;\r\n                    }\r\n                ]\r\n            }\r\n        ]\r\n    }\r\n\r\nImportant note. Input JSON could be empty object &#39;{}&#39; or missing any part of the hierarchy.\r\n\r\n\r\nI need to insert whole hierary or update final entry for &quot;count&quot;. My input arguments are: itemName, binId and new count.\r\n\r\n\r\nSo for &quot;itemA&quot;, &quot;b1&quot; and count 68. I need to set .items -&gt; (item with name: &quot;itemA&quot;) -&gt; (bin with bin_id 68) -&gt; count = 68.\r\n\r\n\r\nI tried using INDEX to access items. And that works... but I can&#39;t seem to further access bins and update final count.\r\n\r\n\r\n**UPDATE:**\r\n\r\nI got something like this:\r\n\r\n    .items |= [INDEX(.[]?;.name) | .itemA |= .+ {name:&quot;itemA&quot;,bins:[INDEX(.bins[]?;.bin_id) | .b1 |= .+ {bin_id:&quot;b1&quot;,count:&quot;188000&quot;} | .[]]} | .[]]\r\n\r\nBut it does look ugly. Can this be done more clearly?",
        "link": "https://stackoverflow.com/questions/79103668/using-jq-query-how-to-update-propery-inside-two-nested-arrays",
        "title": "Using JQ query how to update propery inside two nested arrays?"
    },
    {
        "tags": [
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1143565,
                    "reputation": 535973,
                    "user_id": 1126841,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/fa05233b2357f8d11c22ef4cfc7bb85c?s=256&d=identicon&r=PG",
                    "display_name": "chepner",
                    "link": "https://stackoverflow.com/users/1126841/chepner"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1729620352,
                "post_id": 79115246,
                "comment_id": 139503421,
                "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": 1729620391,
                "post_id": 79115246,
                "comment_id": 139503428,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8372728,
                    "reputation": 278,
                    "user_id": 6287289,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e12a0ec379122416d634941018f7c352?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nbanba",
                    "link": "https://stackoverflow.com/users/6287289/nbanba"
                },
                "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": 1729690748,
                "post_id": 79115246,
                "comment_id": 139508722,
                "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": 1729694297,
                "post_id": 79115246,
                "comment_id": 139509175,
                "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": 1729704088,
                "post_id": 79115246,
                "comment_id": 139510308,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8372728,
                    "reputation": 278,
                    "user_id": 6287289,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e12a0ec379122416d634941018f7c352?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nbanba",
                    "link": "https://stackoverflow.com/users/6287289/nbanba"
                },
                "reply_to_user": {
                    "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": 1729846088,
                "post_id": 79115246,
                "comment_id": 139521270,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8372728,
                    "reputation": 278,
                    "user_id": 6287289,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e12a0ec379122416d634941018f7c352?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nbanba",
                    "link": "https://stackoverflow.com/users/6287289/nbanba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1729846636,
                "post_id": 79115246,
                "comment_id": 139521328,
                "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": 1729848213,
                "post_id": 79115246,
                "comment_id": 139521485,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 8372728,
                    "reputation": 278,
                    "user_id": 6287289,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e12a0ec379122416d634941018f7c352?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "nbanba",
                    "link": "https://stackoverflow.com/users/6287289/nbanba"
                },
                "reply_to_user": {
                    "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": 1730135824,
                "post_id": 79115246,
                "comment_id": 139538311,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1729622640,
                "creation_date": 1729622640,
                "answer_id": 79115403,
                "question_id": 79115246,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "With `paths` you won&#39;t get the exact traversal order of your expected output. If this is not important, here&#39;s one approach using your attempt with `paths`:\r\n```sh\r\npaths as $p |\r\n&quot;\\([$p[] | &quot;.&quot; + strings // &quot;[\\(.)]&quot;] | add[1:]) = \\(getpath($p))&quot;\r\n```\r\n```none\r\nsuccess = true\r\nresult = [{&quot;duplex&quot;:&quot;full&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:2F:8E:AB&quot;,&quot;hostname&quot;:&quot;firewall-net90d&quot;}],&quot;name&quot;:&quot;Ethernet 1&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:1,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;1&quot;},{&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 2&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:2,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;2&quot;},{&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 3&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:3,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;3&quot;},{&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 4&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:4,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;4&quot;},{&quot;duplex&quot;:&quot;full&quot;,&quot;name&quot;:&quot;NBAplug&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:5,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;nbaplug&quot;},{&quot;duplex&quot;:&quot;auto&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:43:B3:73&quot;,&quot;hostname&quot;:&quot;00:00:00:43:B3:73&quot;},{&quot;mac&quot;:&quot;00:00:00:1A:66:60&quot;,&quot;hostname&quot;:&quot;00:00:00:1A:66:60&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:13&quot;,&quot;hostname&quot;:&quot;00:00:00:09:00:13&quot;},{&quot;mac&quot;:&quot;00:00:00:80:29:7C&quot;,&quot;hostname&quot;:&quot;abcd-PLAYER&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:12&quot;,&quot;hostname&quot;:&quot;firewall-net101f-cluster&quot;},{&quot;mac&quot;:&quot;00:00:00:A0:EF:82&quot;,&quot;hostname&quot;:&quot;00:00:00:A0:EF:82&quot;}],&quot;name&quot;:&quot;Sfp lan&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:9999,&quot;mode&quot;:&quot;10000-FD&quot;,&quot;speed&quot;:&quot;10000&quot;,&quot;rrd_id&quot;:&quot;sfp_lan&quot;}]\r\nresult[0] = {&quot;duplex&quot;:&quot;full&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:2F:8E:AB&quot;,&quot;hostname&quot;:&quot;firewall-net90d&quot;}],&quot;name&quot;:&quot;Ethernet 1&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:1,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;1&quot;}\r\nresult[0].duplex = full\r\nresult[0].mac_list = [{&quot;mac&quot;:&quot;00:00:00:2F:8E:AB&quot;,&quot;hostname&quot;:&quot;firewall-net90d&quot;}]\r\nresult[0].mac_list[0] = {&quot;mac&quot;:&quot;00:00:00:2F:8E:AB&quot;,&quot;hostname&quot;:&quot;firewall-net90d&quot;}\r\nresult[0].mac_list[0].mac = 00:00:00:2F:8E:AB\r\nresult[0].mac_list[0].hostname = firewall-net90d\r\nresult[0].name = Ethernet 1\r\nresult[0].link = up\r\nresult[0].id = 1\r\nresult[0].mode = 1000BaseT-FD\r\nresult[0].speed = 1000\r\nresult[0].rrd_id = 1\r\nresult[1] = {&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 2&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:2,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;2&quot;}\r\nresult[1].duplex = half\r\nresult[1].name = Ethernet 2\r\nresult[1].link = down\r\nresult[1].id = 2\r\nresult[1].mode = 10BaseT-HD\r\nresult[1].speed = 10\r\nresult[1].rrd_id = 2\r\nresult[2] = {&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 3&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:3,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;3&quot;}\r\nresult[2].duplex = half\r\nresult[2].name = Ethernet 3\r\nresult[2].link = down\r\nresult[2].id = 3\r\nresult[2].mode = 10BaseT-HD\r\nresult[2].speed = 10\r\nresult[2].rrd_id = 3\r\nresult[3] = {&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 4&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:4,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;4&quot;}\r\nresult[3].duplex = half\r\nresult[3].name = Ethernet 4\r\nresult[3].link = down\r\nresult[3].id = 4\r\nresult[3].mode = 10BaseT-HD\r\nresult[3].speed = 10\r\nresult[3].rrd_id = 4\r\nresult[4] = {&quot;duplex&quot;:&quot;full&quot;,&quot;name&quot;:&quot;NBAplug&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:5,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;nbaplug&quot;}\r\nresult[4].duplex = full\r\nresult[4].name = NBAplug\r\nresult[4].link = up\r\nresult[4].id = 5\r\nresult[4].mode = 1000BaseT-FD\r\nresult[4].speed = 1000\r\nresult[4].rrd_id = nbaplug\r\nresult[5] = {&quot;duplex&quot;:&quot;auto&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:43:B3:73&quot;,&quot;hostname&quot;:&quot;00:00:00:43:B3:73&quot;},{&quot;mac&quot;:&quot;00:00:00:1A:66:60&quot;,&quot;hostname&quot;:&quot;00:00:00:1A:66:60&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:13&quot;,&quot;hostname&quot;:&quot;00:00:00:09:00:13&quot;},{&quot;mac&quot;:&quot;00:00:00:80:29:7C&quot;,&quot;hostname&quot;:&quot;abcd-PLAYER&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:12&quot;,&quot;hostname&quot;:&quot;firewall-net101f-cluster&quot;},{&quot;mac&quot;:&quot;00:00:00:A0:EF:82&quot;,&quot;hostname&quot;:&quot;00:00:00:A0:EF:82&quot;}],&quot;name&quot;:&quot;Sfp lan&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:9999,&quot;mode&quot;:&quot;10000-FD&quot;,&quot;speed&quot;:&quot;10000&quot;,&quot;rrd_id&quot;:&quot;sfp_lan&quot;}\r\nresult[5].duplex = auto\r\nresult[5].mac_list = [{&quot;mac&quot;:&quot;00:00:00:43:B3:73&quot;,&quot;hostname&quot;:&quot;00:00:00:43:B3:73&quot;},{&quot;mac&quot;:&quot;00:00:00:1A:66:60&quot;,&quot;hostname&quot;:&quot;00:00:00:1A:66:60&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:13&quot;,&quot;hostname&quot;:&quot;00:00:00:09:00:13&quot;},{&quot;mac&quot;:&quot;00:00:00:80:29:7C&quot;,&quot;hostname&quot;:&quot;abcd-PLAYER&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:12&quot;,&quot;hostname&quot;:&quot;firewall-net101f-cluster&quot;},{&quot;mac&quot;:&quot;00:00:00:A0:EF:82&quot;,&quot;hostname&quot;:&quot;00:00:00:A0:EF:82&quot;}]\r\nresult[5].mac_list[0] = {&quot;mac&quot;:&quot;00:00:00:43:B3:73&quot;,&quot;hostname&quot;:&quot;00:00:00:43:B3:73&quot;}\r\nresult[5].mac_list[0].mac = 00:00:00:43:B3:73\r\nresult[5].mac_list[0].hostname = 00:00:00:43:B3:73\r\nresult[5].mac_list[1] = {&quot;mac&quot;:&quot;00:00:00:1A:66:60&quot;,&quot;hostname&quot;:&quot;00:00:00:1A:66:60&quot;}\r\nresult[5].mac_list[1].mac = 00:00:00:1A:66:60\r\nresult[5].mac_list[1].hostname = 00:00:00:1A:66:60\r\nresult[5].mac_list[2] = {&quot;mac&quot;:&quot;00:00:00:09:00:13&quot;,&quot;hostname&quot;:&quot;00:00:00:09:00:13&quot;}\r\nresult[5].mac_list[2].mac = 00:00:00:09:00:13\r\nresult[5].mac_list[2].hostname = 00:00:00:09:00:13\r\nresult[5].mac_list[3] = {&quot;mac&quot;:&quot;00:00:00:80:29:7C&quot;,&quot;hostname&quot;:&quot;abcd-PLAYER&quot;}\r\nresult[5].mac_list[3].mac = 00:00:00:80:29:7C\r\nresult[5].mac_list[3].hostname = abcd-PLAYER\r\nresult[5].mac_list[4] = {&quot;mac&quot;:&quot;00:00:00:09:00:12&quot;,&quot;hostname&quot;:&quot;firewall-net101f-cluster&quot;}\r\nresult[5].mac_list[4].mac = 00:00:00:09:00:12\r\nresult[5].mac_list[4].hostname = firewall-net101f-cluster\r\nresult[5].mac_list[5] = {&quot;mac&quot;:&quot;00:00:00:A0:EF:82&quot;,&quot;hostname&quot;:&quot;00:00:00:A0:EF:82&quot;}\r\nresult[5].mac_list[5].mac = 00:00:00:A0:EF:82\r\nresult[5].mac_list[5].hostname = 00:00:00:A0:EF:82\r\nresult[5].name = Sfp lan\r\nresult[5].link = up\r\nresult[5].id = 9999\r\nresult[5].mode = 10000-FD\r\nresult[5].speed = 10000\r\nresult[5].rrd_id = sfp_lan\r\n```\r\n[Demo](https://jqplay.org/s/V2i7l27gDFyFRtS)\r\n\r\n---\r\n\r\nTo retain the order, write a postfix-recursive function that nests the way you want it. For example:\r\n```sh\r\ndef f($p): f($p + (getpath($p) | iterables | keys_unsorted[] |[.])),\r\n  &quot;\\([$p[] | &quot;.&quot; + strings // &quot;[\\(.)]&quot;] | add[1:] | values) = \\(getpath($p))&quot;;\r\nf([])\r\n```\r\n```none\r\nsuccess = true\r\nresult[0].duplex = full\r\nresult[0].mac_list[0].mac = 00:00:00:2F:8E:AB\r\nresult[0].mac_list[0].hostname = firewall-net90d\r\nresult[0].mac_list[0] = {&quot;mac&quot;:&quot;00:00:00:2F:8E:AB&quot;,&quot;hostname&quot;:&quot;firewall-net90d&quot;}\r\nresult[0].mac_list = [{&quot;mac&quot;:&quot;00:00:00:2F:8E:AB&quot;,&quot;hostname&quot;:&quot;firewall-net90d&quot;}]\r\nresult[0].name = Ethernet 1\r\nresult[0].link = up\r\nresult[0].id = 1\r\nresult[0].mode = 1000BaseT-FD\r\nresult[0].speed = 1000\r\nresult[0].rrd_id = 1\r\nresult[0] = {&quot;duplex&quot;:&quot;full&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:2F:8E:AB&quot;,&quot;hostname&quot;:&quot;firewall-net90d&quot;}],&quot;name&quot;:&quot;Ethernet 1&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:1,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;1&quot;}\r\nresult[1].duplex = half\r\nresult[1].name = Ethernet 2\r\nresult[1].link = down\r\nresult[1].id = 2\r\nresult[1].mode = 10BaseT-HD\r\nresult[1].speed = 10\r\nresult[1].rrd_id = 2\r\nresult[1] = {&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 2&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:2,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;2&quot;}\r\nresult[2].duplex = half\r\nresult[2].name = Ethernet 3\r\nresult[2].link = down\r\nresult[2].id = 3\r\nresult[2].mode = 10BaseT-HD\r\nresult[2].speed = 10\r\nresult[2].rrd_id = 3\r\nresult[2] = {&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 3&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:3,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;3&quot;}\r\nresult[3].duplex = half\r\nresult[3].name = Ethernet 4\r\nresult[3].link = down\r\nresult[3].id = 4\r\nresult[3].mode = 10BaseT-HD\r\nresult[3].speed = 10\r\nresult[3].rrd_id = 4\r\nresult[3] = {&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 4&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:4,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;4&quot;}\r\nresult[4].duplex = full\r\nresult[4].name = NBAplug\r\nresult[4].link = up\r\nresult[4].id = 5\r\nresult[4].mode = 1000BaseT-FD\r\nresult[4].speed = 1000\r\nresult[4].rrd_id = nbaplug\r\nresult[4] = {&quot;duplex&quot;:&quot;full&quot;,&quot;name&quot;:&quot;NBAplug&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:5,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;nbaplug&quot;}\r\nresult[5].duplex = auto\r\nresult[5].mac_list[0].mac = 00:00:00:43:B3:73\r\nresult[5].mac_list[0].hostname = 00:00:00:43:B3:73\r\nresult[5].mac_list[0] = {&quot;mac&quot;:&quot;00:00:00:43:B3:73&quot;,&quot;hostname&quot;:&quot;00:00:00:43:B3:73&quot;}\r\nresult[5].mac_list[1].mac = 00:00:00:1A:66:60\r\nresult[5].mac_list[1].hostname = 00:00:00:1A:66:60\r\nresult[5].mac_list[1] = {&quot;mac&quot;:&quot;00:00:00:1A:66:60&quot;,&quot;hostname&quot;:&quot;00:00:00:1A:66:60&quot;}\r\nresult[5].mac_list[2].mac = 00:00:00:09:00:13\r\nresult[5].mac_list[2].hostname = 00:00:00:09:00:13\r\nresult[5].mac_list[2] = {&quot;mac&quot;:&quot;00:00:00:09:00:13&quot;,&quot;hostname&quot;:&quot;00:00:00:09:00:13&quot;}\r\nresult[5].mac_list[3].mac = 00:00:00:80:29:7C\r\nresult[5].mac_list[3].hostname = abcd-PLAYER\r\nresult[5].mac_list[3] = {&quot;mac&quot;:&quot;00:00:00:80:29:7C&quot;,&quot;hostname&quot;:&quot;abcd-PLAYER&quot;}\r\nresult[5].mac_list[4].mac = 00:00:00:09:00:12\r\nresult[5].mac_list[4].hostname = firewall-net101f-cluster\r\nresult[5].mac_list[4] = {&quot;mac&quot;:&quot;00:00:00:09:00:12&quot;,&quot;hostname&quot;:&quot;firewall-net101f-cluster&quot;}\r\nresult[5].mac_list[5].mac = 00:00:00:A0:EF:82\r\nresult[5].mac_list[5].hostname = 00:00:00:A0:EF:82\r\nresult[5].mac_list[5] = {&quot;mac&quot;:&quot;00:00:00:A0:EF:82&quot;,&quot;hostname&quot;:&quot;00:00:00:A0:EF:82&quot;}\r\nresult[5].mac_list = [{&quot;mac&quot;:&quot;00:00:00:43:B3:73&quot;,&quot;hostname&quot;:&quot;00:00:00:43:B3:73&quot;},{&quot;mac&quot;:&quot;00:00:00:1A:66:60&quot;,&quot;hostname&quot;:&quot;00:00:00:1A:66:60&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:13&quot;,&quot;hostname&quot;:&quot;00:00:00:09:00:13&quot;},{&quot;mac&quot;:&quot;00:00:00:80:29:7C&quot;,&quot;hostname&quot;:&quot;abcd-PLAYER&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:12&quot;,&quot;hostname&quot;:&quot;firewall-net101f-cluster&quot;},{&quot;mac&quot;:&quot;00:00:00:A0:EF:82&quot;,&quot;hostname&quot;:&quot;00:00:00:A0:EF:82&quot;}]\r\nresult[5].name = Sfp lan\r\nresult[5].link = up\r\nresult[5].id = 9999\r\nresult[5].mode = 10000-FD\r\nresult[5].speed = 10000\r\nresult[5].rrd_id = sfp_lan\r\nresult[5] = {&quot;duplex&quot;:&quot;auto&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:43:B3:73&quot;,&quot;hostname&quot;:&quot;00:00:00:43:B3:73&quot;},{&quot;mac&quot;:&quot;00:00:00:1A:66:60&quot;,&quot;hostname&quot;:&quot;00:00:00:1A:66:60&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:13&quot;,&quot;hostname&quot;:&quot;00:00:00:09:00:13&quot;},{&quot;mac&quot;:&quot;00:00:00:80:29:7C&quot;,&quot;hostname&quot;:&quot;abcd-PLAYER&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:12&quot;,&quot;hostname&quot;:&quot;firewall-net101f-cluster&quot;},{&quot;mac&quot;:&quot;00:00:00:A0:EF:82&quot;,&quot;hostname&quot;:&quot;00:00:00:A0:EF:82&quot;}],&quot;name&quot;:&quot;Sfp lan&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:9999,&quot;mode&quot;:&quot;10000-FD&quot;,&quot;speed&quot;:&quot;10000&quot;,&quot;rrd_id&quot;:&quot;sfp_lan&quot;}\r\nresult = [{&quot;duplex&quot;:&quot;full&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:2F:8E:AB&quot;,&quot;hostname&quot;:&quot;firewall-net90d&quot;}],&quot;name&quot;:&quot;Ethernet 1&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:1,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;1&quot;},{&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 2&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:2,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;2&quot;},{&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 3&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:3,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;3&quot;},{&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 4&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:4,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;4&quot;},{&quot;duplex&quot;:&quot;full&quot;,&quot;name&quot;:&quot;NBAplug&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:5,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;nbaplug&quot;},{&quot;duplex&quot;:&quot;auto&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:43:B3:73&quot;,&quot;hostname&quot;:&quot;00:00:00:43:B3:73&quot;},{&quot;mac&quot;:&quot;00:00:00:1A:66:60&quot;,&quot;hostname&quot;:&quot;00:00:00:1A:66:60&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:13&quot;,&quot;hostname&quot;:&quot;00:00:00:09:00:13&quot;},{&quot;mac&quot;:&quot;00:00:00:80:29:7C&quot;,&quot;hostname&quot;:&quot;abcd-PLAYER&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:12&quot;,&quot;hostname&quot;:&quot;firewall-net101f-cluster&quot;},{&quot;mac&quot;:&quot;00:00:00:A0:EF:82&quot;,&quot;hostname&quot;:&quot;00:00:00:A0:EF:82&quot;}],&quot;name&quot;:&quot;Sfp lan&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:9999,&quot;mode&quot;:&quot;10000-FD&quot;,&quot;speed&quot;:&quot;10000&quot;,&quot;rrd_id&quot;:&quot;sfp_lan&quot;}]\r\n```\r\n[Demo](https://jqplay.org/s/8fxdDUnEwNuU-M4)",
                "title": "Dump all key pair of a json with JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1729632665,
        "creation_date": 1729618985,
        "question_id": 79115246,
        "body_markdown": "Today I have big troubles in parsing huge json files (bigger than a megabyte) with only pure bash functions (performance issues), so I would like to use JQ parser [https://jqlang.github.io/jq/](https://jqlang.github.io/jq/) to speed up json parsing.\r\n\r\nI&#39;m using some bash functions which help parsing JSON and those functions are highly used in scripts so it will not be possible to change them everywhere but I can upgrade their contents in the library used by all scripts with jq parsing as soon as it produce the exact same output.\r\n\r\nBut for the moment I did not succeeded in producing the same output with some `jq` filters / functions.\r\n\r\n\r\n\r\n\r\n  \r\n\r\nLets see an example, here is a very simple json sample :\r\n\r\n\r\n```\r\n{&quot;success&quot;:true,&quot;result&quot;:[{&quot;duplex&quot;:&quot;full&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:2F:8E:AB&quot;,&quot;hostname&quot;:&quot;firewall-net90d&quot;}],&quot;name&quot;:&quot;Ethernet 1&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:1,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;1&quot;},{&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 2&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:2,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;2&quot;},{&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 3&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:3,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;3&quot;},{&quot;duplex&quot;:&quot;half&quot;,&quot;name&quot;:&quot;Ethernet 4&quot;,&quot;link&quot;:&quot;down&quot;,&quot;id&quot;:4,&quot;mode&quot;:&quot;10BaseT-HD&quot;,&quot;speed&quot;:&quot;10&quot;,&quot;rrd_id&quot;:&quot;4&quot;},{&quot;duplex&quot;:&quot;full&quot;,&quot;name&quot;:&quot;NBAplug&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:5,&quot;mode&quot;:&quot;1000BaseT-FD&quot;,&quot;speed&quot;:&quot;1000&quot;,&quot;rrd_id&quot;:&quot;nbaplug&quot;},{&quot;duplex&quot;:&quot;auto&quot;,&quot;mac_list&quot;:[{&quot;mac&quot;:&quot;00:00:00:43:B3:73&quot;,&quot;hostname&quot;:&quot;00:00:00:43:B3:73&quot;},{&quot;mac&quot;:&quot;00:00:00:1A:66:60&quot;,&quot;hostname&quot;:&quot;00:00:00:1A:66:60&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:13&quot;,&quot;hostname&quot;:&quot;00:00:00:09:00:13&quot;},{&quot;mac&quot;:&quot;00:00:00:80:29:7C&quot;,&quot;hostname&quot;:&quot;abcd-PLAYER&quot;},{&quot;mac&quot;:&quot;00:00:00:09:00:12&quot;,&quot;hostname&quot;:&quot;firewall-net101f-cluster&quot;},{&quot;mac&quot;:&quot;00:00:00:A0:EF:82&quot;,&quot;hostname&quot;:&quot;00:00:00:A0:EF:82&quot;}],&quot;name&quot;:&quot;Sfp lan&quot;,&quot;link&quot;:&quot;up&quot;,&quot;id&quot;:9999,&quot;mode&quot;:&quot;10000-FD&quot;,&quot;speed&quot;:&quot;10000&quot;,&quot;rrd_id&quot;:&quot;sfp_lan&quot;}]}\r\n```\r\n \r\nProcessing this JSON with the BASH function produce this output : \r\n\r\n\r\n```\r\nsuccess = true\r\nresult[0].duplex = full\r\nresult[0].mac_list[0].mac = 00:00:00:2F:8E:AB\r\nresult[0].mac_list[0].hostname = firewall-net90d\r\nresult[0].mac_list[0] = {&quot;mac&quot;:00:00:00:2F:8E:AB,&quot;hostname&quot;:firewall-net90d}\r\nresult[0].mac_list = [{&quot;mac&quot;:00:00:00:2F:8E:AB,&quot;hostname&quot;:firewall-net90d}]\r\nresult[0].name = Ethernet 1\r\nresult[0].link = up\r\nresult[0].id = 1\r\nresult[0].mode = 1000BaseT-FD\r\nresult[0].speed = 1000\r\nresult[0].rrd_id = 1\r\nresult[0] = {&quot;duplex&quot;:full,&quot;mac_list&quot;:[{&quot;mac&quot;:00:00:00:2F:8E:AB,&quot;hostname&quot;:firewall-net90d}],&quot;name&quot;:Ethernet 1,&quot;link&quot;:up,&quot;id&quot;:1,&quot;mode&quot;:1000BaseT-FD,&quot;speed&quot;:1000,&quot;rrd_id&quot;:1}\r\nresult[1].duplex = half\r\nresult[1].name = Ethernet 2\r\nresult[1].link = down\r\nresult[1].id = 2\r\nresult[1].mode = 10BaseT-HD\r\nresult[1].speed = 10\r\nresult[1].rrd_id = 2\r\nresult[1] = {&quot;duplex&quot;:half,&quot;name&quot;:Ethernet 2,&quot;link&quot;:down,&quot;id&quot;:2,&quot;mode&quot;:10BaseT-HD,&quot;speed&quot;:10,&quot;rrd_id&quot;:2}\r\nresult[2].duplex = half\r\nresult[2].name = Ethernet 3\r\nresult[2].link = down\r\nresult[2].id = 3\r\nresult[2].mode = 10BaseT-HD\r\nresult[2].speed = 10\r\nresult[2].rrd_id = 3\r\nresult[2] = {&quot;duplex&quot;:half,&quot;name&quot;:Ethernet 3,&quot;link&quot;:down,&quot;id&quot;:3,&quot;mode&quot;:10BaseT-HD,&quot;speed&quot;:10,&quot;rrd_id&quot;:3}\r\nresult[3].duplex = half\r\nresult[3].name = Ethernet 4\r\nresult[3].link = down\r\nresult[3].id = 4\r\nresult[3].mode = 10BaseT-HD\r\nresult[3].speed = 10\r\nresult[3].rrd_id = 4\r\nresult[3] = {&quot;duplex&quot;:half,&quot;name&quot;:Ethernet 4,&quot;link&quot;:down,&quot;id&quot;:4,&quot;mode&quot;:10BaseT-HD,&quot;speed&quot;:10,&quot;rrd_id&quot;:4}\r\nresult[4].duplex = full\r\nresult[4].name = NBAplug\r\nresult[4].link = up\r\nresult[4].id = 5\r\nresult[4].mode = 1000BaseT-FD\r\nresult[4].speed = 1000\r\nresult[4].rrd_id = nbaplug\r\nresult[4] = {&quot;duplex&quot;:full,&quot;name&quot;:NBAplug,&quot;link&quot;:up,&quot;id&quot;:5,&quot;mode&quot;:1000BaseT-FD,&quot;speed&quot;:1000,&quot;rrd_id&quot;:nbaplug}\r\nresult[5].duplex = auto\r\nresult[5].mac_list[0].mac = 00:00:00:43:B3:73\r\nresult[5].mac_list[0].hostname = 00:00:00:43:B3:73\r\nresult[5].mac_list[0] = {&quot;mac&quot;:00:00:00:43:B3:73,&quot;hostname&quot;:00:00:00:43:B3:73}\r\nresult[5].mac_list[1].mac = 00:00:00:1A:66:60\r\nresult[5].mac_list[1].hostname = 00:00:00:1A:66:60\r\nresult[5].mac_list[1] = {&quot;mac&quot;:00:00:00:1A:66:60,&quot;hostname&quot;:00:00:00:1A:66:60}\r\nresult[5].mac_list[2].mac = 00:00:00:09:00:13\r\nresult[5].mac_list[2].hostname = 00:00:00:09:00:13\r\nresult[5].mac_list[2] = {&quot;mac&quot;:00:00:00:09:00:13,&quot;hostname&quot;:00:00:00:09:00:13}\r\nresult[5].mac_list[3].mac = 00:00:00:80:29:7C\r\nresult[5].mac_list[3].hostname = abcd-PLAYER\r\nresult[5].mac_list[3] = {&quot;mac&quot;:00:00:00:80:29:7C,&quot;hostname&quot;:abcd-PLAYER}\r\nresult[5].mac_list[4].mac = 00:00:00:09:00:12\r\nresult[5].mac_list[4].hostname = firewall-net101f-cluster\r\nresult[5].mac_list[4] = {&quot;mac&quot;:00:00:00:09:00:12,&quot;hostname&quot;:firewall-net101f-cluster}\r\nresult[5].mac_list[5].mac = 00:00:00:A0:EF:82\r\nresult[5].mac_list[5].hostname = 00:00:00:A0:EF:82\r\nresult[5].mac_list[5] = {&quot;mac&quot;:00:00:00:A0:EF:82,&quot;hostname&quot;:00:00:00:A0:EF:82}\r\nresult[5].mac_list = [{&quot;mac&quot;:00:00:00:43:B3:73,&quot;hostname&quot;:00:00:00:43:B3:73},{&quot;mac&quot;:00:00:00:1A:66:60,&quot;hostname&quot;:00:00:00:1A:66:60},{&quot;mac&quot;:00:00:00:09:00:13,&quot;hostname&quot;:00:00:00:09:00:13},{&quot;mac&quot;:00:00:00:80:29:7C,&quot;hostname&quot;:abcd-PLAYER},{&quot;mac&quot;:00:00:00:09:00:12,&quot;hostname&quot;:firewall-net101f-cluster},{&quot;mac&quot;:00:00:00:A0:EF:82,&quot;hostname&quot;:00:00:00:A0:EF:82}]\r\nresult[5].name = Sfp lan\r\nresult[5].link = up\r\nresult[5].id = 9999\r\nresult[5].mode = 10000-FD\r\nresult[5].speed = 10000\r\nresult[5].rrd_id = sfp_lan\r\nresult[5] = {&quot;duplex&quot;:auto,&quot;mac_list&quot;:[{&quot;mac&quot;:00:00:00:43:B3:73,&quot;hostname&quot;:00:00:00:43:B3:73},{&quot;mac&quot;:00:00:00:1A:66:60,&quot;hostname&quot;:00:00:00:1A:66:60},{&quot;mac&quot;:00:00:00:09:00:13,&quot;hostname&quot;:00:00:00:09:00:13},{&quot;mac&quot;:00:00:00:80:29:7C,&quot;hostname&quot;:abcd-PLAYER},{&quot;mac&quot;:00:00:00:09:00:12,&quot;hostname&quot;:firewall-net101f-cluster},{&quot;mac&quot;:00:00:00:A0:EF:82,&quot;hostname&quot;:00:00:00:A0:EF:82}],&quot;name&quot;:Sfp lan,&quot;link&quot;:up,&quot;id&quot;:9999,&quot;mode&quot;:10000-FD,&quot;speed&quot;:10000,&quot;rrd_id&quot;:sfp_lan}\r\nresult = [{&quot;duplex&quot;:full,&quot;mac_list&quot;:[{&quot;mac&quot;:00:00:00:2F:8E:AB,&quot;hostname&quot;:firewall-net90d}],&quot;name&quot;:Ethernet 1,&quot;link&quot;:up,&quot;id&quot;:1,&quot;mode&quot;:1000BaseT-FD,&quot;speed&quot;:1000,&quot;rrd_id&quot;:1},{&quot;duplex&quot;:half,&quot;name&quot;:Ethernet 2,&quot;link&quot;:down,&quot;id&quot;:2,&quot;mode&quot;:10BaseT-HD,&quot;speed&quot;:10,&quot;rrd_id&quot;:2},{&quot;duplex&quot;:half,&quot;name&quot;:Ethernet 3,&quot;link&quot;:down,&quot;id&quot;:3,&quot;mode&quot;:10BaseT-HD,&quot;speed&quot;:10,&quot;rrd_id&quot;:3},{&quot;duplex&quot;:half,&quot;name&quot;:Ethernet 4,&quot;link&quot;:down,&quot;id&quot;:4,&quot;mode&quot;:10BaseT-HD,&quot;speed&quot;:10,&quot;rrd_id&quot;:4},{&quot;duplex&quot;:full,&quot;name&quot;:NBAplug,&quot;link&quot;:up,&quot;id&quot;:5,&quot;mode&quot;:1000BaseT-FD,&quot;speed&quot;:1000,&quot;rrd_id&quot;:nbaplug},{&quot;duplex&quot;:auto,&quot;mac_list&quot;:[{&quot;mac&quot;:00:00:00:43:B3:73,&quot;hostname&quot;:00:00:00:43:B3:73},{&quot;mac&quot;:00:00:00:1A:66:60,&quot;hostname&quot;:00:00:00:1A:66:60},{&quot;mac&quot;:00:00:00:09:00:13,&quot;hostname&quot;:00:00:00:09:00:13},{&quot;mac&quot;:00:00:00:80:29:7C,&quot;hostname&quot;:abcd-PLAYER},{&quot;mac&quot;:00:00:00:09:00:12,&quot;hostname&quot;:firewall-net101f-cluster},{&quot;mac&quot;:00:00:00:A0:EF:82,&quot;hostname&quot;:00:00:00:A0:EF:82}],&quot;name&quot;:Sfp lan,&quot;link&quot;:up,&quot;id&quot;:9999,&quot;mode&quot;:10000-FD,&quot;speed&quot;:10000,&quot;rrd_id&quot;:sfp_lan}]\r\n\r\n```\r\n \r\n\r\nAnd I need to write a `jq` dynamic filter (the depth of the json is not predictible) that produce the exact same output in every situations.\r\n\r\n\r\nFor the moment, I did approach the goal with the following filter, but I don&#39;t achieve to put the number of the part of each arrays in &#39;[]&#39; nor removing the first dot &#39;.&#39; and adding the &#39;=&#39; and the value for each keys (or json) value for each lines\r\n\r\n\r\nHere is the `jq` filter : \r\n\r\n\r\n```\r\njq -rc &#39;[paths|map((&quot;.&quot;+strings)//&quot;[]&quot;)|join(&quot;&quot;)][]&#39; \r\n```\r\n\r\nWith this filter, here is the output when processing the previous json : \r\n\r\n\r\n```.success\r\n.result\r\n.result[]\r\n.result[].duplex\r\n.result[].mac_list\r\n.result[].mac_list[]\r\n.result[].mac_list[].mac\r\n.result[].mac_list[].hostname\r\n.result[].name\r\n.result[].link\r\n.result[].id\r\n.result[].mode\r\n.result[].speed\r\n.result[].rrd_id\r\n.result[]\r\n.result[].duplex\r\n.result[].name\r\n.result[].link\r\n.result[].id\r\n.result[].mode\r\n.result[].speed\r\n.result[].rrd_id\r\n.result[]\r\n.result[].duplex\r\n.result[].name\r\n.result[].link\r\n.result[].id\r\n.result[].mode\r\n.result[].speed\r\n.result[].rrd_id\r\n.result[]\r\n.result[].duplex\r\n.result[].name\r\n.result[].link\r\n.result[].id\r\n.result[].mode\r\n.result[].speed\r\n.result[].rrd_id\r\n.result[]\r\n.result[].duplex\r\n.result[].name\r\n.result[].link\r\n.result[].id\r\n.result[].mode\r\n.result[].speed\r\n.result[].rrd_id\r\n.result[]\r\n.result[].duplex\r\n.result[].mac_list\r\n.result[].mac_list[]\r\n.result[].mac_list[].mac\r\n.result[].mac_list[].hostname\r\n.result[].mac_list[]\r\n.result[].mac_list[].mac\r\n.result[].mac_list[].hostname\r\n.result[].mac_list[]\r\n.result[].mac_list[].mac\r\n.result[].mac_list[].hostname\r\n.result[].mac_list[]\r\n.result[].mac_list[].mac\r\n.result[].mac_list[].hostname\r\n.result[].mac_list[]\r\n.result[].mac_list[].mac\r\n.result[].mac_list[].hostname\r\n.result[].mac_list[]\r\n.result[].mac_list[].mac\r\n.result[].mac_list[].hostname\r\n.result[].name\r\n.result[].link\r\n.result[].id\r\n.result[].mode\r\n.result[].speed\r\n.result[].rrd_id\r\n```\r\n\r\n\r\nBASH parsing is not only slow, when using JSON file with more then 10^8 char, bash functions failed to parse (after hours of 100% CPU), and I read in JQ documentation that `jq` can handle json of more than 1 giga bytes size...\r\n\r\nIf a &#39;jq expert&#39; could help here, it would be very appreciated   \r\n\r\nKind regards\r\nnbanba\r\n \r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/79115246/dump-all-key-pair-of-a-json-with-jq",
        "title": "Dump all key pair of a json with JQ"
    },
    {
        "tags": [
            "json",
            "merge",
            "key",
            "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": 1729697186,
                "post_id": 79118603,
                "comment_id": 139509524,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1730748774,
                "last_edit_date": 1730748774,
                "creation_date": 1729697369,
                "answer_id": 79118634,
                "question_id": 79118603,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using [`reduce()`][1]:\r\n```\r\nreduce .[] as $i ({}; .[$i.SysID] += [$i.Name])\r\n```\r\n\r\nWill give \r\n```\r\n{\r\n  &quot;12345&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;def&quot;\r\n  ],\r\n  &quot;23456&quot;: [\r\n    &quot;hij&quot;,\r\n    &quot;klm&quot;,\r\n    &quot;nop&quot;\r\n  ]\r\n}\r\n```\r\n\r\nWhen called with [`--slurp`][2] to wrap those object into an array.\r\n\r\n\r\n----------\r\n\r\n### [JqPlay Demo](https://jqplay.org/s/VQr2-X1KKxWWkHK)\r\n\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#reduce\r\n  [2]: https://jqlang.github.io/jq/manual/#invoking-jq",
                "title": "How to merge json object with same keys?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1730213589,
                "creation_date": 1730213589,
                "answer_id": 79137753,
                "question_id": 79118603,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can also use `group_by` to merge \r\n\r\n```bash\r\njq &#39;group_by(.SysID)|map({(.[0].SysID): map(.Name)})|add&#39;\r\n```\r\n\r\n```console\r\n$ jq &#39;group_by(.SysID)&#39;    \r\n[\r\n  [{&quot;SysID&quot;:&quot;12345&quot;,&quot;Name&quot;:&quot;abc&quot;},{&quot;SysID&quot;:&quot;12345&quot;,&quot;Name&quot;:&quot;def&quot;}],\r\n  [{&quot;SysID&quot;:&quot;23456&quot;,&quot;Name&quot;:&quot;hij&quot;},{&quot;SysID&quot;:&quot;23456&quot;,&quot;Name&quot;:&quot;klm&quot;},{&quot;SysID&quot;:&quot;23456&quot;,&quot;Name&quot;:&quot;nop&quot;}]\r\n]\r\n\r\n$ jq &#39;group_by(.SysID)|map({(.[0].SysID): map(.Name)})&#39;\r\n[\r\n  {&quot;12345&quot;:[&quot;abc&quot;,&quot;def&quot;]},\r\n  {&quot;23456&quot;:[&quot;hij&quot;,&quot;klm&quot;,&quot;nop&quot;]}\r\n]\r\n\r\n$ jq &#39;group_by(.SysID)|map({(.[0].SysID): map(.Name)})|add&#39;\r\n{\r\n  &quot;12345&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;def&quot;\r\n  ],\r\n  &quot;23456&quot;: [\r\n    &quot;hij&quot;,\r\n    &quot;klm&quot;,\r\n    &quot;nop&quot;\r\n  ]\r\n}\r\n```",
                "title": "How to merge json object with same keys?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1730748774,
        "creation_date": 1729696962,
        "last_edit_date": 1729780677,
        "question_id": 79118603,
        "body_markdown": "Here are the 2 items in one array:\r\n\r\n    {\r\n      &quot;SysID&quot;: &quot;12345&quot;,\r\n      &quot;Name&quot;: &quot;abc&quot;\r\n    }\r\n    {\r\n      &quot;SysID&quot;: &quot;12345&quot;,\r\n      &quot;Name&quot;: &quot;def&quot;\r\n    }\r\n    {\r\n      &quot;SysID&quot;: &quot;23456&quot;,\r\n      &quot;Name&quot;: &quot;hij&quot;\r\n    }\r\n    {\r\n      &quot;SysID&quot;: &quot;23456&quot;,\r\n      &quot;Name&quot;: &quot;klm&quot;\r\n    }\r\n    {\r\n      &quot;SysID&quot;: &quot;23456&quot;,\r\n      &quot;Name&quot;: &quot;nop&quot;\r\n    }\r\n\r\nI would like to transform &quot;SysID&quot; into key and &quot;Name&quot; as the value of it in array:\r\n\r\n    {\r\n      &quot;12345&quot;: [\r\n        &quot;abc&quot;,\r\n        &quot;def&quot;,\r\n      ],\r\n      &quot;23456&quot;: [\r\n        &quot;hij&quot;,\r\n        &quot;klm&quot;,\r\n        &quot;nop&quot;,\r\n      ],\r\n    }\r\n\r\nMay I know how could I do that in jq?",
        "link": "https://stackoverflow.com/questions/79118603/how-to-merge-json-object-with-same-keys",
        "title": "How to merge json object with same keys?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "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": 5,
                "creation_date": 1730126896,
                "post_id": 79133886,
                "comment_id": 139537300,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1308678,
                    "reputation": 3496,
                    "user_id": 1257145,
                    "user_type": "registered",
                    "accept_rate": 95,
                    "profile_image": "https://i.sstatic.net/PrHJg.jpg?s=256",
                    "display_name": "mles",
                    "link": "https://stackoverflow.com/users/1257145/mles"
                },
                "reply_to_user": {
                    "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": 1730127243,
                "post_id": 79133886,
                "comment_id": 139537336,
                "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": 3,
                "creation_date": 1730128050,
                "post_id": 79133886,
                "comment_id": 139537451,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1730126950,
        "creation_date": 1730126636,
        "last_edit_date": 1730126950,
        "question_id": 79133886,
        "body_markdown": "This works:\r\n```\r\n#!/bin/sh -e\r\n\r\ncat &lt;&lt; EOF &gt; error.json\r\n[\r\n  {\r\n    &quot;path&quot;: &quot;path1&quot;,\r\n    &quot;path_with_namespace&quot;: &quot;path_with_namespace1&quot;\r\n  },\r\n  {\r\n    &quot;path&quot;: &quot;path2&quot;,\r\n    &quot;path_with_namespace&quot;: &quot;path_with_namespace2&quot;\r\n  }\r\n]\r\nEOF\r\n\r\njq -c &#39;.[]&#39; error.json | while read PROJECT; do\r\n  # This works\r\n  PATH_WITH_NAMESPACE=$(echo &quot;$PROJECT&quot; | jq .path_with_namespace)\r\n  echo &quot;Shallow cloning $PATH_WITH_NAMESPACE ...&quot;\r\ndone\r\n```\r\nOutput:\r\n```\r\n$ ./error.sh \r\nShallow cloning &quot;path_with_namespace1&quot; ...\r\nShallow cloning &quot;path_with_namespace2&quot; ...\r\n```\r\nExtracting a second value does not work:\r\n```\r\n#!/bin/sh -e\r\n\r\ncat &lt;&lt; EOF &gt; error.json\r\n[\r\n  {\r\n    &quot;path&quot;: &quot;path1&quot;,\r\n    &quot;path_with_namespace&quot;: &quot;path_with_namespace1&quot;\r\n  },\r\n  {\r\n    &quot;path&quot;: &quot;path2&quot;,\r\n    &quot;path_with_namespace&quot;: &quot;path_with_namespace2&quot;\r\n  }\r\n]\r\nEOF\r\n\r\njq -c &#39;.[]&#39; error.json | while read PROJECT; do\r\n  # This works\r\n  PATH_WITH_NAMESPACE=$(echo &quot;$PROJECT&quot; | jq .path_with_namespace)\r\n  echo &quot;Shallow cloning $PATH_WITH_NAMESPACE ...&quot;\r\n\r\n  # This does not\r\n  PATH=$(echo &quot;$PROJECT&quot; | jq .path)\r\n  echo &quot;$PATH&quot;\r\ndone\r\n```\r\nOutput:\r\n```\r\n$ ./error.sh \r\nShallow cloning &quot;path_with_namespace1&quot; ...\r\n&quot;path1&quot;\r\n./error.sh: line 18: jq: command not found\r\n```\r\nI&#39;ve tried numerous variants of looping over arrays with bash and jq. Basically I can&#39;t work with more than one key out of the json file. I need to work with more than one. How would a solution look like?\r\n\r\n@0stone0 quoting `&quot;$PROJECT&quot;` has no effect.",
        "link": "https://stackoverflow.com/questions/79133886/can-not-extract-more-than-one-key-when-looping-over-an-array-with-jq-in-bash",
        "title": "Can not extract more than one key when looping over an array with jq in bash"
    },
    {
        "tags": [
            "json",
            "linux",
            "ubuntu",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1730137845,
                "creation_date": 1730137845,
                "answer_id": 79134559,
                "question_id": 79134544,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `keys_unsorted` or `to_entries` to get access to the keys:\r\n```sh\r\n.hosts | keys_unsorted[] as $key\r\n| [$key, (.[$key] | .name, .env, .options)] | @csv\r\n```\r\n[Demo](https://jqplay.org/s/IqcnRe-z74hYJWT)\r\n\r\nor\r\n```sh\r\n.hosts | to_entries[]\r\n| [.key, (.value | .name, .env, .options)] | @csv\r\n```\r\n[Demo](https://jqplay.org/s/GnF1fQWEk9sOQQd)\r\n\r\n```csv\r\n&quot;1.2.3.4&quot;,&quot;name4&quot;,&quot;test&quot;,&quot;&quot;\r\n&quot;1.2.3.5&quot;,&quot;name5&quot;,&quot;prod&quot;,&quot;opt1,opt2&quot;\r\n&quot;1.2.3.6&quot;,&quot;name6&quot;,&quot;qa&quot;,&quot;&quot;\r\n&quot;1.2.3.7&quot;,&quot;name7&quot;,&quot;staging&quot;,&quot;opt3,opt4&quot;\r\n&quot;1.2.3.8&quot;,&quot;name8&quot;,&quot;dev&quot;,&quot;opt5&quot;\r\n&quot;1.2.3.9&quot;,&quot;name9&quot;,&quot;prod&quot;,&quot;opt6,opt7&quot;\r\n```\r\n",
                "title": "jq referencing an index/key with its inner values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1730137957,
                "creation_date": 1730137957,
                "answer_id": 79134568,
                "question_id": 79134544,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "After playing with jqkungfu dot com, I found the solution:\r\n\r\n    jq --raw-output &#39;.hosts | keys_unsorted[] as $k | [$k, .[$k].name, .[$k].env, .[$k].options] | @csv&#39; my_data.json\r\n\r\nWill return the desired output:\r\n\r\n    &quot;1.2.3.4&quot;,&quot;name4&quot;,&quot;test&quot;,&quot;&quot;\r\n    &quot;1.2.3.5&quot;,&quot;name5&quot;,&quot;prod&quot;,&quot;opt1,opt2&quot;\r\n    &quot;1.2.3.6&quot;,&quot;name6&quot;,&quot;qa&quot;,&quot;&quot;\r\n    &quot;1.2.3.7&quot;,&quot;name7&quot;,&quot;statging&quot;,&quot;opt3,opt4&quot;\r\n    &quot;1.2.3.8&quot;,&quot;name8&quot;,&quot;dev&quot;,&quot;opt5&quot;\r\n    &quot;1.2.3.9&quot;,&quot;name9&quot;,&quot;prod&quot;,&quot;opt6,opt7&quot;",
                "title": "jq referencing an index/key with its inner values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1730137957,
        "creation_date": 1730137552,
        "question_id": 79134544,
        "body_markdown": "I have a JSON similar to the following:\r\n\r\nFile: my_data.json\r\n\r\n    {\r\n      &quot;hosts&quot;: {\r\n        &quot;1.2.3.4&quot;: { &quot;name&quot;: &quot;name4&quot;, &quot;env&quot;: &quot;test&quot;, &quot;options&quot;: &quot;&quot; },\r\n        &quot;1.2.3.5&quot;: { &quot;name&quot;: &quot;name5&quot;, &quot;env&quot;: &quot;prod&quot;, &quot;options&quot;: &quot;opt1,opt2&quot; },\r\n        &quot;1.2.3.6&quot;: { &quot;name&quot;: &quot;name6&quot;, &quot;env&quot;: &quot;qa&quot;, &quot;options&quot;: &quot;&quot; },\r\n        &quot;1.2.3.7&quot;: { &quot;name&quot;: &quot;name7&quot;, &quot;env&quot;: &quot;staging&quot;, &quot;options&quot;: &quot;opt3,opt4&quot; },\r\n        &quot;1.2.3.8&quot;: { &quot;name&quot;: &quot;name8&quot;, &quot;env&quot;: &quot;dev&quot;, &quot;options&quot;: &quot;opt5&quot; },\r\n        &quot;1.2.3.9&quot;: { &quot;name&quot;: &quot;name9&quot;, &quot;env&quot;: &quot;prod&quot;, &quot;options&quot;: &quot;opt6,opt7&quot; }\r\n      }\r\n    }\r\n\r\nI want to extract a CSV file out of this, I have tried several options I found by Googling, but none work. My objective is to get something like the following:\r\n\r\n    &quot;1.2.3.4&quot;,&quot;name4&quot;,&quot;test&quot;,&quot;&quot;\r\n    &quot;1.2.3.5&quot;,&quot;name5&quot;,&quot;prod&quot;,&quot;opt1,opt2&quot;\r\n    &quot;1.2.3.6&quot;,&quot;name6&quot;,&quot;dev&quot;,&quot;&quot;\r\n    &quot;1.2.3.7&quot;,&quot;name7&quot;,&quot;staging&quot;,&quot;opt3,opt4&quot;\r\n    &quot;1.2.3.8&quot;,&quot;name8&quot;,&quot;dev&quot;,&quot;opt5&quot;\r\n    &quot;1.2.3.9&quot;,&quot;name9&quot;,&quot;prod&quot;,&quot;opt6,opt7&quot;\r\n\r\nI got the following, but I can&#39;t address the key and I don&#39;t find a way to get it.\r\n\r\n    jq --raw-output &#39;.hosts[] | [.name, .env, .options] | @csv&#39; my_data.json\r\n\r\nThis is my result, but as seen is not complete. How do I add the key to every object?\r\n\r\n    &quot;name4&quot;,&quot;test&quot;,&quot;&quot;\r\n    &quot;name5&quot;,&quot;prod&quot;,&quot;opt1,opt2&quot;\r\n    &quot;name6&quot;,&quot;qa&quot;,&quot;&quot;\r\n    &quot;name7&quot;,&quot;staging&quot;,&quot;opt3,opt4&quot;\r\n    &quot;name8&quot;,&quot;dev&quot;,&quot;opt5&quot;\r\n    &quot;name9&quot;,&quot;prod&quot;,&quot;opt6,opt7&quot;\r\n\r\nI made this:\r\n\r\n    jq --raw-output &#39;.hosts | keys_unsorted[] | [.] | @csv&#39; my_data.json\r\n\r\nBut that only gets the keys, and I have not found a way to address the object by using the key.\r\n\r\n    &quot;1.2.3.4&quot;\r\n    &quot;1.2.3.5&quot;\r\n    &quot;1.2.3.6&quot;\r\n    &quot;1.2.3.7&quot;\r\n    &quot;1.2.3.8&quot;\r\n    &quot;1.2.3.9&quot;\r\n\r\nI could try to join both tables, but This could lead to errors and I know there should be a way to do it in jq, I just can&#39;t find the way.\r\n\r\nI did several google searches and I got one promising, but it does not work:\r\n\r\n    jq --raw-output &#39;.hosts | keys_unsorted[] as $k | [$k, \\(.[$k] | .name), \\(.[$k] | .env), \\(.[$k] | .options)] | @csv&#39; my_data.json\r\n\r\nThis ones returns a compile errors:\r\n\r\n    jq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .hosts | keys_unsorted[] as $k | [$k, \\(.[$k] | .name), \\(.[$k] | .env), \\(.[$k] | .options)] | @csv\r\n    jq: error: syntax error, unexpected &#39;)&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n    .hosts | keys_unsorted[] as $k | [$k, \\(.[$k] | .name), \\(.[$k] | .env), \\(.[$k] | .options)] | @csv\r\n    jq: 2 compile errors\r\n\r\n",
        "link": "https://stackoverflow.com/questions/79134544/jq-referencing-an-index-key-with-its-inner-values",
        "title": "jq referencing an index/key with its inner values"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": false,
                "score": 4,
                "last_activity_date": 1730144243,
                "creation_date": 1730144243,
                "answer_id": 79134879,
                "question_id": 79134868,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Put just the arrays (don&#39;t destructure them with `.[]`) into an outer array, and use `transpose` to zip them. Then, you can iterate over the result array to get the individual sub-arrays.\r\n```sh\r\njq -r &#39;[.timestamps, .values] | transpose[] | @tsv&#39;\r\n```\r\n```\r\n1730135460000\t15\r\n1730137620000\t23\r\n```\r\n[Demo](https://jqplay.org/s/xOq-6AS081kYSmh)",
                "title": "JQ print two arrays values using the same index"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1730144243,
        "creation_date": 1730143942,
        "question_id": 79134868,
        "body_markdown": "in the following example I have two arrays (timestamp and values) that are related by the same index, so timestamps[0] is related to values[0], timestamps[1] is related to values[1], ... \r\n\r\n    {&quot;timestamps&quot;: [&quot;1730135460000&quot;, &quot;1730137620000&quot;], &quot;values&quot; : [&quot;15&quot;, &quot;23&quot;]}\r\n\r\nI need to print each one in a row like this:\r\n\r\n    1730135460000 15\r\n    1730137620000 23\r\n\r\nBut instead I am getting:\r\n\r\n    1730135460000 1730137620000 15 23\r\n\r\nI know this is wrong but wondering if there is a way to achieve what I am looking for\r\n\r\n    echo &#39;{&quot;timestamps&quot;: [&quot;1730135460000&quot;, &quot;1730137620000&quot;], &quot;values&quot; : [&quot;1&quot;, &quot;2&quot;]}&#39; | jq -r &#39;[ .timestamps[], .values[] ] | @tsv&#39;\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/79134868/jq-print-two-arrays-values-using-the-same-index",
        "title": "JQ print two arrays values using the same index"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1730153937,
                "last_edit_date": 1730153937,
                "creation_date": 1730152986,
                "answer_id": 79135220,
                "question_id": 79135057,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since you want to keep the nulls, you could use ? on the RHS:\r\n\r\n```\r\nmap(.comments |= ( (gsub(&quot;\\r\\n&quot;; &quot;&quot;) | gsub(&quot;\\t&quot;; &quot;&quot;))? // null ))   |\r\nmap(.alert_message |= ( (gsub(&quot;\\r\\n&quot;; &quot;&quot;) | gsub(&quot;\\t&quot;; &quot;&quot;))? // null))\r\n```\r\nAnd for brevity, you could combine the two calls to gsub:\r\n```\r\ngsub(&quot;(\\r\\n)|\\t&quot;; &quot;&quot;)\r\n```\r\nNote also that (assuming your jq allows if-without-else) you could simply write:\r\n```\r\nmap(if .comments then gsub(&quot;\\r\\n&quot;; &quot;&quot;) | gsub(&quot;\\t&quot;; &quot;&quot;) end )\r\n```\r\n---\r\n\r\nFor reference, if you wanted to ensure .comments was always a string, you could use `. // &quot;&quot;` on the RHS of the assignment operator:\r\n```\r\nmap(.comments |= (. // &quot;&quot; | gsub(&quot;\\r\\n&quot;; &quot;&quot;) | gsub(&quot;\\t&quot;; &quot;&quot;)))\r\n```\r\n\r\n",
                "title": "In JQ how to safely process optionally null values"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1730212659,
                "creation_date": 1730212659,
                "answer_id": 79137686,
                "question_id": 79135057,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `tostring` if you don&#39;t mind null values converting to a string (`&quot;comments&quot;: &quot;null&quot;`)\r\n\r\n\r\n```\r\njq &#39;map(.comments|=(tostring|gsub(&quot;[\\\\r\\\\n\\\\t]+&quot;;&quot; &quot;)))&#39;\r\n```",
                "title": "In JQ how to safely process optionally null values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1730212659,
        "creation_date": 1730148365,
        "last_edit_date": 1730149976,
        "question_id": 79135057,
        "body_markdown": "I have this JSON:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;alert_timestamp&quot;: &quot;2024-10-23T08:49:08Z&quot;,\r\n    &quot;odin_timestamp&quot;: &quot;2024-10-23T08:50:10Z&quot;,\r\n    &quot;alert_url&quot;: null,\r\n    &quot;comments&quot;: null,\r\n    &quot;owner&quot;: null,\r\n    &quot;updated_date&quot;: null,\r\n    &quot;clear_timestamp&quot;: &quot;2024-10-23T09:27:39Z&quot;,\r\n    &quot;outage_duration_in_minutes&quot;: 38.52,\r\n    &quot;published_on&quot;: &quot;DEFAULT&quot;,\r\n    &quot;atr_exec_id&quot;: null,\r\n    &quot;atr_status&quot;: null\r\n  }\r\n]\r\n```\r\n\r\nAnd, in the even that some fields, like `comments` isn&#39;t null, I need to strip out newlines and tabs. If it is null, then keep it null\r\n\r\nI have tried the following:\r\n\r\n```\r\nmap(.comments? |= (gsub(&quot;\\r\\n&quot;; &quot;&quot;) | gsub(&quot;\\t&quot;; &quot;&quot;))) |\r\nmap(.alert_message? |= (gsub(&quot;\\r\\n&quot;; &quot;&quot;) | gsub(&quot;\\t&quot;; &quot;&quot;)))\r\n```\r\nWhich results in:\r\n```\r\njq: error (at 16.json:338): null (null) cannot be matched, as it is not a string\r\n```\r\n\r\nAnd I have tried the `//` alternative operator:\r\n\r\n```\r\nmap((.comments // &quot;&quot;) |= (gsub(&quot;\\r\\n&quot;; &quot;&quot;) | gsub(&quot;\\t&quot;; &quot;&quot;))) |\r\nmap((.alert_message // &quot;&quot;) |= (gsub(&quot;\\r\\n&quot;; &quot;&quot;) | gsub(&quot;\\t&quot;; &quot;&quot;)))\r\n```\r\nyielding:\r\n```\r\njq: error (at 16.json:338): Invalid path expression with result &quot;&quot;\r\n```\r\n\r\nThere has to be a simple way to handle this without an `if else`",
        "link": "https://stackoverflow.com/questions/79135057/in-jq-how-to-safely-process-optionally-null-values",
        "title": "In JQ how to safely process optionally null values"
    },
    {
        "tags": [
            "shell",
            "jq",
            "zsh",
            "flatmap"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1730169723,
                "creation_date": 1730169723,
                "answer_id": 79135688,
                "question_id": 79135225,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "jq can only read the contents of named files if the filenames are provided on the command line,\r\nso your construction of &#39;{base_file, ack_file}&#39; objects won&#39;t help.\r\nHowever I believe your approach can be made to work by using the bash `while read` idiom\r\nalong the following lines:\r\n```\r\ncat &quot;$SUCCESS_FILE&quot; |\r\n jq -R &#39;.,  (.[:-5] + &quot;_acknowledgement.json&quot;)&#39; |\r\n while read base_file ack_file ; do jq -s add &quot;$base_file&quot; &quot;$ack_file&quot; |\r\n     jq &#39;.&#39;\r\n done\r\n```\r\nwhere &#39;.&#39; in the last-most invocation of jq above is just a place-holder\r\nfor your main program.\r\n\r\n---\r\n\r\nBTW, in future, it would probably be a good idea to adhere more closely\r\nto the [MCVE](/help/mcve) guidelines.\r\n",
                "title": "Nested Json invocation"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1730169723,
        "creation_date": 1730153113,
        "last_edit_date": 1730162433,
        "question_id": 79135225,
        "body_markdown": "I have a jq script like this: \r\n\r\n```shell\r\njq -s &#39;add&#39; \\\r\n    &lt; ./tmp/dispatch_03494ecb-9f72-3233-b4dc-173aa725dc24.json \\\r\n    &lt; ./tmp/dispatch_03494ecb-9f72-3233-b4dc-173aa725dc24_acknowledgement.json | \\\r\n    jq &#39;{ \r\n        success: .result == &quot;ok&quot;, \r\n        event_type, \r\n        start_time, \r\n        end_time \r\n    }&#39;\r\n```\r\n\r\nand I have a file: `$SUCCESS_FILE` containing a bunch of base json  files, ie:\r\n\r\n```\r\n./tmp/dispatch_03494ecb-9f72-3233-b4dc-173aa725dc24.json\r\n```\r\n\r\nWhich I can tranform to get an array of the path to both the base file and the ack file, ie use this: \r\n\r\n\r\n```shell\r\njq -Rn &#39;\r\n    [inputs] |\r\n    map({\r\n        base_file: .,\r\n        ack_file: (.[:-5] + &quot;_acknowledgement.json&quot;)\r\n    })&#39; &lt; &quot;$SUCCESS_FILE&quot; | jq &#39;.&#39;\r\n```\r\n\r\nto get \r\n\r\n```\r\n[\r\n  {\r\n    &quot;base_file&quot;: &quot;tmp/dispatch_03494ecb-9f72-3233-b4dc-173aa725dc24.json&quot;\r\n    &quot;ack_file&quot;: &quot;tmp/dispatch_03494ecb-9f72-3233-b4dc-173aa725dc24_acknowledgement.json&quot;\r\n  },\r\n]\r\n```\r\n\r\nI want to combine the two scripts so that for each element of the said array I do a jq invocation with the values of the keys: `{base_file, ack_file}`\r\n\r\nie, in FP lingo, I want to flatmap the jq invocation demonstrated earlier to the elements of the array as constructed by the latter jq invocation. Have no idea how though. \r\n\r\nIf this is not possible via jq alone, how can I do this in the shell layer? ideally in zsh",
        "link": "https://stackoverflow.com/questions/79135225/nested-json-invocation",
        "title": "Nested Json invocation"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "miller"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1730749704,
                "post_id": 79152067,
                "comment_id": 139579082,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7529773,
                    "reputation": 83,
                    "user_id": 8520561,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xLdLT.jpg?s=256",
                    "display_name": "Magic Thighs",
                    "link": "https://stackoverflow.com/users/8520561/magic-thighs"
                },
                "reply_to_user": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731034271,
                "post_id": 79152067,
                "comment_id": 139601604,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731049570,
                "post_id": 79152067,
                "comment_id": 139602303,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7529773,
                    "reputation": 83,
                    "user_id": 8520561,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xLdLT.jpg?s=256",
                    "display_name": "Magic Thighs",
                    "link": "https://stackoverflow.com/users/8520561/magic-thighs"
                },
                "reply_to_user": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731148695,
                "post_id": 79152067,
                "comment_id": 139609114,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731308672,
                "post_id": 79152067,
                "comment_id": 139616162,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7529773,
                    "reputation": 83,
                    "user_id": 8520561,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xLdLT.jpg?s=256",
                    "display_name": "Magic Thighs",
                    "link": "https://stackoverflow.com/users/8520561/magic-thighs"
                },
                "reply_to_user": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1731422318,
                "post_id": 79152067,
                "comment_id": 139625150,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731429364,
                "post_id": 79152067,
                "comment_id": 139625992,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7529773,
                    "reputation": 83,
                    "user_id": 8520561,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xLdLT.jpg?s=256",
                    "display_name": "Magic Thighs",
                    "link": "https://stackoverflow.com/users/8520561/magic-thighs"
                },
                "reply_to_user": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731624115,
                "post_id": 79152067,
                "comment_id": 139641868,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731625159,
                "post_id": 79152067,
                "comment_id": 139641927,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7529773,
                    "reputation": 83,
                    "user_id": 8520561,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/xLdLT.jpg?s=256",
                    "display_name": "Magic Thighs",
                    "link": "https://stackoverflow.com/users/8520561/magic-thighs"
                },
                "reply_to_user": {
                    "account_id": 394983,
                    "reputation": 5827,
                    "user_id": 757714,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/1da1f58b5de9f3f644952a23528e5907?s=256&d=identicon&r=PG",
                    "display_name": "aborruso",
                    "link": "https://stackoverflow.com/users/757714/aborruso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731648095,
                "post_id": 79152067,
                "comment_id": 139642861,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1730609986,
                "creation_date": 1730609986,
                "answer_id": 79152080,
                "question_id": 79152067,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n``` none\r\nto_entries | map({pair: .key} + (.value | transpose[] | {x: .[0], y: .[1]}))\r\n```",
                "title": "How to use miller mlr or jq to combine two JSON arrays into one array?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1730622765,
                "creation_date": 1730622765,
                "answer_id": 79152325,
                "question_id": 79152067,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can run\r\n\r\n```\r\njq &#39;\r\n  to_entries |\r\n  map(\r\n    .key as $pair |\r\n    .value.x as $xs |\r\n    .value.y as $ys |\r\n    [range(0; $xs | length) | {pair: $pair, x: $xs[.], y: $ys[.]}]\r\n  ) | add\r\n&#39; input.json\r\n```\r\n\r\nto get \r\n\r\n```\r\n[\r\n  {\r\n    &quot;pair&quot;: &quot;btcusd&quot;,\r\n    &quot;x&quot;: 1254700800000,\r\n    &quot;y&quot;: 0.00076394\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;btcusd&quot;,\r\n    &quot;x&quot;: 1254787200000,\r\n    &quot;y&quot;: 0.00076394\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;btcusd&quot;,\r\n    &quot;x&quot;: 1254873600000,\r\n    &quot;y&quot;: 0.00088456\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;btcusd&quot;,\r\n    &quot;x&quot;: 1730419200000,\r\n    &quot;y&quot;: 69513.1578978095\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;xaubtc&quot;,\r\n    &quot;x&quot;: 1254700800000,\r\n    &quot;y&quot;: 1316202.8431552218\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;xaubtc&quot;,\r\n    &quot;x&quot;: 1254787200000,\r\n    &quot;y&quot;: 1359727.2037070976\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;xaubtc&quot;,\r\n    &quot;x&quot;: 1254873600000,\r\n    &quot;y&quot;: 1176008.410961382\r\n  },\r\n  {\r\n    &quot;pair&quot;: &quot;xaubtc&quot;,\r\n    &quot;x&quot;: 1719446400000,\r\n    &quot;y&quot;: 0.037321851310868535\r\n  }\r\n]\r\n```\r\n\r\n1. `to_entries`: Converts the original JSON object into an array of key-value pairs, allowing us to access keys such as &quot;btcusd&quot; and &quot;xaubtc&quot; as named entries (`pair`).\r\n2. `map(...)`: Processes each of the key-value pairs individually by applying the block of code inside.\r\n3. `.key as $pair`: Stores the key (e.g., &quot;btcusd&quot;) in a variable called `$pair` for later use in each iteration.\r\n4. `.value.x as $xs` and `.value.y as $ys`: Stores the `x` and `y` arrays as temporary variables `$xs` and `$ys`, respectively.\r\n5. `[range(0; $xs | length) | ... ]`: Iterates over the indices of the `x` array (and implicitly `y` since they have the same length).\r\n6. `{pair: $pair, x: $xs[.], y: $ys[.]}`: Creates an object for each index that pairs the value from `x` and `y` along with the pair identifier (`pair`). The dot (`.`) represents the current index in the loop.\r\n7. `add`: Combines the results from all iterations of `map` into a single array.",
                "title": "How to use miller mlr or jq to combine two JSON arrays into one array?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -2,
        "last_activity_date": 1730622765,
        "creation_date": 1730609499,
        "question_id": 79152067,
        "body_markdown": "I used to be a jq masochist, but I discovered mlr, which seems to offer the opportunity for more (yet different) pain.\r\n\r\nI found a nice web site that allows me to issue curl commands without API keys, etc., to give me the data I am interested in. The problem being that my chosen tool for displaying the data (Visual Data Tools&#39; Datagraph) cannot parse the emitted JSON.\r\n\r\nI could write something ugly using awk, sed, etc. but it would be more elegant to use something like jq or mlr to achieve this in one line.\r\n\r\nThe (x, y) pairs are in separate arrays. Is there a one-liner that will achieve the below?\r\n\r\nA truncated example of the data that I need to transform. It seems that I could transform JSON to JSON, else JSON to CSV to achieve my goal.\r\n\r\n```\r\n{\r\n    &quot;btcusd&quot;: {\r\n        &quot;x&quot;: [\r\n            1254700800000,\r\n            1254787200000,\r\n            1254873600000,\r\n            1730419200000\r\n        ],\r\n        &quot;y&quot;: [\r\n            0.00076394,\r\n            0.00076394,\r\n            0.00088456,\r\n            69513.1578978095\r\n        ]\r\n    },\r\n    &quot;xaubtc&quot;: {\r\n        &quot;x&quot;: [\r\n            1254700800000,\r\n            1254787200000,\r\n            1254873600000,\r\n            1719446400000\r\n        ],\r\n        &quot;y&quot;: [\r\n            1316202.8431552218,\r\n            1359727.2037070976,\r\n            1176008.410961382,\r\n            0.037321851310868535\r\n        ]\r\n    }\r\n}\r\n```\r\n\r\nAn example of output data that Datagraph can parse (manually created):\r\n\r\n```\r\n[\r\n   {\r\n      &quot;pair&quot; : &quot;btcusd&quot;,\r\n      &quot;x&quot; : 1254700800000,\r\n      &quot;y&quot; : 0.00076394\r\n   },\r\n   {\r\n      &quot;pair&quot; : &quot;btcusd&quot;,\r\n      &quot;x&quot; : 1254787200000,\r\n      &quot;y&quot; : 0.00076394\r\n   },\r\n   {\r\n      &quot;pair&quot; : &quot;btcusd&quot;,\r\n      &quot;x&quot; : 1254873600000,\r\n      &quot;y&quot; : 0.00088456\r\n   },\r\n   {\r\n      &quot;pair&quot; : &quot;btcusd&quot;,\r\n      &quot;x&quot; : 1730419200000,\r\n      &quot;y&quot; : 69513.1578978095\r\n   },\r\n   {\r\n      &quot;pair&quot; : &quot;xaubtc&quot;,\r\n      &quot;x&quot; : 1254700800000,\r\n      &quot;y&quot; : 1316202.84315522\r\n   },\r\n   {\r\n      &quot;pair&quot; : &quot;xaubtc&quot;,\r\n      &quot;x&quot; : 1254787200000,\r\n      &quot;y&quot; : 1359727.2037071\r\n   },\r\n   {\r\n      &quot;pair&quot; : &quot;xaubtc&quot;,\r\n      &quot;x&quot; : 1254873600000,\r\n      &quot;y&quot; : 1176008.41096138\r\n   },\r\n   {\r\n      &quot;pair&quot; : &quot;xaubtc&quot;,\r\n      &quot;x&quot; : 1719446400000,\r\n      &quot;y&quot; : 0.0373218513108685\r\n   }\r\n]\r\n```\r\n\r\nWhich results in this kind of table in Datagraph\r\n\r\n```\r\npair\ty\t                x\r\nbtcusd\t0.00076394      \t1.2547008e12\r\nbtcusd\t0.00076394\t        1.2547872e12\r\nbtcusd\t0.00088456      \t1.2548736e12\r\nbtcusd\t69513.1578978095\t1.7304192e12\r\nxaubtc\t1.31620284315522e6\t1.2547008e12\r\nxaubtc\t1.3597272037071e6\t1.2547872e12\r\nxaubtc\t1.17600841096138e6\t1.2548736e12\r\nxaubtc\t0.0373218513108686\t1.7194464e12\r\n```\r\n\r\nThough this would be better (manually pretty-printed)\r\n\r\n```\r\npair1   x1             y1                pair2   x2             y2\r\nbtcusd  1254700800000  0.00076394        xaubtc  1254700800000  1316202.8431552218\r\nbtcusd  1254787200000  0.00076394        xaubtc  1254787200000  1359727.2037070976\r\nbtcusd  1254873600000  0.00088456        xaubtc  1254873600000  1176008.410961382\r\nbtcusd  1730419200000  69513.1578978095  xaubtc  1719446400000  0.037321851310868535\r\n\r\n```",
        "link": "https://stackoverflow.com/questions/79152067/how-to-use-miller-mlr-or-jq-to-combine-two-json-arrays-into-one-array",
        "title": "How to use miller mlr or jq to combine two JSON arrays into one array?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1730660686,
                "last_edit_date": 1730660686,
                "creation_date": 1730660118,
                "answer_id": 79153411,
                "question_id": 79153399,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For `while read`, just expand the array instead of listing all variable names.\r\n\r\nChange\r\n```sh\r\nwhile IFS=&#39;,&#39; read -r SOURCE_FILE EXIF_CONTAINER EXIF_CODEC EXIF_ENCODER\r\n```\r\ninto\r\n```sh\r\nwhile IFS=&#39;,&#39; read -r &quot;${COLUMNS[@]}&quot;\r\n```\r\n\r\nAs for `jq`, use the `--args` flag to supply multiple arguments at once, populating jq&#39;s `$ARGS.positional` array. Then, here as well, just expand your Bash array as additional arguments.\r\n\r\nChange\r\n```sh\r\njq -r &#39;.[] | &quot;\\(.SOURCE_FILE),\\(.EXIF_CONTAINER),\\(.EXIF_CODEC),\\(.EXIF_ENCODER)&quot;&#39;\r\n```\r\ninto\r\n```\r\njq -r &#39;.[] | [.[$ARGS.positional[]]] | join(&quot;,&quot;)&#39; --args &quot;${COLUMNS[@]}&quot;\r\n```\r\n\r\nNote: Watch out for upper/lower case column/field names (e.g. `SourceFile` vs. `SOURCE_FILE`), and better use lowercase variable names in Bash (e.g. `columns` instead of `COLUMNS`)",
                "title": "While Loop Read and JQ, use array list of column names"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1730660686,
        "creation_date": 1730659697,
        "question_id": 79153399,
        "body_markdown": "I want to pass a &quot;array&quot; to the while loop so I don&#39;t have to repeat the column names\r\n\r\n    COLUMNS=(&quot;SOURCE_FILE&quot; &quot;EXIF_CONTAINER&quot; &quot;EXIF_CODEC&quot; &quot;EXIF_ENCODER&quot;)\r\n\r\n    while IFS=&#39;,&#39; read -r SOURCE_FILE EXIF_CONTAINER EXIF_CODEC EXIF_ENCODER\r\n    do\r\n\t   #Do Processing here \r\n    done &lt; &lt;(\r\n       echo &quot;$EXIF_DATA&quot;  | jq -cr &#39;.[] | &quot;\\(.SourceFile),\\(.EXIF_CONTAINER),\\(.EXIF_CODEC), \\(.EXIF_ENCODER)&quot;&#39;\r\n    )\r\n\r\nHow do I make the &quot;while loop read&quot; and &quot;jq&quot; use the COLUMNS list instead of having to repeat the column names?",
        "link": "https://stackoverflow.com/questions/79153399/while-loop-read-and-jq-use-array-list-of-column-names",
        "title": "While Loop Read and JQ, use array list of column names"
    },
    {
        "tags": [
            "json",
            "merge",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1731552107,
                "last_edit_date": 1731552107,
                "creation_date": 1730750175,
                "answer_id": 79156822,
                "question_id": 79156798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I&#39;d use `to_entries` (to access keys and values) as part of the iteration:\r\n```sh\r\nreduce (.[] | to_entries[]) as $e ({}; .[$e.key] += [$e.value])\r\n```\r\n[Demo](https://jqplay.org/s/GRTJep5-Cg-kjjc)\r\n\r\nHere&#39;s another way using `group_by` to bring the matching items together:\r\n```sh\r\nmap(to_entries[]) | group_by(.key) | map({(first.key): map(.value)}) | add\r\n```\r\n[Demo](https://jqplay.org/s/KnEukeJF17ngfWd)\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;first&quot;: [\r\n    12355,\r\n    89010,\r\n    23423,\r\n    23456,\r\n    11111\r\n  ],\r\n  &quot;second&quot;: [\r\n    &quot;abc&quot;,\r\n    &quot;def&quot;,\r\n    &quot;hij&quot;,\r\n    &quot;klm&quot;,\r\n    &quot;nop&quot;\r\n  ]\r\n}\r\n```\r\n\r\n---\r\nNote: These solutions expect all input objects to have the same set of keys. Missing keys in single objects will lead to shortened, thus potentially misaligned output arrays. To readjust the arrays by pitching in `null` values, normalize the objects before destructuring them into entries by reconstructing them using a pre-defined set of keys, e.g. `{first, second}`:\r\n```sh\r\nreduce (.[] | {first, second} | to_entries[]) as $e …\r\n# or\r\nmap({first, second} | to_entries[]) | group_by(.key) …\r\n```\r\nIf, however, the actual set of keys is dynamic or unknown, screen and collect them first, e.g. using `(map(keys[]) | unique) as $keys`, then normalize based on that set using `pick(.[$keys[]])` (`pick` was introduced with jq 1.7; older versions could use `.[$keys[]] //= null` instead):\r\n```sh\r\n(map(keys[]) | unique) as $keys\r\n| reduce (.[] | pick(.[$keys[]]) | to_entries[]) as $e …\r\n# or\r\n(map(keys[]) | unique) as $keys\r\n| map(pick(.[$keys[]]) | to_entries[]) | group_by(.key) …\r\n```",
                "title": "in jq, how to merge an array of object into 1 object with an array of values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1730763947,
                "creation_date": 1730763947,
                "answer_id": 79157309,
                "question_id": 79156798,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Or for simplicity, consider using `transpose`, e.g.\r\n```\r\nmap([.[]]) | transpose | {first: first, second: .[1]}\r\n```",
                "title": "in jq, how to merge an array of object into 1 object with an array of values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1731552107,
        "creation_date": 1730749779,
        "last_edit_date": 1730764002,
        "question_id": 79156798,
        "body_markdown": "Let&#39;s say I have this json:\r\n```json\r\n[\r\n  {\r\n    &quot;first&quot;: 12355,\r\n    &quot;second&quot;: &quot;abc&quot;\r\n  },\r\n  {\r\n    &quot;first&quot;: 89010,\r\n    &quot;second&quot;: &quot;def&quot;\r\n  },\r\n  {\r\n    &quot;first&quot;: 23423,\r\n    &quot;second&quot;: &quot;hij&quot;\r\n  },\r\n  {\r\n    &quot;first&quot;: 23456,\r\n    &quot;second&quot;: &quot;klm&quot;\r\n  },\r\n  {\r\n    &quot;first&quot;: 11111,\r\n    &quot;second&quot;: &quot;nop&quot;\r\n  }\r\n]\r\n```\r\nAnd I would like (a generic form) that merges them into 1 object where the value of each key is merged into an array of the corresponding values:\r\n\r\n```json\r\n{\r\n    &quot;first&quot; : [12355,89010,23423,23456,11111],\r\n    &quot;second&quot; : [&quot;abc&quot;,&quot;def&quot;,&quot;hij&quot;,&quot;klm&quot;,&quot;nop&quot;]\r\n}\r\n```\r\nI was trying this, but it produces no output at all. \r\n```\r\nreduce .[] as $final (\r\n    {};\r\n    ((. | keys) as $k |\r\n        map(\r\n            ( (.[$k] // []) += ($final[$k] // []))\r\n        )\r\n    )\r\n)\r\n```",
        "link": "https://stackoverflow.com/questions/79156798/in-jq-how-to-merge-an-array-of-object-into-1-object-with-an-array-of-values",
        "title": "in jq, how to merge an array of object into 1 object with an array of values"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1730915208,
                "creation_date": 1730915208,
                "answer_id": 79163713,
                "question_id": 79163698,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Save the `toDo` array for reference, iterate over the target items, and update them with `|=` using `select` with `inside` to filter for containedness:\r\n```sh\r\n. as {$toDo}\r\n| (.places[].[&quot;fThings&quot;, &quot;sThings&quot;] | arrays[]) |= select(inside($toDo[]))\r\n```\r\n```json\r\n{\r\n  &quot;places&quot;: [\r\n    {\r\n      &quot;location&quot;: &quot;wapc1&quot;,\r\n      &quot;type&quot;: &quot;pcs,cstrl,refdoc&quot;,\r\n      &quot;fGroup&quot;: &quot;cert-apc-1&quot;,\r\n      &quot;fThings&quot;: [\r\n        &quot;pcs_app#2.1#bp&quot;,\r\n        &quot;pcs_app#2.1#bp&quot;,\r\n        &quot;pcs_app#2.1#cc&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wapc2&quot;,\r\n      &quot;type&quot;: &quot;pcs,cstrl&quot;,\r\n      &quot;fGroup&quot;: &quot;cert-apc-2&quot;,\r\n      &quot;fThings&quot;: []\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wapc3&quot;,\r\n      &quot;type&quot;: &quot;pcs,prx,cstrl&quot;,\r\n      &quot;fGroup&quot;: &quot;cert-apc-3&quot;,\r\n      &quot;fThings&quot;: [\r\n        &quot;pcs_app#2.1#d2c&quot;,\r\n        &quot;pcs_app#2.1#ci&quot;,\r\n        &quot;pcs_app#2.1#co&quot;,\r\n        &quot;pcs_app#2.1#dq&quot;\r\n      ],\r\n      &quot;aThings&quot;: [\r\n        &quot;prx&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wapc4&quot;,\r\n      &quot;type&quot;: &quot;pcs,prx,cstrl&quot;,\r\n      &quot;fGroup&quot;: &quot;cert-apc-4&quot;,\r\n      &quot;fThings&quot;: [],\r\n      &quot;aThings&quot;: [\r\n        &quot;prx&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc1&quot;,\r\n      &quot;type&quot;: &quot;bsrv&quot;,\r\n      &quot;sGroup&quot;: [\r\n        &quot;cert-bs-1&quot;\r\n      ],\r\n      &quot;sThings&quot;: [\r\n        &quot;config_svc#1&quot;,\r\n        &quot;erec_svc#1.27&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc2&quot;,\r\n      &quot;type&quot;: &quot;bsrv&quot;,\r\n      &quot;sGroup&quot;: [\r\n        &quot;cert-bs-2&quot;\r\n      ],\r\n      &quot;sThings&quot;: [\r\n        &quot;erec_svc#1.27&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc3&quot;,\r\n      &quot;type&quot;: &quot;bsrv,r-bsrv&quot;,\r\n      &quot;sGroup&quot;: [\r\n        &quot;cert-bs-3&quot;,\r\n        &quot;cert-rs&quot;\r\n      ],\r\n      &quot;sThings&quot;: [\r\n        &quot;erec_svc#1.27&quot;,\r\n        &quot;config_svc#1&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc4&quot;,\r\n      &quot;type&quot;: &quot;bsrv,r-bsrv&quot;,\r\n      &quot;sGroup&quot;: [\r\n        &quot;cert-bs-4&quot;,\r\n        &quot;cert-rs&quot;\r\n      ],\r\n      &quot;sThings&quot;: [\r\n        &quot;erec_svc#1.27&quot;,\r\n        &quot;config_svc#1&quot;,\r\n        &quot;bp_svc#1.46&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;toDo&quot;: [\r\n    &quot;bp_svc#1.46##1.46.0-2410.0-03&quot;,\r\n    &quot;config_svc#1##1.12-2410.0-05&quot;,\r\n    &quot;erec_svc#1.27##1.27-2410.0-03&quot;,\r\n    &quot;pcs_app#2.1#bp##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#ci##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#co##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#cc##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#dq##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#d2c##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#df##2.1-2410.0-05&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/lZJo2sJpPGRtF-E)",
                "title": "Eliminate items from multiple element arrays based on partial matches to another array"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1730915208,
        "creation_date": 1730914901,
        "question_id": 79163698,
        "body_markdown": "Given the JSON below, I am struggling for a jq query that will eliminate any items in ```places[].fThings[]``` or ```places.sThings[]``` that are not a partial string match to any of the strings found in ```toDo[]```.  It should be noted not all ```places``` will have ```fThings``` or ```sThings``` present.  While it most likely be one or the other, *both or neither* could be present.  \r\n\r\nThe output should be the same as the input with the non-matching *Things items filtered out. Empty arrays are fine to return.\r\n\r\nI&#39;ve tried a great many combinations of ```map(select(any(index(...))))``` as well as ```contains``` but I&#39;m tripping over my own feet with ```Cannot index``` or ```Cannot iterate``` errors and fear I have missed something obvious.\r\n\r\n```\r\n{\r\n  &quot;places&quot;: [\r\n    {\r\n      &quot;location&quot;: &quot;wapc1&quot;,\r\n      &quot;type&quot;: &quot;pcs,cstrl,refdoc&quot;,\r\n      &quot;fGroup&quot;: &quot;cert-apc-1&quot;,\r\n      &quot;fThings&quot;: [\r\n        &quot;pcs_app#2.1#bp&quot;,\r\n        &quot;pcs_app#2.0#bp&quot;,\r\n        &quot;pcs_app#2.1#bp&quot;,\r\n        &quot;pcs_app#2.1#cc&quot;,\r\n        &quot;pcs_app#2.1#ex_acct&quot;,\r\n        &quot;pcs_app#2.1#repr&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wapc2&quot;,\r\n      &quot;type&quot;: &quot;pcs,cstrl&quot;,\r\n      &quot;fGroup&quot;: &quot;cert-apc-2&quot;,\r\n      &quot;fThings&quot;: [\r\n        &quot;pcs_app#2.1#mts&quot;,\r\n        &quot;pcs_app#2.1#mts&quot;,\r\n        &quot;pcs_app#2.1#mta&quot;,\r\n        &quot;pcs_app#2.1#mtr&quot;,\r\n        &quot;pcs_app#2.1#mop&quot;,\r\n        &quot;pcs_app#2.1#mor&quot;,\r\n        &quot;pcs_app#2.1#mov&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wapc3&quot;,\r\n      &quot;type&quot;: &quot;pcs,prx,cstrl&quot;,\r\n      &quot;fGroup&quot;: &quot;cert-apc-3&quot;,\r\n      &quot;fThings&quot;: [\r\n        &quot;pcs_app#2.1#d2c&quot;,\r\n        &quot;pcs_app#2.1#ci&quot;,\r\n        &quot;pcs_app#2.1#co&quot;,\r\n        &quot;pcs_app#2.1#gr&quot;,\r\n        &quot;pcs_app#2.1#repr&quot;,\r\n        &quot;pcs_app#2.1#refr&quot;,\r\n        &quot;pcs_app#2.1#gf&quot;,\r\n        &quot;pcs_app#2.1#dq&quot;\r\n      ],\r\n      &quot;aThings&quot;: [\r\n        &quot;prx&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wapc4&quot;,\r\n      &quot;type&quot;: &quot;pcs,prx,cstrl&quot;,\r\n      &quot;fGroup&quot;: &quot;cert-apc-4&quot;,\r\n      &quot;fThings&quot;: [\r\n        &quot;pcs_app#2.1#mtr&quot;,\r\n        &quot;pcs_app#2.1#mtstat&quot;,\r\n        &quot;pcs_app#2.1#mop&quot;\r\n      ],\r\n      &quot;aThings&quot;: [\r\n        &quot;prx&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc1&quot;,\r\n      &quot;type&quot;: &quot;bsrv&quot;,\r\n      &quot;sGroup&quot;: [\r\n        &quot;cert-bs-1&quot;\r\n      ],\r\n      &quot;sThings&quot;: [\r\n        &quot;ci_svc#1.35.0&quot;,\r\n        &quot;config_svc#1&quot;,\r\n        &quot;erec_svc#1.27&quot;,\r\n        &quot;hm_svc#1.34.0&quot;,\r\n        &quot;ri_svc#1.0.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc2&quot;,\r\n      &quot;type&quot;: &quot;bsrv&quot;,\r\n      &quot;sGroup&quot;: [\r\n        &quot;cert-bs-2&quot;\r\n      ],\r\n      &quot;sThings&quot;: [\r\n        &quot;erec_svc#1.27&quot;,\r\n        &quot;profile_svc#1.7&quot;,\r\n        &quot;mor_svc#1.33.0&quot;,\r\n        &quot;mta_svc#1.31.0&quot;,\r\n        &quot;mtr_svc#1.39.0&quot;,\r\n        &quot;mtstat_svc#1.35.0&quot;,\r\n        &quot;ri_svc#1.0.0&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc3&quot;,\r\n      &quot;type&quot;: &quot;bsrv,r-bsrv&quot;,\r\n      &quot;sGroup&quot;: [\r\n        &quot;cert-bs-3&quot;,\r\n        &quot;cert-rs&quot;\r\n      ],\r\n      &quot;sThings&quot;: [\r\n        &quot;co_svc#1.36.0&quot;,\r\n        &quot;d2c_svc#1.34.0&quot;,\r\n        &quot;erec_svc#1.27&quot;,\r\n        &quot;gr_svc#1.19.0&quot;,\r\n        &quot;profile_svc#1.7&quot;,\r\n        &quot;config_svc#1&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;location&quot;: &quot;wwc4&quot;,\r\n      &quot;type&quot;: &quot;bsrv,r-bsrv&quot;,\r\n      &quot;sGroup&quot;: [\r\n        &quot;cert-bs-4&quot;,\r\n        &quot;cert-rs&quot;\r\n      ],\r\n      &quot;sThings&quot;: [\r\n        &quot;erec_svc#1.27&quot;,\r\n        &quot;profile_svc#1.7&quot;,\r\n        &quot;mtstat_svc#1.35.0&quot;,\r\n        &quot;config_svc#1&quot;,\r\n\t\t&quot;bp_svc#1.46&quot;\r\n      ]\r\n    }\r\n  ],\r\n  &quot;toDo&quot;: [\r\n    &quot;bp_svc#1.46##1.46.0-2410.0-03&quot;,\r\n    &quot;config_svc#1##1.12-2410.0-05&quot;,\r\n    &quot;erec_svc#1.27##1.27-2410.0-03&quot;,\r\n    &quot;pcs_app#2.1#bp##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#ci##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#co##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#cc##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#dq##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#d2c##2.1-2410.0-05&quot;,\r\n    &quot;pcs_app#2.1#df##2.1-2410.0-05&quot;\r\n  ]\r\n}\r\n```\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/79163698/eliminate-items-from-multiple-element-arrays-based-on-partial-matches-to-another",
        "title": "Eliminate items from multiple element arrays based on partial matches to another array"
    },
    {
        "tags": [
            "jq",
            "vault"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1730986451,
                "post_id": 79166665,
                "comment_id": 139597709,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1730987799,
                "last_edit_date": 1730987799,
                "creation_date": 1730986537,
                "answer_id": 79166683,
                "question_id": 79166665,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;ll need to [output raw (`-r`)][1] and combine the array into a single output (`[]`).\r\n\r\nDon&#39;t forget an `&gt; ca.crt` to actually [write the output to a file][2].\r\n\r\n```\r\nwget ... | jq -r &#39;.data.ca_chain[]&#39; &gt; ca.crt\r\n```\r\n\r\n\r\n----------\r\n\r\nFrom OP&#39;s comment, to save this in a variable before writing to a file:\r\n```\r\nresult=&quot;$(wget ... | jq -r &#39;.data.ca_chain[]&#39; &gt; ca.crt)&quot;\r\necho -e &quot;Final cert:\\n $result&quot;\r\necho &quot;$result&quot; &gt; ca.crt \r\n```\r\n\r\nDon&#39;t forget the quotes (`&quot;&quot;`) around bash variables, those are very important in this case:\r\n* &lt;https://stackoverflow.com/questions/10067266/when-to-wrap-quotes-around-a-shell-variable&gt;\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#invoking-jq\r\n  [2]: https://stackoverflow.com/questions/11162406/open-and-write-data-to-text-file-using-bash",
                "title": "extract ca chain that has multiple CA as list from vault using jq and format into single ca.crt file"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1730987799,
        "creation_date": 1730986354,
        "last_edit_date": 1730986699,
        "question_id": 79166665,
        "body_markdown": "I trying to generate certs uisng vault pki role. How can i create a single file called ca.crt from the wget command output.\r\n\r\n\r\n```\r\n$ wget --method=POST --header=&quot;X-Vault-Namespace: ns&quot; --header=&quot;X-Vault-Token: $VAULT_TOKEN&quot; --body-data=&#39;{&quot;common_name&quot;: &quot;test.example.com&quot;, &quot;ttl&quot;: &quot;5m&quot;}&#39; https://127.0.0.1:8200/v1/pki/dev/issuing_ca/issue/dev -q -O - | jq &#39;.data.ca_chain&#39;\r\nResponse\r\n[\r\n  &quot;-----BEGIN CERTIFICATE-----\\nMIIF5jCCA86W6j2PehfjWs3\\nR55ogX1Z2jk/dvIIp.......Z067gh7nrDE56fzhyA=\\n-----END CERTIFICATE-----&quot;,\r\n  &quot;-----BEGIN CERTIFICATE-----\\nMIIF4DCCA8iNzdTHItwqVl1cTglr6bcry0vckey68u+.......4gR0CRtJ\\nCaLcNKCBGi/jn6pekNVvgjBamsM=\\n-----END CERTIFICATE-----&quot;,\r\n  &quot;-----BEGIN CERTIFICATE-----\\nMIIFMzCCAxnNDE5MTlaFwumZ8\\nHL8n10r0b35LtMT........CxSXIjAZJRE8Fh9jOIm0\\n-----END CERTIFICATE-----&quot;\r\n]\r\n\r\n```\r\n\r\n\r\n```\r\n$ cat ca.crt\r\n\r\n-----BEGIN CERTIFICATE-----\r\nMIIF5jCCA86W6j2PehfjWs3\r\n.\r\n.\r\n-----END CERTIFICATE-----\r\n-----BEGIN CERTIFICATE-----\r\nMIIF5jCCA86W6j2PehfjWs3\r\n.\r\n.\r\n-----END CERTIFICATE-----\r\n-----BEGIN CERTIFICATE-----\r\nnMIIF4DCCA8iNzdTHItwqVl1c\r\n.\r\n.\r\n-----END CERTIFICATE-----\r\n```",
        "link": "https://stackoverflow.com/questions/79166665/extract-ca-chain-that-has-multiple-ca-as-list-from-vault-using-jq-and-format-int",
        "title": "extract ca chain that has multiple CA as list from vault using jq and format into single ca.crt file"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1731099699,
                "post_id": 79171538,
                "comment_id": 139607360,
                "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": 1,
                "creation_date": 1731101069,
                "post_id": 79171538,
                "comment_id": 139607457,
                "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": 1731101258,
                "post_id": 79171538,
                "comment_id": 139607470,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1731134562,
        "creation_date": 1731099347,
        "last_edit_date": 1731134562,
        "question_id": 79171538,
        "body_markdown": "I&#39;m trying to get a value from the Json and add it to another field of the same json file. I need to do it in a lot of file so I&#39;m using a loop:\r\n\r\n    for i in $(find . -name \\*.txt); do \r\n        valorAPoner=$(cat $i | jq -r .Name); \r\n        tmp=$(mktemp);\r\n        jq -r &#39;.Authentication.ExternalProvider.LdapUserAndDomain |= &quot;$valorAPoner&quot;&#39; $i  &gt; &quot;$tmp&quot; &amp;&amp; mv &quot;$tmp&quot; $i.json; \r\n    done\r\n\r\n\r\nBut when I open $i.json it shows me:\r\n\r\n    {\r\n      &quot;Name&quot;: &quot;dsfdsf&quot;,\r\n      &quot;FullName&quot;: &quot;xxxxx&quot;,\r\n      &quot;Authentication&quot;: {\r\n        &quot;ExternalProvider&quot;: {\r\n          &quot;LdapUserAndDomain&quot;: &quot;$valorAPoner&quot;\r\n\r\nI see the string literal of the variable (valorAPoner) but  I need the value of the variable. Do you know how to answer it?\r\n\r\nThanks",
        "link": "https://stackoverflow.com/questions/79171538/how-to-dynamically-replace-value-with-jq-in-bash",
        "title": "How to dynamically replace value with jq in bash"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 953149,
                    "reputation": 184295,
                    "user_id": 978917,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/92d059913eace78a868a3e87f98e0a57?s=256&d=identicon&r=PG",
                    "display_name": "ruakh",
                    "link": "https://stackoverflow.com/users/978917/ruakh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731281917,
                "post_id": 79176022,
                "comment_id": 139615162,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1486587,
                    "reputation": 15479,
                    "user_id": 1394729,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/B9Ri8.jpg?s=256",
                    "display_name": "tink",
                    "link": "https://stackoverflow.com/users/1394729/tink"
                },
                "reply_to_user": {
                    "account_id": 106364,
                    "reputation": 165516,
                    "user_id": 283366,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/9ad213d8adabe4b64c2d53c5e0e3cab4?s=256&d=identicon&r=PG",
                    "display_name": "Phil",
                    "link": "https://stackoverflow.com/users/283366/phil"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731281919,
                "post_id": 79176022,
                "comment_id": 139615163,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1486587,
                    "reputation": 15479,
                    "user_id": 1394729,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/B9Ri8.jpg?s=256",
                    "display_name": "tink",
                    "link": "https://stackoverflow.com/users/1394729/tink"
                },
                "reply_to_user": {
                    "account_id": 953149,
                    "reputation": 184295,
                    "user_id": 978917,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/92d059913eace78a868a3e87f98e0a57?s=256&d=identicon&r=PG",
                    "display_name": "ruakh",
                    "link": "https://stackoverflow.com/users/978917/ruakh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731282002,
                "post_id": 79176022,
                "comment_id": 139615167,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 953149,
                    "reputation": 184295,
                    "user_id": 978917,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/92d059913eace78a868a3e87f98e0a57?s=256&d=identicon&r=PG",
                    "display_name": "ruakh",
                    "link": "https://stackoverflow.com/users/978917/ruakh"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1731282479,
                "post_id": 79176022,
                "comment_id": 139615183,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1486587,
                    "reputation": 15479,
                    "user_id": 1394729,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/B9Ri8.jpg?s=256",
                    "display_name": "tink",
                    "link": "https://stackoverflow.com/users/1394729/tink"
                },
                "reply_to_user": {
                    "account_id": 953149,
                    "reputation": 184295,
                    "user_id": 978917,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/92d059913eace78a868a3e87f98e0a57?s=256&d=identicon&r=PG",
                    "display_name": "ruakh",
                    "link": "https://stackoverflow.com/users/978917/ruakh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731283067,
                "post_id": 79176022,
                "comment_id": 139615206,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 953149,
                    "reputation": 184295,
                    "user_id": 978917,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/92d059913eace78a868a3e87f98e0a57?s=256&d=identicon&r=PG",
                    "display_name": "ruakh",
                    "link": "https://stackoverflow.com/users/978917/ruakh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731283389,
                "post_id": 79176022,
                "comment_id": 139615211,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1486587,
                    "reputation": 15479,
                    "user_id": 1394729,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/B9Ri8.jpg?s=256",
                    "display_name": "tink",
                    "link": "https://stackoverflow.com/users/1394729/tink"
                },
                "reply_to_user": {
                    "account_id": 953149,
                    "reputation": 184295,
                    "user_id": 978917,
                    "user_type": "registered",
                    "accept_rate": 86,
                    "profile_image": "https://www.gravatar.com/avatar/92d059913eace78a868a3e87f98e0a57?s=256&d=identicon&r=PG",
                    "display_name": "ruakh",
                    "link": "https://stackoverflow.com/users/978917/ruakh"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731283525,
                "post_id": 79176022,
                "comment_id": 139615213,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1731283722,
                "creation_date": 1731283722,
                "answer_id": 79176074,
                "question_id": 79176022,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; The suggested dupe&#39;s syntax gives me a sequence of `explode input must be a string` errors (1 per line of govc output).\r\n\r\nThat&#39;s because one of your devices doesn&#39;t have the `MacAddress` field, and `ascii_downcase` only supports strings, not `null`.\r\n\r\nTo fix this, you can use `// &quot;&quot;` \\[[doc link](https://jqlang.github.io/jq/manual/#alternative-operator)\\] to default to the empty string, and *then* pass that through `ascii_downcase`:\r\n\r\n```\r\ngovc object.collect -json -type m / config.hardware.device \\\r\n  | jq -r &#39;\r\n      .\r\n      | select(.ChangeSet[].Val.VirtualDevice[].MacAddress // &quot;&quot; | ascii_downcase == &quot;00:50:56:bc:5e:3c&quot;)\r\n      | [.Obj.Type, .Obj.Value]\r\n      | join(&quot;:&quot;)\r\n    &#39; \\\r\n  | xargs govc ls -L\r\n```",
                "title": "Case-insensitive check in `jq` for equality"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1731293359,
                "creation_date": 1731293359,
                "answer_id": 79176254,
                "question_id": 79176022,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; it outputs the names of **every** vm, whether they have that MAC or not ...\r\n\r\nEach `…[]` in `.ChangeSet[].Val.VirtualDevice[].MacAddress` creates a stream of potentially more than one result. In the sample given, `.ChangeSet[]` produces one item, and (for each of them) `.Val.VirtualDevice` evaluates to two items, creating a combined stream of two items. If you want to reduce this stream to a binary decision (zero or one items only), use an aggregate function that performs this conversion. For example, if you want `select` to return with one item if at least one of them passes the test, use the `any` [function](https://jqlang.github.io/jq/manual/#any).\r\n\r\n(Also, I&#39;m preferring `strings` over `// &quot;&quot;`, so items without a `.MacAddress` are filtered out immediately instead of replacing them with an empty string that only fails after when compared to another literal string.)\r\n\r\n```sh\r\nselect(any(\r\n  .ChangeSet[].Val.VirtualDevice[].MacAddress | strings;\r\n  ascii_downcase == &quot;00:50:56:bc:5e:3c&quot;\r\n))\r\n| [.Obj.Type, .Obj.Value]\r\n| join(&quot;:&quot;)\r\n```\r\n```\r\nVirtualMachine:vm-666\r\n```\r\n[Demo](https://jqplay.org/s/jJAh8jKVmcsKZAo)",
                "title": "Case-insensitive check in `jq` for equality"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1731296810,
                "creation_date": 1731296810,
                "answer_id": 79176326,
                "question_id": 79176022,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming that normalizing MacAddress to ascii_downcase would be sufficient,   one approach would be to add a pre-processing filter using `walk` like so:\r\n```\r\nwalk(if type == &quot;object&quot; and has(&quot;MacAddress&quot;) \r\n     then .MacAddress |= ascii_downcase end)\r\n```\r\nYou might want a more targeted approach, but the above can still serve as a guide. (*) \r\n\r\nAnother approach would be to use regexp-based matching with the &quot;i&quot; option to &quot;ignore case&quot;, i.e. test(_,&quot;i&quot;).  This would be the recommended approach in cases where `ascii_downcase` doesn&#39;t cut the mustard.\r\n\r\n---\r\n\r\n(*) If your jq is sufficiently antiquated, you&#39;d have to include `else .` as well.",
                "title": "Case-insensitive check in `jq` for equality"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1731296810,
        "creation_date": 1731280957,
        "last_edit_date": 1731283874,
        "question_id": 79176022,
        "body_markdown": "I found the following on the govc [govmomi github pages][1], which allows me to search for VMs by MAC address:\r\n\r\n```bash\r\ngovc object.collect -json -type m / config.hardware.device \\\r\n  | jq -r &#39;\r\n      .\r\n      | select(.ChangeSet[].Val.VirtualDevice[].MacAddress == &quot;00:50:56:bc:5e:3c&quot;)\r\n      | [.Obj.Type, .Obj.Value]\r\n      | join(&quot;:&quot;)\r\n    &#39; \\\r\n  | xargs govc ls -L\r\n```\r\n\r\nPlease find attached a snippet of govc output that should suffice:\r\n```bash\r\n{\r\n  &quot;Obj&quot;: {\r\n    &quot;Type&quot;: &quot;VirtualMachine&quot;,\r\n    &quot;Value&quot;: &quot;vm-666&quot;\r\n  },\r\n  &quot;ChangeSet&quot;: [\r\n    {\r\n      &quot;Val&quot;: {\r\n        &quot;VirtualDevice&quot;: [\r\n          {\r\n          },\r\n          {\r\n            &quot;MacAddress&quot;: &quot;00:50:56:bc:5e:3c&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n\r\nThe problem I&#39;m facing is that some MACs contain upper, some lower case letters, and I don&#39;t know ahead of time which machine uses which scheme. \r\nI can&#39;t figure out how to make the `==` case insensitive.\r\n\r\nI have found answers here on stackoverflow that suggest using `ascii_downcase` as a filter, but I don&#39;t know how to apply that w/ the `==`.\r\n\r\nThe syntax suggested at https://stackoverflow.com/a/62454688 gives me a sequence of `explode input must be a string` errors (1 per line of govc output).\r\n\r\n\r\nIn case this matters for this exercise: this is happening on `Mac OS 15.1`, `jq` is installed via brew, version is `1.7.1`.\r\n\r\n  [1]: https://github.com/vmware/govmomi/issues/1201",
        "link": "https://stackoverflow.com/questions/79176022/case-insensitive-check-in-jq-for-equality",
        "title": "Case-insensitive check in `jq` for equality"
    },
    {
        "tags": [
            "linux",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 316835,
                    "reputation": 118194,
                    "user_id": 997358,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f849cfde4e526e22e916fa69103ef7e7?s=256&d=identicon&r=PG",
                    "display_name": "peak",
                    "link": "https://stackoverflow.com/users/997358/peak"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1731488759,
                "post_id": 79183505,
                "comment_id": 139630020,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1578313,
                    "reputation": 336,
                    "user_id": 1464248,
                    "user_type": "registered",
                    "accept_rate": 17,
                    "profile_image": "https://www.gravatar.com/avatar/91d0627a9b618761a47e27e820c702a4?s=256&d=identicon&r=PG",
                    "display_name": "Prince Garg",
                    "link": "https://stackoverflow.com/users/1464248/prince-garg"
                },
                "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": 1731501922,
                "post_id": 79183505,
                "comment_id": 139631371,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1732285608,
                "last_edit_date": 1732285608,
                "creation_date": 1731515135,
                "answer_id": 79185813,
                "question_id": 79183505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You just want to single those lines out? \r\nAs long as there aren&#39;t newlines embedded (which is absolutely a possibility in JSON) you could just use `grep`.\r\n```\r\n$: grep -no &#39;: *&quot;[^&quot;]* [^&quot;]*&quot;&#39; file\r\n1::&quot;ABCD_BUCKET &quot;\r\n```\r\n`jq` is almost certainly safer, but which `jq` are you using?",
                "title": "How to detect if there is any value which have space inside double quotes (using jq or in linux)?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1731754392,
                "creation_date": 1731754392,
                "answer_id": 79194988,
                "question_id": 79183505,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To print out the .value strings containing blanks:\r\n```\r\njq &#39;def stroll:\r\n      if type == &quot;object&quot; \r\n      then if (.value | type == &quot;string&quot; and test(&quot; &quot;)) then .value\r\n           else .[] | stroll\r\n           end\r\n      elif type == &quot;array&quot; then .[] | stroll\r\n           else empty\r\n      end;  \r\n    stroll&#39; input.json\r\n```\r\n\r\nIf you also want the line numbers, replace `then .value` with something like:\r\n```\r\n    then [input_line_number, .value]\r\n```",
                "title": "How to detect if there is any value which have space inside double quotes (using jq or in linux)?"
            }
        ],
        "is_answered": false,
        "answer_count": 2,
        "score": -5,
        "last_activity_date": 1732285608,
        "creation_date": 1731475220,
        "last_edit_date": 1731478192,
        "question_id": 79183505,
        "body_markdown": "Sample json data as below: \r\nThere are multiple lines in a file. Few lines with NOK sample and rest are OK. \r\nHow to identify such problematic lines which have spaces?\r\n\r\nNOK:\r\n```\r\n[[{&quot;PK&quot;:&quot;ABCD||1000000&quot;,&quot;id&quot;:&quot;ABCD||1000000&quot;,&quot;chargingRules&quot;:{&quot;code&quot;:[{&quot;actions&quot;:[{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Rate&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Target&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;ABCD_BUCKET&quot;}}},{&quot;name&quot;:&quot;Rate&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;VR_0_50&quot;}}}]},{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Tax-Selection&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Data&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;Tax&quot;}}}]}],&quot;condContainer&quot;:{&quot;conditions&quot;:[{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVCallType&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:3,&quot;value&quot;:&quot;CallType.IMS&quot;}},{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVDest_Country&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;IND&quot;}}],&quot;operator&quot;:0},&quot;modifiedDate&quot;:1725306076363,&quot;rulename&quot;:&quot;VOICE&quot;,&quot;schemaVersion&quot;:0},{&quot;actions&quot;:[{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Rate&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Target&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:**&quot;ABCD_BUCKET &quot;**}}},{&quot;name&quot;:&quot;Rate&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;SR_0_12&quot;}}}]},{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Tax-Selection&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Data&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;Tax&quot;}}}]}],&quot;condContainer&quot;:{&quot;conditions&quot;:[{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVCallType&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:3,&quot;value&quot;:&quot;CallType.SMS&quot;}},{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVDest_Country&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;IND&quot;}}],&quot;operator&quot;:0},&quot;modifiedDate&quot;:1725306076363,&quot;rulename&quot;:&quot;SMS&quot;,&quot;schemaVersion&quot;:0},{&quot;actions&quot;:[{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Rate&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Rate&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;DR_0_08&quot;}}},{&quot;name&quot;:&quot;Target&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:**&quot;ABCD_BUCKET &quot;**}}}]},{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Tax-Selection&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Data&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;Tax&quot;}}}]}],&quot;condContainer&quot;:{&quot;conditions&quot;:[{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVCallType&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:3,&quot;value&quot;:&quot;CallType.PS&quot;}}],&quot;operator&quot;:0},&quot;modifiedDate&quot;:1725306076363,&quot;rulename&quot;:&quot;DATA&quot;,&quot;schemaVersion&quot;:0}],&quot;codeMode&quot;:1,&quot;items&quot;:[{&quot;componentId&quot;:&quot;SR_0_12&quot;,&quot;isPrimary&quot;:1,&quot;isRoot&quot;:0,&quot;overrideInst&quot;:0,&quot;subType&quot;:6,&quot;type&quot;:1},{&quot;componentId&quot;:&quot;VR_0_50&quot;,&quot;isPrimary&quot;:1,&quot;isRoot&quot;:0,&quot;overrideInst&quot;:0,&quot;subType&quot;:6,&quot;type&quot;:1},{&quot;componentId&quot;:&quot;ABCD_BUCKET&quot;,&quot;isPrimary&quot;:1,&quot;isRoot&quot;:0,&quot;overrideInst&quot;:0,&quot;subType&quot;:2,&quot;type&quot;:1},{&quot;componentId&quot;:&quot;DR_0_08&quot;,&quot;isPrimary&quot;:1,&quot;isRoot&quot;:0,&quot;overrideInst&quot;:0,&quot;subType&quot;:6,&quot;type&quot;:1}],&quot;splitChFlag&quot;:0,&quot;tariffName&quot;:&quot;ChargingRules&quot;}}],[{&quot;Status&quot;:0}]]\r\n```\r\n\r\nOK:\r\n```\r\n[[{&quot;PK&quot;:&quot;PQRS||2000000&quot;,&quot;id&quot;:&quot;PQRS||2000000&quot;,&quot;chargingRules&quot;:{&quot;code&quot;:[{&quot;actions&quot;:[{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Rate&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Target&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;ABCD_BUCKET&quot;}}},{&quot;name&quot;:&quot;Rate&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;VR_0_50&quot;}}}]},{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Tax-Selection&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Data&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;Tax&quot;}}}]}],&quot;condContainer&quot;:{&quot;conditions&quot;:[{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVCallType&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:3,&quot;value&quot;:&quot;CallType.IMS&quot;}},{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVDest_Country&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;IND&quot;}}],&quot;operator&quot;:0},&quot;modifiedDate&quot;:1725306076363,&quot;rulename&quot;:&quot;VOICE&quot;,&quot;schemaVersion&quot;:0},{&quot;actions&quot;:[{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Rate&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Target&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;ABCD_BUCKET&quot;}}},{&quot;name&quot;:&quot;Rate&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;SR_0_12&quot;}}}]},{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Tax-Selection&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Data&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;Tax&quot;}}}]}],&quot;condContainer&quot;:{&quot;conditions&quot;:[{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVCallType&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:3,&quot;value&quot;:&quot;CallType.SMS&quot;}},{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVDest_Country&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;IND&quot;}}],&quot;operator&quot;:0},&quot;modifiedDate&quot;:1725306076363,&quot;rulename&quot;:&quot;SMS&quot;,&quot;schemaVersion&quot;:0},{&quot;actions&quot;:[{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Rate&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Rate&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;DR_0_08&quot;}}},{&quot;name&quot;:&quot;Target&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;ABCD_BUCKET&quot;}}}]},{&quot;attributeInfo&quot;:{&quot;name&quot;:&quot;Tax-Selection&quot;,&quot;resultContext&quot;:&quot;RATING&quot;},&quot;parameters&quot;:[{&quot;name&quot;:&quot;Data&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;Tax&quot;}}}]}],&quot;condContainer&quot;:{&quot;conditions&quot;:[{&quot;criteria&quot;:{&quot;name&quot;:&quot;Get-Variable&quot;,&quot;sourceContext&quot;:&quot;VARIABLES&quot;},&quot;criteriaArgs&quot;:[{&quot;name&quot;:&quot;Name&quot;,&quot;value&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;GVCallType&quot;}}],&quot;operator&quot;:0,&quot;value&quot;:{&quot;type&quot;:3,&quot;value&quot;:&quot;CallType.PS&quot;}}],&quot;operator&quot;:0},&quot;modifiedDate&quot;:1725306076363,&quot;rulename&quot;:&quot;DATA&quot;,&quot;schemaVersion&quot;:0}],&quot;codeMode&quot;:1,&quot;items&quot;:[{&quot;componentId&quot;:&quot;SR_0_12&quot;,&quot;isPrimary&quot;:1,&quot;isRoot&quot;:0,&quot;overrideInst&quot;:0,&quot;subType&quot;:6,&quot;type&quot;:1},{&quot;componentId&quot;:&quot;VR_0_50&quot;,&quot;isPrimary&quot;:1,&quot;isRoot&quot;:0,&quot;overrideInst&quot;:0,&quot;subType&quot;:6,&quot;type&quot;:1},{&quot;componentId&quot;:&quot;ABCD_BUCKET&quot;,&quot;isPrimary&quot;:1,&quot;isRoot&quot;:0,&quot;overrideInst&quot;:0,&quot;subType&quot;:2,&quot;type&quot;:1},{&quot;componentId&quot;:&quot;DR_0_08&quot;,&quot;isPrimary&quot;:1,&quot;isRoot&quot;:0,&quot;overrideInst&quot;:0,&quot;subType&quot;:6,&quot;type&quot;:1}],&quot;splitChFlag&quot;:0,&quot;tariffName&quot;:&quot;ChargingRules&quot;}}],[{&quot;Status&quot;:0}]]\r\n```\r\n\r\nDifference:\r\n```\r\n...&quot;parameters&quot;:[{&quot;name&quot;:&quot;Target&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;ABCD_BUCKET &quot;}}},...\r\n...&quot;parameters&quot;:[{&quot;name&quot;:&quot;Target&quot;,&quot;value&quot;:{&quot;data&quot;:{&quot;type&quot;:0,&quot;value&quot;:&quot;ABCD_BUCKET&quot;}}},...\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/79183505/how-to-detect-if-there-is-any-value-which-have-space-inside-double-quotes-using",
        "title": "How to detect if there is any value which have space inside double quotes (using jq or in linux)?"
    },
    {
        "tags": [
            "jq",
            "winmerge"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 374049,
                    "reputation": 15207,
                    "user_id": 724039,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/NsCwt.png?s=256",
                    "display_name": "Luuk",
                    "link": "https://stackoverflow.com/users/724039/luuk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1731501997,
                "post_id": 79184922,
                "comment_id": 139631387,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1741540945,
                "last_edit_date": 1741540945,
                "creation_date": 1731501976,
                "answer_id": 79184964,
                "question_id": 79184922,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`jq` does have an option that sorts all the keys inside the objects (see the [manual](https://jqlang.org/manual/)):\r\n\r\n```\r\n--sort-keys / -S:\r\n\r\n        Output the fields of each object with the keys in sorted order.\r\n```\r\n\r\nSo you can just use the following command:\r\n\r\n```bash\r\njq --sort-keys .\r\n```\r\n\r\nOr, in WinMerge syntax:\r\n\r\n```\r\nQueryJSON --sort-keys &quot;.&quot;\r\n```",
                "title": "Sorting and comparing json files with ./jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1741540945,
        "creation_date": 1731501275,
        "question_id": 79184922,
        "body_markdown": "I am trying to compare two long json files with WinMerge by using QueryJSON plugin.\r\nProperties in those files are in random order.\r\nThat parameter for .\\jq does work, but nested objects are not affected:\r\n\r\n    QueryJSON &quot;. | to_entries | sort_by(.key) | from_entries&quot;\r\n    \r\nThere is some &quot;flatten&quot; command which did not provide me result that I searched for (may be used incorrectrly).\r\n\r\nJsons could be for example:\r\n\r\n    {\r\n       &quot;Id&quot;: 1,\r\n       &quot;Addresses&quot;:[\r\n          {&quot;Street&quot;: &quot;Street 1&quot;,\r\n          &quot;PostalCode&quot;: 12345},\r\n          {&quot;Street&quot;: &quot;Street 2&quot;,\r\n          &quot;PostalCode&quot;: 12345}\r\n       ],\r\n       &quot;Person&quot;:{\r\n          &quot;FirstName&quot;: &quot;Mike&quot;,\r\n          &quot;LastName&quot;:&quot;Boe&quot;\r\n       }\r\n    }\r\n\r\n\r\n    {\r\n       &quot;Id&quot;: 2,\r\n       &quot;Person&quot;:{\r\n          &quot;FirstName&quot;: &quot;John&quot;,\r\n          &quot;LastName&quot;:&quot;Boe&quot;\r\n       }\r\n       &quot;Addresses&quot;:[\r\n          {&quot;Street&quot;: &quot;Street 3&quot;,\r\n          &quot;PostalCode&quot;: 12345},\r\n          {&quot;Street&quot;: &quot;Street 2&quot;,\r\n          &quot;PostalCode&quot;: 12345}\r\n       ]\r\n    }\r\n\r\nI can compare nested objects one by one by pointing at them like \r\n\r\n    QueryJSON &quot;.Person | to_entries | sort_by(.key) | from_entries&quot;\r\n\r\nBut is there any way that will sort properties also inside these objects (even if that would flatten them)? Thanks.\r\n\r\n",
        "link": "https://stackoverflow.com/questions/79184922/sorting-and-comparing-json-files-with-jq",
        "title": "Sorting and comparing json files with ./jq"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1731828930,
                "creation_date": 1731828930,
                "answer_id": 79196702,
                "question_id": 79195334,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This should work:\r\n```\r\ndef args2json:\r\n  reduce to_entries[] as $e (null;\r\n    setpath($e.key | split(&quot;.&quot;); $e.value | cast_arg)\r\n  );\r\n```",
                "title": "Issue creating nested object in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1731828930,
        "creation_date": 1731766842,
        "question_id": 79195334,
        "body_markdown": "Im trying to write a JQ function that will take some key/value arguments and format them into a nested object of various data types.\r\n- If the arg key has a period, then use the period as a delimiter for nested object keys. Create that object and place the value there.\r\n- If the value has commas in it, then assume those are array value delimiters, and create the array.\r\n\r\nExamples:\r\n- `--arg foo.bar baz` would create `{&quot;foo&quot;:{&quot;bar&quot;:&quot;baz&quot;}}`\r\n- `--arg numbers.prime 2,3,5,7,11,13` would create `{&quot;numbers&quot;:{&quot;prime&quot;:[2,3,5,7,11,13]}}`\r\n- `--arg someint 123 would create {&quot;someint: 123}`\r\n\r\nContent of args2json.jq:\r\n\r\n    # Cast some text into the most likely value and appropriate data type\r\n    def cast_arg:\r\n        . as $val |\r\n        if $val == &quot;null&quot; then null\r\n        elif $val == &quot;true&quot; then true\r\n        elif $val == &quot;false&quot; then false\r\n        else ( $val \r\n            | try tonumber catch ($val\r\n                | split(&quot;,&quot;) as $segments \r\n                | if ($segments|length) == 0 then null\r\n                  elif ($segments|length) == 1 then $val \r\n                  else ($segments|map(cast_arg))\r\n                  end\r\n            )\r\n        ) end;\r\n        \r\n    \r\n    # Take the --arg foo.bar baz,bang,qux into {foo: {bar: [baz, bang, qux]}}\r\n    def args2json:\r\n        . as $params \r\n        | to_entries \r\n        | reduce .[] as $entrties ([]; \r\n            $entrties \r\n            | (setpath(.key | split(&quot;.&quot;); .value | cast_arg) | del(.key) | del(.value) | $params + . )\r\n        );\r\n    \r\n    .params=($ARGS.named | args2json) \r\n\r\nExecution:\r\n\r\n    jq --null-input \\\r\n      --arg count 5 \\\r\n      --arg name john \\\r\n      --arg enabled false \\\r\n      --arg shouldbenull null \\\r\n      --arg mamals pig,cat,dog \\\r\n      --arg sea.creatures &#39;shark,crab,654,squid&#39; \\\r\n      --from-file ./jq/modifiers/args2json.jq\r\n\r\n\r\nI would expect to see the output:\r\n\r\n    {\r\n      &quot;count&quot;: 5,\r\n      &quot;name&quot;: &quot;john&quot;,\r\n      &quot;enabled&quot;: false,\r\n      &quot;shouldbenull&quot;: null,\r\n      &quot;mamals&quot;: [\r\n        &quot;pig&quot;,\r\n        &quot;cat&quot;,\r\n        &quot;dog&quot;\r\n      ],\r\n      &quot;sea&quot;: {\r\n        &quot;creatures&quot;: [\r\n          &quot;shark&quot;,\r\n          &quot;crab&quot;,\r\n          654,\r\n          &quot;squid&quot;\r\n        ]\r\n      }\r\n    }\r\n\r\nBut here&#39;s the actual output\r\n\r\n    {\r\n      &quot;params&quot;: {\r\n        &quot;count&quot;: &quot;5&quot;,\r\n        &quot;name&quot;: &quot;john&quot;,\r\n        &quot;enabled&quot;: &quot;false&quot;,\r\n        &quot;shouldbenull&quot;: &quot;null&quot;,\r\n        &quot;mamals&quot;: &quot;pig,cat,dog&quot;,\r\n        &quot;sea.creatures&quot;: &quot;shark,crab,654,squid&quot;,\r\n        &quot;sea&quot;: {\r\n          &quot;creatures&quot;: [\r\n            &quot;shark&quot;,\r\n            &quot;crab&quot;,\r\n            654,\r\n            &quot;squid&quot;\r\n          ]\r\n        }\r\n      }\r\n    }\r\n\r\nThe last `{sea: creatures: [...]}}` looks great. All values got casted properly and the *creatures* array is nested inside the *sea* object property. But it only seems to update the very last thing in the output and nothing else which I can&#39;t figure out.\r\n\r\nAny help would be appreciated",
        "link": "https://stackoverflow.com/questions/79195334/issue-creating-nested-object-in-jq",
        "title": "Issue creating nested object in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1732030946,
                "creation_date": 1732030946,
                "answer_id": 79204104,
                "question_id": 79204098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "What I would do:\r\n\r\n    $ jq &#39;.[].fields[] | select(.name == &quot;body_t&quot;) | .value = &quot;TESTOS&quot;&#39; file\r\n    {\r\n      &quot;name&quot;: &quot;body_t&quot;,\r\n      &quot;value&quot;: &quot;TESTOS&quot;\r\n    }\r\n\r\n",
                "title": "Using jq to replace the value of a JSON field is not working correctly"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1732031528,
                "creation_date": 1732031528,
                "answer_id": 79204133,
                "question_id": 79204098,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to keep the original structure, I&#39;d use:\r\n```\r\nmap(.fields[] |= (select(.name == &quot;body_t&quot;).value |= &quot;Some value&quot;))\r\n```\r\n\r\n\r\n----------\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;fields&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;body_t&quot;,\r\n        &quot;value&quot;: &quot;Some value&quot;\r\n      }\r\n    ],\r\n    &quot;id&quot;: &quot;abc123&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n### [JqPlay Demo](https://jqplay.org/s/QNEc-e7VPa5pX9a)",
                "title": "Using jq to replace the value of a JSON field is not working correctly"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1732031528,
        "creation_date": 1732030819,
        "last_edit_date": 1732031035,
        "question_id": 79204098,
        "body_markdown": "I have a template JSON file like this:\r\n\r\n```javascript\r\n[\r\n  {\r\n    &quot;fields&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;body_t&quot;,\r\n        &quot;value&quot;: &quot;TEST&quot;\r\n      }\r\n    ],\r\n    &quot;id&quot;: &quot;abc123&quot;\r\n  }\r\n]\r\n```\r\nI need to replace the &quot;value&quot; of the &quot;body_t&quot; (which is set to TEST in the template).\r\n\r\n    jq &#39;.[].fields[] | select(.name == &quot;body_t&quot;) | .value = &quot;&#39;&quot;TEST&quot;&#39;&quot;&#39; template.json\r\n\r\nI receive back the following error:\r\n\r\nCannot index string with string &quot;fields&quot;\r\n\r\nWhat am I doing wrong here?\r\n\r\n",
        "link": "https://stackoverflow.com/questions/79204098/using-jq-to-replace-the-value-of-a-json-field-is-not-working-correctly",
        "title": "Using jq to replace the value of a JSON field is not working correctly"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1732102918,
                "last_edit_date": 1732102918,
                "creation_date": 1732101480,
                "answer_id": 79206966,
                "question_id": 79206926,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Probably not the cleanest way, but we could:\r\n\r\n1. [Filter on `select(.type == &quot;disk&quot;)`][4] to prevent empty starting arrays.\r\n1. [Recursive (`..`)][1] get all `.mountpoints`  \r\n    (or empty array as [fallback (`// []`)][2]) \r\n3. [`flatten`][3] the arrays to get a single output.\r\n2. Then remove all `null` from the arrays (`values`). \r\n\r\n\r\n\r\n\r\n\r\n----------\r\n\r\n```none\r\n.blockdevices[] | select(.type == &quot;disk&quot;) | [ \r\n    .name, \r\n    (.. | (.mountpoints? // []) | flatten[] | values) \r\n]\r\n```\r\n\r\noutput:\r\n```json\r\n[\r\n  &quot;sda&quot;\r\n]\r\n[\r\n  &quot;sdb&quot;,\r\n  &quot;foo1&quot;,\r\n  &quot;foo2&quot;,\r\n  &quot;foo3&quot;\r\n]\r\n```\r\n\r\n\r\n----------\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/Bl3YTSK_LZi57JT)\r\n\r\n  [1]: https://jqlang.github.io/jq/manual/#recursive-descent\r\n  [2]: https://jqlang.github.io/jq/manual/#alternative-operator\r\n  [3]: https://jqlang.github.io/jq/manual/#flatten\r\n  [4]: https://jqlang.github.io/jq/manual/#select",
                "title": "jq: how do I handle recursion in this case?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1732102918,
        "creation_date": 1732100963,
        "question_id": 79206926,
        "body_markdown": "I have JSON output as shown below (the output of `lsblk`, greatly simplified). I need to generate CSV output which shows the name of a disk, together with a list of mount points, if any. I can generate this for simple cases, but the problem is that there&#39;s a recursive children list, containing additional mountpoints, which I don&#39;t know how to handle.\r\n\r\nThere are a couple of other SO questions which ask specifically about parsing `lsblk` output, but they show a simpler (old?) `lsblk` output, which is flat (and with mountpoints which aren&#39;t arrays).\r\n\r\nFor the example below, I&#39;d like to get CSV output that looks like (without the comments, obviously):\r\n\r\n    &quot;sda&quot;                       # no mountpoints\r\n    &quot;sdb&quot;,&quot;foo1&quot;,&quot;foo2&quot;,&quot;foo3&quot;  # no top-level mountpoint, 3 [grand]children\r\n\r\nNote:\r\n\r\n 1. All `mountpoints` are arrays. Presumably they can contain more than one element (or no elements), but I&#39;ve never seen this\r\n 2. Any `mountpoints` can contain `null` entries, but it seems like the array is always present\r\n 3. The `blockdevices` object contains a list, but only entries of type `disk` are relevant\r\n\r\nAny help much appreciated - I&#39;ve spent several hours trying to find a walk/recurse solution which handles the children.\r\n\r\n    {\r\n       &quot;blockdevices&quot;: [\r\n          {\r\n             &quot;type&quot;: &quot;disk&quot;,\r\n             &quot;name&quot;: &quot;sda&quot;,\r\n             &quot;etc&quot; : &quot;ignore&quot;,\r\n             &quot;mountpoints&quot;: [ null ]\r\n          },{\r\n             &quot;type&quot;: &quot;loop&quot;,\r\n             &quot;etc&quot; : &quot;ignore everything&quot;\r\n          },{\r\n             &quot;type&quot;: &quot;disk&quot;,\r\n             &quot;name&quot;: &quot;sdb&quot;,\r\n             &quot;etc&quot; : &quot;ignore&quot;,\r\n             &quot;mountpoints&quot;: [ null ],\r\n             &quot;children&quot;: [\r\n                {\r\n                   &quot;name&quot;: &quot;ignore&quot;,\r\n                   &quot;etc&quot; : &quot;ignore&quot;,\r\n                   &quot;mountpoints&quot;: [ &quot;foo1&quot; ]\r\n                },{\r\n                   &quot;name&quot;: &quot;ignore&quot;,\r\n                   &quot;etc&quot; : &quot;ignore&quot;,\r\n                   &quot;mountpoints&quot;: [ null ],\r\n                   &quot;children&quot;: [\r\n                      {\r\n                         &quot;name&quot;: &quot;ignore&quot;,\r\n                         &quot;etc&quot; : &quot;ignore&quot;,\r\n                         &quot;mountpoints&quot;: [ &quot;foo2&quot; ]\r\n                      },{\r\n                         &quot;name&quot;: &quot;ignore&quot;,\r\n                         &quot;etc&quot; : &quot;ignore&quot;,\r\n                         &quot;mountpoints&quot;: [ &quot;foo3&quot; ]\r\n                      }\r\n                   ]\r\n                }\r\n             ]\r\n          }\r\n       ]\r\n    }\r\n\r\n",
        "link": "https://stackoverflow.com/questions/79206926/jq-how-do-i-handle-recursion-in-this-case",
        "title": "jq: how do I handle recursion in this case?"
    },
    {
        "tags": [
            "shell",
            "gitlab-ci",
            "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": 1732123269,
                "post_id": 79208308,
                "comment_id": 139673608,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": -2,
                "last_activity_date": 1732122926,
                "creation_date": 1732122926,
                "answer_id": 79208318,
                "question_id": 79208308,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "response=$(curl -s -u &quot;${HARBOR_SWIO_USER}:${HARBOR_SWIO_PASS}&quot; -H &quot;Accept:application/json&quot; &quot;$URL&quot;)\r\n\r\n#This line will fail\r\necho &quot;$response&quot; | jq -e --arg TAG &quot;$TAG&quot; &#39;.[]|select(.tags[].name==$TAG)&#39; &gt; /dev/null\r\n\r\nif [ $? -eq 0 ]; then\r\n    echo &quot;Image exists&quot;\r\nelse\r\n    echo &quot;Image does not exist&quot;",
                "title": "Differnce between linux shell skript and Gitlab shell script"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1732123443,
        "creation_date": 1732122766,
        "question_id": 79208308,
        "body_markdown": "I have a pipeline that always fail with a shell command. This is:\r\n\r\n````\r\nresponse=$(curl -s -u &quot;${HARBOR_SWIO_USER}:${HARBOR_SWIO_PASS}&quot; -H &quot;Accept:application/json&quot; &quot;$URL&quot;)\r\n\r\n#This line will fail\r\necho &quot;$response&quot; | jq -e --arg TAG &quot;$TAG&quot; &#39;.[]|select(.tags[].name==$TAG)&#39; &gt; /dev/null\r\n\r\nif [ $? -eq 0 ]; then\r\n    echo &quot;Image exists&quot;\r\nelse\r\n    echo &quot;Image does not exist&quot;\r\nfi\r\n````\r\n\r\nI put this into a shell script on my Linux and execute it, works well. On Gitlab with a Linux Runner it fails.\r\n\r\nI checked the jq version, both 1.6\r\nI verified the JSON from response with JQ and this is successful (0).\r\n\r\n````\r\necho $response | jq -e . &gt;/dev/null 2&gt;&amp;1  ; echo ${PIPESTATUS[1]}\r\n````\r\n\r\nBut everytime the first call fail on Gitlab. Any Idea what is wrong?",
        "link": "https://stackoverflow.com/questions/79208308/differnce-between-linux-shell-skript-and-gitlab-shell-script",
        "title": "Differnce between linux shell skript and Gitlab shell script"
    },
    {
        "tags": [
            "json",
            "powershell",
            "csv",
            "jq",
            "converters"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 20882047,
                    "reputation": 64022,
                    "user_id": 15339544,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/F0aQdYPV.jpg?s=256",
                    "display_name": "Santiago Squarzon",
                    "link": "https://stackoverflow.com/users/15339544/santiago-squarzon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732317883,
                "post_id": 79216817,
                "comment_id": 139688877,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 7463697,
                    "reputation": 113,
                    "user_id": 5761454,
                    "user_type": "registered",
                    "accept_rate": 20,
                    "profile_image": "https://graph.facebook.com/10208125636317993/picture?type=large",
                    "display_name": "Nash",
                    "link": "https://stackoverflow.com/users/5761454/nash"
                },
                "reply_to_user": {
                    "account_id": 20882047,
                    "reputation": 64022,
                    "user_id": 15339544,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/F0aQdYPV.jpg?s=256",
                    "display_name": "Santiago Squarzon",
                    "link": "https://stackoverflow.com/users/15339544/santiago-squarzon"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732318195,
                "post_id": 79216817,
                "comment_id": 139688896,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1732327414,
                "last_edit_date": 1732327414,
                "creation_date": 1732318503,
                "answer_id": 79216844,
                "question_id": 79216817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Easiest and more efficient way to do it is with [`Group-Object -AsHashtable`][1] to leverage a dictionary type for fast lookups. See [__about_Hash_Tables__][2] for more details.\r\n\r\n```sh\r\n$usersCSV = Import-Csv &#39;users.csv&#39; | Group-Object email -AsHashTable\r\n$watchersJSON = Get-Content -Path &#39;watchers.json&#39; -Raw | ConvertFrom-Json\r\nforeach ($object in $watchersJSON) {\r\n    $object.watchers = $usersCSV[$object.watchers].&#39;User id&#39;\r\n}\r\nConvertTo-Json @($watchersJSON) | Out-File &#39;watchers-with-ID.json&#39;\r\n```\r\n\r\n[1]: https://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.utility/group-object?view=powershell-7.4#-ashashtable\r\n[2]: https://learn.microsoft.com/en-us/powershell/module/microsoft.powershell.core/about/about_hash_tables?view=powershell-7.4",
                "title": "How to put data from CSV to JSON?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1732398427,
                "creation_date": 1732398427,
                "answer_id": 79218916,
                "question_id": 79216817,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a jq-only solution, which does however assume the CSV is easy to parse:\r\n```\r\n&lt; input.json jq --rawfile csv input.csv &#39;\r\n  def toDict: reduce .[] as [$v, $k] ({}; .[$k] = $v);\r\n  ($csv\r\n   | split(&quot;\\n&quot;)\r\n   | map(select(length&gt;0) | split(&quot;,&quot;))\r\n   | toDict) as $dict\r\n  | walk(if type == &quot;object&quot; and .watchers \r\n         then .watchers |= map( $dict[.] // .) end)\r\n&#39;\r\n\r\n```",
                "title": "How to put data from CSV to JSON?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1732398427,
        "creation_date": 1732317304,
        "last_edit_date": 1732321081,
        "question_id": 79216817,
        "body_markdown": "I have a CSV containing two &quot;columns&quot; `&#39;User id&#39;` and `&#39;email&#39;` example:\r\n\r\n    User id,email\r\n    1234-1234-1234,some@email.address\r\n    321-1235-44432,anoteher@email.address\r\n    322136231345,more.email@address.too\r\n\r\nAnd a JSON looking like this:\r\n\r\n        [{\r\n                &quot;externalId&quot;: &quot;100000&quot;,\r\n                &quot;watchers&quot;: [&quot;some@email.address&quot;, &quot;anoteher@email.address&quot;, &quot;more.email@address.too&quot;]\r\n            },\r\n    {\r\n                &quot;externalId&quot;: &quot;100002&quot;,\r\n                &quot;watchers&quot;: [&quot;anoteher@email.address&quot;, &quot;more.email@address.too&quot;]\r\n            }\r\n        ]\r\n\r\nWhat I&#39;m trying to do is to replace the email addresses in the JSON with the &#39;User id&#39; from the CSV accordingly. So far I have the inefficient foreach in foreach code but it only replaces the first email in the watchers array.\r\n\r\n    $usersCSV = Import-Csv &#39;users.csv&#39;\r\n    $watchersJSON = Get-Content -Path &quot;watchers.json&quot; -raw |ConvertFrom-Json\r\n    \r\n    foreach ($watchersJSONdata in $watchersJSON) {\r\n        foreach ($usersCSVdata in $usersCSV){\r\n            if ($watchersJSONdata.watchers -eq $usersCSVdata.email) {\r\n                $watchersJSONdata.watchers = $usersCSVdata.&#39;User id&#39;\r\n            }\r\n        }\r\n    } $watchersJSON |ConvertTo-Json | out-file  &quot;watchers-with-ID.json&quot;\r\n\r\nResult is:\r\n\r\n    [{\r\n            &quot;externalId&quot;: &quot;100000&quot;,\r\n            &quot;watchers&quot;: [&quot;1234-1234-1234&quot;]\r\n        }\r\n    ]\r\n\r\nI&#39;m still working on it but a little help would be great.\r\n\r\nI wouldn&#39;t mind a completely different approach using a single line jq but I don&#39;t know jq at all.\r\n",
        "link": "https://stackoverflow.com/questions/79216817/how-to-put-data-from-csv-to-json",
        "title": "How to put data from CSV to JSON?"
    },
    {
        "tags": [
            "bash",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 15064163,
                    "reputation": 16643,
                    "user_id": 10871900,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/720202b6e19abc330dcd92e6a1254562?s=256&d=identicon&r=PG",
                    "display_name": "dan1st",
                    "link": "https://stackoverflow.com/users/10871900/dan1st"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732524403,
                "post_id": 79221915,
                "comment_id": 139698411,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732527420,
                "post_id": 79221915,
                "comment_id": 139698676,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1732516783,
                "creation_date": 1732516783,
                "answer_id": 79221925,
                "question_id": 79221915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can directly extract, decode, and format the required fields from the data key while retrieving the data. This minimizes post-processing.\r\n\r\n    curl -sX GET &quot;https://platform-explorer.pshenmic.dev/dataContract/GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec/documents?page=23&amp;limit=4&quot; | \\\r\n    jq -r &#39;.resultSet[] | .data | fromjson | .&#39;\r\n\r\n",
                "title": "JQ does not process part of the data"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1732623246,
                "last_edit_date": 1732623246,
                "creation_date": 1732527309,
                "answer_id": 79222430,
                "question_id": 79221915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You didn&#39;t provide the expected output but from what I understand you want to do something like this:\r\n\r\n```sh\r\ncurl -sX GET &quot;https://...&quot; |\r\njq &#39;.resultSet[] |\r\n    {\r\n      &quot;label&quot;: (.data | fromjson | .label),\r\n      &quot;timestamp&quot;: .timestamp\r\n    }\r\n&#39;\r\n```\r\n\r\n```json\r\n{\r\n  &quot;label&quot;: &quot;BFWookie&quot;,\r\n  &quot;timestamp&quot;: &quot;2024-10-23T05:40:07.923Z&quot;\r\n}\r\n...\r\n```",
                "title": "JQ does not process part of the data"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1732559798,
                "creation_date": 1732559798,
                "answer_id": 79224241,
                "question_id": 79221915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Recursively convert all json strings not just `.data`\r\n\r\n```sh\r\njq &#39;walk(fromjson? // .)&#39;\r\n```\r\n\r\n",
                "title": "JQ does not process part of the data"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1732623246,
        "creation_date": 1732516604,
        "question_id": 79221915,
        "body_markdown": "I can simplify the question by providing a link to the source data:\r\n\r\n```\r\ncurl -sX GET &quot;https://platform-explorer.pshenmic.dev/dataContract/GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec/documents?page=23&amp;limit=4&quot; | jq -r .resultSet\r\n```\r\n\r\nAt the end of the code, you can change the value of &quot;limit&quot;, which will determine how many blocks are output. There are more than 1,000 blocks in total, and I need to extract the &quot;label&quot; and &quot;timestamp&quot; information for each block.\r\n\\`\r\nInside  there are identical blocks that contain the raw data for the &quot;data&quot; key.\r\n\r\n```\r\n{\r\n  &quot;identifier&quot;: &quot;BVC9GYvsAwswBTfv4C2eziRZmZ6fUzrmMuvqv1VPdWG3&quot;,\r\n  &quot;dataContractIdentifier&quot;: &quot;GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec&quot;,\r\n  &quot;revision&quot;: 1,\r\n  &quot;txHash&quot;: &quot;03CFE8DAB06ECCCDB1430F149041775263F85DF335046C0421449AA73A46B4DA&quot;,\r\n  &quot;deleted&quot;: false,\r\n  &quot;data&quot;: &quot;{\\&quot;label\\&quot;:\\&quot;BFWookie\\&quot;,\\&quot;records\\&quot;:{\\&quot;identity\\&quot;:\\&quot;Ea8acQwhQbbdaTLytoTiedEkTA89A8dyFpn9jTivr4Ht\\&quot;},\\&quot;preorderSalt\\&quot;:\\&quot;hwebwVCxW+MwBmIqhoYIibGd7s7GOihv+MU6ae8Jj70=\\&quot;,\\&quot;subdomainRules\\&quot;:{\\&quot;allowSubdomains\\&quot;:false},\\&quot;normalizedLabel\\&quot;:\\&quot;bfw00k1e\\&quot;,\\&quot;parentDomainName\\&quot;:\\&quot;dash\\&quot;,\\&quot;normalizedParentDomainName\\&quot;:\\&quot;dash\\&quot;}&quot;,\r\n  &quot;timestamp&quot;: &quot;2024-10-23T05:40:07.923Z&quot;,\r\n  &quot;isSystem&quot;: false,\r\n  &quot;owner&quot;: &quot;Ea8acQwhQbbdaTLytoTiedEkTA89A8dyFpn9jTivr4Ht&quot;\r\n}\r\n```\r\n\r\nI need to convert the data from the &quot;data&quot; key into the correct format :\r\n\r\n```\r\n\r\n{\r\n&quot;label&quot;: &quot;BFWookie&quot;,\r\n&quot;records&quot;: {\r\n&quot;identity&quot;: &quot;Ea8acQwhQbbdaTLytoTiedEkTA89A8dyFpn9jTivr4Ht&quot;\r\n},\r\n&quot;preorderSalt&quot;: &quot;hwebwVCxW+MwBmIqhoYIibGd7s7GOihv+MU6ae8Jj70=&quot;,\r\n&quot;subdomainRules&quot;: {\r\n&quot;allowSubdomains&quot;: false\r\n},\r\n&quot;normalizedLabel&quot;: &quot;bfw00k1e&quot;,\r\n&quot;parentDomainName&quot;: &quot;dash&quot;,\r\n&quot;normalizedParentDomainName&quot;: &quot;dash&quot;\r\n}\r\n```\r\n\r\nI obtained the last one by processing the data from the &quot;data&quot; key using the following command :\r\n\r\n```\r\necho  &quot;{\\&quot;label\\&quot;:\\&quot;BFWookie\\&quot;,\\&quot;records\\&quot;:{\\&quot;identity\\&quot;:\\&quot;Ea8acQwhQbbdaTLytoTiedEkTA89A8dyFpn9jTivr4Ht\\&quot;},\\&quot;preorderSalt\\&quot;:\\&quot;hwebwVCxW+MwBmIqhoYIibGd7s7GOihv+MU6ae8Jj70=\\&quot;,\\&quot;subdomainRules\\&quot;:{\\&quot;allowSubdomains\\&quot;:false},\\&quot;normalizedLabel\\&quot;:\\&quot;bfw00k1e\\&quot;,\\&quot;parentDomainName\\&quot;:\\&quot;dash\\&quot;,\\&quot;normalizedParentDomainName\\&quot;:\\&quot;dash\\&quot;}&quot; | jq\r\n```\r\n\r\nBut how can this be done quickly during the first data processing stage?\r\nOr another option?",
        "link": "https://stackoverflow.com/questions/79221915/jq-does-not-process-part-of-the-data",
        "title": "JQ does not process part of the data"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1732574560,
                "last_edit_date": 1732574560,
                "creation_date": 1732571795,
                "answer_id": 79224705,
                "question_id": 79224684,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you can rely on the ordering of the items, and that only the right messages start with a `#`, you only have to check for occurrences of the latter.\r\n\r\n```sh\r\nreduce .events[] as {$message} ([];   # iterate over events, extract message\r\n  if $message | startswith(&quot;#&quot;)       # if message starts with #\r\n  then . + [{$message}]               # add a new item to the result list\r\n  else last.message += $message end   # otherwise append it to last item&#39;s\r\n)\r\n```\r\n[Demo](https://jqplay.org/s/sRW-Hj0W2VsEOGq)\r\n\r\nHowever, implementing the stricter requirements is not much more difficult. Note that carrying over the `eventId` for comparison necessitates their removal afterwards.\r\n\r\n```sh\r\ndef check($e1; $e2):\r\n  ($e2.message[:1] != &quot;#&quot;) and\r\n  ($e1.eventId | tonumber) + 1 == ($e2.eventId | tonumber);\r\n\r\nreduce .events[1:][] as $e (.events[:1];\r\n  if check(last; $e) then last.message += $e.message else . + [$e] end\r\n)\r\n| map({message})  # drop eventId, just keep message\r\n```\r\n[Demo](https://jqplay.org/s/F-KE0rMLP_o_tn_G)\r\n\r\nOutput:\r\n```json\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 1, 2, 3&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 11&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 12&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: A, B, C&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: C&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: D&quot;\r\n  }\r\n]\r\n````\r\n\r\n",
                "title": "calculate consecutive numeric values, but it fails because of floating point numbers jq command"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1732574560,
        "creation_date": 1732571152,
        "question_id": 79224684,
        "body_markdown": "&lt;br&gt;\r\n\r\nWith a Json field like the one below, if eventId is a continuous value,\r\nI would like to add the value of the message field.&lt;br&gt;\r\n\r\nHowever, even if eventId is continuous, if the message field starts with # Time, the message field is separated.&lt;br&gt;\r\n\r\nThis is the original field of Json.&lt;br&gt;\r\n```\r\n{\r\n    &quot;events&quot;: [\r\n        {\r\n            &quot;message&quot;: &quot;# Time: 1&quot;,\r\n            &quot;eventId&quot;: &quot;38636469249093328935961608873790523617989208925384015872&quot;\r\n        },\r\n        {\r\n            &quot;message&quot;: &quot;, 2, 3&quot;,\r\n            &quot;eventId&quot;: &quot;38636469249093328935961608873790523617989208925384015873&quot;\r\n        },\r\n        {\r\n            &quot;message&quot;: &quot;# Time: 11&quot;,\r\n            &quot;eventId&quot;: &quot;38636469249093328935961608873790523617989208925384015875&quot;\r\n        },\r\n        {\r\n            &quot;message&quot;: &quot;# Time: 12&quot;,\r\n            &quot;eventId&quot;: &quot;38636469249093328935961608873790523617989208925384015876&quot;\r\n        },\r\n        {\r\n            &quot;message&quot;: &quot;# Time: A&quot;,\r\n            &quot;eventId&quot;: &quot;1&quot;\r\n        },\r\n        {\r\n            &quot;message&quot;: &quot;, B, C&quot;,\r\n            &quot;eventId&quot;: &quot;2&quot;\r\n        },\r\n        {\r\n            &quot;message&quot;: &quot;# Time: C&quot;,\r\n            &quot;eventId&quot;: &quot;3&quot;\r\n        },\r\n        {\r\n            &quot;message&quot;: &quot;# Time: D&quot;,\r\n            &quot;eventId&quot;: &quot;5&quot;\r\n        }\r\n    ]\r\n}\r\n```\r\n&lt;br&gt;\r\nHere&#39;s what I want it to look like:&lt;br&gt;\r\n\r\n```\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 1, 2, 3&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 11&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 12&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: A , B, C&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: C&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: D&quot;\r\n  }\r\n]\r\n\r\n```\r\n\r\n\r\nI&#39;ve asked a question about this before and received an answer from a great person. (Thank you pmf.)&lt;br&gt;\r\nAfter this, I tried my best to refine it a little more, but it didn&#39;t work, so I asked once more.&lt;br&gt;\r\n\r\nFirst,  When Ifirst run this JQ, I get the following results.&lt;br&gt;\r\n```\r\njq -r &#39;.events \r\n| reduce .[1:][] as $i (.[:1];\r\n    if ((.[-1].eventId | tonumber + 1 | tostring) != $i.eventId) or ($i.message | startswith(&quot;# Time:&quot;)) then\r\n        . += [$i]\r\n    else\r\n        .[-1].message += &quot; &quot; + $i.message\r\n    end\r\n) \r\n| del(.[].eventId)\r\n&#39;\r\n```\r\n```\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 1&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;, 2, 3&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 11&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 12&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: A , B, C&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: C&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: D&quot;\r\n  }\r\n]\r\n```\r\n\r\n&lt;br&gt;\r\nI saw it as a floating point issue and wanted to compare this number with the string itself, so I created a function as follows, but it did not work.&lt;br&gt;\r\n\r\n```\r\njq &#39;\r\n# Function to add one to a large number represented as a string\r\ndef add_one(num):\r\n  (num | split(&quot;&quot;) | reverse | map(tonumber)) as $digits\r\n  | reduce range(0; length) as $i ([];\r\n      . + if $i == 0 or .[-1] == 10 then\r\n            [($digits[$i] + 1) % 10]\r\n         else\r\n            [$digits[$i]]\r\n         end\r\n    )\r\n  | reverse | map(tostring) | join(&quot;&quot;);\r\n\r\n# Process events and check continuity\r\n.events \r\n| map(.eventId |= tostring) # Ensure all eventIds are strings\r\n| reduce .[1:][] as $i (.[:1];\r\n    if (add_one(.[-1].eventId) != $i.eventId) or ($i.message | startswith(&quot;# Time:&quot;)) then\r\n        . += [$i]\r\n    else\r\n        .[-1].message += &quot; &quot; + $i.message\r\n    end\r\n)\r\n| del(.[].eventId)\r\n&#39;\r\n```\r\n\r\n```\r\n[\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 1&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;, 2, 3&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 11&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: 12&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: A&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;, B, C&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: C&quot;\r\n  },\r\n  {\r\n    &quot;message&quot;: &quot;# Time: D&quot;\r\n  }\r\n]\r\n```\r\n\r\n&lt;br&gt;\r\n\r\nAs I searched further, I found a command called gojq, but I would like to test it first to see if it is possible with jq.&lt;br&gt;\r\n\r\nI am using jq version 1.7.1.",
        "link": "https://stackoverflow.com/questions/79224684/calculate-consecutive-numeric-values-but-it-fails-because-of-floating-point-num",
        "title": "calculate consecutive numeric values, but it fails because of floating point numbers jq command"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663157,
                    "reputation": 17637,
                    "user_id": 3776927,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f97178932f070cb24d06de16a905b196?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "derpirscher",
                    "link": "https://stackoverflow.com/users/3776927/derpirscher"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732700857,
                "post_id": 79229599,
                "comment_id": 139712156,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663157,
                    "reputation": 17637,
                    "user_id": 3776927,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f97178932f070cb24d06de16a905b196?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "derpirscher",
                    "link": "https://stackoverflow.com/users/3776927/derpirscher"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732700946,
                "post_id": 79229599,
                "comment_id": 139712163,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1732699093,
                "creation_date": 1732699093,
                "answer_id": 79229606,
                "question_id": 79229599,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use a recursive function that iterates through each element of the array and checks if it possesses an object with a property name. If it does, then the function calls itself again with the updated array. This way, the function will iterate through all elements of the array and check if they possess an object with a property name.\r\n```js\r\nfunction checkArray(arr) {\r\n  let current = arr;\r\n  while (current.length &gt; 0)) {\r\n    const obj = current[current.length - 1]];\r\n    if (obj &amp;&amp; &#39;object&#39; === typeof obj)) {\r\n      current.pop(current.length - 1]);\r\n      continue;\r\n    }\r\n  }\r\n  return current;\r\n}\r\n\r\n// Test the function\r\nconst array1 = [\r\n  { &quot;name&quot;: &quot;A&quot;, &quot;propertyA1&quot;: &quot;1&quot;, &quot;propertyA2&quot;: &quot;2&quot; }  \r\n];\r\nconst array2 = [\r\n  { &quot;name&quot;: &quot;C&quot;, &quot;propertyC1&quot;: &quot;1&quot;, &quot;propertyC2&quot;: &quot;2&quot; }  \r\n];\r\nconsole.log(checkArray(array1))))\r\n```",
                "title": "How to transform JSON array elements recursively into objects using JQ filter"
            },
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1732701725,
                "creation_date": 1732701725,
                "answer_id": 79229763,
                "question_id": 79229599,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You basically want to turn each array into an object with each item&#39;s `.name` field turned into a key. You could use `from_entries` which requires each key and value as `.name` (or `.key`) and `.value` fields, so all you have to do is to set up a `.value` without the `.name` field. `walk` the document tree to apply this to each `array`.\r\n```sh\r\nwalk(arrays |= (map(.value = del(.name)) | from_entries))\r\n```\r\n```json\r\n{\r\n  &quot;property&quot;: &quot;value&quot;,\r\n  &quot;array1&quot;: {\r\n    &quot;A&quot;: {\r\n      &quot;propertyA1&quot;: &quot;1&quot;,\r\n      &quot;propertyA2&quot;: &quot;2&quot;\r\n    },\r\n    &quot;B&quot;: {\r\n      &quot;propertyB1&quot;: &quot;1&quot;,\r\n      &quot;array2&quot;: {\r\n        &quot;C&quot;: {\r\n          &quot;propertyC1&quot;: &quot;1&quot;,\r\n          &quot;propertyC2&quot;: &quot;2&quot;\r\n        }\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/Bg9PYfslvmgpfQf)",
                "title": "How to transform JSON array elements recursively into objects using JQ filter"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1732702015,
        "creation_date": 1732698956,
        "question_id": 79229599,
        "body_markdown": "I want to transform this JSON\r\n```json\r\n{\r\n    &quot;property&quot;: &quot;value&quot;,\r\n    &quot;array1&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;A&quot;,\r\n            &quot;propertyA1&quot;: &quot;1&quot;,\r\n            &quot;propertyA2&quot;: &quot;2&quot;\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;B&quot;,\r\n            &quot;propertyB1&quot;: &quot;1&quot;,\r\n            &quot;array2&quot;: [\r\n                {\r\n                    &quot;name&quot;: &quot;C&quot;,\r\n                    &quot;propertyC1&quot;: &quot;1&quot;,\r\n                    &quot;propertyC2&quot;: &quot;2&quot;\r\n                }\r\n            ]\r\n        }\r\n    ]\r\n}\r\n```\r\ninto that using a JQ filter.\r\n```json\r\n{\r\n    &quot;property&quot;: &quot;value&quot;,\r\n    &quot;array1&quot;: {\r\n        &quot;A&quot;: {\r\n            &quot;propertyA1&quot;: &quot;1&quot;,\r\n            &quot;propertyA2&quot;: &quot;2&quot;\r\n        },\r\n        &quot;B&quot; : {\r\n            &quot;propertyB1&quot;: &quot;1&quot;,\r\n            &quot;array2&quot;: {\r\n                &quot;C&quot; : {\r\n                    &quot;propertyC1&quot;: &quot;1&quot;,\r\n                    &quot;propertyC2&quot;: &quot;2&quot;\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\nThe difficulty is to make this work recursively. Moreover, only arrays who\r\npossess an object with a property `name` should be considered. I had a few attempts but\r\nit already fails if I want to add a new property do the arrays (I know it&#39;s not possible,\r\nsince it is an array).\r\n",
        "link": "https://stackoverflow.com/questions/79229599/how-to-transform-json-array-elements-recursively-into-objects-using-jq-filter",
        "title": "How to transform JSON array elements recursively into objects using JQ filter"
    },
    {
        "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": 1732727676,
                "post_id": 79230976,
                "comment_id": 139715013,
                "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": 1732728213,
                "post_id": 79230976,
                "comment_id": 139715070,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1732904693,
                "last_edit_date": 1732904693,
                "creation_date": 1732727761,
                "answer_id": 79231271,
                "question_id": 79230976,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `(.myfield | test(&quot;my regexp&quot;))` in a conditional just as you can use `.myfield == &quot;my content&quot;`.\r\n\r\nThus:\r\n\r\n```bash\r\njq -c &#39;\r\n  walk(if type == &quot;object&quot; and\r\n          (.myfield | type) == &quot;string&quot; and\r\n          (.myfield | test(&quot;my regexp&quot;))\r\n       then del(.xxx)\r\n       else . end)\r\n&#39; &lt;&lt;&#39;EOF&#39;\r\n{\r\n  &quot;structure&quot;: {\r\n    &quot;test-match&quot;: {\r\n      &quot;myfield&quot;: &quot;content that matches my regexp&quot;,\r\n      &quot;xxx&quot;: &quot;this should be deleted&quot;\r\n    },\r\n    &quot;test-nomatch&quot;: {\r\n      &quot;myfield&quot;: &quot;content that DOES NOT match the active expression&quot;,\r\n      &quot;xxx&quot;: &quot;this should not be deleted&quot;\r\n    },\r\n    &quot;test-invalid&quot;: {\r\n      &quot;state&quot;: &quot;no myfield exists at all&quot;,\r\n      &quot;xxx&quot;: &quot;this should not be deleted&quot;\r\n    }\r\n  }\r\n}\r\nEOF\r\n```\r\n\r\n...properly emitting as output:\r\n\r\n```json\r\n{\r\n  &quot;structure&quot;: {\r\n    &quot;test-match&quot;: {\r\n      &quot;myfield&quot;: &quot;content that matches my regexp&quot;\r\n    },\r\n    &quot;test-nomatch&quot;: {\r\n      &quot;myfield&quot;: &quot;content that DOES NOT match the active expression&quot;,\r\n      &quot;xxx&quot;: &quot;this should not be deleted&quot;\r\n    },\r\n    &quot;test-invalid&quot;: {\r\n      &quot;state&quot;: &quot;no myfield exists at all&quot;,\r\n      &quot;xxx&quot;: &quot;this should not be deleted&quot;\r\n    }\r\n  }\r\n}\r\n```",
                "title": "jq manipulate object where field matches regex"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1732904693,
        "creation_date": 1732722835,
        "last_edit_date": 1732723583,
        "question_id": 79230976,
        "body_markdown": "I need to delete a field `.xxx` from an object at any depth of the tree where another field `.myfield` matches a regex.\r\n\r\nI know how to match a precise content: \r\n```\r\nwalk(if type == &quot;object&quot; and .myfield == &quot;my content&quot; then del(.xxx) else . end)&#39;\r\n```\r\nI know about the regex _filter_ \r\n```\r\nselect(.myfield | test(my regexp))\r\n```\r\nHow can I convert that filter to a boolean condition for use in the `if` clause?\r\n",
        "link": "https://stackoverflow.com/questions/79230976/jq-manipulate-object-where-field-matches-regex",
        "title": "jq manipulate object where field matches regex"
    },
    {
        "tags": [
            "jq",
            "amazon-cloudtrail"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 52839,
                    "reputation": 99133,
                    "user_id": 157957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MBRE7.jpg?s=256",
                    "display_name": "IMSoP",
                    "link": "https://stackoverflow.com/users/157957/imsop"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1732889322,
                "post_id": 79237305,
                "comment_id": 139725840,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 38009250,
                    "reputation": 1,
                    "user_id": 28548110,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e8f93e8d9e3cd935ed57b277d9685928?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ajith Jesudasan",
                    "link": "https://stackoverflow.com/users/28548110/ajith-jesudasan"
                },
                "reply_to_user": {
                    "account_id": 52839,
                    "reputation": 99133,
                    "user_id": 157957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MBRE7.jpg?s=256",
                    "display_name": "IMSoP",
                    "link": "https://stackoverflow.com/users/157957/imsop"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732910907,
                "post_id": 79237305,
                "comment_id": 139727390,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 38009250,
                    "reputation": 1,
                    "user_id": 28548110,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e8f93e8d9e3cd935ed57b277d9685928?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ajith Jesudasan",
                    "link": "https://stackoverflow.com/users/28548110/ajith-jesudasan"
                },
                "reply_to_user": {
                    "account_id": 52839,
                    "reputation": 99133,
                    "user_id": 157957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MBRE7.jpg?s=256",
                    "display_name": "IMSoP",
                    "link": "https://stackoverflow.com/users/157957/imsop"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732910929,
                "post_id": 79237305,
                "comment_id": 139727394,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 38009250,
                    "reputation": 1,
                    "user_id": 28548110,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e8f93e8d9e3cd935ed57b277d9685928?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Ajith Jesudasan",
                    "link": "https://stackoverflow.com/users/28548110/ajith-jesudasan"
                },
                "reply_to_user": {
                    "account_id": 52839,
                    "reputation": 99133,
                    "user_id": 157957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MBRE7.jpg?s=256",
                    "display_name": "IMSoP",
                    "link": "https://stackoverflow.com/users/157957/imsop"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732910949,
                "post_id": 79237305,
                "comment_id": 139727397,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 52839,
                    "reputation": 99133,
                    "user_id": 157957,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/MBRE7.jpg?s=256",
                    "display_name": "IMSoP",
                    "link": "https://stackoverflow.com/users/157957/imsop"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1732960438,
                "post_id": 79237305,
                "comment_id": 139728865,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1732958814,
                "last_edit_date": 1732958814,
                "creation_date": 1732924085,
                "answer_id": 79238594,
                "question_id": 79237305,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "For CSV output, change your second jq invocation to:\r\n``` \r\njq ‘ [.userIdentity.arn, .eventTime, .responseElements.ConsoleLogin]\r\n| @csv&#39;\r\n```\r\nYou might want to combine the two invocations into one, and/or use `@tsv` or `join(&quot;|&quot;)` instead of `@csv`. \r\nThe Linux/Unix `column` command might be relevant here as well.",
                "title": "How to get this output in TABLE format"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": -1,
        "last_activity_date": 1732958814,
        "creation_date": 1732887760,
        "last_edit_date": 1732928985,
        "question_id": 79237305,
        "body_markdown": "I want to get the below command output in table format using Linux commands:\r\n\r\n```\r\naws --region us-east-1 cloudtrail lookup-events --lookup-attributes AttributeKey=EventName,AttributeValue=ConsoleLogin --start-time $START_TIME | \\\r\njq -r .Events[].CloudTrailEvent | \\\r\njq &#39;.userIdentity.arn, .eventTime, .responseElements.ConsoleLogin&#39;)\r\n```\r\n\r\nCurrent output:\r\n\r\n```none\r\n&quot;arn:aws:sts::accountnum:assumed-role/role/user@com&quot;\r\n\r\n&quot;2024-11-29T06:48:05Z&quot;\r\n\r\n&quot;Success&quot;\r\n\r\n&quot;arn:aws:sts::accountnum:assumed-role/role/user@com&quot;\r\n\r\n&quot;2024-11-29T03:12:14Z&quot;\r\n\r\n&quot;Success&quot;\r\n\r\n&quot;arn:aws:sts::accountnum:assumed-role/role/user@com&quot;\r\n\r\n&quot;2024-11-29T02:42:48Z&quot;\r\n\r\n&quot;Success&quot;\r\n```",
        "link": "https://stackoverflow.com/questions/79237305/how-to-get-this-output-in-table-format",
        "title": "How to get this output in TABLE format"
    },
    {
        "tags": [
            "go",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1733049187,
                "creation_date": 1733049187,
                "answer_id": 79241373,
                "question_id": 79241351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `%:z` instead of `%z`. (You can also shorten `%Y-%m-%d` to `%F` and `%H:%M:%S` to `%T`):\r\n```sh\r\ngojq -nr &#39;&quot;2024-12-01 00:00:00&quot; | strptime(&quot;%F %T&quot;) | strflocaltime(&quot;%FT%T%:z&quot;)&#39;\r\n```\r\n```none\r\n2024-12-01T00:00:00+01:00\r\n```\r\nTested with [gojq](https://github.com/itchyny/gojq) 0.12.16",
                "title": "Use jq to parse local time into Golang RFC 3339"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1733054921,
                "creation_date": 1733054921,
                "answer_id": 79241515,
                "question_id": 79241351,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `sub` to convert to the required format :\r\n\r\n```\r\njq -nr &#39;&quot;2024-12-01 00:00:00&quot; | strptime(&quot;%F %T&quot;) | strflocaltime(&quot;%FT%T%z&quot;) | sub(&quot;\\\\+(?&lt;d&gt;[0-9][0-9])&quot;;&quot;Z\\(.d):&quot;)&#39;\r\n# output: 2024-12-01T00:00:00Z01:00\r\n```",
                "title": "Use jq to parse local time into Golang RFC 3339"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1733054921,
        "creation_date": 1733048449,
        "question_id": 79241351,
        "body_markdown": "I have `&quot;2024-12-01 00:00:00&quot;` in local TZ (Europe/Berlin) and want to parse/convert this into RFC3339 for Go `time.Parse` which would be `&quot;2024-12-01T00:00:00+01:00&quot;`. \r\n\r\nI&#39;ve tried various variants of \r\n\r\n    strptime(&quot;%Y-%m-%d %H:%M:%S&quot;) | strflocaltime(&quot;%Y-%m-%dT%H:%M:%S%z&quot;)\r\n\r\nbut I can&#39;t get the timezone out in a suitable format since RFC 3339 insists on the `:`:\r\n\r\n    RFC3339     = &quot;2006-01-02T15:04:05Z07:00&quot;\r\n\r\nand the above format returns\r\n\r\n    2024-12-01T00:00:00+0100\r\n\r\nwhich is missing the `:` in the timezone.\r\n\r\nHow can I get proper timezone format out of the JQ expression (or parse/convert the timestamp so it can be output as UTC)?",
        "link": "https://stackoverflow.com/questions/79241351/use-jq-to-parse-local-time-into-golang-rfc-3339",
        "title": "Use jq to parse local time into Golang RFC 3339"
    },
    {
        "tags": [
            "jq",
            "ndpi"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 532831,
                    "reputation": 479,
                    "user_id": 903602,
                    "user_type": "registered",
                    "accept_rate": 90,
                    "profile_image": "https://www.gravatar.com/avatar/e7346157c79acc3fd7fd58cae1ea131a?s=256&d=identicon&r=PG",
                    "display_name": "AJM.MARTINEZ",
                    "link": "https://stackoverflow.com/users/903602/ajm-martinez"
                },
                "reply_to_user": {
                    "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": 1733160885,
                "post_id": 79245004,
                "comment_id": 139738870,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1733161227,
                "creation_date": 1733161227,
                "answer_id": 79245066,
                "question_id": 79245004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "That part of the filter can be represented in multiple ways, but in my experience one of the easier ways to work with the keys of an object involves [`to_entries`](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries).\r\n\r\nAs an example, you can use something along the lines of `.ndpi.flow_risk | to_entries[] | select(.key | tonumber | . &lt;= 50 and . &gt;= 0).value | &quot;\\(.risk),\\(.severity)&quot;` to get for those last two pieces of information (if the `&quot;flow risk&quot;` object is guaranteed to have only a single key, which is guaranteed to be numeric)",
                "title": "Parsing json output with JQ - Searching for patterns"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1733161248,
                "creation_date": 1733161248,
                "answer_id": 79245068,
                "question_id": 79245004,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To access a variable but known key, use the `--arg` [flag](https://jqlang.github.io/jq/manual/#invoking-jq) to bind a variable to a value, and then `.[$varname]` to [access the field](https://jqlang.github.io/jq/manual/#object-index):\r\n```sh\r\njq -r --arg n &quot;35&quot; &#39;… .ndpi.flow_risk[$n].risk …&#39;\r\n```\r\n\r\n&gt; is there any chanve to use something like wildcards with jq ?\r\n\r\nTo access all keys, just use `.[]`. However, you presumably want to reference the same keys both times you&#39;ve used `35` in the example. For that, iterate before creating (the relevant part of) the output string, and reference the iteration value (context):\r\n```sh\r\njq -r &#39;… ,\\(.ndpi.flow_risk[] | &quot;\\(.risk),\\(.severity)&quot;)&#39;\r\n```\r\n\r\nTo access a specific range, use `range` to create them, turn it into a string using `tostring`, and proceed as above (`&quot;0&quot; +` prepends the zero, and `[-2:]` reduces it to the last two characters):\r\n```sh\r\njq -r &#39;… ,\\(.ndpi.flow_risk[range (50)+1 | (&quot;0&quot; + tostring)[-2:]] | &quot;\\(.risk),\\(.severity)&quot;)&#39;\r\n```",
                "title": "Parsing json output with JQ - Searching for patterns"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1733186239,
        "creation_date": 1733159883,
        "last_edit_date": 1733186239,
        "question_id": 79245004,
        "body_markdown": "I have the following JSON (based on NDPI output)\r\n\r\n    {\r\n\t\t&quot;src_ip&quot;: &quot;x.x.x.x&quot;,\r\n\t\t&quot;dest_ip&quot;: &quot;x1.x1.x1.x1&quot;,\r\n\t\t&quot;src_port&quot;: 48318,\r\n\t\t&quot;dst_port&quot;: 443,\r\n\t\t&quot;ip&quot;: 4,\r\n\t\t&quot;proto&quot;: &quot;TCP&quot;,\r\n\t\t&quot;ndpi&quot;: {\r\n\t\t\t&quot;flow_risk&quot;: {\r\n\t\t\t\t&quot;35&quot;: {\r\n\t\t\t\t\t&quot;risk&quot;: &quot;Susp Entropy&quot;,\r\n\t\t\t\t\t&quot;severity&quot;: &quot;Medium&quot;,\r\n\t\t\t\t\t&quot;risk_score&quot;: {\r\n\t\t\t\t\t\t&quot;total&quot;: 210,\r\n\t\t\t\t\t\t&quot;client&quot;: 165,\r\n\t\t\t\t\t\t&quot;server&quot;: 45\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\t&quot;confidence&quot;: {\r\n\t\t\t\t&quot;1&quot;: &quot;Match by port&quot;\r\n\t\t\t},\r\n\t\t\t&quot;proto&quot;: &quot;TLS&quot;,\r\n\t\t\t&quot;proto_id&quot;: &quot;91&quot;,\r\n\t\t\t&quot;proto_by_ip&quot;: &quot;Unknown&quot;,\r\n\t\t\t&quot;proto_by_ip_id&quot;: 0,\r\n\t\t\t&quot;encrypted&quot;: 1,\r\n\t\t\t&quot;breed&quot;: &quot;Safe&quot;,\r\n\t\t\t&quot;category_id&quot;: 5,\r\n\t\t\t&quot;category&quot;: &quot;Web&quot;\r\n\t\t},\r\n\t\t&quot;detection_completed&quot;: 1,\r\n\t\t&quot;check_extra_packets&quot;: 0,\r\n\t\t&quot;flow_id&quot;: 0,\r\n\t\t&quot;first_seen&quot;: 1733074272.824,\r\n\t\t&quot;last_seen&quot;: 1733074282.757,\r\n\t\t&quot;duration&quot;: 9.933,\r\n\t\t&quot;vlan_id&quot;: 0,\r\n\t\t&quot;bidirectional&quot;: 1,\r\n\t\t&quot;xfer&quot;: {\r\n\t\t\t&quot;data_ratio&quot;: -0.958,\r\n\t\t\t&quot;data_ratio_str&quot;: &quot;Download&quot;,\r\n\t\t\t&quot;src2dst_packets&quot;: 1268,\r\n\t\t\t&quot;src2dst_bytes&quot;: 86239,\r\n\t\t\t&quot;src2dst_goodput_bytes&quot;: 2551,\r\n\t\t\t&quot;dst2src_packets&quot;: 2693,\r\n\t\t\t&quot;dst2src_bytes&quot;: 4042956,\r\n\t\t\t&quot;dst2src_goodput_bytes&quot;: 3865218\r\n\t\t},\r\n\t\t&quot;iat&quot;: {\r\n\t\t\t&quot;flow_min&quot;: 1,\r\n\t\t\t&quot;flow_avg&quot;: 6.1,\r\n\t\t\t&quot;flow_max&quot;: 4005,\r\n\t\t\t&quot;flow_stddev&quot;: 108.3,\r\n\t\t\t&quot;c_to_s_min&quot;: 0,\r\n\t\t\t&quot;c_to_s_avg&quot;: 7.4,\r\n\t\t\t&quot;c_to_s_max&quot;: 4005,\r\n\t\t\t&quot;c_to_s_stddev&quot;: 137.8,\r\n\t\t\t&quot;s_to_c_min&quot;: 0,\r\n\t\t\t&quot;s_to_c_avg&quot;: 1.4,\r\n\t\t\t&quot;s_to_c_max&quot;: 35,\r\n\t\t\t&quot;s_to_c_stddev&quot;: 2.2\r\n\t\t},\r\n\t\t&quot;pktlen&quot;: {\r\n\t\t\t&quot;c_to_s_min&quot;: 66,\r\n\t\t\t&quot;c_to_s_avg&quot;: 68.0,\r\n\t\t\t&quot;c_to_s_max&quot;: 514,\r\n\t\t\t&quot;c_to_s_stddev&quot;: 28.8,\r\n\t\t\t&quot;s_to_c_min&quot;: 66,\r\n\t\t\t&quot;s_to_c_avg&quot;: 1501.3,\r\n\t\t\t&quot;s_to_c_max&quot;: 1506,\r\n\t\t\t&quot;s_to_c_stddev&quot;: 76.6\r\n\t\t},\r\n\t\t&quot;tcp_flags&quot;: {\r\n\t\t\t&quot;cwr_count&quot;: 0,\r\n\t\t\t&quot;ece_count&quot;: 0,\r\n\t\t\t&quot;urg_count&quot;: 0,\r\n\t\t\t&quot;ack_count&quot;: 3961,\r\n\t\t\t&quot;psh_count&quot;: 1323,\r\n\t\t\t&quot;rst_count&quot;: 0,\r\n\t\t\t&quot;syn_count&quot;: 0,\r\n\t\t\t&quot;fin_count&quot;: 0,\r\n\t\t\t&quot;src2dst_cwr_count&quot;: 0,\r\n\t\t\t&quot;src2dst_ece_count&quot;: 0,\r\n\t\t\t&quot;src2dst_urg_count&quot;: 0,\r\n\t\t\t&quot;src2dst_ack_count&quot;: 1268,\r\n\t\t\t&quot;src2dst_psh_count&quot;: 7,\r\n\t\t\t&quot;src2dst_rst_count&quot;: 0,\r\n\t\t\t&quot;src2dst_syn_count&quot;: 0,\r\n\t\t\t&quot;src2dst_fin_count&quot;: 0,\r\n\t\t\t&quot;dst2src_cwr_count&quot;: 0,\r\n\t\t\t&quot;dst2src_ece_count&quot;: 0,\r\n\t\t\t&quot;dst2src_urg_count&quot;: 0,\r\n\t\t\t&quot;dst2src_ack_count&quot;: 2693,\r\n\t\t\t&quot;dst2src_psh_count&quot;: 1316,\r\n\t\t\t&quot;dst2src_rst_count&quot;: 0,\r\n\t\t\t&quot;dst2src_syn_count&quot;: 0,\r\n\t\t\t&quot;dst2src_fin_count&quot;: 0\r\n\t\t},\r\n\t\t&quot;c_to_s_init_win&quot;: 0,\r\n\t\t&quot;s_to_c_init_win&quot;: 0\r\n\t}\r\n\r\nI can get almost all the information (src_ip, ports, etc.), but there is one thing related to &quot;flow_risk&quot; \r\n\r\n    {&quot;flow_risk&quot;: {&quot;35&quot;: {&quot;risk&quot;:&quot;Susp Entropy&quot;,&quot;severity&quot;:&quot;Medium&quot;\r\n\r\nthat is related to the number (in this case 35). This number can be different (from 01 to 50) and I don&#39;t know how to filter to search for different numbers.\r\n\r\nRight now, this is the filter I&#39;m using\r\n\r\n    cat data.json | jq -r &#39;&quot;\\(.src_ip),\\(.src_port),\\(.dest_ip),\\(.dst_port),\\(.proto),\\(.ndpi.proto),\\(.ndpi.category),\\(.ndpi.hostname),\\(.duration),\\(.vlan_id),\\(.xfer.src2dst_bytes),\\(.xfer.dst2src_bytes),\\(.ndpi.flow_risk.&quot;35&quot;.risk),\\(.ndpi.flow_risk.&quot;35&quot;.severity)&quot;&#39;)\r\n\r\nThis works when the number is exactly 35, but is there any chance to use something like wildcards with jQ? \r\n\r\nI mean how can I do this to accept multiple numbers? (for ex: searching from 01 to 50?)\r\n\r\nSomething like \r\n\r\n    \\(.ndpi.flow_risk.&quot;*&quot;.risk),\\(.ndpi.flow_risk.&quot;*&quot;.severity)&quot;&#39;)\r\n\r\nthanks !\r\n",
        "link": "https://stackoverflow.com/questions/79245004/parsing-json-output-with-jq-searching-for-patterns",
        "title": "Parsing json output with JQ - Searching for patterns"
    },
    {
        "tags": [
            "ansible",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1733205551,
                "creation_date": 1733205551,
                "answer_id": 79246420,
                "question_id": 79246132,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As you&#39;ve tagged [tag:jq], this assumes you want to call [jq](https://github.com/jqlang/jq) with the two JSON responses as its input.\r\n\r\nYou can read in both objects into an array using the `--slurp` (or `-s`) flag, and reduce them to the relevant values. Then, use `transpose` to align the items, and filter for differences using `select`.\r\n```sh\r\njq -s &#39;\r\n  map(.AppCoreDetails) | transpose\r\n  | {AppCoreDetails: map(select(first != last)[0])}\r\n&#39;\r\n```\r\n[Demo](https://jqplay.org/s/iGdF_g1JDnC4-yB)\r\n\r\nThis assumes that the `.ApplicationName` values are already aligned for both cases, i.e. the arrays have the same number of items and the names come in the same order. If this is not necessarily the case, specify how to deal with dangling matches. Here&#39;s an approach using `JOIN` and `INDEX` to find matching `.ApplicationName` values:\r\n\r\n```sh\r\njq -s &#39;map(.AppCoreDetails) | {AppCoreDetails: [JOIN(\r\n  INDEX(last[]; .ApplicationName); first[]; .ApplicationName; select(first != last)[0]\r\n)]}&#39;\r\n```\r\n[Demo](https://jqplay.org/s/X2C3ehaTJ0P9DqP)\r\n\r\nGiven the two sample inputs, both approaches output\r\n```json\r\n{\r\n  &quot;AppCoreDetails&quot;: [\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2023-08-25 12:23:26&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "Ansible compare two JSON responses"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1733243907,
                "last_edit_date": 1733243907,
                "creation_date": 1733243528,
                "answer_id": 79248448,
                "question_id": 79246132,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "* Concatenate the lists and convert the attributes *LastModified* to lists\r\n\r\n```yaml\r\n  nodes: &quot;{{ (node1_applications.AppCoreDetails +\r\n              node2_applications.AppCoreDetails) |\r\n              json_query(&#39;[].{ApplicationName: ApplicationName,\r\n                              LastModified: [LastModified]}&#39;) }}&quot;\r\n```\r\ngives\r\n\r\n```yaml\r\n  nodes:\r\n    - ApplicationName: APP_Config_V1\r\n      LastModified: [&#39;2023-08-25 12:23:26&#39;]\r\n    - ApplicationName: APP_Intervals_V1\r\n      LastModified: [&#39;2022-11-23 14:46:58&#39;]\r\n    - ApplicationName: APP_Config_V1\r\n      LastModified: [&#39;2023-08-25 12:03:30&#39;]\r\n    - ApplicationName: APP_Intervals_V1\r\n      LastModified: [&#39;2022-11-23 14:46:58&#39;]\r\n```\r\n\r\n* Append the lists by the index *ApplicationName*\r\n\r\n```yaml\r\n  nodes_merge: &quot;{{ [nodes, []] |\r\n                   community.general.lists_mergeby(&#39;ApplicationName&#39;,\r\n                                                   list_merge=&#39;append&#39;) }}&quot;\r\n```\r\n\r\ngives\r\n\r\n```yaml\r\n  nodes_merge:\r\n    - ApplicationName: APP_Config_V1\r\n      LastModified: [&#39;2023-08-25 12:23:26&#39;, &#39;2023-08-25 12:03:30&#39;]\r\n    - ApplicationName: APP_Intervals_V1\r\n      LastModified: [&#39;2022-11-23 14:46:58&#39;]\r\n```\r\n\r\n* If there are more items on a list take the first one\r\n\r\n```yaml\r\n  AppCoreDetails_dict: |\r\n    {\r\n    {% for i in nodes_merge %}\r\n    {% if i.LastModified | length &gt; 1 %}\r\n    &quot;{{ i.ApplicationName }}&quot;: &quot;{{ i.LastModified | first }}&quot;,\r\n    {% endif %}\r\n    {% endfor %}\r\n    }\r\n```\r\n\r\ngives\r\n\r\n```yaml\r\n  AppCoreDetails_dict:\r\n    APP_Config_V1: &#39;2023-08-25 12:23:26&#39;\r\n```\r\n\r\n* Convert the dictionary to a list\r\n\r\n```yaml\r\n  AppCoreDetails: &quot;{{ AppCoreDetails_dict | dict2items(key_name=&#39;ApplicationName&#39;,\r\n                                                       value_name=&#39;LastModified&#39;) }}&quot;\r\n```\r\n\r\ngives\r\n\r\n```yaml\r\n  AppCoreDetails:\r\n    [\r\n        {\r\n            &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n            &quot;LastModified&quot;: &quot;2023-08-25 12:23:26&quot;\r\n        }\r\n    ]\r\n```\r\n\r\n&lt;hr&gt;\r\n\r\n&lt;sup&gt;\r\n\r\nExample of a complete playbook for testing\r\n\r\n```yaml\r\n- hosts: localhost\r\n\r\n  vars:\r\n\r\n    node1_applications:\r\n      AppCoreDetails:\r\n        - ApplicationName: APP_Config_V1\r\n          LastModified: &#39;2023-08-25 12:23:26&#39;\r\n        - ApplicationName: APP_Intervals_V1\r\n          LastModified: &#39;2022-11-23 14:46:58&#39;\r\n      Node: ESB1\r\n\r\n    node2_applications:\r\n      AppCoreDetails:\r\n        - ApplicationName: APP_Config_V1\r\n          LastModified: &#39;2023-08-25 12:03:30&#39;\r\n        - ApplicationName: APP_Intervals_V1\r\n          LastModified: &#39;2022-11-23 14:46:58&#39;\r\n      Node: ESB2\r\n\r\n    nodes: &quot;{{ (node1_applications.AppCoreDetails +\r\n                node2_applications.AppCoreDetails) |\r\n                json_query(&#39;[].{ApplicationName: ApplicationName,\r\n                                LastModified: [LastModified]}&#39;) }}&quot;\r\n    nodes_merge: &quot;{{ [nodes, []] |\r\n                     community.general.lists_mergeby(&#39;ApplicationName&#39;,\r\n                                                     list_merge=&#39;append&#39;) }}&quot;\r\n    AppCoreDetails_dict: |\r\n      {\r\n      {% for i in nodes_merge %}\r\n      {% if i.LastModified | length &gt; 1 %}\r\n      &quot;{{ i.ApplicationName }}&quot;: &quot;{{ i.LastModified | first }}&quot;,\r\n      {% endif %}\r\n      {% endfor %}\r\n      }\r\n    AppCoreDetails: &quot;{{ AppCoreDetails_dict | dict2items(key_name=&#39;ApplicationName&#39;,\r\n                                                         value_name=&#39;LastModified&#39;) }}&quot;\r\n\r\n  tasks:\r\n\r\n    - debug:\r\n        var: nodes | to_yaml\r\n\r\n    - debug:\r\n        var: nodes_merge | to_yaml\r\n\r\n    - debug:\r\n        var: AppCoreDetails_dict\r\n\r\n    - debug:\r\n        var: AppCoreDetails\r\n\r\n    - debug:\r\n        msg: |\r\n          AppCoreDetails:\r\n            {{ AppCoreDetails | to_nice_json }}\r\n```\r\n\r\n&lt;/sup&gt;\r\n",
                "title": "Ansible compare two JSON responses"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1733437679,
                "creation_date": 1733437679,
                "answer_id": 79256401,
                "question_id": 79246132,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "To better understand @pmf&#39;s answer I cloned the content in the link to the second [Demo][1] and broke the jq command `map(.AppCoreDetails) | {AppCoreDetails: [JOIN( INDEX(last[]; .ApplicationName); first[]; .ApplicationName; select(first != last)[0] )]}` into it&#39;s component parts, remember to set the -s option in the new playground when you do so.\r\n\r\nI also read through [Understanding jq&#39;s SQL style operators JOIN and INDEX][2]\r\n\r\nStarting with `map(.AppCoreDetails)` we get:\r\n```\r\n[\r\n  [\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2023-08-25 12:23:26&quot;\r\n    },\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Intervals_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2022-11-23 14:46:58&quot;\r\n    }\r\n  ],\r\n  [\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2023-08-25 12:03:30&quot;\r\n    },\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Intervals_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2022-11-23 14:46:58&quot;\r\n    }\r\n  ]\r\n]\r\n```\r\n\r\nPiping the map to last `map(.AppCoreDetails) | last` gives:\r\n```\r\n[\r\n  {\r\n    &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n    &quot;LastModified&quot;: &quot;2023-08-25 12:03:30&quot;\r\n  },\r\n  {\r\n    &quot;ApplicationName&quot;: &quot;APP_Intervals_V1&quot;,\r\n    &quot;LastModified&quot;: &quot;2022-11-23 14:46:58&quot;\r\n  }\r\n]\r\n```\r\n\r\nAdding the brackets `map(.AppCoreDetails) | last[]` gives us:\r\n```\r\n{\r\n  &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n  &quot;LastModified&quot;: &quot;2023-08-25 12:03:30&quot;\r\n}\r\n{\r\n  &quot;ApplicationName&quot;: &quot;APP_Intervals_V1&quot;,\r\n  &quot;LastModified&quot;: &quot;2022-11-23 14:46:58&quot;\r\n}\r\n```\r\nWhich provides the content for the first, stream, parameter of the INDEX function `map(.AppCoreDetails) | INDEX(last[]; .ApplicationName)` giving:\r\n```\r\n{\r\n  &quot;APP_Config_V1&quot;: {\r\n    &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n    &quot;LastModified&quot;: &quot;2023-08-25 12:03:30&quot;\r\n  },\r\n  &quot;APP_Intervals_V1&quot;: {\r\n    &quot;ApplicationName&quot;: &quot;APP_Intervals_V1&quot;,\r\n    &quot;LastModified&quot;: &quot;2022-11-23 14:46:58&quot;\r\n  }\r\n}\r\n```\r\nThe INDEX is then fed into the JOIN \r\n`map(.AppCoreDetails) | JOIN( INDEX(last[]; .ApplicationName); first[]; .ApplicationName; select(first != last)[0] )` giving:\r\n```\r\n{\r\n  &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n  &quot;LastModified&quot;: &quot;2023-08-25 12:23:26&quot;\r\n}\r\n```\r\nAnd so we get to the full command `map(.AppCoreDetails) | {AppCoreDetails: [JOIN( INDEX(last[]; .ApplicationName); first[]; .ApplicationName; select(first != last)[0] )]}` where the wrapper text gets added to provide the desired answer:\r\n```\r\n{\r\n  &quot;AppCoreDetails&quot;: [\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2023-08-25 12:23:26&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nOther experiments included \r\n\r\n 1. Adding an extra entry in the first array which then appears in the output because it just doesn&#39;t exist in the second array.\r\n 2. Swapping first[] and last[] in the command. Which demonstrates the behaviour is order dependent. Think WRT(With Respect To)\r\n 3. Updating the select to compare fields rather than the entire object `select(first.LastModified != last.LastModified)[0])`\r\n\r\nFinally a big thank you to @pmf for his help.\r\n\r\n \r\n\r\n\r\n  [1]: https://jqplay.org/s/X2C3ehaTJ0P9DqP\r\n  [2]: https://qmacro.org/blog/posts/2022/06/23/understanding-jq&#39;s-sql-style-operators-join-and-index/",
                "title": "Ansible compare two JSON responses"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1733437679,
        "creation_date": 1733193863,
        "last_edit_date": 1733198462,
        "question_id": 79246132,
        "body_markdown": "I&#39;m using Ansible to call the same administration API on two different servers and then selecting the core details of the applications from the responses using jq. \r\n\r\nAccording to Ansible type_debug the registered variables are of type dict\r\n```\r\nok: [localhost] =&gt; {\r\n    &quot;node1_applications | type_debug&quot;: &quot;dict&quot;\r\n}\r\n```\r\n```\r\nok: [localhost] =&gt; {\r\n    &quot;node2_applications | type_debug&quot;: &quot;dict&quot;\r\n}\r\n```\r\n\r\nThe JSON from the two responses looks like\r\n```\r\n{\r\n  &quot;Node&quot;: &quot;ESB1&quot;,\r\n  &quot;AppCoreDetails&quot;: [\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2023-08-25 12:23:26&quot;\r\n    },\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Intervals_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2022-11-23 14:46:58&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\n```\r\n{\r\n  &quot;Node&quot;: &quot;ESB2&quot;,\r\n  &quot;AppCoreDetails&quot;: [\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2023-08-25 12:03:30&quot;\r\n    },\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Intervals_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2022-11-23 14:46:58&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nWhere the LastModified date of the first entry in AppCoreDetails is different and for the second entry it&#39;s the same.\r\n\r\nI&#39;d like to get the set of objects where the LastMofified dates are different.\r\n```\r\n{\r\n  &quot;AppCoreDetails&quot;: [\r\n    {\r\n      &quot;ApplicationName&quot;: &quot;APP_Config_V1&quot;,\r\n      &quot;LastModified&quot;: &quot;2023-08-25 12:23:26&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\nBTW I found and tried experimenting with this but failed to convert from simple fields to objects [enter link description here][1]\r\n \r\n\r\n\r\n  [1]: https://stackoverflow.com/questions/70144839/compare-2-json-file-and-copy-the-difference-of-it-to-another-file-based-on-2nd-f",
        "link": "https://stackoverflow.com/questions/79246132/ansible-compare-two-json-responses",
        "title": "Ansible compare two JSON responses"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1733358545,
                "creation_date": 1733358545,
                "answer_id": 79253080,
                "question_id": 79253065,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Loop over the `.Configs` first:\r\n```\r\njq --arg node &quot;host-inf-4&quot; &#39;.[] | select (.SchedulerNodeName == $node).Configs[] | select(.PXType == &quot;data&quot;).ID&#39; /path/to/json\r\n\r\n# &quot;[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk&quot;\r\n```\r\n\r\n\r\nAnd don&#39;t forget to use `--arg` instead of bash vars",
                "title": "jq query with multiple conditions not working"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1733358545,
        "creation_date": 1733357562,
        "question_id": 79253065,
        "body_markdown": "I&#39;m trying to run a jq query with multiple conditions, where the fields in the condition are in different parts of the JSON.  The second condition isn&#39;t narrowing things down, and I need help figuring out why. The JSON is below.\r\n\r\nAs a baseline, querying on one condition gives me the output I expect:\r\n``` lang-sh\r\n$ NODE=&quot;host-inf-4&quot;; cat pxctl-cd-list-short.json | jq -c &#39;.[] | select (.SchedulerNodeName == &#39;\\&quot;${NODE}\\&quot;&#39;)&#39;\r\n```\r\n``` lang-json\r\n{&quot;Configs&quot;:{&quot;[datastore-21] adsadaiuhwiorgwipo/_00ca/hipeghwerwjks.vmdk&quot;:{&quot;Type&quot;:&quot;zeroedthick&quot;,&quot;Size&quot;:32,&quot;ID&quot;:&quot;[datastore--21] adsadaiuhwiorgwipo/_00ca/hipeghwerwjks.vmdk&quot;,&quot;PoolID&quot;:&quot;&quot;,&quot;Path&quot;:&quot;/dev/sdc&quot;,&quot;Iops&quot;:0,&quot;Vpus&quot;:0,&quot;PXType&quot;:&quot;kvdb&quot;,&quot;State&quot;:&quot;Pending Add&quot;,&quot;labels&quot;:{&quot;datastore&quot;:&quot;vsanDatastore&quot;},&quot;AttachOptions&quot;:{&quot;ext&quot;:&quot;.vmdk&quot;},&quot;Provisioner&quot;:&quot;&quot;,&quot;EncryptionKeyInfo&quot;:&quot;&quot;},&quot;[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk&quot;:{&quot;Type&quot;:&quot;lazyzeroedthick&quot;,&quot;Size&quot;:150,&quot;ID&quot;:&quot;[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk&quot;,&quot;PoolID&quot;:&quot;a471iidfisaj8i8124asdadsoif8ie82&quot;,&quot;Path&quot;:&quot;/dev/sdb&quot;,&quot;Iops&quot;:0,&quot;Vpus&quot;:0,&quot;PXType&quot;:&quot;data&quot;,&quot;State&quot;:&quot;In Use&quot;,&quot;labels&quot;:{&quot;datastore&quot;:&quot;vsanDatastore&quot;},&quot;AttachOptions&quot;:{&quot;ext&quot;:&quot;.vmdk&quot;},&quot;Provisioner&quot;:&quot;&quot;,&quot;EncryptionKeyInfo&quot;:&quot;&quot;}},&quot;NodeID&quot;:&quot;16a-8243r20-8fihqwc8-adew-2343ase&quot;,&quot;ReservedInstanceID&quot;:&quot;&quot;,&quot;SchedulerNodeName&quot;:&quot;host-inf-4&quot;,&quot;NodeIndex&quot;:12,&quot;CreateTimestamp&quot;:&quot;2024-11-22T00:27:38.432162311Z&quot;,&quot;InstanceID&quot;:&quot;42sdada08ihjpb3fe-6b-4873-0ya7-be80079acasca&quot;,&quot;Zone&quot;:&quot;default&quot;,&quot;State&quot;:&quot;In Use&quot;,&quot;labels&quot;:{&quot;px/metadata-node&quot;:&quot;true&quot;}}\r\n```\r\n\r\nNarrowing this further, I see two entries for datastore in the JSON that match as expected:\r\n\r\n``` lang-sh\r\n$ NODE=&quot;host-inf-4&quot;; cat pxctl-cd-list-short.json | jq -c &#39;.[] | select (.SchedulerNodeName == &#39;\\&quot;${NODE}\\&quot;&#39;).Configs[].ID&#39;\r\n&quot;[datastore--21] adsadaiuhwiorgwipo/_00ca/hipeghwerwjks.vmdk&quot;\r\n&quot;[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk&quot;\r\n```\r\n\r\nI try adding another select statement for the second condition, which I expect to narrow down to one entry.  But I get the same two entries:\r\n``` lang-sh\r\n$ NODE=&quot;host-inf-4&quot;; cat pxctl-cd-list-short.json | jq -c &#39;.[] | select (.SchedulerNodeName == &#39;\\&quot;${NODE}\\&quot;&#39;) |  select ( .Configs[].PXType == &quot;kvdb&quot;).Configs[].ID&#39;\r\n&quot;[datastore--21] adsadaiuhwiorgwipo/_00ca/hipeghwerwjks.vmdk&quot;\r\n&quot;[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk&quot;\r\n```\r\n\r\nSame thing when I try to add the condition in the first select statement:\r\n```\r\n$ NODE=&quot;host-inf-4&quot;; cat pxctl-cd-list-short.json | jq -c &#39;.[] | select (.SchedulerNodeName == &#39;\\&quot;${NODE}\\&quot;&#39;  and .Configs[].PXType == &quot;data&quot; ).Configs[].ID&#39;\r\n&quot;[datastore--21] adsadaiuhwiorgwipo/_00ca/hipeghwerwjks.vmdk&quot;\r\n&quot;[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk&quot;\r\n```\r\n\r\nAny thoughts on why adding the second condition isn&#39;t working?\r\n\r\nThe JSON is below.\r\n\r\n``` lang-json\r\n{\r\n &quot;1dfasdavsdfsvhoho028&quot;: {\r\n  &quot;Configs&quot;: {\r\n   &quot;[datastore-21] adsadaiuhwiorgwipo/_00ca/hipeghwerwjks.vmdk&quot;: {\r\n    &quot;Type&quot;: &quot;zeroedthick&quot;,\r\n    &quot;Size&quot;: 32,\r\n    &quot;ID&quot;: &quot;[datastore--21] adsadaiuhwiorgwipo/_00ca/hipeghwerwjks.vmdk&quot;,\r\n    &quot;PoolID&quot;: &quot;&quot;,\r\n    &quot;Path&quot;: &quot;/dev/sdc&quot;,\r\n    &quot;Iops&quot;: 0,\r\n    &quot;Vpus&quot;: 0,\r\n    &quot;PXType&quot;: &quot;kvdb&quot;,\r\n    &quot;State&quot;: &quot;Pending Add&quot;,\r\n    &quot;labels&quot;: {\r\n     &quot;datastore&quot;: &quot;vsanDatastore&quot;\r\n    },\r\n    &quot;AttachOptions&quot;: {\r\n     &quot;ext&quot;: &quot;.vmdk&quot;\r\n    },\r\n    &quot;Provisioner&quot;: &quot;&quot;,\r\n    &quot;EncryptionKeyInfo&quot;: &quot;&quot;\r\n   },\r\n   &quot;[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk&quot;: {\r\n    &quot;Type&quot;: &quot;lazyzeroedthick&quot;,\r\n    &quot;Size&quot;: 150,\r\n    &quot;ID&quot;: &quot;[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk&quot;,\r\n    &quot;PoolID&quot;: &quot;a471iidfisaj8i8124asdadsoif8ie82&quot;,\r\n    &quot;Path&quot;: &quot;/dev/sdb&quot;,\r\n    &quot;Iops&quot;: 0,\r\n    &quot;Vpus&quot;: 0,\r\n    &quot;PXType&quot;: &quot;data&quot;,\r\n    &quot;State&quot;: &quot;In Use&quot;,\r\n    &quot;labels&quot;: {\r\n     &quot;datastore&quot;: &quot;vsanDatastore&quot;\r\n    },\r\n    &quot;AttachOptions&quot;: {\r\n     &quot;ext&quot;: &quot;.vmdk&quot;\r\n    },\r\n    &quot;Provisioner&quot;: &quot;&quot;,\r\n    &quot;EncryptionKeyInfo&quot;: &quot;&quot;\r\n   }\r\n  },\r\n  &quot;NodeID&quot;: &quot;16a-8243r20-8fihqwc8-adew-2343ase&quot;,\r\n  &quot;ReservedInstanceID&quot;: &quot;&quot;,\r\n  &quot;SchedulerNodeName&quot;: &quot;host-inf-4&quot;,\r\n  &quot;NodeIndex&quot;: 12,\r\n  &quot;CreateTimestamp&quot;: &quot;2024-11-22T00:27:38.432162311Z&quot;,\r\n  &quot;InstanceID&quot;: &quot;42sdada08ihjpb3fe-6b-4873-0ya7-be80079acasca&quot;,\r\n  &quot;Zone&quot;: &quot;default&quot;,\r\n  &quot;State&quot;: &quot;In Use&quot;,\r\n  &quot;labels&quot;: {\r\n   &quot;px/metadata-node&quot;: &quot;true&quot;\r\n  }\r\n }, \r\n &quot;asdada-42764533fff2&quot;: {\r\n  &quot;Configs&quot;: null,\r\n  &quot;NodeID&quot;: &quot;1&quot;,\r\n  &quot;ReservedInstanceID&quot;: &quot;&quot;,\r\n  &quot;SchedulerNodeName&quot;: &quot;host-wkr-19&quot;,\r\n  &quot;NodeIndex&quot;: 19,\r\n  &quot;CreateTimestamp&quot;: &quot;0001-01-01T00:00:00Z&quot;,\r\n  &quot;InstanceID&quot;: &quot;asda0098q921&quot;,\r\n  &quot;Zone&quot;: &quot;default&quot;,\r\n  &quot;State&quot;: &quot;In Use&quot;,\r\n  &quot;labels&quot;: {\r\n   &quot;px/metadata-node&quot;: &quot;false&quot;\r\n  }\r\n }\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/79253065/jq-query-with-multiple-conditions-not-working",
        "title": "jq query with multiple conditions not working"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1733507349,
                "creation_date": 1733507349,
                "answer_id": 79258901,
                "question_id": 79256227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I was trying a much too complicated approach. Something like this in my sway config worked fine.\r\n\r\n    for_window [class=&quot;frontend&quot;] move to output &quot;DP-1&quot;\r\n",
                "title": "Subscribing to a Window event with Sway"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1734840052,
                "creation_date": 1734840052,
                "answer_id": 79300447,
                "question_id": 79256227,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I ran into this same issue and found that I had to adjust stdin buffering (https://linux.die.net/man/1/stdbuf). For example\r\n\r\n```\r\nswaymsg -m -t subscribe &#39;[&quot;window&quot;]&#39; \\\r\n  | stdbuf -o L jq -c &#39;select(.change == &quot;focus&quot;)&#39; \\\r\n  | while read -r string; do\r\n    echo $string | jq\r\ndone\r\n```\r\n\r\nKey things here are `stdbuf -o L` , which makes the following `jq` command&#39;s output line buffered, and `jq -c` which makes jq output an object all onto one line. With this, the `read` command picks up the entire object into `$string`, which can be further manipulated in later steps.",
                "title": "Subscribing to a Window event with Sway"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1734840052,
        "creation_date": 1733432787,
        "question_id": 79256227,
        "body_markdown": "I&#39;m using sway and would like to perform some action in bash, when a certain window is created. Right now this is what I have:\r\n\r\n    swaymsg -mt subscribe &#39;[&quot;window&quot;]&#39; | \r\n    jq &#39;select(.change == &quot;new&quot;) | \r\n    select(.container.window_properties.class == &quot;frontend&quot;)&#39; |\r\n    while read -r _; do\r\n        echo WORKS          \r\n    done \r\n\r\nSo far, if I remove the while loop, I get the text I expect printed out to the terminal so I think my jq filter works. But I&#39;m stumped why &quot;WORKS&quot; doesn&#39;t get printed. I assume I&#39;m doing something silly that I didn&#39;t realize. Any help is appreciated. :)",
        "link": "https://stackoverflow.com/questions/79256227/subscribing-to-a-window-event-with-sway",
        "title": "Subscribing to a Window event with Sway"
    },
    {
        "tags": [
            "json",
            "shell",
            "awk",
            "sed",
            "jq"
        ],
        "comments": [
            {
                "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": 4,
                "creation_date": 1733480674,
                "post_id": 79257584,
                "comment_id": 139760889,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 113371,
                    "reputation": 104439,
                    "user_id": 298607,
                    "user_type": "registered",
                    "accept_rate": 88,
                    "profile_image": "https://i.sstatic.net/DVW9g.jpg?s=256",
                    "display_name": "dawg",
                    "link": "https://stackoverflow.com/users/298607/dawg"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1733494178,
                "post_id": 79257584,
                "comment_id": 139761954,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1733506511,
                "post_id": 79257584,
                "comment_id": 139763089,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1733516682,
                "post_id": 79257584,
                "comment_id": 139763888,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1733493815,
                "creation_date": 1733493815,
                "answer_id": 79258265,
                "question_id": 79257584,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; seems not every bash environment support jq command\r\n\r\nFirstly determine how common this circumstances are, then how much users can install `jq` and how much users MUST NOT install `jq`. If latter case is rare consider using `jq` AND informing that your script requires `jq` in order to work.\r\n\r\n&gt; tried to resolve this issue by manipulating the string using awk, sed\r\n&gt; and gsup.\r\n\r\nI do not know last tool named, `awk` and `sed` do not support working with JSON. There exists [`gawkextlib`][1] variant of GNU `AWK` which does support working with JSON and XML, but you need to collect dependencies and built it, requirement of doing so would add burden to users of your script.\r\n\r\n&gt; easier way to manipulate JSON object with shell script without using\r\n&gt; jq\r\n\r\nYou might consider using [`json`][2] from `python`&#39;s standard library, as `python` (and its&#39; standard library) are often installed at linux machines, caveat: you should first poll representative sample of your users to determine if they have `jq` or `python` or both operational.\r\n\r\nSimple example assuming top-most structure in your JSON file is always Object. Create `upsert.py` with following content\r\n\r\n    import argparse\r\n    import json\r\n    \r\n    if __name__ == &#39;__main__&#39;:\r\n        parser = argparse.ArgumentParser(description=&#39;UPDATE or INSERT key-value into JSON document&#39;)\r\n        parser.add_argument(&#39;key&#39;)\r\n        parser.add_argument(&#39;value&#39;)\r\n        parser.add_argument(&#39;filename&#39;)\r\n        args = parser.parse_args()\r\n        with open(args.filename, &#39;r&#39;) as f:\r\n            data = json.load(f)\r\n        data[args.key] = args.value\r\n        with open(args.filename, &#39;w&#39;) as f:\r\n            json.dump(data, f)\r\n\r\nand let `file.json` content be\r\n\r\n    {&quot;A&quot;:&quot;Able&quot;,&quot;B&quot;:&quot;Baker&quot;,&quot;C&quot;:&quot;Charlie&quot;}\r\n\r\nthen\r\n\r\n    python upsert.py &#39;D&#39; &#39;Dog&#39; file.json\r\n\r\nwill alter file.json content to\r\n\r\n    {&quot;A&quot;: &quot;Able&quot;, &quot;B&quot;: &quot;Baker&quot;, &quot;C&quot;: &quot;Charlie&quot;, &quot;D&quot;: &quot;Dog&quot;}\r\n\r\nObserve that beyond new entry for `D` spaces were added after `:` and `,` which is default behavior. If you wish to apply different formatting consult [`json.dumps` docs][3].\r\n\r\n*(tested in Python 2.7.18 and Python 3.10.12)*\r\n\r\n\r\n  [1]: https://www.gnu.org/software/gawk/manual/html_node/gawkextlib.html\r\n  [2]: https://docs.python.org/3/library/json.html\r\n  [3]: https://docs.python.org/3/library/json.html#json.dump",
                "title": "How to update JSON file in shell script without using jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1733493815,
        "creation_date": 1733479544,
        "question_id": 79257584,
        "body_markdown": "I am using shell script to update JSON. Previously I used jq command to read/write an JSON object. However it seems not every bash environment support jq command. I tried to resolve this issue by manipulating the string using awk, sed and gsup. \r\n\r\nHowever the syntax is so complicated as below:\r\n\r\n```\r\nupdate_json_key() {\r\n    local key=&quot;$1&quot;\r\n    local value=&quot;$2&quot;\r\n    local filename=&quot;$3&quot;\r\n\r\n    if [[ ! -f &quot;$filename&quot; ]]; then\r\n      echo &quot;{}&quot; &gt; &quot;$filename&quot;\r\n    fi\r\n\r\n    SED_INPLACE=&quot;&quot;\r\n\r\n    if [[ &quot;$OSTYPE&quot; == &quot;darwin&quot;* ]]; then\r\n        SED_INPLACE=&quot;-i &#39;&#39;&quot;  # macOS requires an empty extension for in-place editing\r\n    else\r\n        SED_INPLACE=&quot;-i&quot;     # Linux\r\n    fi\r\n\r\n    # Ensure the file exists and is a valid JSON object\r\n    if [ ! -s &quot;$filename&quot; ] || ! grep -q &quot;{&quot; &quot;$filename&quot;; then\r\n        echo &quot;{}&quot; &gt; &quot;$filename&quot;\r\n    fi\r\n\r\n    # Check if the key exists\r\n    if grep -q &quot;\\&quot;$key\\&quot;: &quot; &quot;$filename&quot;; then\r\n        # Key exists, update it\r\n        # This regex ensures we don&#39;t capture more than we need by being specific with our patterns\r\n        sed $SED_INPLACE &quot;s/\\&quot;$key\\&quot;: \\&quot;[^\\&quot;]*\\&quot;/\\&quot;$key\\&quot;: \\&quot;$value\\&quot;/&quot; &quot;$filename&quot;\r\n    else\r\n        # Key does not exist, add it\r\n        if grep -q &quot;^{}$&quot; &quot;$filename&quot;; then\r\n            # File has only empty JSON, directly add key without comma\r\n            sed $SED_INPLACE &quot;s/{}/{\\&quot;$key\\&quot;: \\&quot;$value\\&quot;}/&quot; &quot;$filename&quot;\r\n        else\r\n            # File is non-empty, append key before the last closing brace\r\n            # This ensures that we correctly find the last closing brace even when it&#39;s not at the very end\r\n            sed $SED_INPLACE &quot;s/\\(.*\\)}$/\\1, \\&quot;$key\\&quot;: \\&quot;$value\\&quot;}/&quot; &quot;$filename&quot;\r\n        fi\r\n    fi\r\n\r\n    if [ -e &quot;$filename&#39;&#39;&quot; ]; then\r\n        rm -f &quot;$filename&#39;&#39;&quot;\r\n    fi\r\n\r\n    if [[ -e &quot;$filename&quot; ]] &amp;&amp; [[ $(wc -l &lt; &quot;$filename&quot;) -gt 1 ]]; then\r\n        raw_json=$(sed -e &#39;:a&#39; -e &#39;N&#39; -e &#39;$!ba&#39; -e &#39;s/\\n//g&#39; -e &#39;s/&quot;: \\?&quot;/&quot;: &quot;/g&#39; -e &#39;s/, \\?&quot;/,&quot;/g&#39; &quot;$filename&quot;)\r\n        rm -f $filename\r\n        echo &quot;$raw_json&quot; &gt; &quot;$filename&quot;\r\n    fi\r\n\r\n    formatted_json=$(awk &#39;BEGIN {\r\n        FS=&quot;,&quot;;\r\n        print &quot;{&quot;\r\n    }\r\n    {\r\n        gsub(/[{}]/, &quot;&quot;);\r\n        n = split($0, a, &quot;,&quot;);\r\n        for (i = 1; i &lt;= n; i++) {\r\n            gsub(/^[[:space:]]+|[[:space:]]+$/, &quot;&quot;, a[i]);\r\n            print &quot;  &quot; a[i] (i &lt; n ? &quot;,&quot; : &quot;&quot;);\r\n        }\r\n    }\r\n    END {\r\n        print &quot;}&quot;\r\n    }&#39; &quot;$filename&quot;)\r\n\r\n    rm -f $filename\r\n    echo &quot;$formatted_json&quot; &gt; &quot;$filename&quot;\r\n}\r\n```\r\n\r\nAnd this syntax not yet handled any nested JSON object iteration yet. I m thinking if there is an easier way to manipulate JSON object with shell script without using jq. ",
        "link": "https://stackoverflow.com/questions/79257584/how-to-update-json-file-in-shell-script-without-using-jq",
        "title": "How to update JSON file in shell script without using jq?"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1733514045,
                "last_edit_date": 1733514045,
                "creation_date": 1733513706,
                "answer_id": 79259185,
                "question_id": 79259166,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`IN/1` is [defined](https://github.com/jqlang/jq/blob/8bcdc9304ace5f2cc9bf662ab8998d75537e05f0/src/builtin.jq#L283) as `def IN(s): any(s == .; .);`, so `map(select(.[0] | IN([&quot;gpu&quot;])))` translates to `map(select(.[0] | any([&quot;gpu&quot;] == .; .)))` but `.` inside the `map` is `[ &quot;gpu&quot; ]`, thus `.[0]` is `&quot;gpu&quot;`, which is not equal to `[ &quot;gpu&quot; ]`, and the filter consequently fails.\r\n\r\nInstead, compare `.[0]` with `&quot;gpu&quot;`:\r\n```sh\r\nmap(select(.[0] | IN(&quot;gpu&quot;)))\r\n```\r\n```json\r\n[\r\n  [\r\n    &quot;gpu&quot;\r\n  ]\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/IS0oeCIJocb6E1m)\r\n\r\nUsing `IN`, however, only makes sense for compacting multiple comparisons. For this single comparison, of course, a simple `map(select(.[0] == &quot;gpu&quot;))` would suffice.",
                "title": "Replacing select condition with jq&#39;s `IN`"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1733515006,
        "creation_date": 1733513182,
        "last_edit_date": 1733515006,
        "question_id": 79259166,
        "body_markdown": "Given the simplified input:\r\n\r\n```json\r\n[\r\n  [ &quot;gpu&quot; ],\r\n  [ &quot;disk&quot; ]\r\n]\r\n```\r\n\r\nI would like to select the arrays for which the first element is `&quot;gpu&quot;`.\r\n\r\nI can do it with a simple condition:\r\n\r\n```sh\r\nmap(select(.[0] == &quot;gpu&quot;))\r\n```\r\n```json\r\n[\r\n  [ &quot;gpu&quot; ]\r\n]\r\n```\r\n\r\nBut I don&#39;t understand what&#39;s wrong when I try to use the `IN` builtin instead:\r\n\r\n```sh\r\nmap(select(.[0] | IN([&quot;gpu&quot;])))\r\n```\r\n```none\r\n[]\r\n```\r\n\r\nI&#39;m using `jq` 1.6",
        "link": "https://stackoverflow.com/questions/79259166/replacing-select-condition-with-jqs-in",
        "title": "Replacing select condition with jq&#39;s `IN`"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "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": 1733772260,
                "post_id": 79266175,
                "comment_id": 139776496,
                "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": 1733772742,
                "post_id": 79266175,
                "comment_id": 139776529,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17574488,
                    "reputation": 1,
                    "user_id": 12749555,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/b700a9a6fde376397dbf9e47ab541ccd?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "amolares",
                    "link": "https://stackoverflow.com/users/12749555/amolares"
                },
                "reply_to_user": {
                    "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": 1733775251,
                "post_id": 79266175,
                "comment_id": 139776727,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1733841222,
                "last_edit_date": 1733841222,
                "creation_date": 1733786010,
                "answer_id": 79266665,
                "question_id": 79266175,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s an attempt at solving the problem; the idea is to first get the unique keys from all the samples and use them to extract the data of each sample in the same order. Also, there&#39;s an additional &quot;trick&quot; which is to prepend the sample name to the sample data object:\r\n\r\n```sh\r\n.report_general_stats_data[1]\r\n| to_entries\r\n| map({&quot;Sample&quot;: .key} * .value)\r\n| ([.[] | keys_unsorted[]] | unique) as $head\r\n| ($head, (.[] | . as $cols | $head | map($cols[.])))\r\n| @tsv\r\n```\r\n\r\n```none\r\nSample              adapter_cutting_adapter_trimmed_bases  adapter_cutting_adapter_trimmed_reads  after_filtering_gc_content  after_filtering_q20_bases  after_filtering_q20_rate  after_filtering_q30_bases  after_filtering_q30_rate  after_filtering_read1_mean_length  after_filtering_read2_mean_length  after_filtering_total_bases  after_filtering_total_reads  before_filtering_total_reads  filtering_result_low_quality_reads  filtering_result_passed_filter_reads  filtering_result_too_long_reads  filtering_result_too_many_N_reads  filtering_result_too_short_reads  pct_adapter        pct_duplication      pct_surviving\r\n24-240_L001_R1_001  1262446.0                              60616.0                                0.565903                    268093576.0                0.903707                  233354655.0                0.786607                  268.0                              267.0                              296659710.0                  1106872.0                    1139014.0                     32142.0                             1106872.0                             0.0                              0.0                                0.0                               5.321795869058677  0.10114              97.1780856073762\r\n24-278_L001_R1_001  4596580.0                              187672.0                               0.560734                    491653949.0                0.928831                  442959345.0                0.836837                  244.0                              244.0                              529325786.0                  2161572.0                    2212442.0                     50870.0                             2161572.0                             0.0                              0.0                                0.0                               8.48257265049208   0.20167800000000002  97.70073068582137\r\n24-288_L001_R1_001  2027444.0                              97506.0                                0.562734                    375027676.0                0.916436                  333000899.0                0.813738                  267.0                              267.0                              409223893.0                  1531162.0                    1582326.0                     51164.0                             1531162.0                             0.0                              0.0                                0.0                               6.162194136985678  0.11451499999999999  96.76653230750173\r\n24-275_L001_R1_001  3353406.0                              149906.0                               0.560707                    401596781.0                0.91412                   354025417.0                0.805837                  262.0                              262.0                              439326257.0                  1673478.0                    1713992.0                     40514.0                             1673478.0                             0.0                              0.0                                0.0                               8.746015150595802  0.10735199999999999  97.6362783490238\r\n24-269_L001_R1_001  5012952.0                              203026.0                               0.565888                    521238294.0                0.929964                  469860972.0                0.8383                    243.0                              243.0                              560492864.0                  2302934.0                    2354474.0                     51540.0                             2302934.0                             0.0                              0.0                                0.0                               8.622987554757454  0.194948             97.81097603965895\r\n24-276_L001_R1_001  3293571.0                              133228.0                               0.559441                    328089731.0                0.916952                  292560788.0                0.817655                  252.0                              252.0                              357804610.0                  1417706.0                    1475364.0                     57658.0                             1417706.0                             0.0                              0.0                                0.0                               9.03017831531744   0.12457900000000001  96.0919474787239\r\n24-246_L001_R1_001  873172.0                               41992.0                                0.560996                    158672752.0                0.90052                   136656453.0                0.775571                  264.0                              263.0                              176201195.0                  666866.0                     679000.0                      12134.0                             666866.0                              0.0                              0.0                                0.0                               6.18438880706922   0.0768778            98.21296023564065\r\n24-287_L001_R1_001  3336030.0                              143030.0                               0.562427                    414709658.0                0.916231                  368660242.0                0.814492                  256.0                              256.0                              452625879.0                  1761992.0                    1819780.0                     57788.0                             1761992.0                             0.0                              0.0                                0.0                               7.859741287408369  0.140786             96.82445130730089\r\n24-270_L001_R1_001  4124802.0                              186984.0                               0.561259                    548648672.0                0.920908                  489253928.0                0.821214                  258.0                              258.0                              595769254.0                  2304254.0                    2364690.0                     60436.0                             2304254.0                             0.0                              0.0                                0.0                               7.907336691067328  0.145389             97.44423159061019\r\n24-279_L001_R1_001  3434243.0                              146844.0                               0.564391                    432758485.0                0.924809                  388427451.0                0.830073                  252.0                              252.0                              467943785.0                  1851444.0                    1907090.0                     55646.0                             1851444.0                             0.0                              0.0                                0.0                               7.699898798693297  0.158147             97.08215134052405\r\n24-295_L001_R1_001  1903577.0                              90732.0                                0.56121                     374266368.0                0.913533                  331209675.0                0.808437                  267.0                              267.0                              409691227.0                  1532672.0                    1591264.0                     58592.0                             1532672.0                             0.0                              0.0                                0.0                               5.701882277233696  0.127194             96.31789571057978\r\n24-277_L001_R1_001  2318318.0                              106956.0                               0.562061                    355870530.0                0.91461                   314058539.0                0.807151                  259.0                              259.0                              389095200.0                  1498306.0                    1531796.0                     33490.0                             1498306.0                             0.0                              0.0                                0.0                               6.982391911194441  0.1132               97.8136775393068\r\n24-274_L001_R1_001  3253300.0                              144878.0                               0.562058                    407856941.0                0.907027                  359065093.0                0.79852                   262.0                              262.0                              449663434.0                  1710930.0                    1783970.0                     73040.0                             1710930.0                             0.0                              0.0                                0.0                               8.12110069115512   0.116482             95.90576074709777\r\n```",
                "title": "Converting part of a multiqc_data JSON to TSV with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1733841222,
        "creation_date": 1733771143,
        "last_edit_date": 1733782939,
        "question_id": 79266175,
        "body_markdown": "I&#39;m trying to convert a multiqc_data.json file to a tsv file. Specifically, I only need part of data from &quot;report_general_stats_data&quot; section. The structure is:\r\n\r\n```json\r\n{\r\n       &quot;report_general_stats_data&quot;: [\r\n        {\r\n            &quot;contigs&quot;: {\r\n                &quot;# contigs (&gt;= 0 bp)&quot;: 232.0,\r\n                &quot;# contigs (&gt;= 1000 bp)&quot;: 169.0,\r\n                &quot;# contigs (&gt;= 5000 bp)&quot;: 121.0,\r\n                &quot;# contigs (&gt;= 10000 bp)&quot;: 107.0,\r\n                &quot;# contigs (&gt;= 25000 bp)&quot;: 75.0,\r\n                &quot;# contigs (&gt;= 50000 bp)&quot;: 37.0,\r\n                &quot;Total length (&gt;= 0 bp)&quot;: 5594769.0,\r\n                &quot;Total length (&gt;= 1000 bp)&quot;: 5569601.0,\r\n                &quot;Total length (&gt;= 5000 bp)&quot;: 5452934.0,\r\n                &quot;Total length (&gt;= 10000 bp)&quot;: 5349401.0,\r\n                &quot;Total length (&gt;= 25000 bp)&quot;: 4801158.0,\r\n                &quot;Total length (&gt;= 50000 bp)&quot;: 3427439.0,\r\n                &quot;# contigs&quot;: 187.0,\r\n                &quot;Largest contig&quot;: 216595.0,\r\n                &quot;Total length&quot;: 5582595.0,\r\n                &quot;Reference length&quot;: 5472672.0,\r\n                &quot;GC (%)&quot;: 57.1,\r\n                &quot;Reference GC (%)&quot;: 57.37,\r\n                &quot;N50&quot;: 63236.0,\r\n                &quot;NG50&quot;: 64616.0,\r\n                &quot;N90&quot;: 19080.0,\r\n                &quot;NG90&quot;: 21621.0,\r\n                &quot;auN&quot;: 81138.9,\r\n                &quot;auNG&quot;: 82768.6,\r\n                &quot;L50&quot;: 26.0,\r\n                &quot;LG50&quot;: 25.0,\r\n                &quot;L90&quot;: 86.0,\r\n                &quot;LG90&quot;: 81.0,\r\n                &quot;# N&#39;s per 100 kbp&quot;: 0.0\r\n            }\r\n        },\r\n        {\r\n            &quot;24-240_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 1106872.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 32142.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.10114,\r\n                &quot;after_filtering_total_reads&quot;: 1106872.0,\r\n                &quot;after_filtering_total_bases&quot;: 296659710.0,\r\n                &quot;after_filtering_q20_bases&quot;: 268093576.0,\r\n                &quot;after_filtering_q30_bases&quot;: 233354655.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.903707,\r\n                &quot;after_filtering_q30_rate&quot;: 0.786607,\r\n                &quot;after_filtering_read1_mean_length&quot;: 268.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 267.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.565903,\r\n                &quot;before_filtering_total_reads&quot;: 1139014.0,\r\n                &quot;pct_surviving&quot;: 97.1780856073762,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 60616.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 1262446.0,\r\n                &quot;pct_adapter&quot;: 5.321795869058677\r\n            },\r\n            &quot;24-278_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 2161572.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 50870.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.20167800000000002,\r\n                &quot;after_filtering_total_reads&quot;: 2161572.0,\r\n                &quot;after_filtering_total_bases&quot;: 529325786.0,\r\n                &quot;after_filtering_q20_bases&quot;: 491653949.0,\r\n                &quot;after_filtering_q30_bases&quot;: 442959345.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.928831,\r\n                &quot;after_filtering_q30_rate&quot;: 0.836837,\r\n                &quot;after_filtering_read1_mean_length&quot;: 244.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 244.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.560734,\r\n                &quot;before_filtering_total_reads&quot;: 2212442.0,\r\n                &quot;pct_surviving&quot;: 97.70073068582137,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 187672.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 4596580.0,\r\n                &quot;pct_adapter&quot;: 8.48257265049208\r\n            },\r\n            &quot;24-288_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 1531162.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 51164.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.11451499999999999,\r\n                &quot;after_filtering_total_reads&quot;: 1531162.0,\r\n                &quot;after_filtering_total_bases&quot;: 409223893.0,\r\n                &quot;after_filtering_q20_bases&quot;: 375027676.0,\r\n                &quot;after_filtering_q30_bases&quot;: 333000899.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.916436,\r\n                &quot;after_filtering_q30_rate&quot;: 0.813738,\r\n                &quot;after_filtering_read1_mean_length&quot;: 267.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 267.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.562734,\r\n                &quot;before_filtering_total_reads&quot;: 1582326.0,\r\n                &quot;pct_surviving&quot;: 96.76653230750173,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 97506.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 2027444.0,\r\n                &quot;pct_adapter&quot;: 6.162194136985678\r\n            },\r\n            &quot;24-275_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 1673478.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 40514.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.10735199999999999,\r\n                &quot;after_filtering_total_reads&quot;: 1673478.0,\r\n                &quot;after_filtering_total_bases&quot;: 439326257.0,\r\n                &quot;after_filtering_q20_bases&quot;: 401596781.0,\r\n                &quot;after_filtering_q30_bases&quot;: 354025417.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.91412,\r\n                &quot;after_filtering_q30_rate&quot;: 0.805837,\r\n                &quot;after_filtering_read1_mean_length&quot;: 262.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 262.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.560707,\r\n                &quot;before_filtering_total_reads&quot;: 1713992.0,\r\n                &quot;pct_surviving&quot;: 97.6362783490238,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 149906.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 3353406.0,\r\n                &quot;pct_adapter&quot;: 8.746015150595802\r\n            },\r\n            &quot;24-269_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 2302934.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 51540.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.194948,\r\n                &quot;after_filtering_total_reads&quot;: 2302934.0,\r\n                &quot;after_filtering_total_bases&quot;: 560492864.0,\r\n                &quot;after_filtering_q20_bases&quot;: 521238294.0,\r\n                &quot;after_filtering_q30_bases&quot;: 469860972.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.929964,\r\n                &quot;after_filtering_q30_rate&quot;: 0.8383,\r\n                &quot;after_filtering_read1_mean_length&quot;: 243.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 243.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.565888,\r\n                &quot;before_filtering_total_reads&quot;: 2354474.0,\r\n                &quot;pct_surviving&quot;: 97.81097603965895,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 203026.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 5012952.0,\r\n                &quot;pct_adapter&quot;: 8.622987554757454\r\n            },\r\n            &quot;24-276_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 1417706.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 57658.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.12457900000000001,\r\n                &quot;after_filtering_total_reads&quot;: 1417706.0,\r\n                &quot;after_filtering_total_bases&quot;: 357804610.0,\r\n                &quot;after_filtering_q20_bases&quot;: 328089731.0,\r\n                &quot;after_filtering_q30_bases&quot;: 292560788.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.916952,\r\n                &quot;after_filtering_q30_rate&quot;: 0.817655,\r\n                &quot;after_filtering_read1_mean_length&quot;: 252.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 252.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.559441,\r\n                &quot;before_filtering_total_reads&quot;: 1475364.0,\r\n                &quot;pct_surviving&quot;: 96.0919474787239,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 133228.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 3293571.0,\r\n                &quot;pct_adapter&quot;: 9.03017831531744\r\n            },\r\n            &quot;24-246_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 666866.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 12134.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.0768778,\r\n                &quot;after_filtering_total_reads&quot;: 666866.0,\r\n                &quot;after_filtering_total_bases&quot;: 176201195.0,\r\n                &quot;after_filtering_q20_bases&quot;: 158672752.0,\r\n                &quot;after_filtering_q30_bases&quot;: 136656453.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.90052,\r\n                &quot;after_filtering_q30_rate&quot;: 0.775571,\r\n                &quot;after_filtering_read1_mean_length&quot;: 264.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 263.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.560996,\r\n                &quot;before_filtering_total_reads&quot;: 679000.0,\r\n                &quot;pct_surviving&quot;: 98.21296023564065,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 41992.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 873172.0,\r\n                &quot;pct_adapter&quot;: 6.18438880706922\r\n            },\r\n            &quot;24-287_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 1761992.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 57788.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.140786,\r\n                &quot;after_filtering_total_reads&quot;: 1761992.0,\r\n                &quot;after_filtering_total_bases&quot;: 452625879.0,\r\n                &quot;after_filtering_q20_bases&quot;: 414709658.0,\r\n                &quot;after_filtering_q30_bases&quot;: 368660242.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.916231,\r\n                &quot;after_filtering_q30_rate&quot;: 0.814492,\r\n                &quot;after_filtering_read1_mean_length&quot;: 256.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 256.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.562427,\r\n                &quot;before_filtering_total_reads&quot;: 1819780.0,\r\n                &quot;pct_surviving&quot;: 96.82445130730089,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 143030.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 3336030.0,\r\n                &quot;pct_adapter&quot;: 7.859741287408369\r\n            },\r\n            &quot;24-270_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 2304254.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 60436.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.145389,\r\n                &quot;after_filtering_total_reads&quot;: 2304254.0,\r\n                &quot;after_filtering_total_bases&quot;: 595769254.0,\r\n                &quot;after_filtering_q20_bases&quot;: 548648672.0,\r\n                &quot;after_filtering_q30_bases&quot;: 489253928.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.920908,\r\n                &quot;after_filtering_q30_rate&quot;: 0.821214,\r\n                &quot;after_filtering_read1_mean_length&quot;: 258.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 258.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.561259,\r\n                &quot;before_filtering_total_reads&quot;: 2364690.0,\r\n                &quot;pct_surviving&quot;: 97.44423159061019,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 186984.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 4124802.0,\r\n                &quot;pct_adapter&quot;: 7.907336691067328\r\n            },\r\n            &quot;24-279_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 1851444.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 55646.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.158147,\r\n                &quot;after_filtering_total_reads&quot;: 1851444.0,\r\n                &quot;after_filtering_total_bases&quot;: 467943785.0,\r\n                &quot;after_filtering_q20_bases&quot;: 432758485.0,\r\n                &quot;after_filtering_q30_bases&quot;: 388427451.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.924809,\r\n                &quot;after_filtering_q30_rate&quot;: 0.830073,\r\n                &quot;after_filtering_read1_mean_length&quot;: 252.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 252.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.564391,\r\n                &quot;before_filtering_total_reads&quot;: 1907090.0,\r\n                &quot;pct_surviving&quot;: 97.08215134052405,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 146844.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 3434243.0,\r\n                &quot;pct_adapter&quot;: 7.699898798693297\r\n            },\r\n            &quot;24-295_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 1532672.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 58592.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.127194,\r\n                &quot;after_filtering_total_reads&quot;: 1532672.0,\r\n                &quot;after_filtering_total_bases&quot;: 409691227.0,\r\n                &quot;after_filtering_q20_bases&quot;: 374266368.0,\r\n                &quot;after_filtering_q30_bases&quot;: 331209675.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.913533,\r\n                &quot;after_filtering_q30_rate&quot;: 0.808437,\r\n                &quot;after_filtering_read1_mean_length&quot;: 267.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 267.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.56121,\r\n                &quot;before_filtering_total_reads&quot;: 1591264.0,\r\n                &quot;pct_surviving&quot;: 96.31789571057978,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 90732.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 1903577.0,\r\n                &quot;pct_adapter&quot;: 5.701882277233696\r\n            },\r\n            &quot;24-277_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 1498306.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 33490.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.1132,\r\n                &quot;after_filtering_total_reads&quot;: 1498306.0,\r\n                &quot;after_filtering_total_bases&quot;: 389095200.0,\r\n                &quot;after_filtering_q20_bases&quot;: 355870530.0,\r\n                &quot;after_filtering_q30_bases&quot;: 314058539.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.91461,\r\n                &quot;after_filtering_q30_rate&quot;: 0.807151,\r\n                &quot;after_filtering_read1_mean_length&quot;: 259.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 259.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.562061,\r\n                &quot;before_filtering_total_reads&quot;: 1531796.0,\r\n                &quot;pct_surviving&quot;: 97.8136775393068,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 106956.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 2318318.0,\r\n                &quot;pct_adapter&quot;: 6.982391911194441\r\n            },\r\n            &quot;24-274_L001_R1_001&quot;: {\r\n                &quot;filtering_result_passed_filter_reads&quot;: 1710930.0,\r\n                &quot;filtering_result_low_quality_reads&quot;: 73040.0,\r\n                &quot;filtering_result_too_many_N_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_short_reads&quot;: 0.0,\r\n                &quot;filtering_result_too_long_reads&quot;: 0.0,\r\n                &quot;pct_duplication&quot;: 0.116482,\r\n                &quot;after_filtering_total_reads&quot;: 1710930.0,\r\n                &quot;after_filtering_total_bases&quot;: 449663434.0,\r\n                &quot;after_filtering_q20_bases&quot;: 407856941.0,\r\n                &quot;after_filtering_q30_bases&quot;: 359065093.0,\r\n                &quot;after_filtering_q20_rate&quot;: 0.907027,\r\n                &quot;after_filtering_q30_rate&quot;: 0.79852,\r\n                &quot;after_filtering_read1_mean_length&quot;: 262.0,\r\n                &quot;after_filtering_read2_mean_length&quot;: 262.0,\r\n                &quot;after_filtering_gc_content&quot;: 0.562058,\r\n                &quot;before_filtering_total_reads&quot;: 1783970.0,\r\n                &quot;pct_surviving&quot;: 95.90576074709777,\r\n                &quot;adapter_cutting_adapter_trimmed_reads&quot;: 144878.0,\r\n                &quot;adapter_cutting_adapter_trimmed_bases&quot;: 3253300.0,\r\n                &quot;pct_adapter&quot;: 8.12110069115512\r\n            }\r\n        },\r\n        {\r\n            &quot;R1.cor&quot;: {\r\n                &quot;s_name&quot;: &quot;R1.cor&quot;,\r\n                &quot;totalpairs&quot;: 855465,\r\n                &quot;discardpairs&quot;: 0,\r\n                &quot;percdiscard&quot;: 0,\r\n                &quot;combopairs&quot;: 796467,\r\n                &quot;inniepairs&quot;: 0,\r\n                &quot;outiepairs&quot;: 0,\r\n                &quot;uncombopairs&quot;: 58998,\r\n                &quot;perccombo&quot;: 93.1\r\n            }\r\n        }\r\n    ],\r\n    &quot;config_creation_date&quot;: &quot;2024-11-28, 17:31 UTC&quot;,\r\n    &quot;config_git_hash&quot;: null,\r\n    &quot;config_intro_text&quot;: null,\r\n    &quot;config_report_comment&quot;: null,\r\n    &quot;config_report_header_info&quot;: null,\r\n    &quot;config_script_path&quot;: &quot;/home/ubuntu/miniconda3/envs/multiqc&quot;,\r\n    &quot;config_short_version&quot;: &quot;1.23&quot;,\r\n    &quot;config_subtitle&quot;: null,\r\n    &quot;config_title&quot;: null,\r\n    &quot;config_version&quot;: &quot;1.23&quot;,\r\n    &quot;config_output_dir&quot;: &quot;/home/ubuntu&quot;\r\n}\r\n```\r\n\r\nI am looking to use jq to extract certain fields from `&quot;report_general_stats_data&quot;` section. My expected output would look something like:\r\n\r\n```json\r\n&quot;Sample&quot;\\t&quot;filtering_result_passed_filter_reads&quot;\\t&quot;filtering_result_low_quality_reads&quot;...\\t&quot;pct_adapter&quot;\r\n&quot;24-240_L001_R1_001&quot;\\t&quot;1106872.0&quot;\\t&quot;32142.0&quot;...\\t&quot;5.321795869058677&quot;\r\n```\r\n\r\nand so on the rest of samples.\r\nSo far I have written following script with no success:\r\n\r\n```sh\r\njq -r &#39;.report_general_stats_data[1] | @tsv&#39; multiqc_data.json &gt; multiqc_data.tsv\r\n```\r\n\r\nAny help is greatly appreciated.\r\n\r\nCheers,\r\n\r\nAlberto",
        "link": "https://stackoverflow.com/questions/79266175/converting-part-of-a-multiqc-data-json-to-tsv-with-jq",
        "title": "Converting part of a multiqc_data JSON to TSV with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1733826282,
                "last_edit_date": 1733826282,
                "creation_date": 1733824603,
                "answer_id": 79267781,
                "question_id": 79267652,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s easier (and faster) to use an object for the order:\r\n\r\n    jq --argjson order &#39;{&quot;dog&quot;:0, &quot;bird&quot;:1, &quot;cat&quot;:2}&#39; \\\r\n        &#39;. | sort_by($order[.entityType])&#39;\r\n\r\nBut if you insist:\r\n\r\n    jq --argjson order &#39;[&quot;dog&quot;, &quot;bird&quot;, &quot;cat&quot;]&#39; \\\r\n        &#39;. | sort_by(.entityType as $type | ($order | index($type)))&#39;",
                "title": "Sorting a JSON array by an arbitrary order using jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1733825772,
                "last_edit_date": 1733825772,
                "creation_date": 1733825448,
                "answer_id": 79267832,
                "question_id": 79267652,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If you want to keep your `order` argument an array, sort by turning it into an implicit boolean array of matches. Note that `false` will be ordered before `true`, so use `!=` to &quot;mismatch&quot; the items.\r\n```sh\r\njq --argjson order &#39;[&quot;dog&quot;, &quot;bird&quot;, &quot;cat&quot;]&#39; &#39;sort_by(.entityType != $order[])&#39;\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;id&quot;: 2,\r\n    &quot;entityType&quot;: &quot;dog&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 3,\r\n    &quot;entityType&quot;: &quot;bird&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 1,\r\n    &quot;entityType&quot;: &quot;cat&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 4,\r\n    &quot;entityType&quot;: &quot;cat&quot;\r\n  }\r\n]\r\n```\r\n\r\nAlternatively, provide the order as single arguments using the `--args` option and the `$ARGS.positional` array:\r\n```sh\r\njq &#39;sort_by(.entityType != $ARGS.positional[])&#39; data.json --args dog bird cat\r\n```",
                "title": "Sorting a JSON array by an arbitrary order using jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1733866736,
                "creation_date": 1733866736,
                "answer_id": 79269878,
                "question_id": 79267652,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "If the order is defined by an array, then for efficiency it would typically be worthwhile converting the array to a dictionary along the lines suggested by @choroba:\r\n```\r\n&lt; input.json jq --argjson order &#39;[&quot;dog&quot;, &quot;bird&quot;, &quot;cat&quot;]&#39; &#39;\r\n   INDEX( $order | to_entries[]; .value ) as $dict\r\n   | sort_by( $dict[.entityType] )\r\n&#39;\r\n```",
                "title": "Sorting a JSON array by an arbitrary order using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1733866736,
        "creation_date": 1733822541,
        "last_edit_date": 1733822767,
        "question_id": 79267652,
        "body_markdown": "Given this JSON data in the file `data.json`:\r\n```\r\n[\r\n  { &quot;id&quot;: 1, &quot;entityType&quot;: &quot;cat&quot; },\r\n  { &quot;id&quot;: 2, &quot;entityType&quot;: &quot;dog&quot; },\r\n  { &quot;id&quot;: 3, &quot;entityType&quot;: &quot;bird&quot; },\r\n  { &quot;id&quot;: 4, &quot;entityType&quot;: &quot;cat&quot; }\r\n]\r\n```\r\n\r\nHow would return an array sorted by some non-alphabetic arbitrary order (e.g dogs, birds and then cats)?\r\n\r\nI&#39;ve tried various permutations along the lines of:\r\n\r\n```lang-bash\r\njq --argjson order &#39;[&quot;dog&quot;, &quot;bird&quot;, &quot;cat&quot;]&#39; &#39;. | sort_by( index($order[], .entityType) )&#39; data.json\r\n```\r\n\r\nbut without any joy.",
        "link": "https://stackoverflow.com/questions/79267652/sorting-a-json-array-by-an-arbitrary-order-using-jq",
        "title": "Sorting a JSON array by an arbitrary order using jq"
    },
    {
        "tags": [
            "jq",
            "startswith"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1733866340,
                "last_edit_date": 1733866340,
                "creation_date": 1733863460,
                "answer_id": 79269750,
                "question_id": 79269732,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re using `startswith` right, but with the preceding `|` you&#39;re starting a new context (holding the value of `.last_name`) in which `.first_name` isn&#39;t valid anymore.\r\n\r\nGenerally speaking, to reference a value at a later time (when it has gone out of context), bind a variable to it when it&#39;s still in context, and use that instead later:\r\n```sh\r\nif .first_name as $fn | .last_name | startswith($fn) then …\r\n```\r\n\r\nYou may also bind the whole object at an earlier stage (e.g. if you happen to need multiple references to it or its parts):\r\n```sh\r\n. as $obj | {name: (if $obj.last_name | startswith($obj.first_name) then …)}\r\n```\r\n\r\nOr define your own function that takes two parameters (e.g. if you need this construct more often):\r\n```sh\r\n# taking two values as parameters which retain their binding\r\ndef startswith($whole; $part): $whole | startswith($part);\r\n\r\n# or carrying over the context to allow for functional parameters\r\ndef startswith(whole; part): . as $ctx | whole | startswith($ctx | part);\r\n\r\n# then\r\n{\r\n  name: (\r\n    if startswith(.last_name; .first_name)\r\n    then .last_name else &quot;\\(.first_name) \\(.last_name)&quot;\r\n    end\r\n  )\r\n}\r\n```",
                "title": "How to use .fieldname to jq&#39;s startswith"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1733866340,
        "creation_date": 1733862905,
        "question_id": 79269732,
        "body_markdown": "In the jq script below I want to print either the concatenation of the `first_name` and the `last_name` or just the `last_name`.\r\n\r\n```bash\r\n$ echo &#39;{&quot;first_name&quot;: &quot;John&quot;, &quot;last_name&quot;: &quot;Johnson&quot;}&#39; | jq -c &#39;{\r\n  &quot;name&quot;: (if (.last_name | startswith(.first_name)) \r\n           then .last_name \r\n           else .first_name + &quot; &quot; + .last_name \r\n           end)\r\n}&#39;\r\n```\r\n\r\nThe error is\r\n\r\n```\r\njq: error (at &lt;stdin&gt;:1): Cannot index string with string &quot;first_name&quot;\r\n```\r\n\r\nThe jq command fails in the call to `startswith` - as if `startswith` only accepted string literals. If I change `startswith(.first_name)` to `startswith(&quot;John&quot;)` then the expression compiles and works as expected. \r\n\r\nIn the real-world example, there is many input records and many different `first_name`s. Is there a way I could plug in `.first_name` to `startswith`? ",
        "link": "https://stackoverflow.com/questions/79269732/how-to-use-fieldname-to-jqs-startswith",
        "title": "How to use .fieldname to jq&#39;s startswith"
    },
    {
        "tags": [
            "ansible",
            "jinja2",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1734008171,
                "post_id": 79275125,
                "comment_id": 139792446,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2433008,
                    "reputation": 40025,
                    "user_id": 2123530,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/37a7fba006184897e8d74f1795e2835b?s=256&d=identicon&r=PG",
                    "display_name": "β.εηοιτ.βε",
                    "link": "https://stackoverflow.com/users/2123530/%ce%b2-%ce%b5%ce%b7%ce%bf%ce%b9%cf%84-%ce%b2%ce%b5"
                },
                "edited": false,
                "score": 3,
                "creation_date": 1734008308,
                "post_id": 79275125,
                "comment_id": 139792459,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1734511699,
                "last_edit_date": 1734511699,
                "creation_date": 1734012045,
                "answer_id": 79275392,
                "question_id": 79275125,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Q: **&quot;_Is there anyway to extract a list with all packages which contain the string `fence-agents`?_&quot;**\r\n\r\nAn approach based on the given question example\r\n\r\n```lang-yaml\r\n  - debug:\r\n      msg: &quot;{{ ansible_facts.packages[item] }}&quot;\r\n    loop: &quot;{{ ansible_facts.packages | select(&#39;search&#39;, regex) }}&quot;\r\n    vars:\r\n      regex: &#39;fence-agents*&#39;\r\n```\r\n\r\n**Similar Q&amp;A**\r\n\r\n* [How to get the available Python versions on Remote Node?](https://stackoverflow.com/a/78766465/6771046)\r\n* [Output the common packages installed in all the servers](https://stackoverflow.com/a/76121069/6771046)",
                "title": "How can I use a jq query to extract a string from this Ansible dictionary?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1734511699,
        "creation_date": 1734006847,
        "last_edit_date": 1734012294,
        "question_id": 79275125,
        "body_markdown": "So I have the following tasks in my playbook\r\n\r\n```lang-yaml\r\n- name: gather package facts\r\n  package_facts:\r\n\r\n- name: send packages containing &#39;fence-agents&#39; to a file\r\n  lineinfile:\r\n    path: /etc/leapp/transaction/to_remove\r\n    line: &quot;{{ item }}&quot;\r\n  loop: &quot;{{ ansible_facts.packages | ???????&quot;\r\n  become: true \r\n```\r\n\r\nIs there anyway to extract a list with all packages which contain the string `fence-agents`? \r\n\r\nI don&#39;t want to loop the entire package list as it would increase the playbook run time significantly.",
        "link": "https://stackoverflow.com/questions/79275125/how-can-i-use-a-jq-query-to-extract-a-string-from-this-ansible-dictionary",
        "title": "How can I use a jq query to extract a string from this Ansible dictionary?"
    },
    {
        "tags": [
            "bash",
            "jq",
            "aws-cli"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1734016799,
                "post_id": 79275641,
                "comment_id": 139793255,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1734017859,
                "post_id": 79275641,
                "comment_id": 139793362,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 355113,
                    "reputation": 1853,
                    "user_id": 693869,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/8a3e7cb8b8bb0cfef223b88912be9cbd?s=256&d=identicon&r=PG",
                    "display_name": "Dave Butler",
                    "link": "https://stackoverflow.com/users/693869/dave-butler"
                },
                "reply_to_user": {
                    "account_id": 212394,
                    "reputation": 187080,
                    "user_id": 465183,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://i.sstatic.net/yhE6n.jpg?s=256",
                    "display_name": "Gilles Qu&#233;not",
                    "link": "https://stackoverflow.com/users/465183/gilles-qu%c3%a9not"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1734017945,
                "post_id": 79275641,
                "comment_id": 139793374,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 355113,
                    "reputation": 1853,
                    "user_id": 693869,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/8a3e7cb8b8bb0cfef223b88912be9cbd?s=256&d=identicon&r=PG",
                    "display_name": "Dave Butler",
                    "link": "https://stackoverflow.com/users/693869/dave-butler"
                },
                "reply_to_user": {
                    "account_id": 2244313,
                    "reputation": 17526,
                    "user_id": 3387716,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/bcad6c8d7a64b0e16fd59996e3835ee9?s=256&d=identicon&r=PG",
                    "display_name": "Fravadona",
                    "link": "https://stackoverflow.com/users/3387716/fravadona"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1734021339,
                "post_id": 79275641,
                "comment_id": 139793747,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 16737833,
                    "reputation": 14593,
                    "user_id": 12098405,
                    "user_type": "registered",
                    "profile_image": "https://lh6.googleusercontent.com/-C7IUyuZ5qqE/AAAAAAAAAAI/AAAAAAAAAAA/ACHi3rehqQyGdh463Xz2DY8S4TYPhnDvzA/s256-rj/photo.jpg",
                    "display_name": "dash-o",
                    "link": "https://stackoverflow.com/users/12098405/dash-o"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1734197080,
                "post_id": 79275641,
                "comment_id": 139803430,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1734016621,
                "creation_date": 1734016621,
                "answer_id": 79275642,
                "question_id": 79275641,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "I think I figured out the answer while writing up the question...\r\n\r\nWhat I think is happening is that the `aws`/`bkt` command actually gets the `SIGPIPE`, and `bash` never sees it because it is just gluing up the pipe... The easiest fix with my case was to change `bash` to `bash -e` so that it quit after the subprocess failed...",
                "title": "Pipe commands not getting killed after head exits"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1734031239,
                "creation_date": 1734031239,
                "answer_id": 79276339,
                "question_id": 79275641,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`aws` command cannot get the SIGPIPE as it&#39;s not writing to closed pipe.\r\n\r\nWhen you run :\r\n\r\n```\r\nseq 100000000000 | sed -E $&#39;s/(.*)/sh -c \\&#39;echo \\\\1; sleep .1\\&#39;/&#39; | sh | head\r\n```\r\n\r\nThe process which writes to the pipe is this one: `sh -c &#39;echo N; sleep .1&#39;`. So the final `sh` didn&#39;t get SIGPIPE, which is the reason why it keeps running.\r\n\r\nYou can notice the difference when you run this :\r\n\r\n```\r\nseq 100000000000 | sed -E $&#39;s/(.*)/echo \\\\1/&#39; | sh | head\r\n```",
                "title": "Pipe commands not getting killed after head exits"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1734198503,
                "creation_date": 1734198503,
                "answer_id": 79281112,
                "question_id": 79275641,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Expanding my comment into answer, given potential more details:\r\n\r\nOP code is\r\n```\r\naws s3 ls s3://REDACTED/ |\r\njq -nR &#39;[inputs | split(&quot; +&quot;; null).[3]] | reverse.[] | &quot;bkt --ttl &#39;1h&#39; -- aws s3 cp s3://REDACTED/\\(.) - | tac&quot;&#39; -r \r\nbash -e |\r\nhead\r\n```\r\n\r\nWhile will load all data for all objects, and process them in memory.\r\nAlternative solution will be to reorder the commands `tac | head` to use `tail | tac`. This will reduce the memory requirements on tac - will only has to store/reverse the last 10 lines of the file\r\n\r\n```\r\naws s3 ls s3://REDACTED/ |\r\njq -nR &#39;[inputs | split(&quot; +&quot;; null).[3]] | reverse.[] | &quot;bkt --ttl &#39;1h&#39; -- aws s3 cp s3://REDACTED/\\(.) - | tail -10&quot;&#39; -r |\r\nbash |\r\nhead\r\n```\r\n\r\n**Notes: I do NOT have access to S3 to check the below. This is based on AWS documentation. Might have typo errors **\r\n\r\nThe solution will still load full objects from S3. To improve performance, and reduce amount of download data (if the S3 objects are big) -  using `get-object` should be considered. It provides an option to download fixed amount of data from the end of the object. Assuming possible to estimate maximum size of the 10 lines (let&#39;s assume 2k), possible to write something like\r\n\r\n~~~\r\naws s3 ls s3://REDACTED/ |\r\njq -nR &#39;[inputs | split(&quot; +&quot;; null).[3]] | reverse.[] | &quot;bkt --ttl &#39;1h&#39; -- aws s3 get-object --bucket: REDACTED --key \\(.) --range=bytes=2000 | tail -10&quot;&#39; -r |\r\nbash |\r\nhead\r\n~~~",
                "title": "Pipe commands not getting killed after head exits"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1734198503,
        "creation_date": 1734016621,
        "last_edit_date": 1734027596,
        "question_id": 79275641,
        "body_markdown": "So, I&#39;m not sure if the commands are actually important, but for background this is the command I was running:\r\n\r\n```\r\naws s3 ls s3://REDACTED/ | jq -nR &#39;[inputs | split(&quot; +&quot;; null).[3]] | reverse.[] | &quot;bkt --ttl &#39;1h&#39; -- aws s3 cp s3://REDACTED/\\(.) - | tac&quot;&#39; -r | bash | head\r\n```\r\n\r\nBasically, I wanted to get the last 10 lines from all the lines of all the objects (by name in lexicographic order).  To do this, I list the bucket, then reverse it, then construct some commands to cat them in reverse order, then run them, then limit the output with head.   For those who don&#39;t know, `bkt` is a wrapper that adds caching to any command...\r\n\r\nWhen I ran that I was a bit surprised that it didn&#39;t quit after the first 10 lines, in-fact it seems like it is still running all the aws cp commands...\r\n\r\nMy question here is why didn&#39;t the `bash` command in the pipe abort? it should have gotten a `SIGPIPE` after `head` exits right? \r\n\r\nEDIT: \r\nThis is a less complicated command that does the same thing:\r\n```\r\nseq 100000000000 | sed -E $&#39;s/(.*)/sh -c \\&#39;echo \\\\1; sleep .1\\&#39;/&#39; | sh | head\r\n```\r\nEDIT:\r\nNote: As @Fravadona brings up, please use caution when piping commands into a shell interpreter. This is not an example of a robust solution to any specific problem",
        "link": "https://stackoverflow.com/questions/79275641/pipe-commands-not-getting-killed-after-head-exits",
        "title": "Pipe commands not getting killed after head exits"
    },
    {
        "tags": [
            "cmd",
            "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": 1734627950,
                "post_id": 79295075,
                "comment_id": 139828817,
                "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": 1734628059,
                "post_id": 79295075,
                "comment_id": 139828825,
                "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": 1734628144,
                "post_id": 79295075,
                "comment_id": 139828832,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 38602454,
                    "reputation": 11,
                    "user_id": 28858585,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c9f2a6fcc274f9e116fe856ca6759862?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user28858585",
                    "link": "https://stackoverflow.com/users/28858585/user28858585"
                },
                "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": 1734628987,
                "post_id": 79295075,
                "comment_id": 139828915,
                "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": 1734629563,
                "post_id": 79295075,
                "comment_id": 139828973,
                "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": 1734630458,
                "post_id": 79295075,
                "comment_id": 139829050,
                "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": 1734630615,
                "post_id": 79295075,
                "comment_id": 139829066,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 38602454,
                    "reputation": 11,
                    "user_id": 28858585,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c9f2a6fcc274f9e116fe856ca6759862?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user28858585",
                    "link": "https://stackoverflow.com/users/28858585/user28858585"
                },
                "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": 1734655694,
                "post_id": 79295075,
                "comment_id": 139830661,
                "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": 1734700520,
                "post_id": 79295075,
                "comment_id": 139833055,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1734630659,
                "creation_date": 1734630659,
                "answer_id": 79295186,
                "question_id": 79295075,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Single quotes do not act as quoting characters in cmd.exe. Since you specify in the question that PowerShell is an option, use it -- your jq command works perfectly there.",
                "title": "jq - difference in behavior between Linux and Windows version"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1734707054,
        "creation_date": 1734627717,
        "last_edit_date": 1734707054,
        "question_id": 79295075,
        "body_markdown": "Using jq 1.7 in Linux and Windows.  The following run fine in Linux (version 5.10.228-219.884.amzn2.x86_64), but gives error &quot;&#39;.[]&#39; is not recognized as an internal or external command, operable program or batch file&quot; in Windows 11 command prompt or Powershell:\r\n\r\n```bash\r\naws dms describe-replication-tasks --filter Name=replication-task-id,Values=TASKNAME --output json | jq &#39;.ReplicationTasks | .[] | .TableMappings |= fromjson | .ReplicationTaskSettings |= fromjson | delpaths([ [&quot;ReplicationTaskArn&quot;],[&quot;ReplicationTaskStartDate&quot;],[&quot;ReplicationTaskStats&quot;],[&quot;Status&quot;],[&quot;StopReason&quot;],[&quot;ReplicationTaskCreationDate&quot;],[&quot;ReplicationTaskSettings&quot;,&quot;Logging&quot;,&quot;CloudWatchLogGroup&quot;],[&quot;ReplicationTaskSettings&quot;,&quot;Logging&quot;,&quot;CloudWatchLogStream&quot;],[&quot;RecoveryCheckpoint&quot;]]) | .TableMappings |= tostring |.ReplicationTaskSettings |= tostring&#39; &gt; TASKNAME.json\r\n```\r\n\r\nI&#39;ve tried various tweaks, like replacing the ticks with quotes, but nothing seems to get this to run on Windows.  \r\n\r\nI expected the Windows command to produce the same output file as the Linux command did.",
        "link": "https://stackoverflow.com/questions/79295075/jq-difference-in-behavior-between-linux-and-windows-version",
        "title": "jq - difference in behavior between Linux and Windows version"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1735030929,
                "post_id": 79305157,
                "comment_id": 139847064,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29651562,
                    "reputation": 45,
                    "user_id": 22725306,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3e6fbd381cccb7dcd1e850448f4e749e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kaya51",
                    "link": "https://stackoverflow.com/users/22725306/kaya51"
                },
                "reply_to_user": {
                    "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": 1735031855,
                "post_id": 79305157,
                "comment_id": 139847108,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 29651562,
                    "reputation": 45,
                    "user_id": 22725306,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/3e6fbd381cccb7dcd1e850448f4e749e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "kaya51",
                    "link": "https://stackoverflow.com/users/22725306/kaya51"
                },
                "reply_to_user": {
                    "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": 1735032299,
                "post_id": 79305157,
                "comment_id": 139847116,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1737440167,
                "last_edit_date": 1737440167,
                "creation_date": 1737354263,
                "answer_id": 79370439,
                "question_id": 79305157,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the following definitions, `$a | subtract_json($b)` produces the desired result, where $a and $b represent the values in a.json and b.json respectively:\r\n```\r\ndef relevant_paths:\r\n  paths\r\n  | select( .[-1] | type != &quot;number&quot;)  ;\r\n  \r\ndef is_scalar: type | IN(&quot;object&quot;, &quot;array&quot;) | not;\r\n\r\ndef subtract_json($y):\r\n  . as $x\r\n  | reduce ($y | relevant_paths) as $p ( $x;\r\n      if (getpath($p)|type == &quot;array&quot;) and\r\n         ($y|getpath($p)|type == &quot;array&quot;)\r\n      then setpath($p;  getpath($p) - ($y|getpath($p)) )\r\n      elif (getpath($p)|is_scalar) and \r\n           ($y|getpath($p)|is_scalar)\r\n      then delpaths( [$p] )\r\n      end);\r\n```",
                "title": "How to Subtract Objects in jq?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1737440167,
        "creation_date": 1735029952,
        "last_edit_date": 1735107304,
        "question_id": 79305157,
        "body_markdown": "We can merge two objects recursively with `*` operator. For example like this: `jq &#39;.[0] * .[1]&#39; -s a.json b.json`. The only problem (I realized) with it is it doesn&#39;t merge the arrays. But [some guys did it](https://stackoverflow.com/q/53661930/13630257).\r\n\r\n---\r\n\r\nWhat I want is the opposite. Assuming the things in b.json are always exist in a.json; a.json, b.json and the result respectively:\r\n\r\n\r\n```json\r\n{\r\n  &quot;background&quot;: {\r\n    &quot;service_worker&quot;: &quot;js/background.js&quot;,\r\n    &quot;type&quot;: &quot;module&quot;\r\n  },\r\n  &quot;manifest_version&quot;: 3,\r\n  &quot;permissions&quot;: [\r\n    &quot;storage&quot;,\r\n    &quot;unlimitedStorage&quot;\r\n  ]\r\n}\r\n```\r\n```json\r\n{\r\n  &quot;background&quot;: {\r\n    &quot;type&quot;: &quot;module&quot;\r\n  },\r\n  &quot;permissions&quot;: [\r\n    &quot;unlimitedStorage&quot;\r\n  ]\r\n}\r\n```\r\n```json\r\n{\r\n  &quot;background&quot;: {\r\n    &quot;service_worker&quot;: &quot;js/background.js&quot;\r\n  },\r\n  &quot;manifest_version&quot;: 3,\r\n  &quot;permissions&quot;: [\r\n    &quot;storage&quot;\r\n  ]\r\n}\r\n```\r\n\r\nThere are some questions on Stack Overflow like this but they are specific cases. I rather have a generic one like the `meld` function.\r\n\r\n---\r\n\r\n\r\nI tried to edit the `meld` function but couldn&#39;t achieve anything worth to mention.",
        "link": "https://stackoverflow.com/questions/79305157/how-to-subtract-objects-in-jq",
        "title": "How to Subtract Objects in jq?"
    },
    {
        "tags": [
            "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": 0,
                "creation_date": 1735082856,
                "post_id": 79306616,
                "comment_id": 139849704,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1735083450,
                "creation_date": 1735083450,
                "answer_id": 79306633,
                "question_id": 79306616,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; How do get something like this?\r\n&gt; ```\r\n&gt; [\r\n&gt;   {\r\n&gt;     &quot;eth0&quot;,\r\n&gt;     &quot;10.1.201.74&quot;\r\n&gt;   }\r\n&gt;   ,\r\n&gt;   {\r\n&gt;     &quot;eth0&quot;,\r\n&gt;     &quot;10.1.202.74&quot;\r\n&gt;   }\r\n&gt; ]\r\n&gt; ```\r\n\r\nThis is not valid JSON. Curly braces surround objects, and objects contain key-value pairs: `{&quot;key1&quot;: &quot;value1&quot;, &quot;key2&quot;: &quot;value2&quot;}`. Arrays only have values (and an implicit index), and are surrounded by square brackets: `[&quot;value1&quot;, &quot;value2&quot;]`.\r\n\r\nThen, with `.[]` you destructure the outer array. Use `map` to retain it. Also, the `if` expression can replaced with `select` as you only need one of the branches (&quot;unselected&quot; items are filtered out automatically).\r\n\r\nGetting an array of objects using `{dev, prefsrc}`:\r\n```sh\r\nmap(select(.dev == &quot;eth0&quot; and .dst != &quot;default&quot;) | {dev, prefsrc})\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;dev&quot;: &quot;eth0&quot;,\r\n    &quot;prefsrc&quot;: &quot;10.1.201.74&quot;\r\n  },\r\n  {\r\n    &quot;dev&quot;: &quot;eth0&quot;,\r\n    &quot;prefsrc&quot;: &quot;10.1.202.74&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/1Bd1bPUa2xwtp2l)\r\n\r\n\r\nGetting an array of arrays using `[.dev, .prefsrc]`:\r\n```sh\r\nmap(select(.dev == &quot;eth0&quot; and .dst != &quot;default&quot;) | [.dev, .prefsrc])\r\n```\r\n```json\r\n[\r\n  [\r\n    &quot;eth0&quot;,\r\n    &quot;10.1.201.74&quot;\r\n  ],\r\n  [\r\n    &quot;eth0&quot;,\r\n    &quot;10.1.202.74&quot;\r\n  ]\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/hf2RgyMDVdIyQTc)",
                "title": "how to return specific properties relative to each other jq 1.5"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1735954824,
        "creation_date": 1735082329,
        "last_edit_date": 1735954824,
        "question_id": 79306616,
        "body_markdown": "I have an input:\r\n\r\n```\r\n$ ip -json route show &gt; ip_routes.json\r\n$ cat ip_routes.json # I&#39;ve pretty printed this for easier reading.\r\n[\r\n  {\r\n    &quot;dst&quot;: &quot;default&quot;,\r\n    &quot;gateway&quot;: &quot;10.1.201.1&quot;,\r\n    &quot;dev&quot;: &quot;eth0&quot;\r\n  },\r\n  {\r\n    &quot;dst&quot;: &quot;10.1.201.0/24&quot;,\r\n    &quot;dev&quot;: &quot;eth0&quot;,\r\n    &quot;prefsrc&quot;: &quot;10.1.201.74&quot;\r\n  },\r\n  {\r\n    &quot;dst&quot;: &quot;10.1.202.0/24&quot;,\r\n    &quot;dev&quot;: &quot;eth0&quot;,\r\n    &quot;prefsrc&quot;: &quot;10.1.202.74&quot;\r\n  },\r\n  {\r\n    &quot;dst&quot;: &quot;10.244.0.0/24&quot;,\r\n    &quot;dev&quot;: &quot;cni0&quot;,\r\n    &quot;prefsrc&quot;: &quot;10.244.0.1&quot;\r\n  },\r\n  {\r\n    &quot;dst&quot;: &quot;10.244.0.0/22&quot;,\r\n    &quot;dev&quot;: &quot;cni0&quot;,\r\n    &quot;scope&quot;: &quot;link&quot;,\r\n    &quot;flags&quot;: []\r\n  }\r\n]\r\n```\r\n\r\nI can do a query where dev is eth0 and not the default gateway:\r\n\r\n```\r\n$ jq &#39;. [] | if .dev == &quot;eth0&quot; and .dst != &quot;default&quot; then . else empty end&#39; ip_routes.json\r\n{\r\n  &quot;dst&quot;: &quot;10.1.201.0/24&quot;,\r\n  &quot;dev&quot;: &quot;eth0&quot;,\r\n  &quot;prefsrc&quot;: &quot;10.1.201.74&quot;\r\n}\r\n{\r\n  &quot;dst&quot;: &quot;10.1.202.0/24&quot;,\r\n  &quot;dev&quot;: &quot;eth0&quot;,\r\n  &quot;prefsrc&quot;: &quot;10.1.202.74&quot;\r\n}\r\n```\r\n\r\nIf I try to select specific properties in the output their association with the object is lost:\r\n\r\n```\r\njq &#39;. [] | if .dev == &quot;eth0&quot; and .dst != &quot;default&quot; then .dev, .prefsrc  else empty end&#39; ip_routes.json\r\n&quot;eth0&quot;\r\n&quot;10.1.201.74&quot;\r\n&quot;eth0&quot;\r\n&quot;10.1.202.74&quot;\r\n```\r\n\r\nHow do get something like this?\r\n\r\n```\r\n[\r\n  {\r\n    &quot;eth0&quot;,\r\n    &quot;10.1.201.74&quot;\r\n  }\r\n  ,\r\n  {\r\n    &quot;eth0&quot;,\r\n    &quot;10.1.202.74&quot;\r\n  }\r\n]\r\n```\r\n\r\nhttps://jqplay.org/s/GsAwBlKJJ92DNAO\r\n\r\n# Edit 1\r\n\r\nThe solution presented by https://stackoverflow.com/users/2158479/pmf does what I intended even though the wording of the question was vague.\r\n\r\n```\r\n$ jq &#39;. | map(select(.dev == &quot;eth0&quot; and .dst != &quot;default&quot;) | {dev, prefsrc})&#39; ip_routes.json\r\n[\r\n  {\r\n    &quot;dev&quot;: &quot;eth0&quot;,\r\n    &quot;prefsrc&quot;: &quot;10.1.201.74&quot;\r\n  },\r\n  {\r\n    &quot;dev&quot;: &quot;eth0&quot;,\r\n    &quot;prefsrc&quot;: &quot;10.1.202.74&quot;\r\n  }\r\n]\r\n```",
        "link": "https://stackoverflow.com/questions/79306616/how-to-return-specific-properties-relative-to-each-other-jq-1-5",
        "title": "how to return specific properties relative to each other jq 1.5"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "sed",
            "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": 2,
                "creation_date": 1735312844,
                "post_id": 79311905,
                "comment_id": 139858665,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 17736811,
                    "reputation": 1,
                    "user_id": 13025232,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/BmeG7.jpg?s=256",
                    "display_name": "ArchaeoRG",
                    "link": "https://stackoverflow.com/users/13025232/archaeorg"
                },
                "reply_to_user": {
                    "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": 1735313072,
                "post_id": 79311905,
                "comment_id": 139858685,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 308303,
                    "reputation": 37458,
                    "user_id": 620097,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/820980fd43f2607a815c1f3dbfe152cc?s=256&d=identicon&r=PG",
                    "display_name": "shellter",
                    "link": "https://stackoverflow.com/users/620097/shellter"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1735314718,
                "post_id": 79311905,
                "comment_id": 139858775,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1965184,
                    "reputation": 72175,
                    "user_id": 1765658,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f2dcfe3194de7a9e1a1cdaa81933b307?s=256&d=identicon&r=PG",
                    "display_name": "F. Hauri  - Give Up GitHub",
                    "link": "https://stackoverflow.com/users/1765658/f-hauri-give-up-github"
                },
                "reply_to_user": {
                    "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": 1,
                "creation_date": 1735323489,
                "post_id": 79311905,
                "comment_id": 139859435,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": false,
                "score": 5,
                "last_activity_date": 1735313172,
                "creation_date": 1735313172,
                "answer_id": 79312176,
                "question_id": 79311905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "No need to use `sed` multiple times. Infact, `jq` can also handle all of this by itself.\r\n\r\nIt seems you want to get rid of all CSV escapes, and use semicolons as delimiters. In that case you could use `join` instead of `@csv`.\r\n\r\nAssuming the following input (from looking at your own attempt), you&#39;d get:\r\n```json\r\n[{\r\n    &quot;MetaData&quot;: [\r\n        {&quot;Nombre&quot;: &quot;&quot;},\r\n        {&quot;Nombre&quot;: &quot;A&quot;},\r\n        {&quot;Nombre&quot;: 2}\r\n    ],\r\n    &quot;Data&quot;: [\r\n        {&quot;Valor&quot;: 11.76},\r\n        {&quot;Valor&quot;: 11.84}\r\n    ]\r\n}]\r\n```\r\n```sh\r\njq -r &#39;\r\n  [&quot;Group&quot;,&quot;Area&quot;,&quot;Total&quot;], (.[]\r\n    | .MetaData as $meta | .Data[]\r\n    | [$meta[1,2].Nombre, (.Valor | tostring | sub(&quot;\\\\.&quot;; &quot;,&quot;))]\r\n  ) | join(&quot;;&quot;)\r\n&#39;\r\n```\r\n```csv\r\nGroup;Area;Total\r\nA;2;11,76\r\nA;2;11,84\r\n```\r\n[Demo](https://jqplay.org/s/spCvMfUC8mSaEe4)",
                "title": "How to properly format CSV output using jq and sed?"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1735394673,
                "creation_date": 1735394673,
                "answer_id": 79313909,
                "question_id": 79311905,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not jq, but I want to introduce you to another useful tool: it&#39;s [Miller][1].\r\n\r\nIf you run\r\n\r\n```\r\nmlr --j2c sub -f Total &quot;,&quot; &quot;.&quot; input.json &gt;output.csv\r\n```\r\n\r\nyou get\r\n\r\n```\r\nGroup,Area,Total\r\nA,00,11.76\r\nA,00,11.84\r\nA,00,11.60\r\nA,00,15.98\r\n```\r\n\r\n- **`--j2c`**: This option tells Miller to read the input data as JSON and to output as CSV. (In this case it is actually only important that input is interpreted as JSON which supports sub operations on strings.)\r\n- **`sub`**: This is the Miller verb or command that performs a substring substitution operation.\r\n- **`-f Total`**: This option, used with the `sub` verb, specifies which field (column) the substitution will be performed on. In this case, it&#39;s the field named `Total`\r\n- **`&quot;,&quot;`**: This is the first argument to the `sub` command and represents the substring you want to search for. In this case, it is a literal comma character.\r\n- **`&quot;.&quot;`**: This is the second argument to the `sub` command and represents the substring that should replace the found matches\r\n\r\n  [1]: https://miller.readthedocs.io/en/6.13.0/",
                "title": "How to properly format CSV output using jq and sed?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1735394673,
        "creation_date": 1735305640,
        "last_edit_date": 1735394266,
        "question_id": 79311905,
        "body_markdown": "I&#39;m trying to process a JSON file and convert it to a CSV format using jq and sed. My goal is to replace decimal points with commas in one of the fields and ensure the output is properly formatted with semicolons as delimiters. However, I&#39;m encountering issues with escaping characters.\r\n\r\nMy sample input json is this\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;Group&quot;: &quot;A&quot;,\r\n    &quot;Area&quot;: &quot;00&quot;,\r\n    &quot;Total&quot;: &quot;11,76&quot;\r\n  },\r\n  {\r\n    &quot;Group&quot;: &quot;A&quot;,\r\n    &quot;Area&quot;: &quot;00&quot;,\r\n    &quot;Total&quot;: &quot;11,84&quot;\r\n  },\r\n  {\r\n    &quot;Group&quot;: &quot;A&quot;,\r\n    &quot;Area&quot;: &quot;00&quot;,\r\n    &quot;Total&quot;: &quot;11,60&quot;\r\n  },\r\n  {\r\n    &quot;Group&quot;: &quot;A&quot;,\r\n    &quot;Area&quot;: &quot;00&quot;,\r\n    &quot;Total&quot;: &quot;15,98&quot;\r\n  }\r\n]\r\n```\r\n\r\n\r\nHere&#39;s the jq and sed script I&#39;m using:\r\n\r\n\r\n```\r\njson_to_csv() {\r\n    input_file=$1 #json file\r\n    output_file=$2 #csv file\r\n\r\njq -r &#39;\r\n.[] |\r\n.MetaData as $meta |\r\n.Data[] |\r\n[\r\n    ($meta[1].Nombre),  #Group\r\n    ($meta[2].Nombre),  #Area\r\n    (.Valor | tostring | gsub(&quot;\\\\.&quot;;&quot;\\\\,&quot;)) #Value\r\n] |\r\n@csv&#39; &quot;$input_file&quot; | \r\nsed &#39;s/&quot;//g&#39; |  # Remove quotes generated by @csv\r\nsed &#39;s/\\\\,/,/g&#39; |  # Remove the backslash escaping the comma\r\nsed &#39;s/,/;/g&#39; &gt; &quot;$output_file&quot;  # Replace commas with semicolons\r\n\r\n# Add header\r\nsed -i &#39;1iGroup;Area;Total&#39; &quot;$output_file&quot;\r\n\r\n    return $?\r\n}\r\n\r\n```\r\n\r\nTHe output I am getting is:\r\n\r\n    Group;Area;Total\r\n    A;2;11\\;76\r\n    A;2;11\\;84\r\n\r\nWhat i need is:\r\n\r\n    Group;Area;Total\r\n    A;2;11,76\r\n    A;2;11,84\r\n\r\nI have tried several variants, but I either get all semicolons, all commas, or a escaping bar",
        "link": "https://stackoverflow.com/questions/79311905/how-to-properly-format-csv-output-using-jq-and-sed",
        "title": "How to properly format CSV output using jq and sed?"
    },
    {
        "tags": [
            "json",
            "filter",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 14063913,
                    "reputation": 27,
                    "user_id": 10159248,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/c9b285e0b38a54e3522ebf68149dd7d6?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "paoloschi",
                    "link": "https://stackoverflow.com/users/10159248/paoloschi"
                },
                "reply_to_user": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1735634070,
                "post_id": 79315409,
                "comment_id": 139872511,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1735681749,
                "creation_date": 1735681749,
                "answer_id": 79320859,
                "question_id": 79315409,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this :\r\n\r\n```\r\njq &#39;map(.id |= tostring | .parent |= tostring) # Convert .id/.parent to string\r\n  | INDEX(.[]; .id) as $r # $r means remaining to be processed.\r\n  | map(.parent as $a | select(any($r[];.id == $a)|not)) as $R # $R means result\r\n  | ($r | del(.[$R | .. | objects | .id])) # Remove processed from $r\r\n  | {R:$R,r:.} # Temporary object\r\n  | until((.r | length) == 0;\r\n        reduce (.R as $R | .r | map(. as $o|select(any($R | .. | objects | $o.parent == .id))))[] as $o ({R, r}; # Find next candidates\r\n          .r |= del(.[$o.id]) # Remove from reminaing\r\n        | .R |= walk(if type == &quot;object&quot; and .id == $o.parent\r\n                     then .children+=[$o]\r\n                     end\r\n                    ) # Add to the results\r\n        )\r\n    ).R\r\n  | walk(if type == &quot;object&quot; then .id |= tonumber | .parent |= tonumber end)\r\n&#39; input.json\r\n```",
                "title": "Filter jq for reshaping a JSON array into a nested representation of parent/child elements relationships"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1735681749,
        "creation_date": 1735468531,
        "last_edit_date": 1735579100,
        "question_id": 79315409,
        "body_markdown": "I have a JSON source like this, in which the root array can vary both in number of elements and in parent relationships, inferred from the values in “id” and “parent” keys (while the “type” key specifies that the parents are all of type == 2).\r\n``` json\r\n[\r\n  { &quot;id&quot;: 7, &quot;parent&quot;: 3, &quot;type&quot;: 1, &quot;title&quot;: &quot;Item 1&quot; },\r\n  { &quot;id&quot;: 8, &quot;parent&quot;: 3, &quot;type&quot;: 2, &quot;title&quot;: &quot;Folder 1&quot; },\r\n  { &quot;id&quot;: 9, &quot;parent&quot;: 8, &quot;type&quot;: 2, &quot;title&quot;: &quot;Folder 2&quot; },\r\n  { &quot;id&quot;: 10, &quot;parent&quot;: 9, &quot;type&quot;: 1, &quot;title&quot;: &quot;Item 3&quot; },\r\n  { &quot;id&quot;: 11, &quot;parent&quot;: 9, &quot;type&quot;: 2, &quot;title&quot;: &quot;Folder 3&quot; },\r\n  { &quot;id&quot;: 12, &quot;parent&quot;: 11, &quot;type&quot;: 1, &quot;title&quot;: &quot;Item 4&quot; },\r\n  { &quot;id&quot;: 13, &quot;parent&quot;: 11, &quot;type&quot;: 1, &quot;title&quot;: &quot;Item 5&quot; },\r\n  { &quot;id&quot;: 15, &quot;parent&quot;: 8, &quot;type&quot;: 1, &quot;title&quot;: &quot;Item 2&quot; },\r\n  { &quot;id&quot;: 16, &quot;parent&quot;: 3, &quot;type&quot;: 1, &quot;title&quot;: &quot;Item 6&quot; }\r\n]\r\n```\r\nI need a filter to be passed to jq (v.1.7.1 currently) that allows me to get a tree reshape for a nested parent/child representation of elements, like this:\r\n\r\n``` json\r\n[\r\n  {\r\n    &quot;title&quot;: &quot;Item 1&quot;,\r\n    &quot;id&quot;: 7,\r\n    &quot;type&quot;: 1\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;Folder 1&quot;,\r\n    &quot;id&quot;: 8,\r\n    &quot;type&quot;: 2,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;title&quot;: &quot;Folder 2&quot;,\r\n        &quot;id&quot;: 9,\r\n        &quot;type&quot;: 2,\r\n        &quot;children&quot;: [\r\n          {\r\n            &quot;title&quot;: &quot;Item 3&quot;,\r\n            &quot;id&quot;: 13,\r\n            &quot;type&quot;: 1\r\n          },\r\n          {\r\n            &quot;title&quot;: &quot;Folder 3&quot;,\r\n            &quot;id&quot;: 14,\r\n            &quot;type&quot;: 2,\r\n            &quot;children&quot;: [\r\n              {\r\n                &quot;title&quot;: &quot;Item 4&quot;,\r\n                &quot;id&quot;: 15,\r\n                &quot;type&quot;: 1\r\n              },\r\n              {\r\n                &quot;title&quot;: &quot;Item 5&quot;,\r\n                &quot;id&quot;: 16,\r\n                &quot;type&quot;: 1\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      },\r\n      {\r\n        &quot;title&quot;: &quot;Item 2&quot;,\r\n        &quot;id&quot;: 11,\r\n        &quot;type&quot;: 1\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;title&quot;: &quot;Item 6&quot;,\r\n    &quot;id&quot;: 12,\r\n    &quot;type&quot;: 1\r\n  }\r\n]\r\n```\r\nPlease don&#39;t mind that the id values in my two examples don&#39;t match: they are code snippets taken at different times. I will finally be able to resolve these inconsistencies precisely when I have the required filter :-)\r\n\r\nI ask this as a novice jq learner...\r\n\r\n**Update - Work in progress**\r\n\r\nBefore opening this help request I had obviously searched but to no avail for an already published **jq** filter that would be suitable for my case.\r\nToday I got the idea to look for a similar scenario developed in **Javascript** and I spotted [this one][1]  \r\nI then tried my hand at translating to **jq** directives the same approach and the result is exceeding my own success expectations :-)  \r\nHere&#39;s what I put together:\r\n``` jq\r\nreduce .[] as $o ( [{}];\r\n  map(\r\n    if $o.parent == $o.id then\r\n      .parents[$o.id] = ($o + {children: []} + (.parents[$o.id] // {}))\r\n    else\r\n      .parents[$o.id] = $o\r\n    end\r\n    |\r\n    if .parents[$o.parent] then\r\n      .parents[$o.parent].children += [.parents[$o.id]] | del(.parents[$o.id])\r\n    end\r\n  )\r\n) | .[0].parents | map(select( . != null))\r\n```\r\nAnd this is the output I&#39;m getting from it\r\n``` json\r\n[\r\n  {\r\n    &quot;id&quot;: 7,\r\n    &quot;parent&quot;: 3,\r\n    &quot;type&quot;: 1,\r\n    &quot;title&quot;: &quot;Item 1&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 8,\r\n    &quot;parent&quot;: 3,\r\n    &quot;type&quot;: 2,\r\n    &quot;title&quot;: &quot;Folder 1&quot;,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;id&quot;: 9,\r\n        &quot;parent&quot;: 8,\r\n        &quot;type&quot;: 2,\r\n        &quot;title&quot;: &quot;Folder 2&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 15,\r\n        &quot;parent&quot;: 8,\r\n        &quot;type&quot;: 1,\r\n        &quot;title&quot;: &quot;Item 2&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 10,\r\n    &quot;parent&quot;: 9,\r\n    &quot;type&quot;: 1,\r\n    &quot;title&quot;: &quot;Item 3&quot;\r\n  },\r\n  {\r\n    &quot;id&quot;: 11,\r\n    &quot;parent&quot;: 9,\r\n    &quot;type&quot;: 2,\r\n    &quot;title&quot;: &quot;Folder 3&quot;,\r\n    &quot;children&quot;: [\r\n      {\r\n        &quot;id&quot;: 12,\r\n        &quot;parent&quot;: 11,\r\n        &quot;type&quot;: 1,\r\n        &quot;title&quot;: &quot;Item 4&quot;\r\n      },\r\n      {\r\n        &quot;id&quot;: 13,\r\n        &quot;parent&quot;: 11,\r\n        &quot;type&quot;: 1,\r\n        &quot;title&quot;: &quot;Item 5&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;id&quot;: 16,\r\n    &quot;parent&quot;: 3,\r\n    &quot;type&quot;: 1,\r\n    &quot;title&quot;: &quot;Item 6&quot;\r\n  }\r\n]\r\n```\r\nIn fact, all elements are in the expected place but I am sure my filter it is largely optimizable.\r\nIn the last line I resolved to those ugly `.[0].parents | map(select( . != null))` to clean up from unwanted `null` elements. In addition to this, I also have to make the &quot;parent&quot; keys disappear from each element.  \r\nThere will certainly be ways to do the same already in the construction phase.   \r\nI will attempt to learn how to improve the whole thing…\r\n\r\n\r\n  [1]: https://stackoverflow.com/a/77033484",
        "link": "https://stackoverflow.com/questions/79315409/filter-jq-for-reshaping-a-json-array-into-a-nested-representation-of-parent-chil",
        "title": "Filter jq for reshaping a JSON array into a nested representation of parent/child elements relationships"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1735586440,
                "post_id": 79318415,
                "comment_id": 139870485,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1735965869,
                "creation_date": 1735965869,
                "answer_id": 79328260,
                "question_id": 79318415,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here is a way if you want the property name with status: \r\n\r\n```console\r\n$ jq &#39;.provisionInfo | with_entries(.value = .value.Status)&#39; tmp.json \r\n\r\n{\r\n  &quot;2b66706e-237c-4d05-b3c0-31b03186b9e5&quot;: &quot;Up&quot;,\r\n  &quot;3fb6886e-9877c-4d05-b39f-31b03186b9e5&quot;: &quot;Up&quot;\r\n}\r\n```",
                "title": "Get sub-objects in JSON where key values unknown"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1735965869,
        "creation_date": 1735585951,
        "last_edit_date": 1735587396,
        "question_id": 79318415,
        "body_markdown": "I have the following JSON generated from a command.  The JSON is composed of objects where the key is a random string, and I want to access data in each of those objects.  Any thoughts on how to do that, without knowing the value of the key for each object?\r\n```json\r\n{\r\n  &quot;provisionInfo&quot;: {\r\n    &quot;2b66706e-237c-4d05-b3c0-31b03186b9e5&quot;: {\r\n      &quot;Status&quot;: &quot;Up&quot;,\r\n      &quot;key&quot;: &quot;value&quot;\r\n    },\r\n    &quot;3fb6886e-9877c-4d05-b39f-31b03186b9e5&quot;: {\r\n      &quot;Status&quot;: &quot;Up&quot;,\r\n      &quot;key&quot;: &quot;value&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI know I can do this to get the objects:\r\n```json\r\n$ cat tmp.json | jq -c &#39;.provisionInfo&#39;\r\n\r\n{&quot;2b66706e-237c-4d05-b3c0-31b03186b9e5&quot;:{&quot;Status&quot;:&quot;Up&quot;,&quot;key&quot;:&quot;value&quot;},&quot;3fb6886e-9877c-4d05-b39f-31b03186b9e5&quot;:{&quot;Status&quot;:&quot;Up&quot;,&quot;key&quot;:&quot;value&quot;}}\r\n```\r\n But how do I access the value of Status for both objects without knowing the index?",
        "link": "https://stackoverflow.com/questions/79318415/get-sub-objects-in-json-where-key-values-unknown",
        "title": "Get sub-objects in JSON where key values unknown"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1735776247,
                "creation_date": 1735776247,
                "answer_id": 79322532,
                "question_id": 79322478,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You&#39;re looking for something like this:\r\n```\r\n.data[] | [.startTime] + (.data[] | [.one, .two]) | join(&quot;, &quot;)",
                "title": "Object item and nested array items on same output line"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1735776247,
        "creation_date": 1735773078,
        "question_id": 79322478,
        "body_markdown": "I&#39;ve got some data that looks like this:\r\n```json\r\n{\r\n&quot;data&quot;: [\r\n    {\r\n      &quot;startTime&quot;: &quot;2024-12-31T00:00:00Z&quot;,\r\n      &quot;data&quot;: [\r\n        {\r\n          &quot;one&quot;: &quot;a&quot;,\r\n          &quot;two&quot;: 1125.000\r\n        },\r\n        {\r\n          &quot;one&quot;: &quot;b&quot;,\r\n          &quot;two&quot;: 2119.000\r\n        },\r\n        {\r\n          &quot;one&quot;: &quot;c&quot;,\r\n          &quot;two&quot;: 0.000\r\n        }\r\n      ]\r\n    },\r\n```\r\nwith multiple objects in the outer data array. What I&#39;m failing at is outputting something like this:\r\n\r\n```\r\nstartTime, one, two\r\n```\r\nwhich in the case of the data above would give me three lines of output.\r\nI can get one and two together, but not startTime: with `jq -r &#39;.data[] | &quot;\\(.startTime)&quot;, (.data[] | &quot;\\(.one), \\(.two)&quot; )&#39;`\r\n```\r\n2024-12-31T00:00:00Z\r\na, 1125.000\r\nb, 2119.000\r\nc, 0.000\r\n```\r\n`jq -r &#39;.data[] | &quot;\\(.startTime)&quot;, (.data[] | &quot;\\(.one), \\(.two)&quot; )&#39;` gets me the following, iterating over each of the last items (&quot;two&quot;):\r\n```\r\n2024-12-31T00:00:00Z, a, 1125.000\r\n2024-12-31T00:00:00Z, b, 1125.000\r\n2024-12-31T00:00:00Z, c, 1125.000\r\n2024-12-31T00:00:00Z, a, 2119.000\r\n2024-12-31T00:00:00Z, b, 2119.000\r\n2024-12-31T00:00:00Z, c, 2119.000\r\n2024-12-31T00:00:00Z, a, 0.000\r\n2024-12-31T00:00:00Z, b, 0.000\r\n2024-12-31T00:00:00Z, c, 0.000\r\n```\r\nI can&#39;t seem to hit on the right syntax.",
        "link": "https://stackoverflow.com/questions/79322478/object-item-and-nested-array-items-on-same-output-line",
        "title": "Object item and nested array items on same output line"
    },
    {
        "tags": [
            "json",
            "key",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1737602173,
                "post_id": 79379669,
                "comment_id": 139986319,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1737602019,
                "creation_date": 1737602019,
                "answer_id": 79379735,
                "question_id": 79379669,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Apparently you&#39;re shooting for:\r\n```\r\njq -r &#39;.[][] | keys_unsorted[]&#39;\r\n```\r\nor perhaps:\r\n```\r\njq -c &#39;[.[][] | keys_unsorted[]]&#39;\r\n```",
                "title": "How can I use jq to extract the first strings inside an object, while ignoring the lists from the object (subcomponents)?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1737621309,
        "creation_date": 1737599260,
        "last_edit_date": 1737621309,
        "question_id": 79379669,
        "body_markdown": "example data.json file:\r\n\r\n```json\r\n{\r\n    &quot;JSON_KEY&quot;: { \r\n        &quot;SOME_TITLE&quot;: {\r\n            &quot;RANDOM_STRING1&quot;: {\r\n                &quot;label&quot;: &quot;value&quot;,\r\n                &quot;units&quot;: {\r\n                    &quot;subunits&quot;: [\r\n                         {&quot;item1&quot;: &quot;1&quot;, &quot;item2&quot;: &quot;2&quot;},\r\n                         {&quot;item3&quot;: &quot;3&quot;, &quot;item4&quot;:&quot;4&quot;}\r\n                    ]\r\n                }\r\n            }\r\n        }\r\n    }\r\n}\r\n```\r\n\r\nImagine this structure. RANDOM_STRING1 is the first random string in a file with hundreds, maybe thousands, of random strings. There is only one JSON key here.\r\n\r\n\r\nI tried searching and the closest I&#39;ve found got me with the following command, found from another stackoverflow post. This command will strip the first parts and leave me with the RANDOM_STRING. but, it includes all it&#39;s objects and lists.\r\n\r\n```sh\r\njq -r &#39;.[] | [.[]]&#39; data.json\r\n```\r\n\r\nresult:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;RANDOM_STRING1&quot;: {\r\n      &quot;label&quot;: &quot;value&quot;,\r\n      &quot;units&quot;: {\r\n        &quot;subunits&quot;: [\r\n          {\r\n            &quot;item1&quot;: &quot;1&quot;,\r\n            &quot;item2&quot;: &quot;2&quot;\r\n          },\r\n          {\r\n            &quot;item3&quot;: &quot;3&quot;,\r\n            &quot;item4&quot;: &quot;4&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  }\r\n]\r\n```\r\n\r\nI need the next step to strip the objects and lists of each RANDOM_STRING, leaving me with a file that shows all RANDOM_STRING names only.\r\n\r\nHow can I accomplish this using jq?\r\n\r\nExpected Output:\r\n````\r\nRANDOM_STRING1\r\nRANDOM_STRING2\r\nRANDOM_STRING3\r\nRANDOM_STRING4\r\n.....\r\nRANDOM_STRING100000\r\n",
        "link": "https://stackoverflow.com/questions/79379669/how-can-i-use-jq-to-extract-the-first-strings-inside-an-object-while-ignoring-t",
        "title": "How can I use jq to extract the first strings inside an object, while ignoring the lists from the object (subcomponents)?"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 127887,
                    "reputation": 3847,
                    "user_id": 325366,
                    "user_type": "registered",
                    "accept_rate": 67,
                    "profile_image": "https://www.gravatar.com/avatar/7d294a16757de93b39df8a272b5b06f1?s=256&d=identicon&r=PG",
                    "display_name": "Chris",
                    "link": "https://stackoverflow.com/users/325366/chris"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1737903889,
                "post_id": 79388729,
                "comment_id": 140003033,
                "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": 1737920613,
                "post_id": 79388729,
                "comment_id": 140003860,
                "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": 1,
                "creation_date": 1737921204,
                "post_id": 79388729,
                "comment_id": 140003878,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1737917481,
                "last_edit_date": 1737917481,
                "creation_date": 1737912535,
                "answer_id": 79388975,
                "question_id": 79388729,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You need to work on `.modules.data` instead of `.modules.data[]`:\r\n\r\n```\r\njq &#39;.modules.data | \r\n    { title: (.[] | select(.id == &quot;aod_play_area&quot;).data[0] | &quot;\\(.titles.primary) - \\(.titles.secondary)&quot;),\r\n      tracks: (.[] | select(.id == &quot;aod_tracks&quot;).data | map({\r\n        title: .titles.primary,\r\n        artist: .titles.secondary,\r\n        start: .offset.start,\r\n        end: .offset.end,\r\n        apple:   .uris[] | select(.id ==&quot;commercial-music-service-apple&quot;).uri,\r\n        spotify: .uris[] | select(.id ==&quot;commercial-music-service-spotify&quot;).uri\r\n    }))\r\n    }&#39; sample.json\r\n```\r\n\r\nWhen you work on `.modules.data[]`, you filter takes as input `.modules.data[0]`, then `.modules.data[1]`, so tries to construct two objects with missing information:\r\n\r\n```\r\n{ title: ..., tracks: empty }\r\n{ title: empty, tracks: ... }\r\n```\r\n\r\nAs each one contains `empty`, which means the overall result is empty.",
                "title": "Using jq to include data taken from two filtered array elements into a single output object"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1737919942,
                "creation_date": 1737919942,
                "answer_id": 79389173,
                "question_id": 79388729,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The `INDEX` [function](https://jqlang.github.io/jq/manual/#sql-style-operators) (available since v1.6, and not to be confused with the lowercase `index` [function](https://jqlang.github.io/jq/manual/#index-rindex)) can convert an array into an object using a specific evaluation on each item to determine the respective keys. Applied to `.modules.data`, `INDEX(.id)` will produce\r\n```json\r\n{\r\n  &quot;aod_play_area&quot;: {\r\n    &quot;id&quot;: &quot;aod_play_area&quot;,\r\n    &quot;data&quot;: […]\r\n  },\r\n  &quot;aod_tracks&quot;: {\r\n    &quot;id&quot;: &quot;aod_tracks&quot;,\r\n    &quot;data&quot;: […]\r\n  }\r\n}\r\n```\r\n\r\nWith this, you can rewrite your own approach to:\r\n```sh\r\n.modules.data | INDEX(.id) | {\r\n  title: .aod_play_area.data[0] | &quot;…&quot;,\r\n  tracks: .aod_tracks.data | map({ … })\r\n}\r\n```\r\n```\r\n{\r\n  &quot;title&quot;: &quot;Primary - Secondary&quot;,\r\n  &quot;tracks&quot;: [\r\n    {\r\n      &quot;title&quot;: &quot;First Artist name here&quot;,\r\n      &quot;artist&quot;: &quot;First Track title here&quot;,\r\n      &quot;start&quot;: null,\r\n      &quot;end&quot;: null,\r\n      &quot;apple&quot;: &quot;https://music.apple.com/gb/album/xyz/1234?i=9876&quot;,\r\n      &quot;spotify&quot;: &quot;https://open.spotify.com/track/1234567890&quot;\r\n    },\r\n    {\r\n      &quot;title&quot;: &quot;Second Artist name here&quot;,\r\n      &quot;artist&quot;: &quot;Second Track title here&quot;,\r\n      &quot;start&quot;: null,\r\n      &quot;end&quot;: null,\r\n      &quot;apple&quot;: &quot;https://music.apple.com/gb/album/abc/5555?i=5555&quot;,\r\n      &quot;spotify&quot;: &quot;https://open.spotify.com/track/555555555555&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/Z5sRK43aZrJp8m1)",
                "title": "Using jq to include data taken from two filtered array elements into a single output object"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1737919942,
        "creation_date": 1737903724,
        "last_edit_date": 1737903900,
        "question_id": 79388729,
        "body_markdown": "Given input JSON like this (there&#39;s a lot more to it really, but I&#39;ve stripped the fields that aren&#39;t of any interest:\r\n\r\n    {\r\n      &quot;modules&quot;: {\r\n        &quot;data&quot;: [\r\n          {\r\n            &quot;id&quot;: &quot;aod_play_area&quot;,\r\n            &quot;data&quot;: [\r\n              {\r\n                &quot;titles&quot;: {\r\n                  &quot;primary&quot;: &quot;Primary&quot;,\r\n                  &quot;secondary&quot;: &quot;Secondary&quot;\r\n                }\r\n              }\r\n             ]\r\n          },\r\n          {\r\n            &quot;id&quot;: &quot;aod_tracks&quot;,\r\n            &quot;data&quot;: [\r\n              {\r\n                &quot;titles&quot;: {\r\n                  &quot;primary&quot;: &quot;First Artist name here&quot;,\r\n                  &quot;secondary&quot;: &quot;First Track title here&quot;\r\n                },\r\n                &quot;uris&quot;: [\r\n                  {\r\n                    &quot;id&quot;: &quot;commercial-music-service-spotify&quot;,\r\n                    &quot;uri&quot;: &quot;https://open.spotify.com/track/1234567890&quot;\r\n                  },\r\n                  {\r\n                    &quot;id&quot;: &quot;commercial-music-service-apple&quot;,\r\n                    &quot;uri&quot;: &quot;https://music.apple.com/gb/album/xyz/1234?i=9876&quot;\r\n                  }\r\n                ]\r\n              },\r\n              {\r\n                &quot;titles&quot;: {\r\n                  &quot;primary&quot;: &quot;Second Artist name here&quot;,\r\n                  &quot;secondary&quot;: &quot;Second Track title here&quot;\r\n                },\r\n                &quot;uris&quot;: [\r\n                  {\r\n                    &quot;id&quot;: &quot;commercial-music-service-spotify&quot;,\r\n                    &quot;label&quot;: &quot;Spotify&quot;,\r\n                    &quot;uri&quot;: &quot;https://open.spotify.com/track/555555555555&quot;\r\n                  },\r\n                  {\r\n                    &quot;id&quot;: &quot;commercial-music-service-apple&quot;,\r\n                    &quot;label&quot;: &quot;Apple Music&quot;,\r\n                    &quot;uri&quot;: &quot;https://music.apple.com/gb/album/abc/5555?i=5555&quot;\r\n                  }\r\n                ]\r\n              }\r\n            ]\r\n          }\r\n        ]\r\n      }\r\n    }\r\n\r\n... and desired output which has two top-level properties, each populated from different elements within the `modules.data[]` array, indexed by their `.id`:\r\n\r\n    {\r\n        &quot;title&quot;: &quot;Primary - Secondary&quot;,\r\n        &quot;tracks&quot;: [\r\n           {\r\n              &quot;title&quot;: &quot;First Track title&quot;,\r\n              &quot;artist&quot;: &quot;First Artist name&quot;,\r\n              &quot;start&quot;: 3645,\r\n              &quot;end&quot;: 3820,\r\n              &quot;apple&quot;: &quot;https://music.apple.com/gb/album/xyz/1234?i=9876&quot;,\r\n              &quot;spotify&quot;: &quot;https://open.spotify.com/track/1234567890&quot;\r\n            },\r\n           {\r\n              &quot;title&quot;: &quot;Second Track title&quot;,\r\n              &quot;artist&quot;: &quot;Second Artist name&quot;,\r\n              &quot;start&quot;: 3645,\r\n              &quot;end&quot;: 3820,\r\n              &quot;apple&quot;: &quot;https://music.apple.com/gb/album/abc/5555?i=5555&quot;,\r\n              &quot;spotify&quot;: &quot;https://open.spotify.com/track/555555555555&quot;\r\n            }\r\n        ]\r\n    }\r\n\r\n... what should my `jq` query look like to pull data from those two objects within `modules.data`? I can write queries to do one or the other, but not both, presumably because my first query has caused `jq` to walk down one branch of the structure and I don&#39;t know how to make it &quot;unwind&quot; so that the second query still works.\r\n\r\nExtracting the titles:\r\n\r\n    cat sample.json | jq &#39;.modules.data.[] | {\r\n        title: select(.id == &quot;aod_play_area&quot;).data[0] | &quot;\\(.titles.primary) - \\(.titles.secondary)&quot;,\r\n        tracks: []\r\n    }&#39;\r\n\r\nProduces:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;Primary - Secondary&quot;,\r\n      &quot;tracks&quot;: []\r\n    }\r\n\r\nExtracting just the tracks:\r\n\r\n    cat sample.json | jq &#39;.modules.data.[] | {\r\n        title: &quot;title&quot;,\r\n        tracks: select(.id == &quot;aod_tracks&quot;).data | map({\r\n            title: .titles.primary,\r\n            artist: .titles.secondary,\r\n            start: .offset.start,\r\n            end: .offset.end,\r\n            apple:   .uris[] | select(.id ==&quot;commercial-music-service-apple&quot;).uri,\r\n            spotify: .uris[] | select(.id ==&quot;commercial-music-service-spotify&quot;).uri\r\n        })\r\n    }&#39;\r\n\r\nProduces:\r\n\r\n    {\r\n      &quot;title&quot;: &quot;title&quot;,\r\n      &quot;tracks&quot;: [\r\n        {\r\n          &quot;title&quot;: &quot;First Artist name here&quot;,\r\n          &quot;artist&quot;: &quot;First Track title here&quot;,\r\n          &quot;start&quot;: null,\r\n          &quot;end&quot;: null,\r\n          &quot;apple&quot;: &quot;https://music.apple.com/gb/album/xyz/1234?i=9876&quot;,\r\n          &quot;spotify&quot;: &quot;https://open.spotify.com/track/1234567890&quot;\r\n        },\r\n        {\r\n          &quot;title&quot;: &quot;Second Artist name here&quot;,\r\n          &quot;artist&quot;: &quot;Second Track title here&quot;,\r\n          &quot;start&quot;: null,\r\n          &quot;end&quot;: null,\r\n          &quot;apple&quot;: &quot;https://music.apple.com/gb/album/abc/5555?i=5555&quot;,\r\n          &quot;spotify&quot;: &quot;https://open.spotify.com/track/555555555555&quot;\r\n        }\r\n      ]\r\n    }\r\n\r\nCombining the two:\r\n\r\n    cat sample.json | jq &#39;.modules.data.[] | {\r\n        title: select(.id == &quot;aod_play_area&quot;).data[0] | &quot;\\(.titles.primary) - \\(.titles.secondary)&quot;,\r\n        tracks: select(.id == &quot;aod_tracks&quot;).data | map({\r\n            title: .titles.primary,\r\n            artist: .titles.secondary,\r\n            start: .offset.start,\r\n            end: .offset.end,\r\n            apple:   .uris[] | select(.id ==&quot;commercial-music-service-apple&quot;).uri,\r\n            spotify: .uris[] | select(.id ==&quot;commercial-music-service-spotify&quot;).uri\r\n        })\r\n    }&#39;\r\n\r\n... produces no output at all. I believe this is because the first `select` has taken us down one &quot;branch&quot; of the outer-most data, so the second `select` doesn&#39;t find what it&#39;s looking for (as children of where it&#39;s ended up down that first branch). How should I rewrite my query to successfully extract all of the data of interest?\r\n\r\n(I&#39;m new to `jq`, so apologies if I&#39;ve misused any terminology)",
        "link": "https://stackoverflow.com/questions/79388729/using-jq-to-include-data-taken-from-two-filtered-array-elements-into-a-single-ou",
        "title": "Using jq to include data taken from two filtered array elements into a single output object"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1737931745,
                "last_edit_date": 1737931745,
                "creation_date": 1737931015,
                "answer_id": 79389420,
                "question_id": 79389414,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; The challenge is how to merge each pair in the input, e.g. in the simpler case `[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]` to `[&quot;ab&quot;,&quot;cd&quot;]`.\r\n\r\nSo your input is an array, and you want to process every two items into a new item. You can use the undocumented `_nwise` [function](https://github.com/jqlang/jq/blob/31dac287cce2d15357c3b78a90009007e9c21493/src/builtin.jq#L105-L107). Applied by itself using an item count of `2`, you get `[&quot;a&quot;,&quot;b&quot;] [&quot;c&quot;,&quot;d&quot;]`, so wrap this stream into an array, and use `add` to process the strings in the two items into one:\r\n```sh\r\njq &#39;[_nwise(2) | add]&#39; &lt;&lt;&lt; &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]&#39;\r\n```\r\n```json\r\n[\r\n  &quot;ab&quot;,\r\n  &quot;cd&quot;\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/thpEmbIx2diayoL)\r\n\r\nIf you&#39;re uncomfortable with undocumented functions, you can replicate its behavior using a `while` loop, that reduces the array by two items until there aren&#39;t any left, and slice each subarray  further to only contain the first two items:\r\n```sh\r\njq &#39;[while(length &gt; 0; .[2:])[:2] | add]&#39; &lt;&lt;&lt; &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]&#39;\r\n```\r\n[Demo](https://jqplay.org/s/pXGXT__k5j5iAD9)",
                "title": "How to merge consecutive JSON objects without shared keys"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1737931745,
        "creation_date": 1737930557,
        "last_edit_date": 1737930702,
        "question_id": 79389414,
        "body_markdown": "I have a JSON file with a bunch of objects and after each, there&#39;s a smaller object with extra data. They don&#39;t share any information, so the position is the only thing connecting them. This unfortunate structure is due to limitations of OverpassQL.\r\n\r\nThe challenge is how to merge each pair in the input, e.g. in the simpler case `[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]` to `[&quot;ab&quot;,&quot;cd&quot;]`.\r\n\r\nIf I put it all in a scripted loop outside of jq and reconstructed the JSON afterwards, something as simple as this would work (but it&#39;d be quite lame):\r\n\r\n```lang-bash\r\n$ jq &#39;.elements[0] + .elements[1]&#39; test.json\r\n```\r\nSo I generated the indices to then use them in the original data:\r\n```lang-bash\r\n$ jq -n &#39;range(0; 2) | foreach . as $idx (0; $idx; [2 * $idx, 2 * $idx + 1])&#39;\r\n[\r\n  0,\r\n  1\r\n]\r\n[\r\n  2,\r\n  3\r\n]\r\n```\r\nBut combining the two still only gives me the first pair. If I use `input` instead, it also prints an error on exit. A simplified version:\r\n```lang-bash\r\n$ jq -n &#39;range(0; 2) |\r\n  foreach . as $idx (0; $idx; inputs |\r\n    nth(2 * $idx; .[]) + nth(2 * $idx + 1; .[]))&#39; &lt;&lt;&lt; &#39;[&quot;a&quot;,&quot;b&quot;,&quot;c&quot;,&quot;d&quot;]&#39;\r\n&quot;ab&quot;\r\n```\r\nI tried a few other things, but to no avail. Is there a way to merge all consecutive objects in just `jq`?\r\n",
        "link": "https://stackoverflow.com/questions/79389414/how-to-merge-consecutive-json-objects-without-shared-keys",
        "title": "How to merge consecutive JSON objects without shared keys"
    },
    {
        "tags": [
            "android",
            "json",
            "grep",
            "jq",
            "logcat"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1738632323,
                "post_id": 79410149,
                "comment_id": 140045222,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1738680258,
                "post_id": 79410149,
                "comment_id": 140048144,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13848097,
                    "reputation": 372,
                    "user_id": 9996747,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-4sQ6NFWD5WY/AAAAAAAAAAI/AAAAAAAAHpQ/zOq3q7fqC14/s256-rj/photo.jpg",
                    "display_name": "Brett",
                    "link": "https://stackoverflow.com/users/9996747/brett"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1738692461,
                "post_id": 79410149,
                "comment_id": 140049230,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 13848097,
                    "reputation": 372,
                    "user_id": 9996747,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-4sQ6NFWD5WY/AAAAAAAAAAI/AAAAAAAAHpQ/zOq3q7fqC14/s256-rj/photo.jpg",
                    "display_name": "Brett",
                    "link": "https://stackoverflow.com/users/9996747/brett"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1738693051,
                "post_id": 79410149,
                "comment_id": 140049294,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1738704378,
                "post_id": 79410149,
                "comment_id": 140050229,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "reply_to_user": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1738762406,
                "post_id": 79410149,
                "comment_id": 140053637,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1738762758,
                "post_id": 79410149,
                "comment_id": 140053687,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1739166830,
                "creation_date": 1739166830,
                "answer_id": 79426171,
                "question_id": 79410149,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Assuming:\r\n- The text of intetest may contain commas and matched (and possibly nested) square brackets.\r\n- The text may be empty.\r\n- Your `grep` supports `-P` (PCRE) option. **[important]**\r\n\r\nThen would you please try:\r\n```\r\ngrep -Po &#39;specificword=(\\[(?&gt;[^][]|(?1))*\\])&#39; test.txt\r\n```\r\ntest.txt:\r\n```\r\nstateEventTime=2025-01-09T17:22:05.635Z)], specificword=[SpecificWord(displayTimestamp=2024-06-01T00:00:00Z, LanguageCode=US English, ScreenId=ABC0-0, EventTime=2025-01-29T19:20:16.521Z)], specificword=[], foo[](bar,baz), specificword=[this is some(of the possible[text]), including commas and paired [square] brackets]\r\n```\r\nOutput:\r\n```\r\nspecificword=[SpecificWord(displayTimestamp=2024-06-01T00:00:00Z, LanguageCode=US English, ScreenId=ABC0-0, EventTime=2025-01-29T19:20:16.521Z)]\r\nspecificword=[]\r\nspecificword=[this is some(of the possible[text]), including commas and paired [square] brackets]\r\n```\r\n**[Explanation of the regex]**\r\n- `specificword=(regex)` matches the literal string followed by the regex\r\n  to be the 1st capture group.\r\n- `\\[ ... \\]` specifies the pattern to be surrounded by square brackets.\r\n- `(?&gt; ... )` configures an atomic group to avoid unnecessary backtracking.\r\n- `[^][]` matches any character other than square brackets.\r\n- `(?1)` tells the regex engine to apply the regex surrounded by the 1st\r\n  (outermost) parentheses at the current position. This enables the recursion\r\n  to match balanced constructs.\r\n- `(?&gt;[^][]|(?1))*` matches 0 or more sequences of alternation which matches\r\n  `[^][]` or `(?1)`.\r\n",
                "title": "Command line getting occurrences of text within brackets following a specificword="
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1739166830,
        "creation_date": 1738621277,
        "last_edit_date": 1738870391,
        "question_id": 79410149,
        "body_markdown": "I am trying to get some specific text from logcat. It could be repeating multiple times. Example content would be:\r\n\r\n    ..., stateEventTime=2025-01-09T17:22:05.635Z)], specificword=[SpecificWord(displayTimestamp=2024-06-01T00:00:00Z, LanguageCode=US English, ScreenId=ABC1-1, EventTime=2025-01-29T19:20:16.521Z)], status=status(more....\r\n\r\nThe problem is when I grep specificword, I am given too much json data to easily visually parse, as I only care about what is within specificword. Note, the brackets could be empty, such as:\r\n\r\n    specificword=[]\r\n\r\nI would love to do the following:\r\n\r\n    adb logcat | grep my.app | command\r\n\r\nAnd received something like the following:\r\n\r\n\r\n    specificword=[SpecificWord(displayTimestamp=2024-06-01T00:00:00Z, LanguageCode=US English, ScreenId=ABC0-0, EventTime=2025-01-29T19:20:16.521Z)]\r\n    specificword=[]\r\nThanks for the help!",
        "link": "https://stackoverflow.com/questions/79410149/command-line-getting-occurrences-of-text-within-brackets-following-a-specificwor",
        "title": "Command line getting occurrences of text within brackets following a specificword="
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1738723169,
                "last_edit_date": 1738723169,
                "creation_date": 1738722330,
                "answer_id": 79413506,
                "question_id": 79413461,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`reduce` over the items, `split` the `.FqdnList` string at `;`, and populate an array in the result object using the substrings as keys and the `.Ip` as array item.\r\n```sh\r\nreduce .[][] as $i ({}; .[$i.FqdnList | splits(&quot;;&quot;)] += [$i.Ip])\r\n```\r\n```json\r\n{\r\n  &quot;vpn.example.com&quot;: [\r\n    &quot;192.168.0.1&quot;,\r\n    &quot;192.168.0.4&quot;\r\n  ],\r\n  &quot;db.example.com&quot;: [\r\n    &quot;192.168.0.2&quot;,\r\n    &quot;192.168.0.3&quot;,\r\n    &quot;192.168.0.5&quot;\r\n  ],\r\n  &quot;sql.example.com&quot;: [\r\n    &quot;192.168.0.2&quot;,\r\n    &quot;192.168.0.3&quot;,\r\n    &quot;192.168.0.5&quot;\r\n  ],\r\n  &quot;nginx.example.com&quot;: [\r\n    &quot;192.168.0.3&quot;,\r\n    &quot;192.168.0.5&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://jqplay.org/s/DL0dHhf57ss531L)\r\n\r\nTo include the `.Proxy` condition, change the generator along the lines of: `reduce (.[][] | select(.Proxy)) as …`.\r\n\r\n---\r\nFor the alternative output, use your initial attempt, wrap it into an array (to get the outer array), and replace `split` with `splits` as it evaluates to a stream of items which automatically multiplies the surrounding object (or manually generate the stream using `.[]`).\r\n```sh\r\n[.[][] | {name: .FqdnList | splits(&quot;;&quot;), value: .Ip}]\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;name&quot;: &quot;vpn.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.1&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;db.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.2&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;sql.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.2&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;nginx.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.3&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;db.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.3&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;sql.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.3&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;vpn.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.4&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;nginx.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.5&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;db.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.5&quot;\r\n  },\r\n  {\r\n    &quot;name&quot;: &quot;sql.example.com&quot;,\r\n    &quot;value&quot;: &quot;192.168.0.5&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://jqplay.org/s/IJ0Xa5FbuPFNBA8)\r\n\r\nSimilarly here, to include the `.Proxy` condition, change the generator along the lines of: `[.[][] | select(.Proxy) | …]`.\r\n",
                "title": "Transposing jq array elements (building x*y key/value pairs from x arrays of y items)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1738723169,
        "creation_date": 1738719599,
        "question_id": 79413461,
        "body_markdown": "I have the following AWS CLI JSON output that contains Instance ID, IP address and some other values from my AWS tags (a list of desired FQDNs and if a proxy should be used or not):\r\n\r\n```json\r\n[\r\n    [\r\n        {\r\n            &quot;InstanceId&quot;: &quot;i-11111111111111111&quot;,\r\n            &quot;ClusterName&quot;: &quot;vpn&quot;,\r\n            &quot;Ip&quot;: &quot;192.168.0.1&quot;,\r\n            &quot;FqdnList&quot;: &quot;vpn.example.com&quot;,\r\n            &quot;Proxy&quot;: null\r\n        }\r\n    ],\r\n    [\r\n        {\r\n            &quot;InstanceId&quot;: &quot;i-22222222222222222&quot;,\r\n            &quot;ClusterName&quot;: &quot;sql&quot;,\r\n            &quot;Ip&quot;: &quot;192.168.0.2&quot;,\r\n            &quot;FqdnList&quot;: &quot;db.example.com;sql.example.com&quot;,\r\n            &quot;Proxy&quot;: &quot;nginx&quot;\r\n        }\r\n    ],\r\n    [\r\n        {\r\n            &quot;InstanceId&quot;: &quot;i-33333333333333333&quot;,\r\n            &quot;ClusterName&quot;: &quot;nginx&quot;,\r\n            &quot;Ip&quot;: &quot;192.168.0.3&quot;,\r\n            &quot;FqdnList&quot;: &quot;nginx.example.com;db.example.com;sql.example.com&quot;,\r\n            &quot;Proxy&quot;: null\r\n        }\r\n    ],\r\n    [\r\n        {\r\n            &quot;InstanceId&quot;: &quot;i-44444444444444444&quot;,\r\n            &quot;ClusterName&quot;: &quot;vpn&quot;,\r\n            &quot;Ip&quot;: &quot;192.168.0.4&quot;,\r\n            &quot;FqdnList&quot;: &quot;vpn.example.com&quot;,\r\n            &quot;Proxy&quot;: null\r\n        }\r\n    ],\r\n    [\r\n        {\r\n            &quot;InstanceId&quot;: &quot;i-55555555555555555&quot;,\r\n            &quot;ClusterName&quot;: &quot;nginx&quot;,\r\n            &quot;Ip&quot;: &quot;192.168.0.5&quot;,\r\n            &quot;FqdnList&quot;: &quot;nginx.example.com;db.example.com;sql.example.com&quot;,\r\n            &quot;Proxy&quot;: null\r\n        }\r\n    ]\r\n]\r\n```\r\n\r\nMy final goal is to use this JSON to build the list of DNS `A` records (for another script that populates our DNS zone), so I am trying to transpose it to something simpler such as:\r\n\r\n```json\r\n{\r\n    &quot;vpn.example.com&quot;: [\r\n        &quot;192.168.0.1&quot;,\r\n        &quot;192.168.0.4&quot;,\r\n    ],\r\n\r\n    &quot;nginx.example.com&quot;: [\r\n        &quot;192.168.0.3&quot;\r\n        &quot;192.168.0.5&quot;\r\n    ],\r\n    &quot;db.example.com&quot;: [\r\n        &quot;192.168.0.3&quot;\r\n        &quot;192.168.0.5&quot;\r\n    ],\r\n    &quot;sql.example.com&quot;: [\r\n        &quot;192.168.0.3&quot;\r\n        &quot;192.168.0.5&quot;\r\n    ]\r\n}\r\n```\r\n\r\nor\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;name&quot;: &quot;vpn.example.com&quot;,\r\n        &quot;value&quot;: &quot;192.168.0.1&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;vpn.example.com&quot;,\r\n        &quot;value&quot;: &quot;192.168.0.4&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;nginx.example.com&quot;,\r\n        &quot;value&quot;: &quot;192.168.0.3&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;nginx.example.com&quot;,\r\n        &quot;value&quot;: &quot;192.168.0.5&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;db.example.com&quot;,\r\n        &quot;value&quot;: &quot;192.168.0.5&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;db.example.com&quot;,\r\n        &quot;value&quot;: &quot;192.168.0.3&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;sql.example.com&quot;,\r\n        &quot;value&quot;: &quot;192.168.0.3&quot;\r\n    },\r\n    {\r\n        &quot;name&quot;: &quot;sql.example.com&quot;,\r\n        &quot;value&quot;: &quot;192.168.0.5&quot;\r\n    }\r\n]\r\n```\r\n\r\nI&#39;ve managed to remove the items that are being a proxy (`Proxy` != `null`, because their addresses are already repeated in the proxy&#39;s tag) and make an array from the FQDNs string using:\r\n\r\n```shell\r\njq &#39;\r\n  .[].[]\r\n  | select(.Proxy | . == null)\r\n  | {\r\n      Ip: .Ip,\r\n      Fqdns: .FqdnList | split(&quot;;&quot;),\r\n    }\r\n  &#39;\r\n```\r\n\r\nWhich gives:\r\n\r\n```json\r\n{\r\n  &quot;Ip&quot;: &quot;192.168.0.1&quot;,\r\n  &quot;Fqdns&quot;: [\r\n    &quot;vpn.example.com&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Ip&quot;: &quot;192.168.0.3&quot;,\r\n  &quot;Fqdns&quot;: [\r\n    &quot;nginx.example.com&quot;,\r\n    &quot;db.example.com&quot;,\r\n    &quot;sql.example.com&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Ip&quot;: &quot;192.168.0.4&quot;,\r\n  &quot;Fqdns&quot;: [\r\n    &quot;vpn.example.com&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;Ip&quot;: &quot;192.168.0.5&quot;,\r\n  &quot;Fqdns&quot;: [\r\n    &quot;nginx.example.com&quot;,\r\n    &quot;db.example.com&quot;,\r\n    &quot;sql.example.com&quot;\r\n  ]\r\n}\r\n```\r\n\r\nBut how do I &quot;create&quot; rows/items for each item in `Fqdns` arrays?\r\n\r\nI&#39;m not sure it&#39;s even possible in `jq`.\r\n\r\nIt can easily be done in a PHP/Python script but I rather keep it &quot;simple&quot;.\r\n\r\nCan `map()` + `group_by()` be useful like in this SO answer? https://stackoverflow.com/questions/32357240/transposing-objects-in-jq",
        "link": "https://stackoverflow.com/questions/79413461/transposing-jq-array-elements-building-xy-key-value-pairs-from-x-arrays-of-y-i",
        "title": "Transposing jq array elements (building x*y key/value pairs from x arrays of y items)"
    },
    {
        "tags": [
            "json",
            "command-line",
            "jq"
        ],
        "comments": [
            {
                "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": 1738858450,
                "post_id": 79418315,
                "comment_id": 140060530,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1738852376,
                "creation_date": 1738852376,
                "answer_id": 79418325,
                "question_id": 79418315,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use [`with_entries`][1] to update the `.value` of the object to the value of `.connected`:\r\n\r\n```\r\n.connections | with_entries(.value = .value.connected)\r\n```\r\n\r\n#### [JqPlay Demo](https://jqplay.org/s/OjEdGfD6EpghDMo)\r\n\r\n```json\r\n{\r\n  &quot;7MXYADN-WDXFLSC-3JBG57R-JHZXXYP-ZROJDED-YFQYNCL-WTHPSOQ-KHOLXAP&quot;: false,\r\n  &quot;QYMGEAI-FXM6I6W-FQ574FL-XABEKPV-VK5M42T-AQ7TERD-VVEJ2F7-SFSRYQG&quot;: false\r\n}\r\n```\r\n\r\n\r\n  [1]: https://jqlang.org/manual/#to_entries-from_entries-with_entries",
                "title": "Filtering key and specific value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1738857750,
                "creation_date": 1738857750,
                "answer_id": 79418581,
                "question_id": 79418315,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can use `map_values` :\r\n\r\n```\r\njq &#39;.connections | map_values(.connected)&#39; input.json\r\n```",
                "title": "Filtering key and specific value"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1738889679,
                "creation_date": 1738889679,
                "answer_id": 79419749,
                "question_id": 79418315,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s how to tweak your original code (incase you were wondering):\r\n\r\n```sh\r\n# your original code\r\njq &#39;{ id: .connections | keys[], status: .connections[].connected }&#39;\r\n\r\n# updated code\r\njq &#39;[{ key: .connections | keys[], value: .connections[].connected }] | from_entries&#39;\r\n```\r\n\r\n* [1] Wrap in array, [2] change {id,status} to {key,value}, [3] convert using from_entries  \r\n  \r\n  **jq -n &#39;[{&quot;key&quot;:&quot;a&quot;,&quot;value&quot;:1},{&quot;key&quot;:&quot;b&quot;,&quot;value&quot;:2}] | from_entries&#39;**  \r\n  will output =&gt; **{&quot;a&quot;: 1, &quot;b&quot;: 2}**\r\n",
                "title": "Filtering key and specific value"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 1,
        "last_activity_date": 1738889679,
        "creation_date": 1738852226,
        "last_edit_date": 1738852337,
        "question_id": 79418315,
        "body_markdown": "Using the following json document :\r\n\r\n```\r\n{\r\n  &quot;connections&quot;: {\r\n    &quot;7MXYADN-WDXFLSC-3JBG57R-JHZXXYP-ZROJDED-YFQYNCL-WTHPSOQ-KHOLXAP&quot;: {\r\n      &quot;address&quot;: &quot;&quot;,\r\n      &quot;at&quot;: &quot;0001-01-01T00:00:00Z&quot;,\r\n      &quot;clientVersion&quot;: &quot;&quot;,\r\n      &quot;connected&quot;: false,\r\n      &quot;crypto&quot;: &quot;&quot;,\r\n      &quot;inBytesTotal&quot;: 0,\r\n      &quot;isLocal&quot;: false,\r\n      &quot;outBytesTotal&quot;: 0,\r\n      &quot;paused&quot;: false\r\n    },\r\n    &quot;QYMGEAI-FXM6I6W-FQ574FL-XABEKPV-VK5M42T-AQ7TERD-VVEJ2F7-SFSRYQG&quot;: {\r\n      &quot;address&quot;: &quot;&quot;,\r\n      &quot;at&quot;: &quot;0001-01-01T00:00:00Z&quot;,\r\n      &quot;clientVersion&quot;: &quot;&quot;,\r\n      &quot;connected&quot;: false,\r\n      &quot;crypto&quot;: &quot;&quot;,\r\n      &quot;inBytesTotal&quot;: 0,\r\n      &quot;isLocal&quot;: false,\r\n      &quot;outBytesTotal&quot;: 0,\r\n      &quot;paused&quot;: false\r\n    }\r\n  }\r\n}\r\n```\r\nI would like to filter it using jq get a `&quot;connection.(value?)&quot;: &quot;connection.(value?).connected&quot;` report using only command-line tools:\r\n```\r\n{\r\n   &quot;7MXYADN-WDXFLSC-3JBG57R-JHZXXYP-ZROJDED-YFQYNCL-WTHPSOQ-KHOLXAP&quot;: false,\r\n   &quot;QYMGEAI-FXM6I6W-FQ574FL-XABEKPV-VK5M42T-AQ7TERD-VVEJ2F7-SFSRYQG&quot;: false\r\n}\r\n```\r\nThe best results I catched is below. I can&#39;t find a better way to iterate twice those values correctly and to get rid of &quot;id&quot; &amp; &quot;status&quot; keys.\r\n```\r\n$ jq &#39;{ id: .connections | keys[] , status : .connections[].connected }&#39; &lt; demo.json \r\n{\r\n  &quot;id&quot;: &quot;7MXYADN-WDXFLSC-3JBG57R-JHZXXYP-ZROJDED-YFQYNCL-WTHPSOQ-KHOLXAP&quot;,\r\n  &quot;status&quot;: false\r\n}\r\n{\r\n  &quot;id&quot;: &quot;7MXYADN-WDXFLSC-3JBG57R-JHZXXYP-ZROJDED-YFQYNCL-WTHPSOQ-KHOLXAP&quot;,\r\n  &quot;status&quot;: false\r\n}\r\n{\r\n  &quot;id&quot;: &quot;QYMGEAI-FXM6I6W-FQ574FL-XABEKPV-VK5M42T-AQ7TERD-VVEJ2F7-SFSRYQG&quot;,\r\n  &quot;status&quot;: false\r\n}\r\n{\r\n  &quot;id&quot;: &quot;QYMGEAI-FXM6I6W-FQ574FL-XABEKPV-VK5M42T-AQ7TERD-VVEJ2F7-SFSRYQG&quot;,\r\n  &quot;status&quot;: false\r\n}\r\n```\r\nI think I have to figure what is the `(value?)` thing and how to deal with.\r\n\r\nThank you",
        "link": "https://stackoverflow.com/questions/79418315/filtering-key-and-specific-value",
        "title": "Filtering key and specific value"
    },
    {
        "tags": [
            "json",
            "variables",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1738877165,
                "last_edit_date": 1738877165,
                "creation_date": 1738873434,
                "answer_id": 79419256,
                "question_id": 79419250,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "As `HOUR` is a number, you can use `--argjson` instead of `--arg`. The (only) benefit is that you won&#39;t have to do the conversion from string to number yourself:\r\n\r\n```sh\r\njq --argjson hour &quot;$HOUR&quot; &#39;.energy.todayHours[$hour].priceIncludingVat&#39; &lt; &quot;$JSON&quot;\r\n```",
                "title": "Using jq with the value of a variable as field value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1738917939,
        "creation_date": 1738873292,
        "last_edit_date": 1738917939,
        "question_id": 79419250,
        "body_markdown": "I have a JSON file which I got via curl with hourly energy prices.\r\n\r\nI can output the price for 6 o&#39;clock with\r\n\r\n```js\r\njq &#39;.energy | .todayHours | .[6] | .priceIncludingVat&#39; &lt; &quot;$JSON&quot;\r\n```\r\n\r\nI get the actual hour via date command:  `HOUR=$(date &#39;+%-H&#39;)`\r\n\r\nHow do I get the price for the actual hour? I have no clue how to insert the value of **$HOUR** into the jq query instead of the &quot;**6**&quot;\r\n\r\nThanks a lot!\r\n\r\nPlayed around with different things I found e.g. with the &quot;**--arg**&quot; option but got nowhere, but maybe I tried them a wrong way :-(",
        "link": "https://stackoverflow.com/questions/79419250/using-jq-with-the-value-of-a-variable-as-field-value",
        "title": "Using jq with the value of a variable as field value"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1739017552,
                "last_edit_date": 1739017552,
                "creation_date": 1739017332,
                "answer_id": 79423167,
                "question_id": 79423019,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Your input is not valid due to a few extra commas. Otherwise, using a recursive function will get expected result:\r\n\r\n```\r\njq -c &#39;def down($parents):\r\n           ($parents + .name.data) as $pass |\r\n           { id: .id, name: $pass }, (.children[]|down($pass + &quot;/&quot;));\r\n       .[] | down(&quot;&quot;)&#39; input.json\r\n```",
                "title": "How do I turn tagged recursive object into pairs of tag and absolute path?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1739018536,
        "creation_date": 1739011335,
        "last_edit_date": 1739018536,
        "question_id": 79423019,
        "body_markdown": "How do I turn a recursive object `{ id, name: { data }, children: self[] }` into array of something like `{ id: id, name: name.data | join(&#39;/&#39;) }` ?\r\n\r\nFor example, I&#39;d like to convert given following data\r\n\r\n```json\r\n[\r\n    {&quot;id&quot;: &quot;1&quot;, &quot;name&quot;: { &quot;data&quot;: &quot;foo&quot; }, &quot;children&quot;: [] },\r\n    {&quot;id&quot;: &quot;2&quot;, &quot;name&quot;: { &quot;data&quot;: &quot;bar&quot; }, &quot;children&quot;: [\r\n        {&quot;id&quot;: &quot;4&quot;, &quot;name&quot;: { &quot;data&quot;: &quot;melon&quot; }, &quot;children&quot;: [\r\n            {&quot;id&quot;: &quot;5&quot;, &quot;name&quot;: { &quot;data&quot;: &quot;soda&quot; }, &quot;children&quot;: [] }\r\n        ] }\r\n    ] },\r\n    {&quot;id&quot;: &quot;3&quot;, &quot;name&quot;: { &quot;data&quot;: &quot;baz&quot; }, &quot;children&quot;: [\r\n        {&quot;id&quot;: &quot;6&quot;, &quot;name&quot;: { &quot;data&quot;: &quot;my data&quot; }, &quot;children&quot;: [] }\r\n    ] }\r\n]\r\n```\r\n\r\ninto:\r\n\r\n```json\r\n{&quot;id&quot;: &quot;1&quot;, &quot;name&quot;: &quot;foo&quot;},\r\n{&quot;id&quot;: &quot;2&quot;, &quot;name&quot;: &quot;bar&quot;},\r\n{&quot;id&quot;: &quot;4&quot;, &quot;name&quot;: &quot;bar/melon&quot;},\r\n{&quot;id&quot;: &quot;5&quot;, &quot;name&quot;: &quot;bar/melon/soda&quot;},\r\n{&quot;id&quot;: &quot;3&quot;, &quot;name&quot;: &quot;baz&quot;},\r\n{&quot;id&quot;: &quot;6&quot;, &quot;name&quot;: &quot;baz/my data&quot;},\r\n```\r\n\r\nI don&#39;t mind orders of element, because each `id` of given object have unique value in each input.\r\n\r\nMy attempt is\r\n\r\n```jq\r\n.. | (.children? // empty) | .[] | { id: .id, name: .name.data }\r\n```\r\n\r\nbut this yields name of the single layer (i.e. `foo`, `bar`, `melon`, ...).\r\n",
        "link": "https://stackoverflow.com/questions/79423019/how-do-i-turn-tagged-recursive-object-into-pairs-of-tag-and-absolute-path",
        "title": "How do I turn tagged recursive object into pairs of tag and absolute path?"
    },
    {
        "tags": [
            "json",
            "jq",
            "rounding"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1739172063,
                "creation_date": 1739172063,
                "answer_id": 79426337,
                "question_id": 79426318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can walk through the json object, and if it is a number, multiply by 100, round, and then divide by 100. This will give two decimal positions (not two significant figures). But it produces your expected output, however `a = -0`\r\n\r\n`jq &#39;walk(if type == &quot;number&quot; then (.* 100 | round / 100) else . end)&#39; data.json`",
                "title": "Round numbers anywhere in a JSON document"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1739459885,
                "last_edit_date": 1739459885,
                "creation_date": 1739458568,
                "answer_id": 79436594,
                "question_id": 79426318,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Using the `QUERY |= TRANSFORM` pattern to obtain two decimal positions:\r\n\r\n```sh\r\njq &#39;( .. | numbers ) |= ( . * 100 | round / 100 )&#39;\r\n```\r\n\r\nOr if you don&#39;t want negative zeroes,\r\n\r\n```sh\r\njq &#39;( .. | numbers ) |= ( . * 100 | round / 100 + 0 )&#39;\r\n```",
                "title": "Round numbers anywhere in a JSON document"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1739459885,
        "creation_date": 1739171399,
        "last_edit_date": 1739173823,
        "question_id": 79426318,
        "body_markdown": "I want to compare lots of JSON-Documents without caring about a precision more then 2 digits. I want to round any number in a JSON-Document, but I do not know where in the documents numbers are (but they are not keys).  \r\nI&#39;m currently just using a regex (`sed &#39;s/\\(\\.[0-9][0-9]\\)[0-9]*/\\1/g&#39;`), but like this, `0.9999` or `1.0001` do have the same result.\r\n\r\nI know how to do it when I know in which paths numbers are, but how do I do it, if I do not specify any location of numbers in the document?\r\n\r\nFrom this source:\r\n```json\r\n{\r\n  &quot;a&quot;: -4e-12,\r\n  &quot;b&quot;: {\r\n    &quot;c&quot;: 0.999999999999997,\r\n    &quot;d&quot;: 101.12222222222\r\n  }\r\n}\r\n```\r\nI&#39;d expect a result like:\r\n```json\r\n{\r\n  &quot;a&quot;: 0,\r\n  &quot;b&quot;: {\r\n    &quot;c&quot;: 1,\r\n    &quot;d&quot;: 101.12\r\n  }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/79426318/round-numbers-anywhere-in-a-json-document",
        "title": "Round numbers anywhere in a JSON document"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1739475520,
                "creation_date": 1739475520,
                "answer_id": 79437551,
                "question_id": 79437457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You were close, it&#39;s just that you need to nest your `select`s:\r\n\r\n```jp\r\n.Records[] |\r\nselect(\r\n    .Tags[] |\r\n    select(.Key == &quot;name&quot; and .Value == &quot;uiop&quot;)\r\n) |\r\n.RecType\r\n```",
                "title": "How to JQ select a record where a sub-node matches both values"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1739880946,
                "creation_date": 1739880946,
                "answer_id": 79448219,
                "question_id": 79437457,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternate approach:\r\n\r\n```jq\r\n.Records[] | select( .Tags | from_entries | .name == &quot;uiop&quot; ) | .RecType\r\n```\r\n\r\n---\r\n\r\n`from_entries` turns\r\n\r\n```json\r\n[\r\n    {\r\n        &quot;Key&quot;: &quot;category&quot;,\r\n        &quot;Value&quot;: &quot;bar&quot;\r\n    },\r\n    {\r\n        &quot;Key&quot;: &quot;name&quot;,\r\n        &quot;Value&quot;: &quot;uiop&quot;\r\n    }\r\n]\r\n```\r\n\r\ninto\r\n\r\n```json\r\n{\r\n    &quot;category&quot;: &quot;bar&quot;,\r\n    &quot;name&quot;: &quot;uiop&quot;\r\n}\r\n```",
                "title": "How to JQ select a record where a sub-node matches both values"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1739880946,
        "creation_date": 1739472786,
        "last_edit_date": 1739880833,
        "question_id": 79437457,
        "body_markdown": "I have a JSON similar to the following. I have multiple records, and I&#39;m trying to extract the field value for &quot;RecType&quot; from the record which has the tag where `Key==name` and `Value==uiop`.\r\n\r\n```\r\n{\r\n  &quot;Records&quot;: [\r\n    {\r\n      &quot;RecType&quot;: &quot;type-A&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;category&quot;,\r\n          &quot;Value&quot;: &quot;foo&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;name&quot;,\r\n          &quot;Value&quot;: &quot;qwerty&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;RecType&quot;: &quot;type-B&quot;,\r\n      &quot;Tags&quot;: [\r\n        {\r\n          &quot;Key&quot;: &quot;category&quot;,\r\n          &quot;Value&quot;: &quot;bar&quot;\r\n        },\r\n        {\r\n          &quot;Key&quot;: &quot;name&quot;,\r\n          &quot;Value&quot;: &quot;uiop&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nI&#39;ve been trying to do the command below, but it returns the RecType for BOTH records, presumably because the `Key==Name` appears in both. But what I&#39;m trying to do is pull the record where the Key/Value pair where `name==uiop`; I think what I&#39;m doing is saying &quot;pull all records where there is a `Key==name` AND `Value==uiop` which is not the intent.\r\n```js\r\njq &quot;.Records[] | (select(.Tags[].Key==\\&quot;Name\\&quot;)) \r\n               | (select(.Tags[].Value==\\&quot;uiop\\&quot;))&quot; \r\n               | jq &quot;.RecType&quot; \r\n```\r\nI&#39;ve tried doing an &quot;and&quot; for the two select statements, but it seems to result in booleans, not the matching I&#39;m hoping for.\r\n\r\nAny ideas?\r\n",
        "link": "https://stackoverflow.com/questions/79437457/how-to-jq-select-a-record-where-a-sub-node-matches-both-values",
        "title": "How to JQ select a record where a sub-node matches both values"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1740076360,
                "last_edit_date": 1740076360,
                "creation_date": 1740072969,
                "answer_id": 79455382,
                "question_id": 79455244,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; this whitespace problem that is not mentioned by jq\r\n\r\nThis is not a problem with jq on Linux, so I guess it has to do with the different quoting/escaping rules in Windows/PowerShell. Apparently, adding a space character either after the opening or before the closing code quote seems to work (with jq 1.7.1 in PS 5.1 on Win 10):\r\n```sh\r\necho &#39;{&quot;key&quot;: &quot;value&quot;}&#39; | jq &#39; \\&quot;The input was:\\(.key)\\&quot;&#39;\r\n# space added here -----------^     or here -----------v\r\necho &#39;{&quot;key&quot;: &quot;value&quot;}&#39; | jq &#39;\\&quot;The input was:\\(.key)\\&quot; &#39;\r\n```\r\n```json\r\n&quot;The input was:value&quot;\r\n```",
                "title": "Powershell not handling whitespaces in jq string interpolation command"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1740076360,
        "creation_date": 1740070061,
        "question_id": 79455244,
        "body_markdown": "I&#39;m trying to follow this: https://jqlang.org/manual/#string-interpolation\r\n\r\nIn powershell I try this:\r\n`echo &#39;{&quot;key&quot;: &quot;value&quot;}&#39; | jq &#39;\\&quot;Theinputwas:\\(.key)\\&quot;&#39;`\r\n\r\nAnd get this: `&quot;Theinputwas:value&quot;`\r\n\r\nBut, if I try to add whitespaces in the string: `echo &#39;{&quot;key&quot;: &quot;value&quot;}&#39; | jq &#39;\\&quot;The input was:\\(.key)\\&quot;&#39;`\r\n\r\nI get: `jq: error: syntax error, unexpected end of file, expecting QQSTRING_TEXT or QQSTRING_INTERP_START or QQSTRING_END (Windows cmd shell quoting issues?)`\r\n\r\nI spent a lot of time to finally make the interpolation work on powershell because of the multiple quotes, but now I&#39;m stuck with this whitespace problem that is not mentioned by jq.",
        "link": "https://stackoverflow.com/questions/79455244/powershell-not-handling-whitespaces-in-jq-string-interpolation-command",
        "title": "Powershell not handling whitespaces in jq string interpolation command"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1740569112,
                "creation_date": 1740569112,
                "answer_id": 79469530,
                "question_id": 79469366,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes, you can iterate over `.data[]` implicitly.\r\n```sh\r\n&lt; file.json jq  -r \\\r\n    &#39;.[] | .user as $user | .data[] | [$user.foo, $user.bar, .beq] | @tsv&#39; \r\na1\tb1\td1.1\r\na1\tb1\td1.2\r\na2\tb2\td2.1\r\na2\tb2\td2.2\r\na2\tb2\td2.3\r\n```",
                "title": "how to &quot;unpack&quot; nested json data into csv-like with jq"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1740574951,
                "creation_date": 1740574951,
                "answer_id": 79469833,
                "question_id": 79469366,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "A solution without variables would simply add together the parts coming from the different branches. jq will multiply them out automatically.\r\n```sh\r\n.[] | [.user | .foo, .bar] + (.data[] | [.beq]) | @tsv\r\n```\r\n```\r\na1\tb1\td1.1\r\na1\tb1\td1.2\r\na2\tb2\td2.1\r\na2\tb2\td2.2\r\na2\tb2\td2.3\r\n```\r\n[Demo](https://play.jqlang.org/s/9-oIOJohewkWike)",
                "title": "how to &quot;unpack&quot; nested json data into csv-like with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1740574951,
        "creation_date": 1740565776,
        "question_id": 79469366,
        "body_markdown": "having a data eg like:\r\n```\r\n[\r\n    {\r\n        &quot;user&quot;: {\r\n            &quot;foo&quot;: &quot;a1&quot;,\r\n            &quot;bar&quot;: &quot;b1&quot;\r\n        },\r\n        &quot;data&quot;: [\r\n            {\r\n                &quot;baz&quot;: &quot;c1.1&quot;,\r\n                &quot;beq&quot;: &quot;d1.1&quot;\r\n            },\r\n            {\r\n                &quot;baz&quot;: &quot;c1.2&quot;,\r\n                &quot;beq&quot;: &quot;d1.2&quot;\r\n            }\r\n        ]\r\n\r\n    },\r\n    {\r\n        &quot;user&quot;: {\r\n            &quot;foo&quot;: &quot;a2&quot;,\r\n            &quot;bar&quot;: &quot;b2&quot;\r\n        },\r\n        &quot;data&quot;: [\r\n            {\r\n                &quot;baz&quot;: &quot;c2.1&quot;,\r\n                &quot;beq&quot;: &quot;d2.1&quot;\r\n            },\r\n            {\r\n                &quot;baz&quot;: &quot;c2.2&quot;,\r\n                &quot;beq&quot;: &quot;d2.2&quot;\r\n            },\r\n            {\r\n                &quot;baz&quot;: &quot;c2.3&quot;,\r\n                &quot;beq&quot;: &quot;d2.3&quot;\r\n            }\r\n        ]\r\n    }\r\n]\r\n```\r\ni want to &quot;ungroup&quot; it into a csv-like output \r\n```\r\na1\tb1\td1.1\r\na1\tb1\td1.2\r\na2\tb2\td2.1\r\na2\tb2\td2.2\r\na2\tb2\td2.3\r\n```\r\ni was able to achieve it (https://play.jqlang.org/s/G8PLRDlxx4Ym3-W), but with a `foreach` and assigning the data to some variable - well generally it looks pretty clumsy\r\n```\r\n.[] | .user as $user | foreach .data[] as $d ([]; . ; . + [$user.foo, $user.bar, $d.beq]) | @tsv\r\n```\r\nisn&#39;t there a simpler way?\r\n",
        "link": "https://stackoverflow.com/questions/79469366/how-to-unpack-nested-json-data-into-csv-like-with-jq",
        "title": "how to &quot;unpack&quot; nested json data into csv-like with jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1740633191,
                "creation_date": 1740633191,
                "answer_id": 79471653,
                "question_id": 79471640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```bash\r\njq --arg date &quot;$(date &#39;+%Y-%m-%dT%H:%M&#39;)&quot; &#39;\r\n  select(.time | startswith($date)) | .log\r\n&#39; logs.json\r\n```\r\n\r\nThis Filters logs where `time` matches the current minute and Extracts only the `log` field",
                "title": "How to extract specific fields of JSON with jq based on partially match of one fileld?"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1740641058,
                "creation_date": 1740641058,
                "answer_id": 79471879,
                "question_id": 79471640,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Note that you can also retrieve the current timestamp from within jq using `now`, then reformat it using `strftime`, and follow [@Quantum&#39;s approach](https://stackoverflow.com/a/79471653/2158479) from there, e.g. something along the lines of:\r\n```\r\nselect(.time | startswith(now | strftime(&quot;%Y-%m-%dT%H:%M&quot;)))\r\n```",
                "title": "How to extract specific fields of JSON with jq based on partially match of one fileld?"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1740641058,
        "creation_date": 1740632677,
        "question_id": 79471640,
        "body_markdown": "Grafana log have this format.\r\n\r\n    {\r\n      &quot;log&quot;: &quot;message&quot;,\r\n      &quot;stream&quot;: &quot;stdout&quot;,\r\n      &quot;time&quot;: &quot;2025-02-27T14:52:50.01405178Z&quot;\r\n    }\r\n\r\nI need to extract all fields with the `time` equals to the current minute I can define with\r\n\r\n`--arg date &quot;$(date &#39;+%Y-%m-%dT%H:%M&#39;)&quot;`\r\n\r\n.\r\n\r\nHow to use new `date` variable to select suitable records and then filter it by `log` field?",
        "link": "https://stackoverflow.com/questions/79471640/how-to-extract-specific-fields-of-json-with-jq-based-on-partially-match-of-one-f",
        "title": "How to extract specific fields of JSON with jq based on partially match of one fileld?"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": -1,
                "last_activity_date": 1740668577,
                "creation_date": 1740668577,
                "answer_id": 79473083,
                "question_id": 79473037,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You could use `--slurp` to read in the stream as an array:\r\n\r\n```bash\r\n$ jq -s -r &#39;(&quot;name,aliases&quot;), (.[] | &quot;\\(.name),\\(.aliases[])&quot;)&#39; filename.json\r\nname,aliases\r\npickles,birds\r\ncheese,cheese1\r\ncheese,cheese2\r\n```",
                "title": "Cannot index string with string &quot;name&quot; - CSV output from JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1740668577,
        "creation_date": 1740667606,
        "last_edit_date": 1740668156,
        "question_id": 79473037,
        "body_markdown": "I&#39;m trying to output data in a JSON file I have with a few thousand rows to CSV. The JSON components follow this general pattern:\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;pickles&quot;,\r\n  &quot;aliases&quot;: [\r\n    &quot;birds&quot;\r\n  ]\r\n}\r\n{\r\n  &quot;name&quot;: &quot;cheese&quot;,\r\n  &quot;aliases&quot;: [\r\n    &quot;cheese1&quot;,\r\n    &quot;cheese2&quot;\r\n  ]\r\n}\r\n```\r\nSome of the aliases have more than 1 value (up to four) and some just have one. I&#39;m looking for a CSV output to have two columns - one for name, and one for aliases, where the value in name will be in the name column and value for aliases will be in the aliases column (see below). \r\n```lang-plaintext\r\nname,aliases\r\npickles,birds\r\ncheese, cheese1\r\ncheese, cheese2\r\n```\r\nI&#39;m trying to figure out which jq command(s) to use to get this output, but I&#39;m stuck with the error *Cannot index string with string &quot;name&quot;*\r\n\r\nI&#39;ve tried a few jq commands and I&#39;m getting similar errors. Most recently I tried: \r\n```lang-bash\r\njq -r &#39;.[] | . as {$name} | [$name, .name, .aliases] | @csv&#39; filename.json\r\n```\r\n\r\n",
        "link": "https://stackoverflow.com/questions/79473037/cannot-index-string-with-string-name-csv-output-from-json",
        "title": "Cannot index string with string &quot;name&quot; - CSV output from JSON"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 8002,
                    "reputation": 298159,
                    "user_id": 14122,
                    "user_type": "registered",
                    "accept_rate": 71,
                    "profile_image": "https://www.gravatar.com/avatar/5e2861b08f37fa306fbf5384994af688?s=256&d=identicon&r=PG",
                    "display_name": "Charles Duffy",
                    "link": "https://stackoverflow.com/users/14122/charles-duffy"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1741021469,
                "post_id": 79481609,
                "comment_id": 140172236,
                "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": 1741021544,
                "post_id": 79481609,
                "comment_id": 140172243,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5351266,
                    "reputation": 73064,
                    "user_id": 4265352,
                    "user_type": "registered",
                    "profile_image": "https://lh4.googleusercontent.com/-lzAUc5pYb24/AAAAAAAAAAI/AAAAAAAAAGQ/q3h7bZUnqrs/s256-rj/photo.jpg",
                    "display_name": "axiac",
                    "link": "https://stackoverflow.com/users/4265352/axiac"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1741021642,
                "post_id": 79481609,
                "comment_id": 140172249,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1741021116,
                "creation_date": 1741021116,
                "answer_id": 79481631,
                "question_id": 79481609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The pipe operator (`|`) has higher precedence than you think and the condition in `map(select(...))` is evaluated in a different way that you want.\r\n\r\nYou can fix it by wrapping `.key | test(&quot;^ofasd\\\\.io/arch\\\\.&quot;)` in parenthesis.\r\n\r\nInstead of `join(&quot;\\n&quot;)` I would use the array iterator (`.[]`). Combined with command line option `-r` (raw output), it produces the output that you expect.\r\n\r\n```json\r\n.properties[] \r\n| select(.type == &quot;new.data&quot;) \r\n| .value.labels \r\n| to_entries \r\n| map(select((.key | test(&quot;^ofasd\\\\.io/arch\\\\.&quot;)) and .value == &quot;supported&quot;)) \r\n| map(.key | sub(&quot;^ofasd\\\\.io/arch\\\\.&quot;; &quot;&quot;))\r\n| .[]\r\n```\r\n\r\nIf you apply the iterator earlier, after `to_entries`, there is no need for `map()` any more:\r\n\r\n```jq\r\n.properties[] \r\n| select(.type == &quot;new.data&quot;) \r\n| .value.labels \r\n| to_entries[]\r\n| select((.key | test(&quot;^ofasd\\\\.io/arch\\\\.&quot;)) and .value == &quot;supported&quot;)\r\n| .key\r\n| sub(&quot;^ofasd\\\\.io/arch\\\\.&quot;; &quot;&quot;)\r\n```\r\n\r\nYou can see it working on this [JQ playground](https://play.jqlang.org/s/p2wI4-Vo1xwGiUj).",
                "title": "jq: error Cannot index string with string &quot;value&quot;"
            },
            {
                "up_vote_count": 3,
                "is_accepted": true,
                "score": 3,
                "last_activity_date": 1741073934,
                "last_edit_date": 1741073934,
                "creation_date": 1741021125,
                "answer_id": 79481632,
                "question_id": 79481609,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "In `select(.key | test(&quot;^ofasd\\\\.io/arch\\\\.&quot;) and .value == &quot;supported&quot;)`, you dive into `.key`, make your `test` (which, btw, could be simplified to `startswith(&quot;ofasd.io/arch.&quot;)`), but then there&#39;s no `.value` (inside `.key`) anymore. Wrap it in parens to keep the context: `select((.key | test(&quot;^ofasd\\\\.io/arch\\\\.&quot;)) and .value == &quot;supported&quot;)`\r\n\r\nHere&#39;s a simplified version\r\n```sh\r\n.properties[]\r\n| select(.type == &quot;new.data&quot;)\r\n| .value.labels\r\n| to_entries[]\r\n| select(.value == &quot;supported&quot;).key\r\n| scan(&quot;^ofasd\\\\.io/arch\\\\.\\\\K.*&quot;)\r\n```\r\n```\r\namd64\r\narm64\r\nppc64le\r\n```\r\n[Demo](https://play.jqlang.org/s/XbCPHxaWFy5cVXn)",
                "title": "jq: error Cannot index string with string &quot;value&quot;"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 2,
        "last_activity_date": 1741073934,
        "creation_date": 1741020488,
        "last_edit_date": 1741023214,
        "question_id": 79481609,
        "body_markdown": "Given:\r\n\r\n    MY_JSON=$(cat &lt;&lt;EOF\r\n    {\r\n      &quot;schema&quot;: &quot;my.schema&quot;,\r\n      &quot;properties&quot;: [\r\n        {\r\n          &quot;type&quot;: &quot;new.data&quot;,\r\n          &quot;value&quot;: {\r\n            &quot;labels&quot;: {\r\n              &quot;ofasd.io/arch.amd64&quot;: &quot;supported&quot;,\r\n              &quot;ofasd.io/arch.arm64&quot;: &quot;supported&quot;,\r\n              &quot;ofasd.io/arch.ppc64le&quot;: &quot;supported&quot;,\r\n              &quot;ofasd.io/arch.s390x&quot;: &quot;unsupported&quot;\r\n            }\r\n          }\r\n        }\r\n      ]\r\n    }\r\n    EOF\r\n    )\r\n\r\nI&#39;m trying to filter only &quot;supported&quot; architectures:\r\n\r\n    arches=$(echo &quot;$MY_JSON&quot; | tr -d &#39;\\000-\\031&#39; | jq -r &#39;\r\n    .properties[] \r\n    | select(.type == &quot;new.data&quot;) \r\n    | .value.labels \r\n    | to_entries \r\n    | map(select(.key | test(&quot;^ofasd\\\\.io/arch\\\\.&quot;) and .value == &quot;supported&quot;)) \r\n    | map(.key | sub(&quot;^ofasd\\\\.io/arch\\\\.&quot;; &quot;&quot;)) \r\n    | join(&quot;\\n&quot;)&#39;)\r\n\r\nExpected output:\r\n\r\n    amd64\r\n    arm64\r\n    ppc64le\r\n\r\n\r\nActual output:\r\n\r\n    jq: error (at &lt;stdin&gt;:0): Cannot index string with string &quot;value&quot;\r\n\r\n\r\nCould someone please help me understand what I&#39;m doing wrong?\r\nIt seems like the issue is that ofasd.io/arch.* filtering is not working.\r\nWhen I run:\r\n\r\n    echo &quot;$MY_JSON&quot; | jq -r &#39;\r\n    .properties[] \r\n    | select(.type == &quot;new.data&quot;) \r\n    | .value.labels \r\n    | to_entries \r\n    | map(select(.key | test(&quot;^ofasd.io/arch\\\\.&quot;) and .value == &quot;supported&quot;))&#39;\r\n\r\nI get:\r\n\r\n    echo &quot;$MY_JSON&quot; | jq -r &#39;&#39; failed with status 5\r\n",
        "link": "https://stackoverflow.com/questions/79481609/jq-error-cannot-index-string-with-string-value",
        "title": "jq: error Cannot index string with string &quot;value&quot;"
    },
    {
        "tags": [
            "mapping",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1741098884,
                "last_edit_date": 1741098884,
                "creation_date": 1741090438,
                "answer_id": 79483672,
                "question_id": 79483599,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; What am I missing?\r\n\r\nThe function `get_account_data(account)` defines `account` as a function, so it won&#39;t be evaluated immediately. Thus, when calling `get_account_data` with `.` as the argument, any reference of `account` inside of it will be substituted by the function `.`, and then evaluated in that target context. So, `(.accountnumber | tostring) == (account | tostring)` would become `(.accountnumber | tostring) == (. | tostring)`, with `.` being evaluated to the current context, which by then is different to the items from the input (which has been the context at the time of calling the function). To mitigate this, call the function by value by defining its argument as a variable, i.e. `get_account_data($account)`. This way, it is the value being passed over, so `(.accountnumber | tostring) == ($account | tostring)` becomes `(.accountnumber | tostring) == (&quot;1100&quot; | tostring)` in the first iteration, etc.\r\n\r\nHere&#39;s a simplified version of your approach:\r\n```sh\r\necho &#39;[&quot;1100&quot;, &quot;1234&quot;, &quot;1350&quot;]&#39; | jq --slurpfile accountsdata accounts.json &#39;\r\n\r\n  def get_account_data($account):\r\n    [ $accountsdata[][]\r\n      | select(.accountnumber | tostring == $account)\r\n    ] as $output\r\n    | if $output | length == 0 then {name: &quot;no mapping for \\($account).&quot;}\r\n      else $output[0] end;\r\n\r\n  def get_name:\r\n    get_account_data(.).name;\r\n\r\n  map(get_name)\r\n&#39;\r\n```\r\n```json\r\n[\r\n  &quot;Account A&quot;,\r\n  &quot;no mapping for 1234.&quot;,\r\n  &quot;Account B&quot;\r\n]\r\n```\r\n\r\nHowever, I&#39;d rather create a lookup object which you can query repeatedly without iterating over the accounts data again and again for each input number. For creating such object, you could employ the `INDEX` function, and combine it with `JOIN` to produce the matches, while defaulting with `//` to another expression if there&#39;s no match, as accessing a missing object key (i.e. performing an unsuccessful lookup) always evaluates to `null`:\r\n\r\n```sh\r\necho &#39;[&quot;1100&quot;, &quot;1234&quot;, &quot;1350&quot;]&#39; | jq --slurpfile accountsdata accounts.json &#39;[\r\n  JOIN(INDEX($accountsdata[][]; .accountnumber);\r\n    .[]; .; last.name // &quot;no mapping for \\(first).&quot;\r\n  )\r\n]&#39;\r\n```\r\n```json\r\n[\r\n  &quot;Account A&quot;,\r\n  &quot;no mapping for 1234.&quot;,\r\n  &quot;Account B&quot;\r\n]\r\n```",
                "title": "Mapping from file in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1741098884,
        "creation_date": 1741088992,
        "question_id": 79483599,
        "body_markdown": "I&#39;m trying to use jq to look up data from a json file with account mappings. So given an account number as input, I want to look up it&#39;s name from a file, and it needs to handle the account not being found.\r\n\r\n```bash\r\necho &#39;[&quot;1100&quot;, &quot;1350&quot;]&#39; | jq --slurpfile accountsdata accounts.json &#39;\r\n    def get_account_data(account):\r\n        [$accountsdata[]\r\n        | .[]\r\n        | select((.accountnumber | tostring) == (account | tostring))] as $output\r\n        | if $output | length == 0 then {&quot;name&quot;: (&quot;no mapping for &quot; + account + &quot;.&quot;)} else $output[0] end;\r\n\r\n    def get_name(account):\r\n        get_account_data(account).name;\r\n\r\n. | map(get_name(.))\r\n&#39;\r\n```\r\n\r\nThe account mapping file is as follows:\r\n```json\r\n[\r\n  {\r\n    &quot;accountnumber&quot;: 1100,\r\n    &quot;name&quot;: &quot;Account A&quot;\r\n  },\r\n  {\r\n    &quot;accountnumber&quot;: 1350,\r\n    &quot;name&quot;: &quot;Account B&quot;\r\n  },\r\n  {\r\n    &quot;accountnumber&quot;: 1356,\r\n    &quot;name&quot;: &quot;Account C&quot;\r\n  }\r\n]\r\n```\r\n\r\nExpected output:\r\n```\r\n[\r\n  &quot;Account A&quot;,\r\n  &quot;Account B&quot;\r\n]\r\n```\r\n\r\nActual output:\r\n```\r\n[\r\n  &quot;no mapping for 1100.&quot;,\r\n  &quot;no mapping for 1350.&quot;\r\n]\r\n```\r\n\r\nHowever, if I change the call from `. | map(get_name(.))` to `. | map(get_name(&quot;1100&quot;))` (i.e. hardcode the `accountnumber`), I get the expected\r\n\r\n```\r\n[\r\n  &quot;Account A&quot;,\r\n  &quot;Account A&quot;\r\n]\r\n```\r\n\r\nWhat am I missing?",
        "link": "https://stackoverflow.com/questions/79483599/mapping-from-file-in-jq",
        "title": "Mapping from file in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1741173187,
                "last_edit_date": 1741173187,
                "creation_date": 1741170929,
                "answer_id": 79486193,
                "question_id": 79486152,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "`.db` is an array, so you need `.db[]` to iterate over its items. `.db[].tables[]` suffices to reach the table level. For the columns, descend further into `.cols[]`. No need to go deeper (or use a recursive descent) as you only need the respective `.name` values.\r\n```sh\r\n[\r\n  .db[].tables[] | {type: &quot;TABLE&quot;, name},\r\n  {type: &quot;COLUMN&quot;, name: .cols[].name, ofTable: .name}\r\n]\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;type&quot;: &quot;TABLE&quot;,\r\n    &quot;name&quot;: &quot;tblFoo&quot;\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;COLUMN&quot;,\r\n    &quot;name&quot;: &quot;created&quot;,\r\n    &quot;ofTable&quot;: &quot;tblFoo&quot;\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;COLUMN&quot;,\r\n    &quot;name&quot;: &quot;updated&quot;,\r\n    &quot;ofTable&quot;: &quot;tblFoo&quot;\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;COLUMN&quot;,\r\n    &quot;name&quot;: &quot;username&quot;,\r\n    &quot;ofTable&quot;: &quot;tblFoo&quot;\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;TABLE&quot;,\r\n    &quot;name&quot;: &quot;tblBar&quot;\r\n  },\r\n  {\r\n    &quot;type&quot;: &quot;COLUMN&quot;,\r\n    &quot;name&quot;: &quot;created&quot;,\r\n    &quot;ofTable&quot;: &quot;tblBar&quot;\r\n  }\r\n]\r\n```\r\n[Demo](https://play.jqlang.org/s/XcmfYfcraIUEM7o)\r\n\r\nNote that jq is geared towards processing JSON data logically, therefore its formatting capabilities are limited. You basically have two options: a pretty-printed output (see above), or a compacted one with all insignificant whitespace characters (including newlines) removed. You could get closer to your desired formatting by applying the latter using the `--compact-output` (or `-c`) flag while omitting the outer array brackets to get a stream of JSON objects, each printed on its own line. Note the missing outer brackets, and the missing commas after each (but the last) line.\r\n```json\r\n{&quot;type&quot;:&quot;TABLE&quot;,&quot;name&quot;:&quot;tblFoo&quot;}\r\n{&quot;type&quot;:&quot;COLUMN&quot;,&quot;name&quot;:&quot;created&quot;,&quot;ofTable&quot;:&quot;tblFoo&quot;}\r\n{&quot;type&quot;:&quot;COLUMN&quot;,&quot;name&quot;:&quot;updated&quot;,&quot;ofTable&quot;:&quot;tblFoo&quot;}\r\n{&quot;type&quot;:&quot;COLUMN&quot;,&quot;name&quot;:&quot;username&quot;,&quot;ofTable&quot;:&quot;tblFoo&quot;}\r\n{&quot;type&quot;:&quot;TABLE&quot;,&quot;name&quot;:&quot;tblBar&quot;}\r\n{&quot;type&quot;:&quot;COLUMN&quot;,&quot;name&quot;:&quot;created&quot;,&quot;ofTable&quot;:&quot;tblBar&quot;}\r\n```\r\n[Demo](https://play.jqlang.org/s/gS34sutBTAfQznK)\r\n\r\nTo exactly reproduce your desired formatting, you&#39;d need to compose it manually as a string. But this comes with a huge error-inviting complexity trade-off, and is thus, generally speaking, not recommended. This would be one way, using the `--raw-output` (or `-r`) flag to strip the JSON encoding from the string lines composed:\r\n```sh\r\n[\r\n  .db[].tables[] | {type: &quot;TABLE&quot;, name},\r\n  {type: &quot;COLUMN&quot;, name: .cols[].name, ofTable: .name} | @json\r\n]\r\n| .[:-1][] += &quot;,&quot; | &quot;[&quot;, .[], &quot;]&quot;\r\n```\r\n```json\r\n[\r\n{&quot;type&quot;:&quot;TABLE&quot;,&quot;name&quot;:&quot;tblFoo&quot;},\r\n{&quot;type&quot;:&quot;COLUMN&quot;,&quot;name&quot;:&quot;created&quot;,&quot;ofTable&quot;:&quot;tblFoo&quot;},\r\n{&quot;type&quot;:&quot;COLUMN&quot;,&quot;name&quot;:&quot;updated&quot;,&quot;ofTable&quot;:&quot;tblFoo&quot;},\r\n{&quot;type&quot;:&quot;COLUMN&quot;,&quot;name&quot;:&quot;username&quot;,&quot;ofTable&quot;:&quot;tblFoo&quot;},\r\n{&quot;type&quot;:&quot;TABLE&quot;,&quot;name&quot;:&quot;tblBar&quot;},\r\n{&quot;type&quot;:&quot;COLUMN&quot;,&quot;name&quot;:&quot;created&quot;,&quot;ofTable&quot;:&quot;tblBar&quot;}\r\n]\r\n```\r\n[Demo](https://play.jqlang.org/s/3nOf_CmcUwXntKs)",
                "title": "Using jq, how to transform a nested data structure into a &quot;flat&quot; command-like sequence"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1741173187,
        "creation_date": 1741170397,
        "question_id": 79486152,
        "body_markdown": "I have the following JSON structure that represents a database schema:\r\n\r\n```json\r\n{\r\n  &quot;db&quot;: [\r\n    {\r\n      &quot;tables&quot;: [\r\n        {\r\n          &quot;name&quot;: &quot;tblFoo&quot;,\r\n          &quot;cols&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;created&quot;,\r\n              &quot;types&quot;: [ { &quot;data_type&quot;: &quot;timestamp&quot; } ]\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;updated&quot;,\r\n              &quot;types&quot;: [ { &quot;data_type&quot;: &quot;timestamp&quot; } ]\r\n            },\r\n            {\r\n              &quot;name&quot;: &quot;username&quot;,\r\n              &quot;types&quot;: [ { &quot;data_type&quot;: &quot;timestamp&quot; } ]\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;name&quot;: &quot;tblBar&quot;,\r\n          &quot;cols&quot;: [\r\n            {\r\n              &quot;name&quot;: &quot;created&quot;,\r\n              &quot;types&quot;: [ { &quot;data_type&quot;: &quot;timestamp&quot; } ]\r\n            },\r\n…\r\n```\r\n\r\netc., you get the idea.\r\nI need it transformed to a sequential set of json &quot;commands&quot; where every table _and_ its columns is a separate line, like so:\r\n\r\n```json\r\n[\r\n{&quot;type&quot;: &quot;TABLE&quot;, name:&quot;tblFoo&quot;},\r\n{&quot;type&quot;: &quot;COLUMN&quot;, name:&quot;created&quot;, ofTable: &quot;tblFoo&quot;},\r\n{&quot;type&quot;: &quot;COLUMN&quot;, name:&quot;updated&quot;, ofTable: &quot;tblFoo&quot;},\r\n…\r\n{&quot;type&quot;: &quot;TABLE&quot;, name:&quot;tblBar&quot;},\r\n{&quot;type&quot;: &quot;COLUMN&quot;, name:&quot;created&quot;, ofTable: &quot;tblBar&quot;},\r\n\r\n]\r\n```\r\n\r\nI just can&#39;t wrap my head around it. I&#39;ve tried `.db.tables[] | map(…)` at first but this obviously only creates an array of the first level, tables, and I can&#39;t add/inject the column definitions into the same level.\r\n\r\nThen I&#39;ve tried iterating over the columns like `.db.tables[].cols[]` with the recursive decent operator, but again the resulting list is only those of the columns and I fail to add/inject the table ones into the outgoing list.\r\n\r\nCan you help me please getting on the right track?",
        "link": "https://stackoverflow.com/questions/79486152/using-jq-how-to-transform-a-nested-data-structure-into-a-flat-command-like-se",
        "title": "Using jq, how to transform a nested data structure into a &quot;flat&quot; command-like sequence"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1741433699,
                "creation_date": 1741433699,
                "answer_id": 79494313,
                "question_id": 79494219,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `fromjson` to parse json text:\r\n\r\n```\r\n$ skopeo inspect docker://ghcr.io/ublue-os/bluefin-dx:gts | jq &#39;.Labels.&quot;dev.hhd.rechunk.info&quot; | fromjson.packages&#39;\r\n{\r\n  &quot;libgcc&quot;: &quot;14.2.1-3.fc40&quot;\r\n}\r\n```",
                "title": "Extract &quot;packages&quot; key from skopeo output with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1741433699,
        "creation_date": 1741429176,
        "question_id": 79494219,
        "body_markdown": "I&#39;m trying to extract the list of packages from skopeo inspect output, but this does not seem to work:\r\n\r\n```\r\n❯ skopeo inspect docker://ghcr.io/ublue-os/bluefin-dx:gts | jq &#39;.Labels.&quot;dev.hhd.rechunk.info&quot;.packages&#39;\r\n```\r\n\r\nThe above works without the &quot;.packages&quot; part and the content is:\r\n\r\n```\r\n❯ skopeo inspect docker://ghcr.io/ublue-os/bluefin-dx:gts | jq &#39;.Labels.&quot;dev.hhd.rechunk.info&quot;&#39;\r\n&quot;{\\&quot;version\\&quot;: 2, \\&quot;uniq\\&quot;: \\&quot;gts-40.20250305\\&quot;, \\&quot;packages\\&quot;: {\\&quot;libgcc\\&quot;: \\&quot;14.2.1-3.fc40\\&quot;, .....\r\n```\r\n\r\nHow can I ask jq to go into this object and extract just the &quot;packages&quot; part?",
        "link": "https://stackoverflow.com/questions/79494219/extract-packages-key-from-skopeo-output-with-jq",
        "title": "Extract &quot;packages&quot; key from skopeo output with jq"
    },
    {
        "tags": [
            "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": 1741609947,
                "post_id": 79497997,
                "comment_id": 140199485,
                "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": 1741610566,
                "post_id": 79497997,
                "comment_id": 140199551,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4490449,
                    "reputation": 134,
                    "user_id": 4086391,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/AuzTG.png?s=256",
                    "display_name": "sjoblomj",
                    "link": "https://stackoverflow.com/users/4086391/sjoblomj"
                },
                "reply_to_user": {
                    "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": 1741610669,
                "post_id": 79497997,
                "comment_id": 140199561,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1741611433,
                "creation_date": 1741611433,
                "answer_id": 79498058,
                "question_id": 79497997,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "From first principles:\r\n\r\n```\r\nreduce .[] as $x ( {index: {}, result: [], n: -1};\r\n   $x.ref as $ref\r\n   | if .index[$ref]\r\n     then .result += [ $x + {num: .index[$ref]} ]\r\n     else .n += 1\r\n     | .index[$ref] = .n \r\n     | .result += [ $x + {num: .n} ]\r\n     end\r\n)\r\n| .result\r\n\r\n```",
                "title": "Assigning incrementing numbers in order-preserving way"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1741612984,
                "creation_date": 1741612984,
                "answer_id": 79498125,
                "question_id": 79497997,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Keep a lookup table for the `.ref` values, and determine the next value by its size (`length`):\r\n\r\n```sh\r\nreduce .[] as $i ({};\r\n  .num |= (.[$i.ref] //= length) | .arr += [$i + {num: .num[$i.ref]}]\r\n) | .arr\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;ref&quot;: &quot;e13bb9&quot;,\r\n    &quot;name&quot;: &quot;One&quot;,\r\n    &quot;num&quot;: 0\r\n  },\r\n  {\r\n    &quot;ref&quot;: &quot;11b8cc&quot;,\r\n    &quot;name&quot;: &quot;Two&quot;,\r\n    &quot;num&quot;: 1\r\n  },\r\n  {\r\n    &quot;ref&quot;: &quot;e13bb9&quot;,\r\n    &quot;name&quot;: &quot;Three&quot;,\r\n    &quot;num&quot;: 0\r\n  }\r\n]\r\n```\r\n[Demo](https://play.jqlang.org/s/kEMr-9lKQJBi1Ls)",
                "title": "Assigning incrementing numbers in order-preserving way"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1741612984,
        "creation_date": 1741609790,
        "last_edit_date": 1741612168,
        "question_id": 79497997,
        "body_markdown": "Using jq, I want to assign an incrementing number `num` to each element in the order they appear in the input, but keep the same number for elements that share a `ref` value with other elements.\r\n\r\nSo considering this input,\r\n```json\r\n[\r\n  {&quot;ref&quot;: &quot;e13bb9&quot;, &quot;name&quot;: &quot;One&quot;},\r\n  {&quot;ref&quot;: &quot;11b8cc&quot;, &quot;name&quot;: &quot;Two&quot;},\r\n  {&quot;ref&quot;: &quot;e13bb9&quot;, &quot;name&quot;: &quot;Three&quot;}\r\n]\r\n```\r\nI would want the following output:\r\n\r\n```json\r\n[\r\n  {&quot;ref&quot;: &quot;e13bb9&quot;, &quot;name&quot;: &quot;One&quot;, &quot;num&quot;: 0},\r\n  {&quot;ref&quot;: &quot;11b8cc&quot;, &quot;name&quot;: &quot;Two&quot;, &quot;num&quot;: 1},\r\n  {&quot;ref&quot;: &quot;e13bb9&quot;, &quot;name&quot;: &quot;Three&quot;, &quot;num&quot;: 0}\r\n]\r\n```\r\n\r\nIn other words, the element with `&quot;name&quot; == &quot;One&quot;` should have `&quot;num&quot;: 0` (since it is the first element), then the element with `&quot;name&quot; == &quot;Two&quot;` should have `&quot;num&quot;: 1` (since it is the second element, and its `ref` value has not occurred before), then the element with `&quot;name&quot; == &quot;Three&quot;` should again have `&quot;num&quot;: 0` (since it has the same `ref` as the element with `&quot;name&quot; == &quot;One&quot;`, and should thus share its `num`).\r\n\r\nI tried to use `group_by(.ref)` to group the elements with the same `ref` together, but that does not preserve the order in which they occur in the input; in other words, `&quot;name&quot; == &quot;Two&quot;` came before `&quot;name&quot; == &quot;One&quot;` and `&quot;name&quot; == &quot;Three&quot;`.",
        "link": "https://stackoverflow.com/questions/79497997/assigning-incrementing-numbers-in-order-preserving-way",
        "title": "Assigning incrementing numbers in order-preserving way"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 922778,
                    "reputation": 157,
                    "user_id": 954145,
                    "user_type": "registered",
                    "profile_image": "https://graph.facebook.com/1080573872/picture?type=large",
                    "display_name": "Robert",
                    "link": "https://stackoverflow.com/users/954145/robert"
                },
                "reply_to_user": {
                    "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": 1741783332,
                "post_id": 79503504,
                "comment_id": 140209212,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1741788524,
                "last_edit_date": 1741788524,
                "creation_date": 1741786239,
                "answer_id": 79503758,
                "question_id": 79503504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "&gt; My goal is to get only the &quot;scale&quot; and &quot;energy&quot; values from &quot;forecast.solar&quot;, and also other elements on the same level as &quot;forecast&quot;, such as &quot;siteTitle&quot;.\r\n\r\nAs you want to keep `.scale` and all siblings that contain `.energy` (IIUC), you could also just `del(.timestamp)` instead, then filter for `values` to eliminate empty results.\r\n```sh\r\n.result | .forecast |= (.solar | del(.timeseries) | values)\r\n```\r\n\r\nFor your sample containing a non-empty `.forecast`, this produces\r\n```json\r\n{\r\n  &quot;forecast&quot;: {\r\n    &quot;scale&quot;: 0.5792918589105848,\r\n    &quot;today&quot;: {\r\n      &quot;energy&quot;: 21142.72731634481,\r\n      &quot;complete&quot;: true\r\n    },\r\n    &quot;tomorrow&quot;: {\r\n      &quot;energy&quot;: 36320.01044880075,\r\n      &quot;complete&quot;: true\r\n    },\r\n    &quot;dayAfterTomorrow&quot;: {\r\n      &quot;energy&quot;: 12222.739005817713,\r\n      &quot;complete&quot;: false\r\n    }\r\n  },\r\n  &quot;siteTitle&quot;: &quot;KOG&quot;\r\n}\r\n```\r\n\r\nFor your other samples, one with no `.forecast`, the other one with it being an empty object, it produces\r\n```json\r\n{\r\n  &quot;siteTitle&quot;: &quot;KOG&quot;\r\n}\r\n```\r\n\r\n[Demo](https://play.jqlang.org/s/MczL5t509oZuQ7J) for all three cases.",
                "title": "Include element only if present"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1741788524,
        "creation_date": 1741780437,
        "last_edit_date": 1741783284,
        "question_id": 79503504,
        "body_markdown": "I am implementing a program accessing a REST API, which can be filtered server-side by passing in a jq-statement. My issue is with writing a jq filter that includes an element called &quot;forecast.forecast&quot; in the output only if it has content in the input, and also filters the content.\r\n\r\nHere is an example of the input with forecast being present:\r\n\r\n    {\r\n       &quot;result&quot;:{\r\n          &quot;forecast&quot;:{\r\n             &quot;solar&quot;:{\r\n                &quot;scale&quot;:0.5792918589105848,\r\n                &quot;today&quot;:{\r\n                   &quot;energy&quot;:21142.72731634481,\r\n                   &quot;complete&quot;:true\r\n                },\r\n                &quot;tomorrow&quot;:{\r\n                   &quot;energy&quot;:36320.01044880075,\r\n                   &quot;complete&quot;:true\r\n                },\r\n                &quot;dayAfterTomorrow&quot;:{\r\n                   &quot;energy&quot;:12222.739005817713,\r\n                   &quot;complete&quot;:false\r\n                },\r\n                &quot;timeseries&quot;:[\r\n                   {\r\n                      &quot;ts&quot;:&quot;2025-03-12T00:00:00+01:00&quot;,\r\n                      &quot;val&quot;:0\r\n                   }\r\n                ]\r\n             }\r\n          },\r\n          &quot;siteTitle&quot;:&quot;KOG&quot;\r\n       }\r\n    }\r\n\r\nHere is an example with forecast being empty:\r\n\r\n    {\r\n       &quot;result&quot;:{\r\n          &quot;forecast&quot;:{},\r\n          &quot;siteTitle&quot;:&quot;KOG&quot;\r\n       }\r\n    }\r\n\r\nThe &quot;forecast&quot; element may also be not present at all:\r\n\r\n    {\r\n       &quot;result&quot;:{\r\n          &quot;siteTitle&quot;:&quot;KOG&quot;\r\n       }\r\n    }\r\n\r\nMy goal is to get only the &quot;scale&quot; and &quot;energy&quot; values from &quot;forecast.solar&quot;, and also other elements on the same level as &quot;forecast&quot;, such as &quot;siteTitle&quot;.\r\n\r\nHere an example that gives me the &quot;siteTitle&quot; and the &quot;scale&quot;:\r\n\r\n    {result:{siteTitle:.siteTitle,forecast:{solar:{scale:.forecast.solar.scale}}}}\r\n\r\nHowever, even if the &quot;scale&quot; value is not present in the input, the output contains it as null:\r\n\r\n    {\r\n       &quot;result&quot;:{\r\n          &quot;forecast&quot;:{\r\n             &quot;solar&quot;:{\r\n                &quot;scale&quot;:null\r\n             }\r\n          },\r\n          &quot;siteTitle&quot;:&quot;KOG&quot;\r\n       }\r\n    }\r\n\r\nI already tried using select to check if &quot;forecast.solar&quot; is present, but with what I came up with, the complete result is empty when &quot;forecast.solar&quot; is not present.\r\n\r\n    jq={result:{siteTitle:.siteTitle,forecast:(.forecast|select(.solar?)|{solar:{scale:.solar.scale}})}}\r\n\r\nThis returns:\r\n\r\n    jq: empty result\r\n\r\nHow does the statement need to look like to include fields like the &quot;siteTitle&quot;, even if &quot;forecast.solar&quot; is not present?",
        "link": "https://stackoverflow.com/questions/79503504/include-element-only-if-present",
        "title": "Include element only if present"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1742462444,
                "creation_date": 1742462444,
                "answer_id": 79522435,
                "question_id": 79522387,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use `select` to filter for user-2 then use the `+=` operator to append to the videos array:\r\n\r\n```\r\n$ jq &#39;.[] | select(.user == &quot;user-2&quot;).videos += [{&quot;key&quot;:&quot;key3&quot;,&quot;url&quot;:&quot;url3&quot;}]&#39;\r\n{\r\n  &quot;user&quot;: &quot;user-1&quot;,\r\n  &quot;videos&quot;: [\r\n    {\r\n      &quot;key&quot;: &quot;key1&quot;,\r\n      &quot;url&quot;: &quot;url1&quot;\r\n    }\r\n  ]\r\n}\r\n{\r\n  &quot;user&quot;: &quot;user-2&quot;,\r\n  &quot;videos&quot;: [\r\n    {\r\n      &quot;key&quot;: &quot;key2&quot;,\r\n      &quot;url&quot;: &quot;url2&quot;\r\n    },\r\n    {\r\n      &quot;key&quot;: &quot;key3&quot;,\r\n      &quot;url&quot;: &quot;url3&quot;\r\n    }\r\n  ]\r\n}\r\n```",
                "title": "How to insert JSON into table beside a specific value using JQ"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1742479366,
                "creation_date": 1742479366,
                "answer_id": 79523189,
                "question_id": 79522387,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Note that for this and similar (but not necessarily all) tasks it&#39;d more efficient to store the outer array as an object, with the unique keys used as field names. You can get to this structure by applying `INDEX(.user)` to your original input, resulting in:\r\n```json\r\n{\r\n  &quot;user-1&quot;: {\r\n    &quot;user&quot;: &quot;user-1&quot;,\r\n    &quot;videos&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;,\r\n        &quot;url&quot;: &quot;url1&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;user-2&quot;: {\r\n    &quot;user&quot;: &quot;user-2&quot;,\r\n    &quot;videos&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;,\r\n        &quot;url&quot;: &quot;url2&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\nDepending on how you want to access the data in your other use-cases, you could even get rid of the `.user` entries altogether. But either way, with the keys in place, your original task is reduced to just `.&quot;user-2&quot;.videos += [{key: &quot;key3&quot;, url: &quot;url3&quot;}]`, which avoids iterating over all items using `.[]` (or `map` which internally also just uses `.[]`) which gets more expensive the more items the array contains. Accessing a given key directly, with `.&quot;user-2&quot;` in this case, is carried out in constant time, regardless of the total number of items. Here&#39;s how you&#39;d also use the `--arg` options to import the values from the calling environment:\r\n```sh\r\njq --arg user &quot;user-2&quot; --arg key &quot;key3&quot; --arg url &quot;url3&quot; &#39;\r\n  .[$user].videos += [{$key, $url}]\r\n&#39;\r\n```\r\n```json\r\n{\r\n  &quot;user-1&quot;: {\r\n    &quot;user&quot;: &quot;user-1&quot;,\r\n    &quot;videos&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key1&quot;,\r\n        &quot;url&quot;: &quot;url1&quot;\r\n      }\r\n    ]\r\n  },\r\n  &quot;user-2&quot;: {\r\n    &quot;user&quot;: &quot;user-2&quot;,\r\n    &quot;videos&quot;: [\r\n      {\r\n        &quot;key&quot;: &quot;key2&quot;,\r\n        &quot;url&quot;: &quot;url2&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;: &quot;key3&quot;,\r\n        &quot;url&quot;: &quot;url3&quot;\r\n      }\r\n    ]\r\n  }\r\n}\r\n```\r\n[Demo](https://play.jqlang.org/s/Z_qKSBfEf7FfUct)",
                "title": "How to insert JSON into table beside a specific value using JQ"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1742481418,
        "creation_date": 1742461282,
        "last_edit_date": 1742481418,
        "question_id": 79522387,
        "body_markdown": "In this JSON snippet\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;user&quot;:&quot;user-1&quot;,\r\n    &quot;videos&quot;:[\r\n      {\r\n        &quot;key&quot;:&quot;key1&quot;,\r\n        &quot;url&quot;:&quot;url1&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;user&quot;:&quot;user-2&quot;,\r\n    &quot;videos&quot;:[\r\n      {\r\n        &quot;key&quot;:&quot;key2&quot;,\r\n        &quot;url&quot;:&quot;url2&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI want to add `{&quot;key&quot;:&quot;key3&quot;,&quot;url&quot;:&quot;url3&quot;}` under `videos` that is beside `&quot;user&quot;:&quot;user-2&quot;`\r\n\r\nideally it will look like this:\r\n\r\n```json\r\n[\r\n  {\r\n    &quot;user&quot;:&quot;user-1&quot;,\r\n    &quot;videos&quot;:[\r\n      {\r\n        &quot;key&quot;:&quot;key1&quot;,\r\n        &quot;title&quot;:&quot;title1&quot;\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;user&quot;:&quot;user-2&quot;,\r\n    &quot;videos&quot;:[\r\n      {\r\n        &quot;key&quot;:&quot;key2&quot;,\r\n        &quot;title&quot;:&quot;title2&quot;\r\n      },\r\n      {\r\n        &quot;key&quot;:&quot;key3&quot;,\r\n        &quot;title&quot;:&quot;title3&quot;\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n\r\nI tried \r\n```json\r\njq &#39;. += [{&quot;user&quot;:&quot;user-2&quot;,&quot;videos&quot;:[{&quot;key&quot;:&quot;key3&quot;,&quot;title&quot;:&quot;title3&quot;}]}]&#39;\r\n``` \r\nbut it adds a whole new user-2",
        "link": "https://stackoverflow.com/questions/79522387/how-to-insert-json-into-table-beside-a-specific-value-using-jq",
        "title": "How to insert JSON into table beside a specific value using JQ"
    },
    {
        "tags": [
            "sorting",
            "jq",
            "numeric"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1743071970,
                "post_id": 79538297,
                "comment_id": 140268975,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 334861,
                    "reputation": 19253,
                    "user_id": 661589,
                    "user_type": "registered",
                    "accept_rate": 79,
                    "profile_image": "https://www.gravatar.com/avatar/54d910c2365b1e965a4007607a71b162?s=256&d=identicon&r=PG",
                    "display_name": "Gavriel",
                    "link": "https://stackoverflow.com/users/661589/gavriel"
                },
                "reply_to_user": {
                    "account_id": 1020072,
                    "reputation": 243994,
                    "user_id": 1030675,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/957956ce51706d03f19a4dc85a767bb1?s=256&d=identicon&r=PG",
                    "display_name": "choroba",
                    "link": "https://stackoverflow.com/users/1030675/choroba"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1743159109,
                "post_id": 79538297,
                "comment_id": 140273311,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1743145728,
                "last_edit_date": 1743145728,
                "creation_date": 1743079039,
                "answer_id": 79538878,
                "question_id": 79538297,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "### The wrong goal\r\n\r\nWhile the encoding of a JSON object inherently reveals some ordering of its items, JSON objects actually don&#39;t convey the notion of an order (only JSON arrays do). So, forcefully inducing a specific order onto its items is ephemeral at best. It may hold for the document&#39;s current representation, but any subsequent processor could very well just disregard this configuration, and break this order without reason, without giving any notice, and, most importantly, without violating the JSON specs. Therefore, relying on a specific order apparent in a given encoding (the actual representation as a stream of characters) is a computational bug, and should therefore be discouraged.\r\n\r\n### But if you must\r\n\r\nThat said, using `jq`, you can turn the items of an object into an array of key-value pairs using `to_entries`, sort that array by the numeric representation of each `.key` using `sort_by` and `to_number`, and then re-compose the object based on that array using `from_entries`, which `jq` will perform in the order of the array. Finally, apply this function composition to both the root node `.` and its children `.[]`.\r\n\r\n### A word of caution\r\n\r\nAgain, note that this side-effect is just the actual behavior of [jqlang/jq](https://github.com/jqlang/jq) (but not of [itchyny/gojq](https://github.com/itchyny/gojq), for example), and is nowhere guaranteed to stay that way. However, the current and several latest versions of jqlang/jq (at least until v1.7) seem to be implemented this way.\r\n\r\n```sh\r\n(.[], .) |= (to_entries | sort_by(.key | tonumber) | from_entries)\r\n```\r\n```json\r\n{\r\n  &quot;1&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    &quot;2&quot;: {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    &quot;10&quot;: {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    }\r\n  },\r\n  &quot;2&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    &quot;2&quot;: {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    &quot;10&quot;: {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    }\r\n  },\r\n  &quot;10&quot;: {\r\n    &quot;1&quot;: {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    &quot;2&quot;: {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    },\r\n    &quot;10&quot;: {\r\n      &quot;foo&quot;: &quot;bar&quot;\r\n    }\r\n  }\r\n}\r\n```\r\n[Demo](https://play.jqlang.org/s/zhk3_qVlLXezRMG)",
                "title": "sort json object numerically by key"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": -3,
        "last_activity_date": 1743159541,
        "creation_date": 1743065144,
        "last_edit_date": 1743159541,
        "question_id": 79538297,
        "body_markdown": "I have the following json format. It&#39;s basically a representation of the calendar:\r\n\r\n    {&quot;month1&quot;: {&quot;day1&quot;:{...}, &quot;day2&quot;: {...}}, &quot;month2&quot;: {...}}\r\n\r\nI&#39;d like to sort it such that both the months and the days will be in numeric order. The below input is the output of `jq -S`, but as you see it&#39;s sorted like: 1,10,2, and I&#39;d like to sort it like 1,2,10. How can I do that with jq?\r\n\r\n\r\nInput:\r\n\r\n    {\r\n        &quot;1&quot;:{&quot;1&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;10&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;2&quot;:{&quot;foo&quot;:&quot;bar&quot;}},\r\n        &quot;10&quot;:{&quot;1&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;10&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;2&quot;:{&quot;foo&quot;:&quot;bar&quot;}},\r\n        &quot;2&quot;:{&quot;1&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;10&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;2&quot;:{&quot;foo&quot;:&quot;bar&quot;}}\r\n    }\r\n\r\nExpected output:\r\n\r\n    {\r\n        &quot;1&quot;:{&quot;1&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;2&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;10&quot;:{&quot;foo&quot;:&quot;bar&quot;}},\r\n        &quot;2&quot;:{&quot;1&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;2&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;10&quot;:{&quot;foo&quot;:&quot;bar&quot;}},\r\n        &quot;10&quot;:{&quot;1&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;2&quot;:{&quot;foo&quot;:&quot;bar&quot;},&quot;10&quot;:{&quot;foo&quot;:&quot;bar&quot;}}\r\n    }\r\n\r\nupdate:\r\n\r\nI want to have this sorting for 2 reasons:\r\n1. it&#39;s nice to have it ordered in the &quot;human logical&quot; way.\r\n2. I&#39;d like to be able to diff 2 similar jsons in this format. (I guess this would work even with the current order) \r\n\r\nFor all the downvoters: `jq -S` wasn&#39;t invented by me and it does sort the keys of an object. Many use jq as a json prettifier/formatter/identer, so I think this is a legitimate use-case. You don&#39;t have to sort your json objects, that&#39;s fine, but why down-voting?",
        "link": "https://stackoverflow.com/questions/79538297/sort-json-object-numerically-by-key",
        "title": "sort json object numerically by key"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 28020964,
                    "reputation": 1364,
                    "user_id": 21401783,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/996ad2cce9f2c7ce625441792ae67659?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Dinux",
                    "link": "https://stackoverflow.com/users/21401783/dinux"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1743220664,
                "post_id": 79542775,
                "comment_id": 140276156,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 673865,
                    "reputation": 5739,
                    "user_id": 889053,
                    "user_type": "registered",
                    "accept_rate": 38,
                    "profile_image": "https://www.gravatar.com/avatar/3e26b08aa9c9bff40d6dab7b98680bf4?s=256&d=identicon&r=PG",
                    "display_name": "Christian Bongiorno",
                    "link": "https://stackoverflow.com/users/889053/christian-bongiorno"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1743616853,
                "post_id": 79542775,
                "comment_id": 140291615,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1743222267,
                "last_edit_date": 1743222267,
                "creation_date": 1743221824,
                "answer_id": 79542785,
                "question_id": 79542775,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Iterate over each item in question using `.States[]`, and update `|=` them  accordingly.\r\n\r\nTo change the field name `Cities` into `City`, create a new object, keeping `Name` as is, while adding a new `City` field whose value comes from the old `.Cities` field:\r\n```sh\r\n.States[] |= {Name, City: .Cities}\r\n```\r\n[Demo](https://play.jqlang.org/s/I4pC1olZknhh3-u)\r\n\r\nIf you don&#39;t want to spell out the field(s) to keep, you can also compose the new object by deleting the one to remove using `del`, while adding new fields via a new object:\r\n```sh\r\n.States[] |= del(.Cities) + {City: .Cities}\r\n```\r\n[Demo](https://play.jqlang.org/s/h_0waVWnQJM0XNg)\r\n\r\nBoth approaches produce:\r\n```json\r\n{\r\n  &quot;Country&quot;: &quot;India&quot;,\r\n  &quot;States&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;TN&quot;,\r\n      &quot;City&quot;: [\r\n        &quot;city1&quot;,\r\n        &quot;city2&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;KL&quot;,\r\n      &quot;City&quot;: [\r\n        &quot;city3&quot;,\r\n        &quot;city4&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```\r\n",
                "title": "The entire object gets duplicated in output when trying to parse array nested inside object using jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1743616807,
        "creation_date": 1743220454,
        "last_edit_date": 1743616807,
        "question_id": 79542775,
        "body_markdown": "I have the following json data:\r\n\r\n```json\r\n{\r\n  &quot;Country&quot;: &quot;India&quot;,\r\n  &quot;States&quot;: [\r\n    {\r\n      &quot;Name&quot;: &quot;TN&quot;,\r\n      &quot;Cities&quot;: [\r\n        &quot;city1&quot;,\r\n        &quot;city2&quot;\r\n      ]\r\n    },\r\n    {\r\n      &quot;Name&quot;: &quot;KL&quot;,\r\n      &quot;Cities&quot;: [\r\n        &quot;city3&quot;,\r\n        &quot;city4&quot;\r\n      ]\r\n    }\r\n  ]\r\n}\r\n\r\n```\r\n\r\njq expression:\r\n```\r\n{\r\n  country:.Country,states: .States | (\r\n    foreach .[] as $item (0; \r\n      {\r\n       name:$item.Name,\r\n       city:$item.Cities\r\n      } \r\n    )\r\n  )\r\n}\r\n```\r\n\r\nI get the following output:\r\n\r\n```json\r\n{\r\n  &quot;country&quot;: &quot;India&quot;,\r\n  &quot;states&quot;: {\r\n    &quot;name&quot;: &quot;TN&quot;,\r\n    &quot;city&quot;: [\r\n      &quot;city1&quot;,\r\n      &quot;city2&quot;\r\n    ]\r\n  }\r\n}\r\n{\r\n  &quot;country&quot;: &quot;India&quot;,\r\n  &quot;states&quot;: {\r\n    &quot;name&quot;: &quot;KL&quot;,\r\n    &quot;city&quot;: [\r\n      &quot;city3&quot;,\r\n      &quot;city4&quot;\r\n    ]\r\n  }\r\n}\r\n\r\n```\r\n\r\nI don’t want the country to be repeated two times. The main requirement is to change the key names, like `city` instead of `Cities`",
        "link": "https://stackoverflow.com/questions/79542775/the-entire-object-gets-duplicated-in-output-when-trying-to-parse-array-nested-in",
        "title": "The entire object gets duplicated in output when trying to parse array nested inside object using jq"
    },
    {
        "tags": [
            "json",
            "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": 0,
                "creation_date": 1744216528,
                "post_id": 79564850,
                "comment_id": 140317120,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5073248,
                    "reputation": 1499,
                    "user_id": 4071435,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/06c377cba931fbd44c3865315f9edcad?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paul Grinberg",
                    "link": "https://stackoverflow.com/users/4071435/paul-grinberg"
                },
                "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": 1744217284,
                "post_id": 79564850,
                "comment_id": 140317150,
                "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": 1744217529,
                "post_id": 79564850,
                "comment_id": 140317156,
                "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": 1,
                "creation_date": 1744217625,
                "post_id": 79564850,
                "comment_id": 140317163,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5073248,
                    "reputation": 1499,
                    "user_id": 4071435,
                    "user_type": "registered",
                    "accept_rate": 80,
                    "profile_image": "https://www.gravatar.com/avatar/06c377cba931fbd44c3865315f9edcad?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Paul Grinberg",
                    "link": "https://stackoverflow.com/users/4071435/paul-grinberg"
                },
                "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": 1744218459,
                "post_id": 79564850,
                "comment_id": 140317206,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1744220203,
                "creation_date": 1744220203,
                "answer_id": 79564991,
                "question_id": 79564850,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a `reduce`-based approach that iterates over all items while adding up the corresponding array `length`s:\r\n```sh\r\nreduce .[] as {$a,$b} ({}; .[$a] += ($b | length))\r\n```\r\n```json\r\n{\r\n  &quot;foo&quot;: 3,\r\n  &quot;bar&quot;: 0\r\n}\r\n```",
                "title": "jq group by both outer and inner value within arrays"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1744708799,
        "creation_date": 1744216150,
        "last_edit_date": 1744217964,
        "question_id": 79564850,
        "body_markdown": "My data is in the following simplified format\r\n```json\r\n[\r\n  {\r\n    &quot;a&quot;: &quot;foo&quot;,\r\n    &quot;b&quot;: [\r\n      {\r\n        &quot;x&quot;: 1,\r\n        &quot;y&quot;: true\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;foo&quot;,\r\n    &quot;b&quot;: [\r\n      {\r\n        &quot;x&quot;: 1,\r\n        &quot;y&quot;: true\r\n      },\r\n      {\r\n        &quot;x&quot;: 99,\r\n        &quot;y&quot;: false\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;a&quot;: &quot;bar&quot;,\r\n    &quot;b&quot;: []\r\n  }\r\n]\r\n```\r\nI am trying to get the count of _all_ entries in `b` for each unique `a`. I tried to first group by a with `jq &#39;. | group_by(.a)[]` which at least gets me the &quot;unique `a`&quot; part. However, I can&#39;t figure out howt o get the count of all `b` entries within the group_by result. Simply grouping by `b` like `jq &#39;. | group_by(.a)[] | group_by(.b)[]&#39;` doesn&#39;t work.\r\n\r\nAlternatively, I tried `jq -n &#39;jq &#39;[ .[] | {a, n:(.b|length)} ] | group_by(.a)&#39;` but I&#39;m still stuck on how to count _across_ entries.\r\n\r\nAny suggestions? The ultimate answer for this example would be 3 `b` entries for `foo` and 0 `b` entries for `bar`",
        "link": "https://stackoverflow.com/questions/79564850/jq-group-by-both-outer-and-inner-value-within-arrays",
        "title": "jq group by both outer and inner value within arrays"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "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": 1744394265,
                "post_id": 79569370,
                "comment_id": 140325717,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1744392006,
                "creation_date": 1744392006,
                "answer_id": 79569414,
                "question_id": 79569370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "This returns the summary and ids of the failed checks if there are any:\r\n\r\n    jq &#39;.summary, (.checks[] | select(.status != &quot;OK&quot;) | .id)&#39; file.json",
                "title": "JQ and Multiple Fields with a SELECT"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1744394224,
                "creation_date": 1744394224,
                "answer_id": 79569462,
                "question_id": 79569370,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Seems like all you need is to update `|=` all items instead of descending with them into a new context:\r\n```sh\r\n# jq 1.7+\r\njq &#39;.checks[] |= select(.status != &quot;OK&quot;)&#39; &lt;&lt;&lt; &quot;$json_string&quot;\r\n\r\n# jq 1.3+\r\njq &#39;.checks |= map(select(.status != &quot;OK&quot;))&#39; &lt;&lt;&lt; &quot;$json_string&quot;\r\n```\r\n```json\r\n{\r\n  &quot;summary&quot;: &quot;1 failure&quot;,\r\n  &quot;checks&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;check2&quot;,\r\n      &quot;status&quot;: &quot;FAILED&quot;\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;check3&quot;,\r\n      &quot;status&quot;: &quot;CONFIG_WARNING&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n[Demo](https://play.jqlang.org/s/h8mVhIonXtpWpgJ)",
                "title": "JQ and Multiple Fields with a SELECT"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1744394224,
        "creation_date": 1744390604,
        "last_edit_date": 1744392997,
        "question_id": 79569370,
        "body_markdown": "Let&#39;s say I have json returned as such:\r\n```bash\r\nexport json_string=&#39;{\r\n    &quot;summary&quot;: &quot;1 failure&quot;,\r\n    &quot;checks&quot;: [\r\n        {\r\n            &quot;id&quot;: &quot;check1&quot;,\r\n            &quot;status&quot;: &quot;OK&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;check2&quot;,\r\n            &quot;status&quot;: &quot;FAILED&quot;\r\n        },\r\n        {\r\n            &quot;id&quot;: &quot;check3&quot;,\r\n            &quot;status&quot;: &quot;CONFIG_WARNING&quot;\r\n        }\r\n    ]\r\n}&#39;\r\n```\r\n\r\nHow do I get the summary returned and the check that failed to return? I can get the failed check via something like:\r\n\r\n```bash\r\necho &quot;$json_string&quot; | jq &#39;.checks | .[] | select(.status != &quot;OK&quot;)&#39;\r\n```\r\n\r\nBut I would really like to get the summary and the failed checks, or just the summary if there are no failures. \r\n\r\n*UPDATE*\r\nThe accepted answer pointed me in the right direction. Here is the command I ended up using to get the output formatted how I wanted it:\r\n\r\n```bash\r\necho &quot;$json_string&quot; | jq &#39;{&quot;summary&quot;: .summary, &quot;checks&quot;:[.checks[] | select(.status != &quot;OK&quot;)]}&#39;\r\n```",
        "link": "https://stackoverflow.com/questions/79569370/jq-and-multiple-fields-with-a-select",
        "title": "JQ and Multiple Fields with a SELECT"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2230457,
                    "reputation": 17671,
                    "user_id": 1968182,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/E5nF2.jpg?s=256",
                    "display_name": "Ulrich Eckhardt",
                    "link": "https://stackoverflow.com/users/1968182/ulrich-eckhardt"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1744788359,
                "post_id": 79576341,
                "comment_id": 140339665,
                "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": 1744835056,
                "post_id": 79576341,
                "comment_id": 140342293,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1744852931,
                "last_edit_date": 1744852931,
                "creation_date": 1744780361,
                "answer_id": 79576431,
                "question_id": 79576341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Yes.\r\n\r\n`empty as $v` is indeed special: `empty` causes backtracking, not the binding of $v to nothing.\r\n\r\nNote that jq, jaq, and gojq (the C, Rust and Go implementations of jq) are all agreed that `empty as $v` causes the behavior you observe.\r\n\r\nTo understand what&#39;s going on, it might be worth considering the following:\r\n\r\n```\r\njq -n &#39;0 | [1,2,3][] as $x | .&#39;\r\n```\r\n\r\n```\r\n0\r\n0\r\n0\r\n```",
                "title": "jq: &#39;empty&#39; variable leads to empty output - is it expected behavior?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1746153813,
                "last_edit_date": 1746153813,
                "creation_date": 1745416970,
                "answer_id": 79588798,
                "question_id": 79576341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It can&#39;t be any other way because `$var` must have a value for the rest to be evaluated, and `empty` produces no values. (Don&#39;t confuse a lack of value and the value `null`.)\r\n\r\nBut the behaviour is also derivable from existing principles. What follows is a demonstration of this.\r\n\r\n---\r\n\r\nIt seems pretty obvious that\r\n\r\n```jq\r\nX | Y | Z\r\n```\r\n\r\ncan also be written as\r\n\r\n```jq\r\nX | Y as $y | $y | Z\r\n```\r\n\r\nThat means that\r\n\r\n```jq\r\nX | (4,5,6) | Z\r\n```\r\n\r\nis equivalent to\r\n\r\n```jq\r\nX | (4,5,6) as $y | $y | Z\r\n```\r\n\r\nAnd the only way that&#39;s true is if \r\n\r\n```jq\r\n(4,5,6) as $y | ...\r\n```\r\n\r\nevaluates `...` three times per input (once with `$y` as `4`, once as `5`, and once as `6`).\r\n\r\nSimilarly,\r\n\r\n* `(7,8) as $y | ...` evaluates `...` twice per input (once with `$y` as `7`, and once as `8`).\r\n* `9 as $y | ...` evaluates `...` once per input (with `$y` as `9`).\r\n* `empty as $y | ...` evaluates `...` zero times.\r\n",
                "title": "jq: &#39;empty&#39; variable leads to empty output - is it expected behavior?"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1746172146,
                "last_edit_date": 1746172146,
                "creation_date": 1745693648,
                "answer_id": 79594289,
                "question_id": 79576341,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "The manual says:\r\n\r\n&gt; The expression `exp as $x | ...` means: for each value of expression `exp`, run the rest of the pipeline with the entire original input, and with `$x` set to that value. Thus `as` functions as something of a foreach loop.\r\n&gt;\r\n&gt; https://jqlang.org/manual/#variable-symbolic-binding-operator\r\n\r\nSince the `empty` keyword means &quot;no value/no input -- not even `null`&quot; this boils down to a loop with zero iterations.",
                "title": "jq: &#39;empty&#39; variable leads to empty output - is it expected behavior?"
            }
        ],
        "is_answered": true,
        "answer_count": 3,
        "score": 2,
        "last_activity_date": 1746172146,
        "creation_date": 1744774088,
        "question_id": 79576341,
        "body_markdown": "In my understanding unused variable in *jq* query shouldn&#39;t affect output, for example this echoes it&#39;s input: `&quot;bla&quot; as $str | .&quot;`.\r\n\r\nHowever, `empty as $var | .` produces no output. Is it expected?",
        "link": "https://stackoverflow.com/questions/79576341/jq-empty-variable-leads-to-empty-output-is-it-expected-behavior",
        "title": "jq: &#39;empty&#39; variable leads to empty output - is it expected behavior?"
    },
    {
        "tags": [
            "json",
            "linux",
            "csv",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 9097660,
                    "reputation": 12571,
                    "user_id": 6771046,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/K59fa.png?s=256",
                    "display_name": "U880D",
                    "link": "https://stackoverflow.com/users/6771046/u880d"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1746451919,
                "post_id": 79607007,
                "comment_id": 140397020,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1746453467,
                "creation_date": 1746453467,
                "answer_id": 79607064,
                "question_id": 79607007,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Descend into the respective parts of the document, and create an array of values, which can then be passed to `@csv`. Use the `-r` flag to strip the JSON encoding.\r\n```sh\r\n.jobActivityLog[] | . as {$taskId} | .jobs[] | .fileDetails[] as $fd | [\r\n  $taskId, .runId, .startTime, .endTime, .status,\r\n  $fd.path, $fd.transferDirection\r\n] | @csv\r\n```\r\n```csv\r\n&quot;gNngdUm4p0WfBDKHJqQ2S8&quot;,63750,&quot;2025-05-04T19:03:48Z&quot;,&quot;2025-05-04T19:03:50Z&quot;,&quot;SUCCESS&quot;,&quot;/in/finance/ALL_GL_AHCS/2025/05/04/XlaTransaction_ALL_20250504T1902314697.zip&quot;,&quot;UPLOAD&quot;\r\n```\r\n[Demo](https://play.jqlang.org/s/bd68HsXBm8Eh5Lm)",
                "title": "Flatten multi-level JSON to CSV output"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 2,
        "last_activity_date": 1746453467,
        "creation_date": 1746451438,
        "last_edit_date": 1746453158,
        "question_id": 79607007,
        "body_markdown": "I am working on a `jq` utility on Linux to process JSON file and convert it into a CSV format. I have the following JSON with multi-level hierarchy which I want to flatten into CSV:\r\n\r\n```lang-json\r\n{\r\n  &quot;totalJobCount&quot;: 13,\r\n  &quot;jobActivityLog&quot;: [\r\n    {\r\n      &quot;taskId&quot;: &quot;gNngdUm4p0WfBDKHJqQ2S8&quot;,\r\n      &quot;jobs&quot;: [\r\n        {\r\n          &quot;runId&quot;: 63750,\r\n          &quot;startedBy&quot;: &quot;svc-ctmagent&quot;,\r\n          &quot;startTime&quot;: &quot;2025-05-04T19:03:48Z&quot;,\r\n          &quot;endTime&quot;: &quot;2025-05-04T19:03:50Z&quot;,\r\n          &quot;status&quot;: &quot;SUCCESS&quot;,\r\n          &quot;logLocation&quot;: &quot;26.1.1/../data/taskLogs/2025-05-04/1000007899913.log&quot;,\r\n          &quot;messageText&quot;: &quot;Job completed normally&quot;,\r\n          &quot;successFiles&quot;: 1,\r\n          &quot;failedFiles&quot;: 0,\r\n          &quot;fileDetails&quot;: [\r\n            {\r\n              &quot;path&quot;: &quot;/in/finance/ALL_GL_AHCS/2025/05/04/XlaTransaction_ALL_20250504T1902314697.zip&quot;,\r\n              &quot;size&quot;: 17172,\r\n              &quot;lastModified&quot;: &quot;2025-05-04T19:02:32Z&quot;,\r\n              &quot;startTime&quot;: &quot;2025-05-04T19:03:49Z&quot;,\r\n              &quot;status&quot;: &quot;SUCCESS&quot;,\r\n              &quot;duration&quot;: 390,\r\n              &quot;transferDirection&quot;: &quot;UPLOAD&quot;\r\n            }\r\n          ]\r\n        }\r\n\t\t]\r\n\t}\r\n\t]\r\n}\r\n```\r\n\r\nI would like to see the CSV in the following output: \r\n\r\n```lang-plaintext\r\ntaskId, jobs.runId, jobs.startTime, jobs.endTime, jobs.status, jobs.fileDetails.path, jobs.fileDetails.transferDirection\r\n```\r\n\r\nHow is it possible?",
        "link": "https://stackoverflow.com/questions/79607007/flatten-multi-level-json-to-csv-output",
        "title": "Flatten multi-level JSON to CSV output"
    },
    {
        "tags": [
            "json",
            "bash",
            "csv",
            "jq",
            "klipfolio"
        ],
        "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": 1746524946,
                "post_id": 79608401,
                "comment_id": 140399680,
                "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": 1,
                "creation_date": 1746525199,
                "post_id": 79608401,
                "comment_id": 140399697,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 61108,
                    "reputation": 478,
                    "user_id": 182260,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/66856c30111a94a92d16750347107cb2?s=256&d=identicon&r=PG",
                    "display_name": "Stew-au",
                    "link": "https://stackoverflow.com/users/182260/stew-au"
                },
                "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": 1746528404,
                "post_id": 79608401,
                "comment_id": 140399882,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1746529526,
                "post_id": 79608401,
                "comment_id": 140399971,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 61108,
                    "reputation": 478,
                    "user_id": 182260,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/66856c30111a94a92d16750347107cb2?s=256&d=identicon&r=PG",
                    "display_name": "Stew-au",
                    "link": "https://stackoverflow.com/users/182260/stew-au"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746530875,
                "post_id": 79608401,
                "comment_id": 140400081,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746533343,
                "post_id": 79608401,
                "comment_id": 140400243,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746533941,
                "post_id": 79608401,
                "comment_id": 140400292,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 61108,
                    "reputation": 478,
                    "user_id": 182260,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/66856c30111a94a92d16750347107cb2?s=256&d=identicon&r=PG",
                    "display_name": "Stew-au",
                    "link": "https://stackoverflow.com/users/182260/stew-au"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746535226,
                "post_id": 79608401,
                "comment_id": 140400391,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 61108,
                    "reputation": 478,
                    "user_id": 182260,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/66856c30111a94a92d16750347107cb2?s=256&d=identicon&r=PG",
                    "display_name": "Stew-au",
                    "link": "https://stackoverflow.com/users/182260/stew-au"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746535521,
                "post_id": 79608401,
                "comment_id": 140400417,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 32512612,
                    "reputation": 1135,
                    "user_id": 25260101,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/51N5bwvH.jpg?s=256",
                    "display_name": "ticktalk",
                    "link": "https://stackoverflow.com/users/25260101/ticktalk"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1746540668,
                "post_id": 79608401,
                "comment_id": 140400737,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746540978,
                "post_id": 79608401,
                "comment_id": 140400757,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746547052,
                "post_id": 79608401,
                "comment_id": 140401105,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746559896,
                "post_id": 79608401,
                "comment_id": 140401684,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "reply_to_user": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746561113,
                "post_id": 79608401,
                "comment_id": 140401724,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1965184,
                    "reputation": 72175,
                    "user_id": 1765658,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f2dcfe3194de7a9e1a1cdaa81933b307?s=256&d=identicon&r=PG",
                    "display_name": "F. Hauri  - Give Up GitHub",
                    "link": "https://stackoverflow.com/users/1765658/f-hauri-give-up-github"
                },
                "reply_to_user": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1746569762,
                "post_id": 79608401,
                "comment_id": 140402065,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 61108,
                    "reputation": 478,
                    "user_id": 182260,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/66856c30111a94a92d16750347107cb2?s=256&d=identicon&r=PG",
                    "display_name": "Stew-au",
                    "link": "https://stackoverflow.com/users/182260/stew-au"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746571536,
                "post_id": 79608401,
                "comment_id": 140402109,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746572109,
                "post_id": 79608401,
                "comment_id": 140402121,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "reply_to_user": {
                    "account_id": 1965184,
                    "reputation": 72175,
                    "user_id": 1765658,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f2dcfe3194de7a9e1a1cdaa81933b307?s=256&d=identicon&r=PG",
                    "display_name": "F. Hauri  - Give Up GitHub",
                    "link": "https://stackoverflow.com/users/1765658/f-hauri-give-up-github"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746574125,
                "post_id": 79608401,
                "comment_id": 140402162,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746574526,
                "post_id": 79608401,
                "comment_id": 140402168,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 61108,
                    "reputation": 478,
                    "user_id": 182260,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/66856c30111a94a92d16750347107cb2?s=256&d=identicon&r=PG",
                    "display_name": "Stew-au",
                    "link": "https://stackoverflow.com/users/182260/stew-au"
                },
                "reply_to_user": {
                    "account_id": 5425221,
                    "reputation": 37827,
                    "user_id": 7366100,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/139c7d4589b263c62cb63692b913fde0?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "markp-fuso",
                    "link": "https://stackoverflow.com/users/7366100/markp-fuso"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746581051,
                "post_id": 79608401,
                "comment_id": 140402304,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746621570,
                "post_id": 79608401,
                "comment_id": 140404004,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 61108,
                    "reputation": 478,
                    "user_id": 182260,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/66856c30111a94a92d16750347107cb2?s=256&d=identicon&r=PG",
                    "display_name": "Stew-au",
                    "link": "https://stackoverflow.com/users/182260/stew-au"
                },
                "reply_to_user": {
                    "account_id": 1938048,
                    "reputation": 207858,
                    "user_id": 1745001,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://www.gravatar.com/avatar/99a3ebae89496eb16afe453aae97f5be?s=256&d=identicon&r=PG",
                    "display_name": "Ed Morton",
                    "link": "https://stackoverflow.com/users/1745001/ed-morton"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1746623169,
                "post_id": 79608401,
                "comment_id": 140404156,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1746606878,
                "creation_date": 1746606878,
                "answer_id": 79610110,
                "question_id": 79608401,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "if the main goal is to extract the json data you can run \r\n\r\n```\r\ncurl -kL https://app.klipfolio.com/published/6b16ab677623c60708ba3ef462e6ad8e/football-victoria-referee-appointments \\\r\n  | grep -oP &#39;dashboardSchemaString = &quot;\\K.*?(?=&quot;;)&#39; \\\r\n  | sed &#39;s/.*/&quot;&amp;&quot;/&#39; \\\r\n  | jq -rR &#39;fromjson&#39;\r\n```\r\n\r\nto get a json output.\r\n\r\nThen the goal is simply to parse the various arrays with the data.\r\n\r\n[![enter image description here](https://i.sstatic.net/xH6B2oiI.png)](https://i.sstatic.net/xH6B2oiI.png)",
                "title": "Extract csv from klipfolio table"
            },
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1746637688,
                "creation_date": 1746637688,
                "answer_id": 79611080,
                "question_id": 79608401,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Since the output is not json formatted , it is improper to use [tag:Bash] to parse it.\r\n\r\nA workaround would be copy the `table` element of the html manually and parse it with an html parse like [pup](https://github.com/ericchiang/pup)\r\n\r\nAssuming you have the table.html file , here the commands \r\n\r\n### first table row select `tr:nth-child(1)`\r\n\r\n```\r\n### command\r\n./pup &#39;tbody tr:nth-child(1) td text{}&#39; &lt; file.html  | perl -lpe  &#39;s/^[^\\w+]|\\s+/-/g&#39; | xargs | column  -to&#39;,&#39;\r\n\r\n### output &#39;,&#39;\r\nFriday-2-May,6:15-PM,Veto-Sports-State-League-(Womens),Women-1-South-East-Reserves,Croydon-City-Soccer-Club-(SLW1),Ashburton-United-SC-(SLW1),Dorset-Recreation-Reserve,FV-Appointed,-\\xa0,-\\xa0\r\n``` \r\n\r\n### second table row, select `tr:nth-child(2)`\r\n\r\n```bash\r\n### command\r\n./pup &#39;tbody tr:nth-child(2) td text{}&#39; &lt; file.html  | perl -lpe  &#39;s/^[^\\w+]|\\s+/-/g&#39; | xargs | column  -to&#39;,&#39;\r\n\r\n### output\r\nFriday-2-May,6:30-PM,Veto-Sports-State-League-(Womens),Women-3-South,Chelsea-FC-(SLW3),Monash-University-SC---Women&amp;#39;s-Thirds-(SLW3),Edithvale-Recreation-Reserve,FV-Appointed,-\\xa0,-\\xa0\r\n```\r\n\r\nNote\r\n - you can loop and update `tr:nth-child($counter)` to have all the rows \r\n - before using `column` , `perl` used to remove spaces so `column` can work properly\r\n - you can tweak the [tag:Perl] [tag:regex] `&#39;s/^[^\\w+]|\\s+/-/g&#39;` for better output\r\n - watch out for not-printable characters !",
                "title": "Extract csv from klipfolio table"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1746637688,
        "creation_date": 1746524085,
        "last_edit_date": 1746530923,
        "question_id": 79608401,
        "body_markdown": "How can I use a bash script to extract the data from this klipfolio table into a csv file? \r\n[![klipfolio table of referee appointments][1]][1]\r\nhttps://app.klipfolio.com/published/6b16ab677623c60708ba3ef462e6ad8e/football-victoria-referee-appointments\r\n\r\nAll columns and rows are required, including the *name* of the Referee, AR1 &amp; AR2 (which are visible in the page source). Example of required output (top 3 rows only):\r\n```\r\nDATE,TIME,COMPETITION,DIVISION,HOME TEAM,AWAY TEAM,VENUE,REFEREE,AR1,AR2,REFEREE NAME,AR1 NAME,AR2 NAME\r\nFriday 2 May,18:15,Veto Sports State League (Womens),Women 1 South-East Reserves,Croydon City Soccer Club (SLW1),Ashburton United SC (SLW1),Dorset Recreation Reserve,FV Appointed,,,Kosta Kelly,,\r\nFriday 2 May,18:30,Veto Sports State League (Womens),Women 3 South,Chelsea FC (SLW3),Monash University SC - Women&#39;s Thirds (SLW3),Edithvale Recreation Reserve,FV Appointed,,,Sarah Rogers,,\r\nFriday 2 May,18:30,Veto Sports State League (Womens),Women 4 East,Mooroolbark SC (SLW4),Eastern Lions SC (SLW4),Esther Park,FV Appointed,,,Pearl Peckrose,,\r\n```\r\n\r\nMy attempts thus far have yielded the first 100 unique values for each column. Starting to feel like I may be barking up the wrong tree?\r\n\r\n```\r\n#!/bin/bash\r\nFileBase=&quot;${HOME}/tmp/RefAppts_tmp&quot;\r\nRefApptUrl=&quot;https://app.klipfolio.com/published/6b16ab677623c60708ba3ef462e6ad8e/football-victoria-referee-appointments&quot;\r\ncurl ${RefApptUrl} -o $FileBase.1\r\n\r\n#Extact the line with the data string\r\ncat $FileBase.1 | grep dashboardSchemaString  | head -1 &gt; $FileBase.2\r\n\r\n#Extract the data string from within the double quotes\r\ncut -d&quot;\\&quot;&quot; -f2 $FileBase.2 &gt; $FileBase.3\r\n\r\n#Make readable json by unescaping the data string\r\necho -e $(cat $FileBase.3) &gt; $FileBase.4\r\n\r\n#Extract a subset of the data which looks interesting. \r\njq .[].klips[].components[].components $FileBase.4 &gt; $FileBase.5\r\n\r\n#Extract Venues\r\njq &#39;.[] | select(.displayName==&quot;FV Venue&quot;)&#39; $FileBase.5 &gt; $FileBase.6\r\n\r\n#Extract TIMEs\r\njq &#39;.[] | select(.displayName==&quot;TIME&quot;)&#39; $FileBase.5 &gt; $FileBase.7\r\n\r\n#And so on for each column\r\n```\r\n\r\n\r\n  [1]: https://i.sstatic.net/F2QLgpVo.png",
        "link": "https://stackoverflow.com/questions/79608401/extract-csv-from-klipfolio-table",
        "title": "Extract csv from klipfolio table"
    },
    {
        "tags": [
            "bash",
            "shell",
            "parsing",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1746954039,
                "last_edit_date": 1746954039,
                "creation_date": 1746938560,
                "answer_id": 79616171,
                "question_id": 79616141,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Why not use the `$1` positional parameter to pass that information into the `jq` query? You will have to change and double-quote the `jq` expression and escape the internal double-quotes in order for *variable-expansion* to work, but it is fairly simple to do.\r\n\r\nYou can do something similar to the following where you must *single-quote* the command line input that you want to pass so the double-quotes are preserved. Create `script.sh` (or whatever you want to call it) similar to:\r\n\r\n```bash\r\n#!/bin/bash\r\n\r\ninput=&quot;$1&quot;\r\ndata=&quot;${2:-data.txt}&quot;\r\n\r\njq \\\r\n  --compact-output \\\r\n  --raw-output \\\r\n  &quot;.[] | select(.[\\&quot;PublicIpAddress\\&quot;] | IN($input)) | .[\\&quot;InstanceId\\&quot;]&quot; \\\r\n  &quot;$data&quot;\r\n```\r\n\r\nWhere above your command line input of `&#39;&quot;i1.i2.i3&quot;,&quot;i10.i11.i12&quot;&#39;` will result in your desired output. Note that the first positional (command-line) parameter is assigned to `input` and the second positional parameter allows you to provide the filename to apply the `jq` expression to (which defaults to `data.txt`)\r\n\r\n(**note:** as mentioned in the comments, it is up to you to further validate what the user enters as input. All input validations were omitted as they were not sought as part of the question. Using regex matching with `[[ input =~ regex ]]` to test the input is one approach you can take.)\r\n\r\n**Example Use/Output**\r\n\r\nYou can make the script executable and run it as `./script.sh` or simply call the interpreter passing the script name and positional parameters are arguments, e.g.\r\n\r\n```none\r\n$ bash script.sh &#39;&quot;i1.i2.i3&quot;,&quot;i10.i11.i12&quot;&#39;\r\no1.o2.o3\r\no10.o11.o12\r\n```\r\n\r\nOr, changing your command-line input to return the middle-two entries:\r\n\r\n```none\r\n$ bash script.sh &#39;&quot;i4.i5.i6&quot;,&quot;i7.i8.i9&quot;&#39;\r\no4.o5.o6\r\no7.o8.o9\r\n```\r\n\r\nLet me know if I misunderstood or if you have further questions.\r\n\r\n---\r\n\r\n\r\nAlso, avoid *UUOc* (*Unnecessary Use of `cat`*, also stated as *Useless Use of `cat`*). Whenever you do `cat file ...` and are not concatenating files, it is a *UUOc*. Usually seen as `cat file | someUtility`. See [Useless Use of Cat](https://porkmail.org/era/unix/award.html). Instead all utilities will either take the filenames as an argument or take input on `stdin` which you can provide by simple redirection.",
                "title": "JQ - List Objects Where Key Is in a list"
            },
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1746951608,
                "last_edit_date": 1746951608,
                "creation_date": 1746951075,
                "answer_id": 79616282,
                "question_id": 79616141,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Use the `--args` flag with `jq`, and append all shell parameters with `$@`. This way, you can access them all using the `$ARGS.positional` array. Have `run` contain:\r\n```sh\r\n#!/bin/sh\r\n\r\n&lt; data.txt jq --args --raw-output &#39;\r\n  .[] | select(IN(.PublicIpAddress; $ARGS.positional[])).InstanceId\r\n&#39; &quot;$@&quot;\r\n```\r\n\r\nThen invoke it simply using positional arguments: `./run i1.i2.i3 i10.i11.i12`\r\n```\r\no1.o2.o3\r\no10.o11.o12\r\n```\r\n\r\n---\r\n\r\nIf you want to also pass `data.txt` as an argument, provide it at first argument by running `./run data.txt i1.i2.i3 i10.i11.i12`, then chop it off in your script using `shift`. Change `run` to:\r\n```sh\r\n#!/bin/sh\r\n\r\ndatafile=&quot;${1?No source provided}&quot;; shift\r\n&lt; &quot;$datafile&quot; jq --args --raw-output &#39;\r\n  .[] | select(IN(.PublicIpAddress; $ARGS.positional[])).InstanceId\r\n&#39; &quot;$@&quot;\r\n```\r\n\r\nAlternatively, have the caller manage the input stream, by running `./run &lt; data.txt i1.i2.i3 i10.i11.i12`, and reducing `run` to:\r\n```sh\r\n#!/bin/sh\r\n\r\njq --args --raw-output &#39;\r\n  .[] | select(IN(.PublicIpAddress; $ARGS.positional[])).InstanceId\r\n&#39; &quot;$@&quot;\r\n```",
                "title": "JQ - List Objects Where Key Is in a list"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 1,
        "last_activity_date": 1746954039,
        "creation_date": 1746935272,
        "question_id": 79616141,
        "body_markdown": "```\r\n$ cat data.txt \r\n[\r\n  {\r\n    &quot;PublicIpAddress&quot;: &quot;i1.i2.i3&quot;,\r\n    &quot;InstanceId&quot;: &quot;o1.o2.o3&quot;\r\n  },\r\n  {\r\n    &quot;PublicIpAddress&quot;: &quot;i4.i5.i6&quot;,\r\n    &quot;InstanceId&quot;: &quot;o4.o5.o6&quot;\r\n  },\r\n  {\r\n    &quot;PublicIpAddress&quot;: &quot;i7.i8.i9&quot;,\r\n    &quot;InstanceId&quot;: &quot;o7.o8.o9&quot;\r\n  },\r\n  {\r\n    &quot;PublicIpAddress&quot;: &quot;i10.i11.i12&quot;,\r\n    &quot;InstanceId&quot;: &quot;o10.o11.o12&quot;\r\n  }\r\n]\r\n\r\n$ cat run \r\ncat data.txt |\r\njq \\\r\n    --compact-output \\\r\n    --raw-output \\\r\n    &#39;.[] | select(.[&quot;PublicIpAddress&quot;] | IN(&quot;i1.i2.i3&quot;,&quot;i10.i11.i12&quot;)) | .[&quot;InstanceId&quot;] // empty&#39;\r\n\r\n$ ./run \r\no1.o2.o3\r\no10.o11.o12\r\n```\r\n\r\nThe above jq works when I hard coded `&quot;i1.i2.i3&quot;,&quot;i10.i11.i12&quot;`. Now I want to pass `&quot;i1.i2.i3&quot;,&quot;i10.i11.i12&quot;` as a shell script variable but I don&#39;t know how. Please help. Thanks.",
        "link": "https://stackoverflow.com/questions/79616141/jq-list-objects-where-key-is-in-a-list",
        "title": "JQ - List Objects Where Key Is in a list"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 3,
                "is_accepted": false,
                "score": 3,
                "last_activity_date": 1747000720,
                "creation_date": 1747000720,
                "answer_id": 79616954,
                "question_id": 79616915,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Here&#39;s a somewhat simplified approach without variables, and using `map` to keep the outer array:\r\n```sh\r\nmap({year, subject} | .subject[] |= (.module | {name, unit}) + {amount})\r\n```\r\n```json\r\n[\r\n  {\r\n    &quot;year&quot;: &quot;year1&quot;,\r\n    &quot;subject&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;maths&quot;,\r\n        &quot;unit&quot;: &quot;vect&quot;,\r\n        &quot;amount&quot;: 5.88\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;electronics&quot;,\r\n        &quot;unit&quot;: &quot;laws&quot;,\r\n        &quot;amount&quot;: 2.3\r\n      }\r\n    ]\r\n  },\r\n  {\r\n    &quot;year&quot;: &quot;year2&quot;,\r\n    &quot;subject&quot;: [\r\n      {\r\n        &quot;name&quot;: &quot;electronics&quot;,\r\n        &quot;unit&quot;: &quot;laws&quot;,\r\n        &quot;amount&quot;: 12.51\r\n      },\r\n      {\r\n        &quot;name&quot;: &quot;maths&quot;,\r\n        &quot;unit&quot;: &quot;vect&quot;,\r\n        &quot;amount&quot;: 4.44\r\n      }\r\n    ]\r\n  }\r\n]\r\n```\r\n[Demo](https://play.jqlang.org/s/YftotHvQqmeGYXz)",
                "title": "Parsing nested JSON data with jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1747130496,
        "creation_date": 1746997627,
        "last_edit_date": 1747130496,
        "question_id": 79616915,
        "body_markdown": "I have JSON data that looks like this:\r\n```lang-json\r\n[\r\n {\r\n  &quot;class&quot;: &quot;class1&quot;,\r\n  &quot;year&quot;: &quot;year1&quot;,\r\n  &quot;subject&quot;: [\r\n   {\r\n    &quot;id&quot;: 7654,\r\n    &quot;type&quot;: &quot;subject&quot;,\r\n    &quot;module&quot;: {\r\n     &quot;id&quot;: 765,\r\n     &quot;number&quot;: 654,\r\n     &quot;name&quot;: &quot;maths&quot;,\r\n     &quot;unit&quot;: &quot;vect&quot;,\r\n    },\r\n    &quot;amount&quot;: 5.88\r\n   },\r\n   {\r\n    &quot;id&quot;: 7612,\r\n    &quot;type&quot;: &quot;subject&quot;,\r\n    &quot;module&quot;: {\r\n     &quot;id&quot;: 747,\r\n     &quot;number&quot;: 234,\r\n     &quot;name&quot;: &quot;electronics&quot;,\r\n     &quot;unit&quot;: &quot;laws&quot;,\r\n    },\r\n    &quot;amount&quot;: 2.3\r\n   }\r\n  ]\r\n },\r\n {\r\n  &quot;class&quot;: &quot;class1&quot;,\r\n  &quot;year&quot;: &quot;year2&quot;,\r\n  &quot;subject&quot;: [\r\n   {\r\n    &quot;id&quot;: 8634,\r\n    &quot;type&quot;: &quot;subject&quot;,\r\n    &quot;module&quot;: {\r\n     &quot;id&quot;: 465,\r\n     &quot;number&quot;: 253,\r\n     &quot;name&quot;: &quot;electronics&quot;,\r\n     &quot;unit&quot;: &quot;laws&quot;,\r\n    },\r\n    &quot;amount&quot;: 12.51\r\n   },\r\n   {\r\n    &quot;id&quot;: 7654,\r\n    &quot;type&quot;: &quot;subject&quot;,\r\n    &quot;module&quot;: {\r\n     &quot;id&quot;: 765,\r\n     &quot;number&quot;: 654,\r\n     &quot;name&quot;: &quot;maths&quot;,\r\n     &quot;unit&quot;: &quot;vect&quot;,\r\n    },\r\n    &quot;amount&quot;: 4.44\r\n   }\r\n  ]\r\n }\r\n]\r\n```\r\nand I want an outcome of this:\r\n```lang-json\r\n[\r\n {\r\n  &quot;year&quot;: &quot;year1&quot;\r\n   &quot;subject&quot;: [\r\n    {\r\n     &quot;name&quot;: &quot;maths&quot;,\r\n     &quot;unit&quot;: &quot;vect&quot;,\r\n     &quot;amount&quot;: 5.88,\r\n    },\r\n    {\r\n     &quot;name&quot;: &quot;electronics&quot;,\r\n     &quot;unit&quot;: &quot;laws&quot;,\r\n     &quot;amount&quot;: 2.3,\r\n    }\r\n   ]\r\n {\r\n  &quot;year&quot;: &quot;year2&quot;\r\n   &quot;subject&quot;: [\r\n    {\r\n     &quot;name&quot;: &quot;electronics&quot;,\r\n     &quot;unit&quot;: &quot;laws&quot;,\r\n     &quot;amount&quot;: 12.51,\r\n    },\r\n    {\r\n     &quot;name&quot;: &quot;maths&quot;,\r\n     &quot;unit&quot;: &quot;vect&quot;,\r\n     &quot;amount&quot;: 4.44,\r\n    }\r\n   ]\r\n  ]\r\n```\r\nI used this for jq but it didn&#39;t quite give me the correct outcome. It kept putting the &quot;year&quot; key in front of every key value pair.\r\n```lang-bash\r\njq &#39;.[] | .year as $year | .subject[] | {$year, &quot;name&quot;: .subject.name, &quot;amount&quot;: .amount, &quot;unit&quot;: .subject.unit}&#39; &lt; classes &gt; test\r\n```  ",
        "link": "https://stackoverflow.com/questions/79616915/parsing-nested-json-data-with-jq",
        "title": "Parsing nested JSON data with jq"
    },
    {
        "tags": [
            "shell",
            "parsing",
            "jq"
        ],
        "comments": [
            {
                "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": 1,
                "creation_date": 1747034441,
                "post_id": 79617276,
                "comment_id": 140416894,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2117537,
                    "reputation": 5780,
                    "user_id": 1881450,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/202416461e32a17e8b99fc658c058888?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nam Nguyen",
                    "link": "https://stackoverflow.com/users/1881450/nam-nguyen"
                },
                "reply_to_user": {
                    "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": 1747034949,
                "post_id": 79617276,
                "comment_id": 140416918,
                "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": 1747036323,
                "post_id": 79617276,
                "comment_id": 140416994,
                "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": 1,
                "creation_date": 1747036879,
                "post_id": 79617276,
                "comment_id": 140417030,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2117537,
                    "reputation": 5780,
                    "user_id": 1881450,
                    "user_type": "registered",
                    "accept_rate": 83,
                    "profile_image": "https://www.gravatar.com/avatar/202416461e32a17e8b99fc658c058888?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "Nam Nguyen",
                    "link": "https://stackoverflow.com/users/1881450/nam-nguyen"
                },
                "reply_to_user": {
                    "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": 1747056812,
                "post_id": 79617276,
                "comment_id": 140418071,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1747034073,
        "creation_date": 1747030635,
        "last_edit_date": 1747034073,
        "question_id": 79617276,
        "body_markdown": "DATA:\r\n\r\n```\r\n[\r\n  {\r\n    &quot;NetworkInterfaces&quot;: [\r\n      {\r\n        &quot;NetworkInterfaceId&quot;: &quot;eni-1&quot;\r\n      },\r\n      {\r\n        &quot;NetworkInterfaceId&quot;: &quot;eni-2&quot;\r\n      }\r\n    ],\r\n    &quot;InstanceId&quot;: &quot;i-1&quot;\r\n  },\r\n  {\r\n    &quot;NetworkInterfaces&quot;: [\r\n      {\r\n        &quot;NetworkInterfaceId&quot;: &quot;eni-3&quot;\r\n      },\r\n      {\r\n        &quot;NetworkInterfaceId&quot;: &quot;eni-4&quot;\r\n      }\r\n    ],\r\n    &quot;InstanceId&quot;: &quot;i-2&quot;\r\n  },\r\n  {\r\n    &quot;NetworkInterfaces&quot;: [\r\n      {\r\n        &quot;NetworkInterfaceId&quot;: &quot;eni-5&quot;\r\n      },\r\n      {\r\n        &quot;NetworkInterfaceId&quot;: &quot;eni-6&quot;\r\n      }\r\n    ],\r\n    &quot;InstanceId&quot;: &quot;i-3&quot;\r\n  }\r\n]\r\n```\r\n\r\nJQ QUERIES :\r\n\r\n\r\nWORKS :\r\n\r\n`.[] | select(.[&quot;NetworkInterfaces&quot;] | .[] | select(.[&quot;NetworkInterfaceId&quot;] | IN(&quot;eni-1&quot;, &quot;eni-3&quot;))) | .[&quot;InstanceId&quot;] // empty` =&gt; return ```&quot;i-1&quot;\r\n&quot;i-2&quot;``` which is correct\r\n\r\n\r\nISSUE 1 : (NOT SOLVE YET)\r\n\r\n`.[] | select(.[&quot;NetworkInterfaces&quot;] | .[] | select(.[&quot;NetworkInterfaceId&quot;] | IN(&quot;eni-1&quot;, &quot;eni-3&quot;) | not)) | .[&quot;InstanceId&quot;] // empty` =&gt; return ```&quot;i-1&quot;\r\n&quot;i-2&quot;\r\n&quot;i-3&quot;\r\n&quot;i-3&quot;``` which is NOT what I want. I would like it returns only ```&quot;i-3&quot;```. How do I fix this query?\r\n\r\n\r\nISSUE 2 : (SOLVED)\r\n\r\n`.[] | select(.[&quot;NetworkInterfaces&quot;] | .[] | select(.[&quot;NetworkInterfaceId&quot;] | IN(&quot;eni-1&quot;, &quot;eni-2&quot;))) | .[&quot;InstanceId&quot;] // empty` =&gt; return ```&quot;i-1&quot;\r\n&quot;i-1&quot;```. I would like it returns only one ```&quot;i-1&quot;```. How do I fix this query (hope not to use shell command `sort -u -f`?\r\n\r\nlook like I figured out this issue by using fist() `.[] | first(select(.[&quot;NetworkInterfaces&quot;] | .[] | select(.[&quot;NetworkInterfaceId&quot;] | IN(&quot;eni-1&quot;, &quot;eni-2&quot;)))) | .[&quot;InstanceId&quot;] // empty`\r\n\r\nThanks!!!!",
        "link": "https://stackoverflow.com/questions/79617276/jq-select-not-in-does-not-return-correct-data",
        "title": "JQ select NOT IN does not return correct data"
    },
    {
        "tags": [
            "json",
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 16872618,
                    "reputation": 1614,
                    "user_id": 12200808,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d7c46fc17be48297d8630ef076e7d780?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "stackbiz",
                    "link": "https://stackoverflow.com/users/12200808/stackbiz"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1747145020,
                "post_id": 79619739,
                "comment_id": 140421705,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 4,
                "is_accepted": true,
                "score": 4,
                "last_activity_date": 1747145871,
                "last_edit_date": 1747145871,
                "creation_date": 1747145078,
                "answer_id": 79619829,
                "question_id": 79619739,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "There is no need for those extra 2 steps/variables, you can achieve the expected output with 1 JQ call like so:\r\n```\r\njq &#39;.combined = .hello + .world&#39; &lt;&lt;&lt; &quot;$json_string&quot;\r\n```\r\n\r\n* ##### [JqPlay Demo](https://play.jqlang.org/s/P6hukJU_92flmZ1)\r\n\r\n* Based on OP&#39;s comment, another **[JqPlay Demo](https://play.jqlang.org/s/13U4e-m9ofGd_DL)** with multiple keys inside `.world`\r\n\r\n----------\r\n\r\n\r\nBut if you define `world` and `hello` as seperate variabels,\r\nyou can pass those objects back to jq with [`--argjson`][1] and combine them in a new key:\r\n\r\n```\r\njq \\\r\n  --argjson hello &quot;$hello&quot; \\\r\n  --argjson world &quot;$world&quot; \\\r\n  &#39;.combined = $hello + $world&#39; &lt;&lt;&lt; &quot;$json_string&quot;\r\n```\r\n\r\n\r\n  [1]: https://jqlang.org/manual/#invoking-jq",
                "title": "How to add and combine objects in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1747145871,
        "creation_date": 1747142374,
        "last_edit_date": 1747142548,
        "question_id": 79619739,
        "body_markdown": "I want to use `jq` to add new objects into the following JSON string.\r\n\r\nHere is the test `json_string`:\r\n```lang-bash\r\njson_string=&quot;$(cat &lt;&lt;&#39;END&#39;\r\n{\r\n  &quot;hello&quot;: {\r\n    &quot;foo&quot;: {\r\n      &quot;version&quot;: &quot;1.1.1&quot;\r\n    }\r\n  },\r\n  &quot;world&quot;: {\r\n    &quot;bar&quot;: {\r\n      &quot;version&quot;: &quot;2.2.2&quot;\r\n    }\r\n  }\r\n}\r\nEND\r\n)&quot;\r\n```\r\nHere is the `hello`:\r\n```lang-bash\r\n# hello=&quot;$(jq -r &quot;.hello&quot; &lt;&lt;&lt; &quot;$json_string&quot;)&quot;\r\n# echo &quot;$hello&quot;\r\n{\r\n  &quot;foo&quot;: {\r\n    &quot;version&quot;: &quot;1.1.1&quot;\r\n  }\r\n}\r\n```\r\nHere is the `world`:\r\n```lang-bash\r\n# world=&quot;$(jq -r &quot;.world&quot; &lt;&lt;&lt; &quot;$json_string&quot;)&quot;\r\n# echo &quot;$world&quot;\r\n{\r\n  &quot;bar&quot;: {\r\n    &quot;version&quot;: &quot;2.2.2&quot;\r\n  }\r\n}\r\n```\r\nHere is the full JSON string including the newly added `combined`:\r\n```lang-bash\r\n# full=&quot;$(jq -r &quot;.+= combined ${hello} ${world}&quot; &lt;&lt;&lt; &quot;$json_string&quot;)&quot;\r\njq: error: syntax error, unexpected &#39;{&#39;, expecting $end (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n.+= combined {             \r\njq: 1 compile error\r\n```\r\nHere is the expected full JSON:\r\n```lang-bash\r\n# echo &quot;$full&quot;\r\n{\r\n  &quot;hello&quot;: {\r\n    &quot;foo&quot;: {\r\n      &quot;version&quot;: &quot;1.1.1&quot;\r\n    }\r\n  },\r\n  &quot;world&quot;: {\r\n    &quot;bar&quot;: {\r\n      &quot;version&quot;: &quot;2.2.2&quot;\r\n    }\r\n  }\r\n  &quot;combined&quot;: {\r\n    &quot;foo&quot;: {\r\n      &quot;version&quot;: &quot;1.1.1&quot;\r\n    },\r\n    &quot;bar&quot;: {\r\n      &quot;version&quot;: &quot;2.2.2&quot;\r\n    }\r\n  }\r\n}\r\n```\r\nHow to generate the &quot;full&quot; JSON with `jq`?",
        "link": "https://stackoverflow.com/questions/79619739/how-to-add-and-combine-objects-in-jq",
        "title": "How to add and combine objects in jq"
    },
    {
        "tags": [
            "jq",
            "zsh"
        ],
        "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": 1747253539,
                "post_id": 79622181,
                "comment_id": 140426491,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 449951,
                    "reputation": 2178,
                    "user_id": 845038,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/6dc21a22ca7dfbb859720b1de6def676?s=256&d=identicon&r=PG",
                    "display_name": "DMCApps",
                    "link": "https://stackoverflow.com/users/845038/dmcapps"
                },
                "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": 1747253913,
                "post_id": 79622181,
                "comment_id": 140426503,
                "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": 2,
                "creation_date": 1747254313,
                "post_id": 79622181,
                "comment_id": 140426535,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 449951,
                    "reputation": 2178,
                    "user_id": 845038,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/6dc21a22ca7dfbb859720b1de6def676?s=256&d=identicon&r=PG",
                    "display_name": "DMCApps",
                    "link": "https://stackoverflow.com/users/845038/dmcapps"
                },
                "reply_to_user": {
                    "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": 1747254529,
                "post_id": 79622181,
                "comment_id": 140426549,
                "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": 1747254649,
                "post_id": 79622181,
                "comment_id": 140426553,
                "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": 1747254763,
                "post_id": 79622181,
                "comment_id": 140426558,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 449951,
                    "reputation": 2178,
                    "user_id": 845038,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/6dc21a22ca7dfbb859720b1de6def676?s=256&d=identicon&r=PG",
                    "display_name": "DMCApps",
                    "link": "https://stackoverflow.com/users/845038/dmcapps"
                },
                "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": 1747254978,
                "post_id": 79622181,
                "comment_id": 140426569,
                "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": 1747255904,
                "post_id": 79622181,
                "comment_id": 140426611,
                "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": 1747256712,
                "post_id": 79622181,
                "comment_id": 140426649,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 449951,
                    "reputation": 2178,
                    "user_id": 845038,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/6dc21a22ca7dfbb859720b1de6def676?s=256&d=identicon&r=PG",
                    "display_name": "DMCApps",
                    "link": "https://stackoverflow.com/users/845038/dmcapps"
                },
                "reply_to_user": {
                    "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": 1747256882,
                "post_id": 79622181,
                "comment_id": 140426657,
                "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": 1747256962,
                "post_id": 79622181,
                "comment_id": 140426659,
                "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": 1747257984,
                "post_id": 79622181,
                "comment_id": 140426685,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 449951,
                    "reputation": 2178,
                    "user_id": 845038,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/6dc21a22ca7dfbb859720b1de6def676?s=256&d=identicon&r=PG",
                    "display_name": "DMCApps",
                    "link": "https://stackoverflow.com/users/845038/dmcapps"
                },
                "reply_to_user": {
                    "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": 1747263332,
                "post_id": 79622181,
                "comment_id": 140426842,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 449951,
                    "reputation": 2178,
                    "user_id": 845038,
                    "user_type": "registered",
                    "accept_rate": 76,
                    "profile_image": "https://www.gravatar.com/avatar/6dc21a22ca7dfbb859720b1de6def676?s=256&d=identicon&r=PG",
                    "display_name": "DMCApps",
                    "link": "https://stackoverflow.com/users/845038/dmcapps"
                },
                "reply_to_user": {
                    "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": 1747263633,
                "post_id": 79622181,
                "comment_id": 140426852,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1749594486,
                "creation_date": 1749594486,
                "answer_id": 79661189,
                "question_id": 79622181,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "When you invoked `jq`, `$qa_assigned_from_to_me` is a variable of type `string`. It&#39;s not going to be evaluated like you&#39;re expecting and `jq` does not have a mechanism to evaluate a string as a jq expression.\r\n\r\nYou&#39;re effectively trying to write a dynamic program. Rather than passing the dynamic part as an argument, you would have to insert it into the program text itself. Depending on your shell, this could be easy or a little complicated. Otherwise, you would have to specify a configuration which you would write logic to filter as you want, but that would be a lot more work.\r\n\r\n---\r\n\r\nFor a perhaps slightly easier and far less hacky approach, you could put the contents of the filter into a file, formatted to be used as a module which you could import into your main program and invoke where needed.\r\n\r\n```sh\r\n$ cat filter.jq\r\ndef filter: (.fromString == &quot;Person A&quot; and .toString == &quot;Person B&quot;);\r\n\r\n$ jq &#39;include &quot;filter&quot;;            # source the file &quot;filter.jq&quot;\r\n[\r\n  .values\r\n  | sort_by(.id)\r\n  | reverse\r\n  | .[].items[]\r\n  | select(\r\n    .field == &quot;assignee&quot;           # your sample input does not have this field\r\n    and (\r\n      filter                       # invoke filter\r\n    )\r\n  )\r\n]\r\n| first\r\n| .fromString\r\n&#39; input.json\r\n```\r\n\r\nThe contents of `filter.jq` is what you would generate, and put into a function (&quot;filter&quot; in this case). Then include the file and use the function.",
                "title": "jq how to create a dynamic select list"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1749594486,
        "creation_date": 1747252263,
        "last_edit_date": 1747254856,
        "question_id": 79622181,
        "body_markdown": "I&#39;m wondering how you can I create a dynamic select statement to be used with jq. I want to be able to search a result based on names of people that I provide to my script. e.g.\r\n\r\n```\r\nqa_assigned_from_to_me=&quot;&quot;\r\n\r\nIFS=&#39;;&#39; read -r -A jira_name_qa_all_array &lt;&lt;&lt; &quot;$jira_name_qa_all&quot;\r\nfor jira_name_qa in &quot;${jira_name_qa_all_array[@]}&quot;; do\r\n  if [[ &quot;$qa_assigned_from_to_me&quot; == &quot;&quot; ]]; then\r\n    qa_assigned_from_to_me=&quot;(.fromString == \\&quot;${jira_name_qa}\\&quot; and .toString == \\&quot;${jira_name_me}\\&quot;)&quot;\r\n  else\r\n    qa_assigned_from_to_me=&quot;${qa_assigned_from_to_me} or (.fromString == \\&quot;${jira_name_qa}\\&quot; and .toString == \\&quot;${jira_name_me}\\&quot;)&quot;\r\n  fi\r\ndone\r\n\r\nlast_qa_assigned_to_me=$(jq \\\r\n  --arg qa_assigned_from_to_me $qa_assigned_from_to_me \\\r\n  -r &#39;[\r\n    .values\r\n    | sort_by(.id)\r\n    | reverse\r\n    | .[].items[]\r\n    | select(\r\n      .field == &quot;assignee&quot;\r\n      and (\r\n        $qa_assigned_from_to_me\r\n      )\r\n    )\r\n  ]\r\n  | first\r\n  | .fromString&#39; \\\r\n&quot;$tmp_response_file&quot;)\r\n```\r\n\r\nhowever this doesn&#39;t use the dynamically created select statement in place, instead it seems to just ignore it completely.\r\n\r\nWhen I check the result of the statement created using:\r\n\r\n```\r\nlast_qa_assigned_to_me=$(jq -n --arg qa_assigned_from_to_me $qa_assigned_from_to_me &#39;$qa_assigned_from_to_me&#39;)\r\n\r\necho &quot;last_qa_assigned_to_me: $last_qa_assigned_to_me&quot;\r\n```\r\n\r\nIt returns a quoted (&quot;) string, so I&#39;m wondering if it&#39;s quoting it in the select statement and basically just ignoring it as a condition?\r\n\r\nSample of `$qa_assigned_from_to_me`\r\n\r\n```\r\n(.fromString == &quot;Person A&quot; and .toString == &quot;Person B&quot;)\r\n```\r\n\r\nHere is a sample `$tmp_response_file`\r\n\r\n```\r\n{\r\n  &quot;values&quot;: [\r\n    {\r\n      &quot;id&quot;: &quot;1&quot;,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;fromString&quot;: &quot;Person A&quot;,\r\n          &quot;toString&quot;: &quot;Person B&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;2&quot;,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;fromString&quot;: &quot;Person B&quot;,\r\n          &quot;toString&quot;: &quot;Person A&quot;\r\n        }\r\n      ]\r\n    },\r\n    {\r\n      &quot;id&quot;: &quot;3&quot;,\r\n      &quot;items&quot;: [\r\n        {\r\n          &quot;fromString&quot;: &quot;Person C&quot;,\r\n          &quot;toString&quot;: &quot;Person D&quot;\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}\r\n```",
        "link": "https://stackoverflow.com/questions/79622181/jq-how-to-create-a-dynamic-select-list",
        "title": "jq how to create a dynamic select list"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "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": 1747381717,
                "post_id": 79624707,
                "comment_id": 140431370,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1747381507,
                "creation_date": 1747381507,
                "answer_id": 79624710,
                "question_id": 79624707,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Don&#39;t iterate over the keys, just take the array:\r\n```sh\r\n.bundleDependencies = (.dependencies | keys)\r\n```\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;hello&quot;,\r\n  &quot;dependencies&quot;: {\r\n    &quot;progress&quot;: &quot;^2.0.0&quot;,\r\n    &quot;tar&quot;: &quot;^6.2.1&quot;\r\n  },\r\n  &quot;bundleDependencies&quot;: [\r\n    &quot;progress&quot;,\r\n    &quot;tar&quot;\r\n  ]\r\n}\r\n```\r\n[Demo](https://play.jqlang.org/s/6SxVkBama5_CVuQ)\r\n\r\nNote: `keys` sorts the array. Use `keys_unsorted` to prevent that.",
                "title": "How to add array from object&#39;s keys in jq"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1747381618,
                "creation_date": 1747381618,
                "answer_id": 79624714,
                "question_id": 79624707,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You have an extra `)` at the end, and `.dependencies | keys[]` will return each key **individually**, not as an array, which is not what you want.\r\n\r\nTry this:\r\n\r\n```\r\n\r\njq &#39;.bundleDependencies = (.dependencies | keys)&#39; &lt;&lt;&lt; &quot;$json_string&quot;\r\n```",
                "title": "How to add array from object&#39;s keys in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1747381618,
        "creation_date": 1747381399,
        "question_id": 79624707,
        "body_markdown": "I want to add `bundleDependencies` from the `dependencies`&#39;s keys by using `jq`.\r\n\r\n    json_string=&quot;$(cat &lt;&lt;&#39;END&#39;\r\n    {\r\n      &quot;name&quot;: &quot;hello&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;progress&quot;: &quot;^2.0.0&quot;,\r\n        &quot;tar&quot;: &quot;^6.2.1&quot;\r\n      }\r\n    }\r\n    END\r\n    )&quot;\r\n\r\nHere is the command for adding `bundleDependencies` but got error:\r\n\r\n    # jq &quot;.bundleDependencies = (.dependencies | keys[])&quot; &lt;&lt;&lt; &quot;$json_string&quot;)&quot;\r\n    bash: syntax error near unexpected token `)&#39;\r\n\r\nHere is the expected output:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;hello&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;progress&quot;: &quot;^2.0.0&quot;,\r\n        &quot;tar&quot;: &quot;^6.2.1&quot;\r\n      },\r\n      &quot;bundleDependencies&quot;: [&quot;progress&quot;, &quot;tar&quot;]\r\n    }\r\n\r\nWhat&#39;s wrong in my `jq` command and how to fix?",
        "link": "https://stackoverflow.com/questions/79624707/how-to-add-array-from-objects-keys-in-jq",
        "title": "How to add array from object&#39;s keys in jq"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 481437,
                    "reputation": 5327,
                    "user_id": 895279,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5cc8354b6c084f50364db5bd2cfe9904?s=256&d=identicon&r=PG",
                    "display_name": "Mate",
                    "link": "https://stackoverflow.com/users/895279/mate"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1747460767,
                "post_id": 79626225,
                "comment_id": 140434460,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 4663062,
                    "reputation": 89888,
                    "user_id": 3776858,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/Cagbk.jpg?s=256",
                    "display_name": "Cyrus",
                    "link": "https://stackoverflow.com/users/3776858/cyrus"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1747466242,
                "post_id": 79626225,
                "comment_id": 140434586,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1747460798,
                "creation_date": 1747460798,
                "answer_id": 79626234,
                "question_id": 79626225,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\n$ echo $json_string | jq &#39;.dependencies |= map_values(&quot;&quot;)&#39;\r\n{\r\n  &quot;name&quot;: &quot;hello&quot;,\r\n  &quot;dependencies&quot;: {\r\n    &quot;progress&quot;: &quot;&quot;,\r\n    &quot;tar&quot;: &quot;&quot;\r\n  }\r\n}\r\n```",
                "title": "How to clear all object keys&#39;s value in jq"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1747471785,
                "creation_date": 1747471785,
                "answer_id": 79626343,
                "question_id": 79626225,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You can access the items of an object (here: `.dependencies`) by iterating over it using `.[]`. Thus, all you need is to set them to `&quot;&quot;` (no need for `|=`, `with_entries`, or `map_values`):\r\n```sh\r\njq &#39;.dependencies[] = &quot;&quot;&#39; &lt;&lt;&lt; &quot;$json_string&quot;\r\n```\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;hello&quot;,\r\n  &quot;dependencies&quot;: {\r\n    &quot;progress&quot;: &quot;&quot;,\r\n    &quot;tar&quot;: &quot;&quot;\r\n  }\r\n}\r\n```\r\n[Demo](https://play.jqlang.org/s/1uSjSMMiTn3nqVd)\r\n\r\n---\r\n\r\n&gt; I want to clear all values\r\n\r\nNote: To &quot;clear&quot; the values, you may want to consider using `null` instead of `&quot;&quot;`.",
                "title": "How to clear all object keys&#39;s value in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": -1,
        "last_activity_date": 1747471785,
        "creation_date": 1747460343,
        "question_id": 79626225,
        "body_markdown": "I want to clear all values from &quot;`dependencies`&quot; by using `jq`:\r\n\r\n    json_string=&quot;$(cat &lt;&lt;&#39;END&#39;\r\n    {\r\n      &quot;name&quot;: &quot;hello&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;progress&quot;: &quot;^2.0.0&quot;,\r\n        &quot;tar&quot;: &quot;^6.2.1&quot;\r\n      }\r\n    }\r\n    END\r\n    )&quot;\r\n\r\nHere is the expected output:\r\n\r\n    {\r\n      &quot;name&quot;: &quot;hello&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;progress&quot;: &quot;&quot;,\r\n        &quot;tar&quot;: &quot;&quot;\r\n      }\r\n    }\r\n\r\nI have tried but not work:\r\n\r\n    # output=&quot;$(jq &quot;.dependencies =(.dependencies | keys)&quot; &lt;&lt;&lt; &quot;$json_string&quot;)&quot;\r\n    # echo &quot;output is: $output&quot;\r\n    output is: {\r\n      &quot;name&quot;: &quot;hello&quot;,\r\n      &quot;dependencies&quot;: [\r\n        &quot;progress&quot;,\r\n        &quot;tar&quot;\r\n      ]\r\n    }\r\n\r\nIt only converts the object to an array, but I want it still as object and only clear all values inside all keys.\r\n\r\nWhat&#39;s wrong in my `jq` command and how to fix?",
        "link": "https://stackoverflow.com/questions/79626225/how-to-clear-all-object-keyss-value-in-jq",
        "title": "How to clear all object keys&#39;s value in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1747502430,
                "creation_date": 1747502430,
                "answer_id": 79626818,
                "question_id": 79626804,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It&#39;s not working because once you&#39;ve accessed `.text` you&#39;ve lost the parent context. `.search_for` and `.replace_with` are resolved *relative to `.text`*, rather than relative to the parent object.\r\n\r\nTo fix this you can stash them in variables before accessing `.text`:\r\n\r\n```\r\n$ jq &#39;.example | .search_for as $s | .replace_with as $r | .text | sub($s; $r)&#39; test.json\r\n&quot;I want to have the full URL, not https://my.site.com&quot;\r\n```\r\n\r\n",
                "title": "How do I use an element in a subfunction?"
            }
        ],
        "is_answered": false,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1747517340,
        "creation_date": 1747501972,
        "last_edit_date": 1747517340,
        "question_id": 79626804,
        "body_markdown": "I&#39;m trying to use the sub function to search/replace, but using JSON elements rather than literals. \r\n\r\n\r\nHere&#39;s a simple example JSON:\r\n```json\r\n{\r\n    &quot;example&quot;: {\r\n        &quot;search_for&quot;: &quot;https://a-url-using-a-shortener.com&quot;,\r\n        &quot;replace_with&quot;: &quot;https://my.site.com&quot;,\r\n        &quot;text&quot;: &quot;I want to have the full URL, not https://a-url-using-a-shortener.com&quot; \r\n    }\r\n}\r\n```\r\n\r\nI can search/replace the string using the following jq with literals:\r\n\r\n```jq\r\n.example | .text | sub( &quot;https://a-url-using-a-shortener.com&quot;;&quot;https://my.site.com&quot;)\r\n```\r\n\r\nAnd I get the result I expect:\r\n\r\n```json\r\n&quot;I want to have the full URL, not https://my.site.com&quot;\r\n```\r\n\r\nBut what I want to do is use the other elements for the search and replace:\r\n\r\n```jq\r\n.example | .text | sub( .search_for ; .replace_with )\r\n```\r\n\r\nBut this throws up an error:\r\n\r\n```shell\r\njq: error (at /dev/stdin:6): Cannot index string with string &quot;search_for&quot;\r\n``` \r\n\r\nI&#39;ve tried a few variations e.g. `.search_for.value` and `.search_for | tostring`. Have I missed something stupid? \r\n",
        "link": "https://stackoverflow.com/questions/79626804/how-do-i-use-an-element-in-a-subfunction",
        "title": "How do I use an element in a subfunction?"
    },
    {
        "tags": [
            "bash",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1747639996,
                "last_edit_date": 1747639996,
                "creation_date": 1747638617,
                "answer_id": 79628242,
                "question_id": 79628235,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "```\r\njq &#39;.bundleDependencies |= unique&#39;\r\n```\r\n\r\nDocumented [here](https://jqlang.org/manual/#unique-unique_by).\r\n\r\nIt also looks like you can do everything at once, without the need for `unique`:\r\n```\r\njq &quot;.bundleDependencies += (.dependencies + .devDependencies | keys)&quot;\r\n```\r\n\r\nIf `bundleDependencies` is already populated, you can use this:\r\n```\r\njq &quot;.bundleDependencies = ((.dependencies + .devDependencies | keys) + .bundleDependencies | unique)&quot;\r\n```",
                "title": "How to ignore duplicated array items in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1747639996,
        "creation_date": 1747638325,
        "last_edit_date": 1747638961,
        "question_id": 79628235,
        "body_markdown": "I want to set `bundleDependencies` by using `jq`:\r\n\r\n    json_string=&quot;$(cat &lt;&lt;&#39;END&#39;\r\n    {\r\n      &quot;name&quot;: &quot;hello&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;progress&quot;: &quot;^2.0.0&quot;,\r\n        &quot;tar&quot;: &quot;^6.2.1&quot;\r\n      },\r\n      &quot;devDependencies&quot;: {\r\n        &quot;node-fetch&quot;: &quot;~2.6.1&quot;,\r\n        &quot;yargs&quot;: &quot;^16.2.0&quot;\r\n      }\r\n    }\r\n    END\r\n    )&quot;\r\n\r\nNow add `dependencies` to the `bundleDependencies`:\r\n\r\n    # json_string=&quot;$(jq -r &quot;.bundleDependencies += (.dependencies | keys)&quot; &lt;&lt;&lt; &quot;$json_string&quot;)&quot;\r\n\r\nNow add `devDependencies` to the `bundleDependencies`:\r\n\r\n    # json_string=&quot;$(jq -r &quot;.bundleDependencies += (.devDependencies | keys)&quot; &lt;&lt;&lt; &quot;$json_string&quot;)&quot;\r\n\r\nFinally, add `devDependencies` again for testing if `jq` can ignore the duplicated items:\r\n\r\n    # jq -r &quot;.bundleDependencies += (.devDependencies | keys)&quot; &lt;&lt;&lt; &quot;$json_string&quot;\r\n    {\r\n      &quot;name&quot;: &quot;hello&quot;,\r\n      &quot;dependencies&quot;: {\r\n        &quot;progress&quot;: &quot;^2.0.0&quot;,\r\n        &quot;tar&quot;: &quot;^6.2.1&quot;\r\n      },\r\n      &quot;devDependencies&quot;: {\r\n        &quot;node-fetch&quot;: &quot;~2.6.1&quot;,\r\n        &quot;yargs&quot;: &quot;^16.2.0&quot;\r\n      },\r\n      &quot;bundleDependencies&quot;: [\r\n        &quot;progress&quot;,\r\n        &quot;tar&quot;,\r\n        &quot;node-fetch&quot;,\r\n        &quot;yargs&quot;,\r\n        &quot;node-fetch&quot;,\r\n        &quot;yargs&quot;\r\n      ]\r\n    }\r\n\r\nHow to make `jq` ignore the duplicated items when it already existed in the array?",
        "link": "https://stackoverflow.com/questions/79628235/how-to-ignore-duplicated-array-items-in-jq",
        "title": "How to ignore duplicated array items in jq"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1747677849,
                "post_id": 79629191,
                "comment_id": 140440250,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 19060324,
                    "reputation": 5,
                    "user_id": 13916579,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/e33b273beb4e17967d63e28d834a4205?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "chris93",
                    "link": "https://stackoverflow.com/users/13916579/chris93"
                },
                "reply_to_user": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1747678430,
                "post_id": 79629191,
                "comment_id": 140440275,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1042959,
                    "reputation": 668672,
                    "user_id": 1048572,
                    "user_type": "registered",
                    "accept_rate": 77,
                    "profile_image": "https://www.gravatar.com/avatar/7f2c4de95e8f4f8f5a71c3aaf0ed312a?s=256&d=identicon&r=PG",
                    "display_name": "Bergi",
                    "link": "https://stackoverflow.com/users/1048572/bergi"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1747680491,
                "post_id": 79629191,
                "comment_id": 140440374,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1747680288,
                "last_edit_date": 1747680288,
                "creation_date": 1747678927,
                "answer_id": 79629280,
                "question_id": 79629191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "It seems you&#39;ll need additional parenthesis, as otherwise `//` binds stronger than the `|` and you&#39;re piping *all* `attributes` through an expression that always returns a value.\r\n\r\n```jq\r\n{\r\n    created: ((.attributes[] | select(.objectTypeAttribute.name==&quot;Created&quot;).objectAttributeValues[0].value) // null),\r\n    updated: ((.attributes[] | select(.objectTypeAttribute.name==&quot;Updated&quot;).objectAttributeValues[0].value) // null),\r\n}\r\n```\r\n&lt;sup&gt;([online demo](https://play.jqlang.org/s/p55G9sqVvp_Us2E))&lt;/sup&gt;\r\n\r\n----\r\n\r\nAn imo simpler solution is to build the objects dynamically with the specified key names and values, using `from_entries`:\r\n```jq\r\n.attributes | map({\r\n    key: .objectTypeAttribute.name | ascii_downcase,\r\n    value: .objectAttributeValues[0].value\r\n}) | from_entries\r\n```\r\n&lt;sup&gt;([online demo](https://play.jqlang.org/s/OTQN6uoop3YUpQ6))&lt;/sup&gt;\r\n\r\n… or `add`:\r\n```jq\r\n.attributes | map({\r\n    (.objectTypeAttribute.name | ascii_downcase): .objectAttributeValues[0].value\r\n}) | add\r\n```\r\n&lt;sup&gt;([online demo](https://play.jqlang.org/s/qwxBzXIAEwS1k82))&lt;/sup&gt;",
                "title": "Jq create object fails when key is missing"
            },
            {
                "up_vote_count": 0,
                "is_accepted": false,
                "score": 0,
                "last_activity_date": 1747679803,
                "creation_date": 1747679803,
                "answer_id": 79629292,
                "question_id": 79629191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "An alternative approach could be to use `INDEX` to implode the `.attributes` array into an object, extract the two keys you are interested in (which will default to `null` if non-existent), and adjust their values:\r\n```sh\r\n.attributes | INDEX(.objectTypeAttribute.name)\r\n| {Created, Updated} | .[] |= .objectAttributeValues[0].value\r\n```\r\n```json\r\n{\r\n  &quot;Created&quot;: &quot;create time 1&quot;,\r\n  &quot;Updated&quot;: &quot;update time 1&quot;\r\n}\r\n{\r\n  &quot;Created&quot;: &quot;create time 2&quot;,\r\n  &quot;Updated&quot;: null\r\n}\r\n```\r\n[Demo](https://play.jqlang.org/s/_hEmfm33pSgckZS)",
                "title": "Jq create object fails when key is missing"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1747680866,
        "creation_date": 1747674302,
        "last_edit_date": 1747680866,
        "question_id": 79629191,
        "body_markdown": "I have two example files\r\n\r\nexample1:\r\n\r\n    {\r\n      &quot;label&quot;: &quot;Example1&quot;,\r\n      &quot;attributes&quot;: [\r\n        {\r\n           &quot;objectTypeAttribute&quot;: {\r\n            &quot;name&quot;: &quot;Created&quot;},\r\n          &quot;objectAttributeValues&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;create time 1&quot;\r\n            }\r\n          ]\r\n        },\r\n        {\r\n          &quot;objectTypeAttribute&quot;: {\r\n            &quot;name&quot;: &quot;Updated&quot;},\r\n          &quot;objectAttributeValues&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;update time 1&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\n\r\nand example2\r\n\r\n    {\r\n      &quot;label&quot;: &quot;Example2&quot;,\r\n      &quot;attributes&quot;: [\r\n        {\r\n           &quot;objectTypeAttribute&quot;: {\r\n            &quot;name&quot;: &quot;Created&quot;},\r\n          &quot;objectAttributeValues&quot;: [\r\n            {\r\n              &quot;value&quot;: &quot;create time 2&quot;\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n\r\nWhen I apply \r\n\r\n    cat example1 | jq &#39;{created: .attributes[] | select(.objectTypeAttribute.name==&quot;Created&quot;).objectAttributeValues[0].value,\r\n    updated:.attributes[] | select(.objectTypeAttribute.name==&quot;Updated&quot;).objectAttributeValues[0].value}&#39;\r\n\r\non the first everything works fine and I get expected result\r\n\r\n    {\r\n      &quot;created&quot;: &quot;create time 1&quot;,\r\n      &quot;updated&quot;: &quot;update time 1&quot;\r\n    }\r\n\r\n, however applying \r\n\r\n    cat example2 | jq &#39;{created: .attributes[] | select(.objectTypeAttribute.name==&quot;Created&quot;).objectAttributeValues[0].value,\r\n    updated:.attributes[] | select(.objectTypeAttribute.name==&quot;Updated&quot;).objectAttributeValues[0].value}&#39;\r\n\r\nI get no result at all, the result i would expect is\r\n\r\n    {\r\n      &quot;created&quot;: &quot;create time 2&quot;,\r\n      &quot;created&quot;: &quot;NULL&quot;\r\n    }\r\n\r\nAfter researching similar questions I have tried the following:\r\n\r\n    cat example2 | jq &#39;try (.attributes[] | select(.objectTypeAttribute.name==&quot;Created&quot;).objectAttributeValues[0].value) // &quot;NULL&quot;, try (.attributes[] | select(\r\n    .objectTypeAttribute.name==&quot;Updated&quot;).objectAttributeValues[0].value) // &quot;NULL&quot;&#39;\r\n\r\nhowever this doesn&#39;t work when I try rewriting the key like here:\r\n\r\n    cat example2 | jq &#39;{created: (try (.attributes[] | select(.objectTypeAttribute.name==&quot;Created&quot;).objectAttributeValues[0].value) // &quot;NULL&quot;), updated: try (.a\r\n    ttributes[] | select(.objectTypeAttribute.name==&quot;Updated&quot;).objectAttributeValues[0].value) // &quot;NULL&quot;}&#39;\r\n\r\nAlso I have tried\r\n\r\n    cat example2 | jq &#39;{created: (.attributes[] | select(.objectTypeAttribute.name==&quot;Created&quot;).objectAttributeValues[0].value? //&quot;null1&quot;),\r\n    updated: (.attributes[] | select(.objectTypeAttribute.name==&quot;Updated&quot;).objectAttributeValues[0].value? //&quot;NULL&quot;)}&#39;\r\n\r\nwhich works for example2 but doesn&#39;t for example1  \r\n\r\n    cat example1 | jq &#39;{created: (.attributes[] | select(.objectTypeAttribute.name==&quot;Created&quot;).objectAttributeValues[0].value? //&quot;NULL&quot;),\r\n    updated: (.attributes[] | select(.objectTypeAttribute.name==&quot;Updated&quot;).objectAttributeValues[0].value? //&quot;NULL&quot;)}&#39;\r\n\r\nwhich results in\r\n\r\n    {\r\n      &quot;created&quot;: &quot;create time 1&quot;,\r\n      &quot;updated&quot;: &quot;NULL&quot;\r\n    }\r\n    {\r\n      &quot;created&quot;: &quot;create time 1&quot;,\r\n      &quot;updated&quot;: &quot;update time 1&quot;\r\n    }\r\n    {\r\n      &quot;created&quot;: &quot;NULL&quot;,\r\n      &quot;updated&quot;: &quot;NULL&quot;\r\n    }\r\n    {\r\n      &quot;created&quot;: &quot;NULL&quot;,\r\n      &quot;updated&quot;: &quot;update time 1&quot;\r\n    }\r\n    enter code here\r\n\r\n\r\n\r\n\r\n",
        "link": "https://stackoverflow.com/questions/79629191/jq-create-object-fails-when-key-is-missing",
        "title": "Jq create object fails when key is missing"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1748050359,
                "creation_date": 1748050359,
                "answer_id": 79636349,
                "question_id": 79636342,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Instead of applying a function to `.to_exclude` using `.to_exclude |= …`, apply it to all keys after filtering them using a simple `select`. For example:\r\n```\r\n.[keys[] | select(. != &quot;to_exclude&quot;)] |= …\r\n```\r\n[Demo](https://play.jqlang.org/s/VZaqW24Sm54G6MI)\r\n\r\nTo exclude a list of keys, you could also use array subtraction:\r\n```\r\n.[keys - [&quot;to_exclude&quot;] | .[]] |= …\r\n```\r\n[Demo](https://play.jqlang.org/s/J41I_bYtwLLD7NE)",
                "title": "How to exclude a particular subtree from processing descendants in jq"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1748050359,
        "creation_date": 1748049744,
        "question_id": 79636342,
        "body_markdown": "I have the following json input:\r\n```json\r\n{\r\n  &quot;to_exclude&quot;: {\r\n    &quot;x&quot;: &quot;something&quot;,\r\n    &quot;aa&quot;: {\r\n      &quot;x&quot;: &quot;something&quot;,\r\n      &quot;aaa&quot;: {\r\n        &quot;x&quot;: &quot;something&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;a&quot;: {\r\n    &quot;x&quot;: &quot;something else&quot;,\r\n    &quot;aa&quot;: {\r\n      &quot;x&quot;: &quot;something else&quot;,\r\n      &quot;aaa&quot;: {\r\n        &quot;x&quot;: &quot;something else&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;b&quot;: {\r\n    &quot;x&quot;: &quot;something else&quot;,\r\n    &quot;bb&quot;: {\r\n      &quot;x&quot;: &quot;something else&quot;,\r\n      &quot;bbb&quot;: {\r\n        &quot;x&quot;: &quot;something else&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;...&quot;: {\r\n    &quot;x&quot;: &quot;something else&quot;,\r\n    &quot;......&quot;: {\r\n      &quot;x&quot;: &quot;something else&quot;,\r\n      &quot;.........&quot;: {\r\n        &quot;x&quot;: &quot;something else&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nI&#39;d like to replace the values of all `x` keys that are ***not*** descendants of `to_exclude` by `anything`.\r\n\r\nThe output should look like this:\r\n\r\n```json\r\n{\r\n  &quot;to_exclude&quot;: {\r\n    &quot;x&quot;: &quot;something&quot;,\r\n    &quot;aa&quot;: {\r\n      &quot;x&quot;: &quot;something&quot;,\r\n      &quot;aaa&quot;: {\r\n        &quot;x&quot;: &quot;something&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;a&quot;: {\r\n    &quot;x&quot;: &quot;anything&quot;,\r\n    &quot;aa&quot;: {\r\n      &quot;x&quot;: &quot;anything&quot;,\r\n      &quot;aaa&quot;: {\r\n        &quot;x&quot;: &quot;anything&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;b&quot;: {\r\n    &quot;x&quot;: &quot;anything&quot;,\r\n    &quot;bb&quot;: {\r\n      &quot;x&quot;: &quot;anything&quot;,\r\n      &quot;bbb&quot;: {\r\n        &quot;x&quot;: &quot;anything&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;...&quot;: {\r\n    &quot;x&quot;: &quot;anything&quot;,\r\n    &quot;......&quot;: {\r\n      &quot;x&quot;: &quot;anything&quot;,\r\n      &quot;.........&quot;: {\r\n        &quot;x&quot;: &quot;anything&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n\r\nHow can I achieve this in a similarily compact way as I could easily achieve the opposite? (the replacement for all values of `x` keys that are descendants of `to_exclude`):\r\n\r\n\r\n```jq\r\n.to_exclude |= (.. |= ( if type == &quot;object&quot; and has(&quot;x&quot;) then .x = &quot;anything&quot; else . end))\r\n```\r\n\r\nOutput:\r\n```json\r\n{\r\n  &quot;to_exclude&quot;: {\r\n    &quot;x&quot;: &quot;anything&quot;,\r\n    &quot;aa&quot;: {\r\n      &quot;x&quot;: &quot;anything&quot;,\r\n      &quot;aaa&quot;: {\r\n        &quot;x&quot;: &quot;anything&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;a&quot;: {\r\n    &quot;x&quot;: &quot;something else&quot;,\r\n    &quot;aa&quot;: {\r\n      &quot;x&quot;: &quot;something else&quot;,\r\n      &quot;aaa&quot;: {\r\n        &quot;x&quot;: &quot;something else&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;b&quot;: {\r\n    &quot;x&quot;: &quot;something else&quot;,\r\n    &quot;bb&quot;: {\r\n      &quot;x&quot;: &quot;something else&quot;,\r\n      &quot;bbb&quot;: {\r\n        &quot;x&quot;: &quot;something else&quot;\r\n      }\r\n    }\r\n  },\r\n  &quot;...&quot;: {\r\n    &quot;x&quot;: &quot;something else&quot;,\r\n    &quot;......&quot;: {\r\n      &quot;x&quot;: &quot;something else&quot;,\r\n      &quot;.........&quot;: {\r\n        &quot;x&quot;: &quot;something else&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/79636342/how-to-exclude-a-particular-subtree-from-processing-descendants-in-jq",
        "title": "How to exclude a particular subtree from processing descendants in jq"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "qpdf"
        ],
        "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": 1748080247,
                "post_id": 79636504,
                "comment_id": 140454994,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 42164926,
                    "reputation": 13,
                    "user_id": 30622754,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/087eb35b4d2a5c9e62659709c516f717?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user30622754",
                    "link": "https://stackoverflow.com/users/30622754/user30622754"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1748088202,
                "post_id": 79636504,
                "comment_id": 140455222,
                "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": 1748114408,
                "post_id": 79636504,
                "comment_id": 140455967,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1748114123,
                "creation_date": 1748114123,
                "answer_id": 79637091,
                "question_id": 79636504,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Given your sample JSON input, you can use jq to\r\n- find all objects with an empty array under `.kids` (the leaves)\r\n- extract their paths and slice it to each occurrence of `&quot;kids&quot;` (the levels)\r\n- realize the data under these paths using `getpath`, then compose from it an array of values (the records)\r\n- and encode this array into a CSV output line using `@csv` (and `jq -r`)\r\n\r\n```sh\r\npath(.. | objects | select(.kids == [])) as $p\r\n| [getpath($p | .[:.[[&quot;kids&quot;]][], length])]\r\n| [reverse[].title, last.destpageposfrom1]\r\n| @csv\r\n```\r\n```\r\n&quot;Piece 1&quot;,&quot;Author 1&quot;,&quot;Contents&quot;,2\r\n&quot;Piece 2&quot;,&quot;Author 1&quot;,&quot;Contents&quot;,3\r\n&quot;Piece 3&quot;,&quot;Author 2&quot;,&quot;Contents&quot;,4\r\n&quot;Movement 1&quot;,&quot;Piece 4&quot;,&quot;Author 2&quot;,&quot;Contents&quot;,5\r\n&quot;Movement 2&quot;,&quot;Piece 4&quot;,&quot;Author 2&quot;,&quot;Contents&quot;,6\r\n&quot;Movement 3&quot;,&quot;Piece 4&quot;,&quot;Author 2&quot;,&quot;Contents&quot;,7\r\n&quot;Piece 5&quot;,&quot;Author 2&quot;,&quot;Contents&quot;,8\r\n```\r\n[Demo](https://play.jqlang.org/s/ShJuLhnC5wQB2bg)\r\n\r\nNote that `@csv` uses `,` as item delimiter, and escapes strings using double quotes `&quot;`. Use e.g. `map` and `join` to create another formatting.",
                "title": "JQ: How to convert a very nested JSON file (tree like), in CSV with same key at different levels?"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1748114123,
        "creation_date": 1748070197,
        "last_edit_date": 1748070321,
        "question_id": 79636504,
        "body_markdown": "I have a PDF bookmark structure (tree like), which looks like this:\r\n\r\n```\r\nContent\r\n  Author 1\r\n    Piece 1\r\n    Piece 2\r\n  Author 2\r\n    Piece 3\r\n    Piece 4\r\n      Movement 1\r\n      Movement 2\r\n      Movement 3\r\n    Piece 5\r\n```\r\n\r\nUsing qpdf, it could be formatted in JSON like this:\r\n\r\n```\r\n{\r\n  &quot;version&quot;: 2,\r\n  &quot;parameters&quot;: {\r\n    &quot;decodelevel&quot;: &quot;generalized&quot;\r\n  },\r\n  &quot;outlines&quot;: [\r\n    {\r\n      &quot;dest&quot;: [\r\n        &quot;4 0 R&quot;,\r\n        &quot;/Fit&quot;\r\n      ],\r\n      &quot;destpageposfrom1&quot;: 1,\r\n      &quot;kids&quot;: [\r\n        {\r\n          &quot;dest&quot;: [\r\n            &quot;10 0 R&quot;,\r\n            &quot;/Fit&quot;\r\n          ],\r\n          &quot;destpageposfrom1&quot;: 2,\r\n          &quot;kids&quot;: [\r\n            {\r\n              &quot;dest&quot;: [\r\n                &quot;10 0 R&quot;,\r\n                &quot;/Fit&quot;\r\n              ],\r\n              &quot;destpageposfrom1&quot;: 2,\r\n              &quot;kids&quot;: [],\r\n              &quot;object&quot;: &quot;177 0 R&quot;,\r\n              &quot;open&quot;: true,\r\n              &quot;title&quot;: &quot;Piece 1&quot;\r\n            },\r\n            {\r\n              &quot;dest&quot;: [\r\n                &quot;15 0 R&quot;,\r\n                &quot;/Fit&quot;\r\n              ],\r\n              &quot;destpageposfrom1&quot;: 3,\r\n              &quot;kids&quot;: [],\r\n              &quot;object&quot;: &quot;178 0 R&quot;,\r\n              &quot;open&quot;: true,\r\n              &quot;title&quot;: &quot;Piece 2&quot;\r\n            }\r\n          ],\r\n          &quot;object&quot;: &quot;176 0 R&quot;,\r\n          &quot;open&quot;: true,\r\n          &quot;title&quot;: &quot;Author 1&quot;\r\n        },\r\n        {\r\n          &quot;dest&quot;: [\r\n            &quot;38 0 R&quot;,\r\n            &quot;/Fit&quot;\r\n          ],\r\n          &quot;destpageposfrom1&quot;: 4,\r\n          &quot;kids&quot;: [\r\n            {\r\n              &quot;dest&quot;: [\r\n                &quot;38 0 R&quot;,\r\n                &quot;/Fit&quot;\r\n              ],\r\n              &quot;destpageposfrom1&quot;: 4,\r\n              &quot;kids&quot;: [],\r\n              &quot;object&quot;: &quot;180 0 R&quot;,\r\n              &quot;open&quot;: true,\r\n              &quot;title&quot;: &quot;Piece 3&quot;\r\n            },\r\n            {\r\n              &quot;dest&quot;: [\r\n                &quot;45 0 R&quot;,\r\n                &quot;/Fit&quot;\r\n              ],\r\n              &quot;destpageposfrom1&quot;: 5,\r\n              &quot;kids&quot;: [\r\n                {\r\n                  &quot;dest&quot;: [\r\n                    &quot;45 0 R&quot;,\r\n                    &quot;/Fit&quot;\r\n                  ],\r\n                  &quot;destpageposfrom1&quot;: 5,\r\n                  &quot;kids&quot;: [],\r\n                  &quot;object&quot;: &quot;182 0 R&quot;,\r\n                  &quot;open&quot;: true,\r\n                  &quot;title&quot;: &quot;Movement 1&quot;\r\n                },\r\n                {\r\n                  &quot;dest&quot;: [\r\n                    &quot;53 0 R&quot;,\r\n                    &quot;/Fit&quot;\r\n                  ],\r\n                  &quot;destpageposfrom1&quot;: 6,\r\n                  &quot;kids&quot;: [],\r\n                  &quot;object&quot;: &quot;183 0 R&quot;,\r\n                  &quot;open&quot;: true,\r\n                  &quot;title&quot;: &quot;Movement 2&quot;\r\n                },\r\n                {\r\n                  &quot;dest&quot;: [\r\n                    &quot;58 0 R&quot;,\r\n                    &quot;/Fit&quot;\r\n                  ],\r\n                  &quot;destpageposfrom1&quot;: 7,\r\n                  &quot;kids&quot;: [],\r\n                  &quot;object&quot;: &quot;184 0 R&quot;,\r\n                  &quot;open&quot;: true,\r\n                  &quot;title&quot;: &quot;Movement 3&quot;\r\n                }\r\n              ],\r\n              &quot;object&quot;: &quot;181 0 R&quot;,\r\n              &quot;open&quot;: true,\r\n              &quot;title&quot;: &quot;Piece 4&quot;\r\n            },\r\n            {\r\n              &quot;dest&quot;: [\r\n                &quot;79 0 R&quot;,\r\n                &quot;/Fit&quot;\r\n              ],\r\n              &quot;destpageposfrom1&quot;: 8,\r\n              &quot;kids&quot;: [],\r\n              &quot;object&quot;: &quot;185 0 R&quot;,\r\n              &quot;open&quot;: true,\r\n              &quot;title&quot;: &quot;Piece 5&quot;\r\n            }\r\n          ],\r\n          &quot;object&quot;: &quot;179 0 R&quot;,\r\n          &quot;open&quot;: true,\r\n          &quot;title&quot;: &quot;Author 2&quot;\r\n        }\r\n      ],\r\n      &quot;object&quot;: &quot;175 0 R&quot;,\r\n      &quot;open&quot;: true,\r\n      &quot;title&quot;: &quot;Contents&quot;\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nAs you see, the key &#39;title&#39; is used at different levels of the tree, and each node could have a &#39;kids&#39; array, and so on... I cannot guess how deeply the JSON file will be nested.\r\n\r\nI would like to create a csv file which would retain only the last &quot;title&quot; occurrence in each branch, but also memorize all the path to get to it and its destination page. To be more specific, I would like to create something like this:\r\n\r\n```\r\nPiece 1;Author 1;Content;2\r\nPiece 2;Author 1;Content;3\r\nPiece 3;Author 2;Content;4\r\nMovement 1;Piece 4;Author 2;Content;5\r\nMovement 2;Piece 4;Author 2;Content;6\r\nMovement 3;Piece 4;Author 2;Content;7\r\nPiece 5;Author 2;Content;8\r\n```\r\n\r\nI am struggling to achieve that for a few days now, reading what I could find on the internet about JQ, but I did not succeed to find a similar problem with a proper solution. Any help at this point would be deeply appreciated!\r\n\r\nThanks!",
        "link": "https://stackoverflow.com/questions/79636504/jq-how-to-convert-a-very-nested-json-file-tree-like-in-csv-with-same-key-at",
        "title": "JQ: How to convert a very nested JSON file (tree like), in CSV with same key at different levels?"
    },
    {
        "tags": [
            "jq",
            "yq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1748143180,
                "last_edit_date": 1748143180,
                "creation_date": 1748142810,
                "answer_id": 79637338,
                "question_id": 79637297,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Note: As you&#39;ve tagged both [tag:yq] and [tag:jq], I assume you&#39;re referring to [kislyuk/yq](https://github.com/kislyuk/yq), not [mikefarah/yq](https://github.com/mikefarah/yq) (see the [tag:yq] [tag info](https://stackoverflow.com/tags/yq/info)).\r\n\r\nTo avoid messing with more complex structures (not addressed by your sample), I&#39;ve added the condition that an object candidate must also have both keys `x` and `y` present.\r\n\r\nOne way could be to iterate over all `paths` (matching my added condition), then check for your path condition, and use `setpath` or `delpaths` accordingly:\r\n\r\n```sh\r\nreduce paths(objects | has(&quot;x&quot;) and has(&quot;y&quot;)) as $p (.;\r\n  if $p[:3] == [&quot;deep&quot;,&quot;path&quot;,&quot;matching&quot;]\r\n  then setpath($p + [&quot;x&quot;]; &quot;changed&quot;)\r\n  else delpaths([$p + [&quot;y&quot;]]) end\r\n)\r\n```\r\n```yaml\r\ndeep:\r\n  path:\r\n    matching:\r\n      m:\r\n        x: changed\r\n        y: don&#39;t touch\r\n      n:\r\n        nn:\r\n          x: changed\r\n          y: don&#39;t touch\r\n    other_a:\r\n      a:\r\n        x: don&#39;t touch\r\n    other_b:\r\n      b:\r\n        bb:\r\n          x: don&#39;t touch\r\nanother_other:\r\n  x: don&#39;t touch\r\n```",
                "title": "Apply jq functions conditionally to matching and non-matching JSON subtrees"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1748185002,
        "creation_date": 1748135581,
        "last_edit_date": 1748185002,
        "question_id": 79637297,
        "body_markdown": "I want to apply one function to all descendants of a particular node in a tree, and a different function to all other nodes, in the following way:\r\n\r\n`if path_matches(.deep.path.matching) then apply_function_matching else apply_function_other end`\r\n\r\nTo make writing and reading more comfortable I use yaml, but I&#39;m looking for the jq solution.\r\n\r\nAs a practical example for applying particular functions to matching and non-matching subtrees I&#39;d like to start with:\r\n\r\n`if path_matches(.deep.path.matching) then change_x else delete_y end`\r\n\r\nWith this input ...\r\n\r\n```yaml\r\ndeep:\r\n  path:\r\n    matching:\r\n      m:\r\n        x: change it\r\n        y: don&#39;t touch\r\n      n:\r\n        nn:\r\n          x: change it\r\n          y: don&#39;t touch\r\n    other_a:\r\n      a:\r\n        x: don&#39;t touch\r\n        y: delete it\r\n    other_b:\r\n      b:\r\n        bb:\r\n          x: don&#39;t touch\r\n          y: delete it\r\nanother_other:\r\n  x: don&#39;t touch\r\n  y: delete it\r\n```\r\n\r\n... the output should be:\r\n\r\n```yaml\r\ndeep:\r\n  path:\r\n    matching:\r\n      m:\r\n        x: changed\r\n        y: don&#39;t touch # not touched\r\n      n:\r\n        nn:\r\n          x: changed\r\n          y: don&#39;t touch # not touched\r\n    other_a:\r\n      a:\r\n        x: don&#39;t touch # not touched\r\n        # y deleted\r\n    other_b:\r\n      b:\r\n        bb:\r\n          x: don&#39;t touch # not touched\r\n          # y deleted\r\nanother_other:\r\n  x: don&#39;t touch # not touched\r\n  # y deleted\r\n```\r\n\r\nMaybe there are solutions that are quite compact, maybe there are solutions that are performant because they avoid traversing the tree twice, or maybe there are even solutions that achieve both.\r\n\r\nI&#39;m interested in all of them, but so far, I haven&#39;t found any.\r\n",
        "link": "https://stackoverflow.com/questions/79637297/apply-jq-functions-conditionally-to-matching-and-non-matching-json-subtrees",
        "title": "Apply jq functions conditionally to matching and non-matching JSON subtrees"
    },
    {
        "tags": [
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 23460,
                    "reputation": 179409,
                    "user_id": 58808,
                    "user_type": "registered",
                    "accept_rate": 78,
                    "profile_image": "https://www.gravatar.com/avatar/7cefc64f7b1b53513625bf3487ecd16d?s=256&d=identicon&r=PG",
                    "display_name": "Ionuț G. Stan",
                    "link": "https://stackoverflow.com/users/58808/ionu%c8%9b-g-stan"
                },
                "edited": false,
                "score": 2,
                "creation_date": 1748246341,
                "post_id": 79638468,
                "comment_id": 140458743,
                "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": 1748246656,
                "post_id": 79638468,
                "comment_id": 140458756,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2927437,
                    "reputation": 1441,
                    "user_id": 2508466,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/UHx7w.jpg?s=256",
                    "display_name": "yaccob",
                    "link": "https://stackoverflow.com/users/2508466/yaccob"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1748273934,
                "post_id": 79638468,
                "comment_id": 140460125,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2927437,
                    "reputation": 1441,
                    "user_id": 2508466,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/UHx7w.jpg?s=256",
                    "display_name": "yaccob",
                    "link": "https://stackoverflow.com/users/2508466/yaccob"
                },
                "reply_to_user": {
                    "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": 1748274813,
                "post_id": 79638468,
                "comment_id": 140460149,
                "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": 1748281545,
                "post_id": 79638468,
                "comment_id": 140460391,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 2927437,
                    "reputation": 1441,
                    "user_id": 2508466,
                    "user_type": "registered",
                    "accept_rate": 0,
                    "profile_image": "https://i.sstatic.net/UHx7w.jpg?s=256",
                    "display_name": "yaccob",
                    "link": "https://stackoverflow.com/users/2508466/yaccob"
                },
                "reply_to_user": {
                    "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": 1748302156,
                "post_id": 79638468,
                "comment_id": 140460954,
                "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": 1748332185,
                "post_id": 79638468,
                "comment_id": 140461627,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": true,
                "score": 2,
                "last_activity_date": 1748303864,
                "creation_date": 1748303864,
                "answer_id": 79639675,
                "question_id": 79638468,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Finally I found that there is an amazingly straightforward way to fulfill all requirements specified in my original post.\r\n\r\nKey to the solution is, that filters always receive an input (accessible as `.`), so it&#39;s simply not necessary to pass a parameterized function. You can pass any callback function that processes the output of the calling function:\r\n\r\n```lang-jq\r\ndef process_matching_and_others(path_list; filter_for_matching; filter_for_others):\r\n  reduce paths(objects) as $p (\r\n    .;\r\n    if $p[:path_list | length] == path_list\r\n    then getpath($p) |= matching\r\n    else getpath($p) |= others\r\n    end\r\n  )\r\n;\r\n\r\ndef callback_1: if has(&quot;x&quot;) then .x = &quot;changed&quot; else . end;\r\ndef callback_2: if has(&quot;y&quot;) then del(.y) else . end;\r\n\r\nprocess_matching_and_others([&quot;deep&quot;,&quot;path&quot;,&quot;matching&quot;]; callback_1; callback_2)\r\n```\r\n\r\nOr you simply pass an appropriate filter that does the processing you want. Very similar to a lambda expression in other programming languages. This is an even more dynamic approach.\r\n\r\n```lang-jq\r\ndef process_matching_and_others(path_list; filter_for_matching; filter_for_others):\r\n  reduce paths(objects) as $p (\r\n    .;\r\n    if $p[:path_list | length] == path_list\r\n    then getpath($p) |= matching\r\n    else getpath($p) |= others\r\n    end\r\n  )\r\n;\r\n\r\nprocess_matching_and_others(\r\n  [&quot;deep&quot;,&quot;path&quot;,&quot;matching&quot;];\r\n  if has(&quot;x&quot;) then .x = &quot;changed&quot; else . end;\r\n  if has(&quot;y&quot;) then del(.y) else . end\r\n)\r\n```\r\n",
                "title": "Pass parameterized functions as callbacks to `jq` function"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1748303974,
        "creation_date": 1748243721,
        "last_edit_date": 1748303974,
        "question_id": 79638468,
        "body_markdown": "I&#39;d like to dynamically pass parameterized processing functions as callbacks to a selective traversing function (`process_matching_and_others`).\r\n\r\nIn the example below, that&#39;s based on [this excellent answer to a different question](https://stackoverflow.com/questions/79637297/apply-jq-functions-conditionally-to-matching-and-non-matching-json-subtrees#answer-79637338), I statically define the callback functions.\r\nThis works, but has some disadvantages.\r\n\r\nApart from lacking encapsulation in general, my concern is, that I can&#39;t move the generic traversing function (`process_matching_and_others`) to a library.\r\n\r\nI understood that `jq` doesn&#39;t support lambdas in the way, other programming languages do.\r\n\r\nIs there any way to achieve the goal of ***dynamically define callbacks*** when invoking the traversal function?\r\n\r\nOr maybe a completely different approach of encapsulating the traversal while defining the processing outside the traversal function?\r\n\r\nI thought about the option to let the traversal function output two subtrees that can then be processed separately and finally be merged.\r\nBut I hope for something more straightforward and less verbose. \r\n\r\nHere my current code and how I verify it:\r\n\r\n```lang-bash\r\n$ yq -y -f demo.jq input.yaml &gt; actual.yaml \\\r\n&amp;&amp; diff expected.yaml actual.yaml \\\r\n&amp;&amp; echo &quot;SUCCESS&quot; || echo &quot;FAILURE&quot;\r\n```\r\n```lang-jq\r\n# demo.jq\r\ndef callback_1(node): if node | has(&quot;x&quot;) then node.x = &quot;changed&quot; else . end;\r\ndef callback_2(node): if node | has(&quot;y&quot;) then del(node.y) else . end;\r\n\r\n# This function invokes one callback for objects that are children of path_list and another callback for objects that aren&#39;t. \r\n# The current approach works as long as the callbacks are defined before the traverse function is defined. \r\n# I&#39;d rather like to leave it to the caller of the traverse-function to decide how to process nodes that match the path and how to process others.\r\ndef process_matching_and_others(path_list):\r\n  reduce paths(objects) as $p (.; if $p[:path_list | length] == path_list then callback_1(getpath($p)) else callback_2(getpath($p)) end)\r\n;\r\n\r\nprocess_matching_and_others(\r\n  [&quot;deep&quot;,&quot;path&quot;,&quot;matching&quot;]\r\n)\r\n\r\n# What I&#39;d like to do instead would be something like this: \r\n# process_matching_and_others(\r\n#   [&quot;deep&quot;,&quot;path&quot;,&quot;matching&quot;]; callback_x; callback_y\r\n# )\r\n# But I don&#39;t know how to achieve something similar, because the callbacks require an argument that&#39;s passed on invocation of the callbacks by traverse_and_invoke_callbacks\r\n```\r\n```lang-yaml\r\n# input.yaml\r\ndeep:\r\n  path:\r\n    matching:\r\n      m:\r\n        x: change it\r\n        y: don&#39;t touch\r\n      n:\r\n        nn:\r\n          x: change it\r\n          y: don&#39;t touch\r\n    other_a:\r\n      a:\r\n        x: don&#39;t touch\r\n        y: delete it\r\n    other_b:\r\n      b:\r\n        bb:\r\n          x: don&#39;t touch\r\n          y: delete it\r\n    other_list:\r\n      - a\r\n      - b\r\n      - c\r\nanother_other:\r\n  - a:\r\n      x: don&#39;t touch\r\n      y: delete it\r\n  - a:\r\n      x: don&#39;t touch\r\n      y: delete it\r\n```\r\n```lang-yaml\r\n# expected.yaml\r\ndeep:\r\n  path:\r\n    matching:\r\n      m:\r\n        x: changed\r\n        y: don&#39;t touch\r\n      n:\r\n        nn:\r\n          x: changed\r\n          y: don&#39;t touch\r\n    other_a:\r\n      a:\r\n        x: don&#39;t touch\r\n    other_b:\r\n      b:\r\n        bb:\r\n          x: don&#39;t touch\r\n    other_list:\r\n      - a\r\n      - b\r\n      - c\r\nanother_other:\r\n  - a:\r\n      x: don&#39;t touch\r\n  - a:\r\n      x: don&#39;t touch\r\n\r\nSUCCESS\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/79638468/pass-parameterized-functions-as-callbacks-to-jq-function",
        "title": "Pass parameterized functions as callbacks to `jq` function"
    },
    {
        "tags": [
            "json",
            "csv",
            "jq",
            "pretty-print",
            "miller"
        ],
        "answers": [
            {
                "up_vote_count": 0,
                "is_accepted": true,
                "score": 0,
                "last_activity_date": 1748377566,
                "last_edit_date": 1748377566,
                "creation_date": 1748376308,
                "answer_id": 79641132,
                "question_id": 79641106,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You won&#39;t need both `jq` *and* `mlr`. Pick your favorite. Here&#39;s an approach using `jq` with `@csv`:\r\n```sh\r\njq -r &#39;.data[] | [.id, .name, ._embedded.addresses[0].address] | @csv&#39;\r\n```\r\n```csv\r\n100920,&quot;bam&quot;,&quot;10.244.134.115&quot;\r\n100983,&quot;testrecord&quot;,&quot;10.244.134.115&quot;\r\n101001,&quot;testrecord2lab&quot;,&quot;10.244.134.115&quot;\r\n101009,&quot;a&quot;,&quot;10.244.134.100&quot;\r\n101019,&quot;test&quot;,&quot;10.244.134.101&quot;\r\n101020,&quot;something&quot;,\r\n101024,&quot;db&quot;,&quot;10.244.134.11&quot;\r\n101036,&quot;hello&quot;,&quot;192.168.30.102&quot;\r\n101037,&quot;external.com&quot;,\r\n101038,&quot;hey.dbacevic.com&quot;,\r\n101039,&quot;testexternal&quot;,\r\n101043,&quot;ns1&quot;,&quot;10.244.134.134&quot;\r\n101044,&quot;cname&quot;,\r\n101051,&quot;haha&quot;,&quot;10.244.134.102&quot;\r\n101063,&quot;testsomething&quot;,&quot;192.168.30.100&quot;\r\n101103,&quot;test&quot;,\r\n101121,&quot;hostnamefromgateway&quot;,&quot;192.168.30.130&quot;\r\n101128,&quot;micetro-central&quot;,&quot;10.244.134.219&quot;\r\n101144,&quot;testingdhcp&quot;,&quot;191.168.200.242&quot;\r\n101167,&quot;testCNAME&quot;,\r\n101168,&quot;testCNAMEtwo&quot;,\r\n101169,&quot;test&quot;,\r\n101170,&quot;test&quot;,\r\n101174,&quot;asd&quot;,&quot;1.1.1.1&quot;\r\n101179,&quot;test&quot;,&quot;2.2.2.2&quot;\r\n101184,&quot;arrray1&quot;,&quot;3.3.3.3&quot;\r\n101189,&quot;array2&quot;,&quot;4.4.4.4&quot;\r\n101195,&quot;ghr&quot;,&quot;6.6.6.6&quot;\r\n```\r\n[Demo](https://play.jqlang.org/s/6JMzoI_pSrsBgEB)\r\n\r\nNotes:\r\n\r\n- To add a header line, prepend it statically, e.g. as `[&quot;id&quot;, &quot;name&quot;, &quot;address&quot;], (.data[] | [.id, .name, ._embedded.addresses[0].address]) | @csv`. [Demo](https://play.jqlang.org/s/b365WgJ45EYR26v)\r\n\r\n- To print literally `{}` or `[]` if traversing the path `._embedded.addresses[0].address` fails at some point, you could use the `//` operator to provide alternatives, and `@json` to transform such empty container into a JSON-encoded string. Replace the traversal with `(._embedded.addresses[0].address // ._embedded.addresses // ._embedded | strings // @json)`. [Demo](https://play.jqlang.org/s/ERCMuB5Jjhe1uua)\r\n- To produce multiple lines if the `.addresses` array contains more than one item, iterate over them using no index. For example: `.data[] | (._embedded.addresses[]? // null) as {$address} | [.id, .name, $address] | @csv` [Demo](https://play.jqlang.org/s/gyjDzXHH0pyMwAw)",
                "title": "CSV/PPrint output/conversion from json via the command line (linux)"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1748377566,
        "creation_date": 1748374842,
        "question_id": 79641106,
        "body_markdown": "I&#39;d like to get a csv/prettyprint output from the following `json`.\r\n\r\n```\r\n{\r\n  &quot;count&quot;: 28,\r\n  &quot;data&quot;: [\r\n    {\r\n      &quot;id&quot;: 100920,\r\n      &quot;name&quot;: &quot;bam&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;10.244.134.115&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 100983,\r\n      &quot;name&quot;: &quot;testrecord&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;10.244.134.115&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101001,\r\n      &quot;name&quot;: &quot;testrecord2lab&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;10.244.134.115&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101009,\r\n      &quot;name&quot;: &quot;a&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;10.244.134.100&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101019,\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;10.244.134.101&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101020,\r\n      &quot;name&quot;: &quot;something&quot;,\r\n      &quot;_embedded&quot;: {}\r\n    },\r\n    {\r\n      &quot;id&quot;: 101024,\r\n      &quot;name&quot;: &quot;db&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;10.244.134.11&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101036,\r\n      &quot;name&quot;: &quot;hello&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;192.168.30.102&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101037,\r\n      &quot;name&quot;: &quot;external.com&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: []\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101038,\r\n      &quot;name&quot;: &quot;hey.dbacevic.com&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: []\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101039,\r\n      &quot;name&quot;: &quot;testexternal&quot;,\r\n      &quot;_embedded&quot;: {}\r\n    },\r\n    {\r\n      &quot;id&quot;: 101043,\r\n      &quot;name&quot;: &quot;ns1&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;10.244.134.134&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101044,\r\n      &quot;name&quot;: &quot;cname&quot;,\r\n      &quot;_embedded&quot;: {}\r\n    },\r\n    {\r\n      &quot;id&quot;: 101051,\r\n      &quot;name&quot;: &quot;haha&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;10.244.134.102&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101063,\r\n      &quot;name&quot;: &quot;testsomething&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;192.168.30.100&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101103,\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;_embedded&quot;: {}\r\n    },\r\n    {\r\n      &quot;id&quot;: 101121,\r\n      &quot;name&quot;: &quot;hostnamefromgateway&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;192.168.30.130&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101128,\r\n      &quot;name&quot;: &quot;micetro-central&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;10.244.134.219&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101144,\r\n      &quot;name&quot;: &quot;testingdhcp&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;191.168.200.242&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101167,\r\n      &quot;name&quot;: &quot;testCNAME&quot;,\r\n      &quot;_embedded&quot;: {}\r\n    },\r\n    {\r\n      &quot;id&quot;: 101168,\r\n      &quot;name&quot;: &quot;testCNAMEtwo&quot;,\r\n      &quot;_embedded&quot;: {}\r\n    },\r\n    {\r\n      &quot;id&quot;: 101169,\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;_embedded&quot;: {}\r\n    },\r\n    {\r\n      &quot;id&quot;: 101170,\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;_embedded&quot;: {}\r\n    },\r\n    {\r\n      &quot;id&quot;: 101174,\r\n      &quot;name&quot;: &quot;asd&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;1.1.1.1&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101179,\r\n      &quot;name&quot;: &quot;test&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;2.2.2.2&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101184,\r\n      &quot;name&quot;: &quot;arrray1&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;3.3.3.3&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101189,\r\n      &quot;name&quot;: &quot;array2&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;4.4.4.4&quot;\r\n          }\r\n        ]\r\n      }\r\n    },\r\n    {\r\n      &quot;id&quot;: 101195,\r\n      &quot;name&quot;: &quot;ghr&quot;,\r\n      &quot;_embedded&quot;: {\r\n        &quot;addresses&quot;: [\r\n          {\r\n            &quot;address&quot;: &quot;6.6.6.6&quot;\r\n          }\r\n        ]\r\n      }\r\n    }\r\n  ]\r\n}\r\n```\r\n\r\nSomething along the lines of:\r\n\r\n```\r\nid,name,address\r\n101121,hostnamefromgateway,192.168.30.130\r\n101128,micetro-central,10.244.134.219\r\n101144,testingdhcp,191.168.200.242\r\n101103,test,{}\r\n101037,external.com,[]\r\n101038,hey.dbacevic.com,[]\r\n...\r\n```\r\n\r\nSo far I&#39;ve been able to get a result like this using `jq &#39;del(.count) | .data[]&#39; | mlr --ijson --ocsv unsparsify`. \r\n\r\n*Note: The input is from a `curl` and not from a file just to be clear.*\r\n\r\n```\r\nid,name,_embedded.addresses.1.address\r\n100920,bam,10.244.134.115\r\n100983,testrecord,10.244.134.115\r\n101001,testrecord2lab,10.244.134.115\r\n101009,a,10.244.134.100\r\n101019,test,10.244.134.101\r\n\r\nid,name,_embedded\r\n101020,something,{}\r\n\r\nid,name,_embedded.addresses.1.address\r\n101024,db,10.244.134.11\r\n101036,hello,192.168.30.102\r\n\r\nid,name,_embedded.addresses\r\n101037,external.com,[]\r\n101038,hey.dbacevic.com,[]\r\n\r\nid,name,_embedded\r\n101039,testexternal,{}\r\n\r\nid,name,_embedded.addresses.1.address\r\n101043,ns1,10.244.134.134\r\n\r\nid,name,_embedded\r\n101044,cname,{}\r\n\r\nid,name,_embedded.addresses.1.address\r\n101051,haha,10.244.134.102\r\n101063,testsomething,192.168.30.100\r\n\r\nid,name,_embedded\r\n101103,test,{}\r\n\r\nid,name,_embedded.addresses.1.address\r\n101121,hostnamefromgateway,192.168.30.130\r\n101128,micetro-central,10.244.134.219\r\n101144,testingdhcp,191.168.200.242\r\n\r\nid,name,_embedded\r\n101167,testCNAME,{}\r\n101168,testCNAMEtwo,{}\r\n101169,test,{}\r\n101170,test,{}\r\n\r\nid,name,_embedded.addresses.1.address\r\n101174,asd,1.1.1.1\r\n101179,test,2.2.2.2\r\n101184,arrray1,3.3.3.3\r\n101189,array2,4.4.4.4\r\n101195,ghr,6.6.6.6\r\n```\r\n\r\nIs there a way to achieve what I need while only resorting to CLI and not some third party UI websites?",
        "link": "https://stackoverflow.com/questions/79641106/csv-pprint-output-conversion-from-json-via-the-command-line-linux",
        "title": "CSV/PPrint output/conversion from json via the command line (linux)"
    },
    {
        "tags": [
            "json",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 6196394,
                    "reputation": 86601,
                    "user_id": 5291015,
                    "user_type": "registered",
                    "accept_rate": 100,
                    "profile_image": "https://i.sstatic.net/4tAvO.jpg?s=256",
                    "display_name": "Inian",
                    "link": "https://stackoverflow.com/users/5291015/inian"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1748506911,
                "post_id": 79643490,
                "comment_id": 140468654,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1748506843,
        "creation_date": 1748504412,
        "question_id": 79643490,
        "body_markdown": "I can&#39;t seem to get jq to escape a TAB character for me properly. This is a json I&#39;m working with:\r\n\r\n    {\r\n      &quot;api01&quot;: {\r\n        &quot;before&quot;: {\r\n          &quot;path&quot;: &quot;api01&quot;,\r\n          &quot;user&quot;: &quot;admin&quot;\r\n        }\r\n      },\r\n      &quot;server01&quot;: {\r\n        &quot;before&quot;: {\r\n          &quot;path&quot;: &quot;server01&quot;,\r\n          &quot;user&quot;: &quot;admin&quot;\r\n        }\r\n      },\r\n      &quot;server11&quot;: {\r\n        &quot;before&quot;: {\r\n          &quot;path&quot;: &quot;server11&quot;,\r\n          &quot;user&quot;: &quot;admin&quot;\r\n        }\r\n      },\r\n      &quot;staging01&quot;: {\r\n        &quot;after&quot;: {\r\n          &quot;path&quot;: &quot;/home/admin/test/user/dotfiles&quot;,\r\n          &quot;user&quot;: &quot;git&quot;\r\n        },\r\n        &quot;before&quot;: {\r\n          &quot;path&quot;: &quot;staging01&quot;,\r\n          &quot;user&quot;: &quot;admin&quot;\r\n        }\r\n      }\r\n    }\r\n\r\nNow I tried to iterate over every json key and value in bash and output the corresponding string:\r\n\r\n```\r\njq &#39;to_entries[] | &quot;\\(.key)\\t\\(.value)&quot;&#39; test.json | while IFS=$&#39;\\t&#39; read -r key value; do\r\n  echo &quot;key = $key, value = $value&quot;\r\ndone\r\n```\r\n\r\nBut the output is not split into key and value pairs:\r\n\r\n    key = &quot;api01\\t{\\&quot;before\\&quot;:{\\&quot;path\\&quot;:\\&quot;api01\\&quot;,\\&quot;user\\&quot;:\\&quot;admin\\&quot;}}&quot;, value =\r\n    key = &quot;server01\\t{\\&quot;before\\&quot;:{\\&quot;path\\&quot;:\\&quot;server01\\&quot;,\\&quot;user\\&quot;:\\&quot;admin\\&quot;}}&quot;, value =\r\n    key = &quot;server11\\t{\\&quot;before\\&quot;:{\\&quot;path\\&quot;:\\&quot;server11\\&quot;,\\&quot;user\\&quot;:\\&quot;admin\\&quot;}}&quot;, value =\r\n    key = &quot;staging01\\t{\\&quot;after\\&quot;:{\\&quot;path\\&quot;:\\&quot;/home/admin/test/user/dotfiles\\&quot;,\\&quot;user\\&quot;:\\&quot;git\\&quot;},\\&quot;before\\&quot;:{\\&quot;path\\&quot;:\\&quot;staging01\\&quot;,\\&quot;user\\&quot;:\\&quot;admin\\&quot;}}&quot;, value =\r\n\r\nAs you can see `value = `, so value remains unassigned.\r\n\r\nThe problem seems to be that jq inserts the \\t character literally, as can be seen in this hexdump:\r\n\r\n    jq &#39;to_entries[] | &quot;\\(.key)\\t\\(.value)&quot;&#39; test.json | hexdump -C\r\n\r\n\r\n    00000000  22 61 70 69 30 31 5c 74  7b 5c 22 62 65 66 6f 72  |&quot;api01\\t{\\&quot;befor|\r\n    00000010  65 5c 22 3a 7b 5c 22 70  61 74 68 5c 22 3a 5c 22  |e\\&quot;:{\\&quot;path\\&quot;:\\&quot;|\r\n    00000020  61 70 69 30 31 5c 22 2c  5c 22 75 73 65 72 5c 22  |api01\\&quot;,\\&quot;user\\&quot;|\r\n    00000030  3a 5c 22 61 64 6d 69 6e  5c 22 7d 7d 22 0a 22 73  |:\\&quot;admin\\&quot;}}&quot;.&quot;s|\r\n    00000040  65 72 76 65 72 30 31 5c  74 7b 5c 22 62 65 66 6f  |erver01\\t{\\&quot;befo|\r\n    00000050  72 65 5c 22 3a 7b 5c 22  70 61 74 68 5c 22 3a 5c  |re\\&quot;:{\\&quot;path\\&quot;:\\|\r\n    00000060  22 73 65 72 76 65 72 30  31 5c 22 2c 5c 22 75 73  |&quot;server01\\&quot;,\\&quot;us|\r\n    00000070  65 72 5c 22 3a 5c 22 61  64 6d 69 6e 5c 22 7d 7d  |er\\&quot;:\\&quot;admin\\&quot;}}|\r\n    00000080  22 0a 22 73 65 72 76 65  72 31 31 5c 74 7b 5c 22  |&quot;.&quot;server11\\t{\\&quot;|\r\n    00000090  62 65 66 6f 72 65 5c 22  3a 7b 5c 22 70 61 74 68  |before\\&quot;:{\\&quot;path|\r\n    000000a0  5c 22 3a 5c 22 73 65 72  76 65 72 31 31 5c 22 2c  |\\&quot;:\\&quot;server11\\&quot;,|\r\n    000000b0  5c 22 75 73 65 72 5c 22  3a 5c 22 61 64 6d 69 6e  |\\&quot;user\\&quot;:\\&quot;admin|\r\n    000000c0  5c 22 7d 7d 22 0a 22 73  74 61 67 69 6e 67 30 31  |\\&quot;}}&quot;.&quot;staging01|\r\n    000000d0  5c 74 7b 5c 22 61 66 74  65 72 5c 22 3a 7b 5c 22  |\\t{\\&quot;after\\&quot;:{\\&quot;|\r\n    000000e0  70 61 74 68 5c 22 3a 5c  22 2f 68 6f 6d 65 2f 61  |path\\&quot;:\\&quot;/home/a|\r\n    000000f0  64 6d 69 6e 2f 74 65 73  74 2f 75 73 65 72 2f 64  |dmin/test/user/d|\r\n    00000100  6f 74 66 69 6c 65 73 5c  22 2c 5c 22 75 73 65 72  |otfiles\\&quot;,\\&quot;user|\r\n    00000110  5c 22 3a 5c 22 67 69 74  5c 22 7d 2c 5c 22 62 65  |\\&quot;:\\&quot;git\\&quot;},\\&quot;be|\r\n    00000120  66 6f 72 65 5c 22 3a 7b  5c 22 70 61 74 68 5c 22  |fore\\&quot;:{\\&quot;path\\&quot;|\r\n    00000130  3a 5c 22 73 74 61 67 69  6e 67 30 31 5c 22 2c 5c  |:\\&quot;staging01\\&quot;,\\|\r\n    00000140  22 75 73 65 72 5c 22 3a  5c 22 61 64 6d 69 6e 5c  |&quot;user\\&quot;:\\&quot;admin\\|\r\n    00000150  22 7d 7d 22 0a                                    |&quot;}}&quot;.|\r\n    00000155\r\n\r\nWhere literal `\\t` corresponds to (`5c 74`).\r\n\r\nSo how do I advise `jq` to output an actual tab character so that it can be split correctly by my bash `while read`?",
        "link": "https://stackoverflow.com/questions/79643490/make-jq-output-an-escaped-sequence",
        "title": "Make jq output an escaped sequence"
    },
    {
        "tags": [
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 5,
                "is_accepted": true,
                "score": 5,
                "last_activity_date": 1749502863,
                "last_edit_date": 1749502863,
                "creation_date": 1749500139,
                "answer_id": 79659485,
                "question_id": 79659475,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Making content from an outer context available is an ideal use case for jq&#39;s variable references: `X as $name | ...` defines `$name` as available to refer to  within `...` on the right.\r\n\r\n```jq\r\n.current_fish_version as $version\r\n| .fish[]\r\n| select(.version == $version)\r\n| .name\r\n```",
                "title": "Select object from list where value is elsewhere in the JSON"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1749502863,
        "creation_date": 1749499815,
        "last_edit_date": 1749500243,
        "question_id": 79659475,
        "body_markdown": "Let&#39;s say I have a bit of JSON that looks like this\r\n```lang-json\r\n{\r\n    &quot;fish&quot;: [\r\n        {\r\n            &quot;name&quot;: &quot;pike&quot;,\r\n            &quot;version&quot;: 1\r\n        },\r\n        {\r\n            &quot;name&quot;: &quot;haddock&quot;,\r\n            &quot;version&quot;: 2\r\n        }\r\n    ],\r\n    &quot;current_fish_version&quot;: 2\r\n}\r\n```\r\n\r\nAnd I wanted to get the name of the fish with the version equal to current_fish_version.\r\n\r\nHow would I go about doing that?\r\n   ",
        "link": "https://stackoverflow.com/questions/79659475/select-object-from-list-where-value-is-elsewhere-in-the-json",
        "title": "Select object from list where value is elsewhere in the JSON"
    },
    {
        "tags": [
            "json",
            "debugging",
            "jq"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 2435703,
                    "reputation": 27493,
                    "user_id": 2125671,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/13a492143ab4a2575b5a1f500691193c?s=256&d=identicon&r=PG",
                    "display_name": "Philippe",
                    "link": "https://stackoverflow.com/users/2125671/philippe"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1752001876,
                "post_id": 79694539,
                "comment_id": 140574771,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 9629731,
                    "reputation": 51350,
                    "user_id": 10248678,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/d8f818402f22d485b135a3b685ef908e?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "oguz ismail",
                    "link": "https://stackoverflow.com/users/10248678/oguz-ismail"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1752001962,
                "post_id": 79694539,
                "comment_id": 140574783,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1706838,
                    "reputation": 541,
                    "user_id": 1565742,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/93313a2845c019dd97aec824e44f5672?s=256&d=identicon&r=PG",
                    "display_name": "diekunstderfuge",
                    "link": "https://stackoverflow.com/users/1565742/diekunstderfuge"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1752091398,
                "post_id": 79694539,
                "comment_id": 140577987,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1751991358,
        "creation_date": 1751991358,
        "question_id": 79694539,
        "body_markdown": "I&#39;m trying to get more information on an error in `jq`.\r\n\r\nI have two files, let&#39;s call them `file1.json` and `file2.json`, both of which contain an array of objects that I want to join by a common property, `.id`. I&#39;m using a combination of the `INDEX` and `JOIN` built-in functions. (Shout-out to this [incredibly helpful blog post][1] for helping me understand how `INDEX` and `JOIN` work.)\r\n\r\nI&#39;m running the following command:\r\n```\r\njq &#39;[JOIN(INDEX(input[], .id); .[]; (.id|tostring); add)]&#39; file1.json file2.json &gt; joined.json\r\n```\r\nwhich gives me the following error:\r\n```\r\njq: error (at file2.json:11329): break\r\n```\r\nLine 11329 is the last line of `file2.json`, which contains the closing `]` for the JSON array. Here is the end of `file2.json`\r\n```\r\n 1      [\r\n ...      ...,\r\n 11304    {\r\n 11305      &quot;count_by_file_type&quot;: {\r\n 11306        &quot;gitignore&quot;: 1,\r\n 11307        &quot;json&quot;: 1\r\n 11308      },\r\n 11309      &quot;id&quot;: 972\r\n 11310    },\r\n 11311    {\r\n 11312      &quot;count_by_file_type&quot;: {\r\n 11313        &quot;html&quot;: 3\r\n 11314      },\r\n 11315      &quot;id&quot;: 975\r\n 11316    },\r\n 11317    {\r\n 11318      &quot;count_by_file_type&quot;: {\r\n 11319        &quot;html&quot;: 3\r\n 11320      },\r\n 11321      &quot;id&quot;: 994\r\n 11322    },\r\n 11323    {\r\n 11324      &quot;count_by_file_type&quot;: {\r\n 11325        &quot;html&quot;: 2\r\n 11326      },\r\n 11327      &quot;id&quot;: 999\r\n 11328    }\r\n 11329  ]\r\n```\r\nI have no idea what&#39;s causing the `break` to happen (I&#39;m assuming it&#39;s the `JOIN` function but really I don&#39;t know that for sure). I know there&#39;s a `debug` function but I don&#39;t believe it&#39;s possible to use it to &quot;step into&quot; a function. Because it&#39;s erroring on the last line of the file I thought maybe it found something unexpected instead of `EOF`, or that somehow it was invalid JSON. I checked with a validator and `file2.json` is valid JSON.\r\n\r\nIf I could drill down into the `JOIN` function and debug the intermediate inputs, maybe `jq` would give me a more helpful error message. I&#39;ve tried `try-catch` but it&#39;s not producing the output I&#39;d want (if I even knew what I wanted it to print on failure). I feel like I don&#39;t even have enough information to know what to try next.\r\n\r\nDoes anybody have ideas for how I could debug this further? Thanks!!\r\n\r\n  [1]: https://qmacro.org/blog/posts/2022/06/23/understanding-jq&#39;s-sql-style-operators-join-and-index/",
        "link": "https://stackoverflow.com/questions/79694539/debugging-break-error-in-jq-join-function",
        "title": "debugging break error in jq JOIN function"
    },
    {
        "tags": [
            "macos",
            "jq",
            "zsh"
        ],
        "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": 0,
                "creation_date": 1752090366,
                "post_id": 79696130,
                "comment_id": 140577941,
                "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": 1752090889,
                "post_id": 79696130,
                "comment_id": 140577964,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "is_answered": false,
        "answer_count": 0,
        "score": 0,
        "last_activity_date": 1752090347,
        "creation_date": 1752087593,
        "last_edit_date": 1752090347,
        "question_id": 79696130,
        "body_markdown": "I&#39;m trying to pull a bunch of metadata from a bunch of epubs.  I&#39;m on a Mac, using Ace by Daisy.\r\n\r\nSo far I have:\r\n\r\n    #!/bin/zsh\r\n    \r\n    if [[ -e ./report.txt ]]; then  \r\n        rm ./report.txt\r\n    fi\r\n    \r\n    titles=(&quot;ISBN&quot; &quot;Features&quot;)\r\n    fields=(&quot;dc:identifier&quot; &quot;schema:accessibilityFeature&quot;)\r\n    \r\n    for file in $PWD/unprocessed/*\r\n    do\r\n       filename=$file:t:r\r\n       report=$PWD/output/$filename/report.json\r\n       ace --outdir $PWD/output/$filename $file\r\n       mv $file $PWD/processed/\r\n        \r\n       for ((i=1; i&lt;=${#titles[@]}; i++))\r\n       do\r\n           echo -n &quot;${titles[$i]}: &quot; &gt;&gt; report.txt\r\n           cat $report | jq -r &#39;.&quot;earl:testSubject&quot;.metadata.&quot;${fields[$i]}&quot;&#39; &gt;&gt; report.txt\r\n       done\r\n    done\r\n\r\nWhen I run it, I get a lot of &quot;null&quot; back from the jq call.  But if I run:\r\n\r\n    cat $report | jq -r &#39;.&quot;earl:testSubject&quot;.metadata.&quot;dc:identifier&quot;&#39; &gt;&gt; report.txt\r\n...this will return the data I expect. Do i need to construct the call differently?",
        "link": "https://stackoverflow.com/questions/79696130/using-zsh-and-ace-to-pull-metadata-from-epub-using-recursion",
        "title": "Using zsh and ace to pull metadata from epub using recursion"
    },
    {
        "tags": [
            "json",
            "xml",
            "jq",
            "yq"
        ],
        "comments": [
            {
                "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": 1752316100,
                "post_id": 79699191,
                "comment_id": 140584408,
                "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": 1752316430,
                "post_id": 79699191,
                "comment_id": 140584414,
                "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": 1752316920,
                "post_id": 79699191,
                "comment_id": 140584425,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 42997298,
                    "reputation": 13,
                    "user_id": 31024636,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f81423f24ac175ed6598b6dc0315b17b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user31024636",
                    "link": "https://stackoverflow.com/users/31024636/user31024636"
                },
                "reply_to_user": {
                    "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": 1752318386,
                "post_id": 79699191,
                "comment_id": 140584449,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 42997298,
                    "reputation": 13,
                    "user_id": 31024636,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f81423f24ac175ed6598b6dc0315b17b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user31024636",
                    "link": "https://stackoverflow.com/users/31024636/user31024636"
                },
                "reply_to_user": {
                    "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": 1752318564,
                "post_id": 79699191,
                "comment_id": 140584453,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 42997298,
                    "reputation": 13,
                    "user_id": 31024636,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/f81423f24ac175ed6598b6dc0315b17b?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "user31024636",
                    "link": "https://stackoverflow.com/users/31024636/user31024636"
                },
                "reply_to_user": {
                    "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": 1752318995,
                "post_id": 79699191,
                "comment_id": 140584463,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1752392159,
                "last_edit_date": 1752392159,
                "creation_date": 1752379925,
                "answer_id": 79699725,
                "question_id": 79699191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Thankyou to @pmf, that is the filter I was after. The issue that I encountered related to a lack of data normalisation, as most keys under Event\\[\\] were: `[&quot;EventData&quot;,&quot;System&quot;,xmlns&quot;]` but one of them was `[&quot;System&quot;,&quot;UserData&quot;,&quot;xmlns&quot;]` . This is almost certainly the cause of the `jq: error (at Security.json:12490): Cannot iterate over null (null)` error. For those looking to troubleshoot the same issue in the future, check all of your keys:\r\n\r\n```bash\r\njq -c &#39;.Event[] | keys&#39; Security.json \\\r\n| sort \\\r\n| uniq -c\r\n```\r\n\r\n(There&#39;s probably a nice way to format it in jq too, but I&#39;m a tad burnt out by this now).\r\n\r\nSelecting for the value that was missing:\r\n\r\n```bash\r\njq &#39;.Event[] | (select(.EventData == null))&#39; Security.json\r\n```\r\n\r\nFinally - I&#39;ve figured out the way to handle this correctly, and it *is* listed in the documentation - the [character &#39;?&#39;](https://jqlang.org/manual/#.%5B%5D?):\r\n\r\n```\r\njq -c &#39;.Event[].EventData?.Data[]? |= {(.Name): .content} | .Event[] | keys&#39; Security.json\r\n```\r\n\r\nThis allows jq to iterate over values that are not arrays or objects (i.e. null) and continue processing. I feel like the documentation should be clarified and that particular paragraph should be linked to the &#39;Cannot iterate over null&#39; error for future troubleshooting.\r\n\r\n----------\r\n\r\n## Other Notes\r\n\r\nAlong the way, I&#39;ve found some rather unintuitive behaviours of jq; for example, if I try to search for occasions where UserData is not null (ie. where the event is UserData not EventData) using the logic of UserData != null, it will still return null values:\r\n\r\n```bash\r\njq -c &#39;.Event[] |= select(.UserData != null) | .Event[].UserData&#39; Security.json\r\nnull\r\nnull\r\nnull\r\n# Several more null\r\n{&quot;ServiceShutdown&quot;:{&quot;xmlns&quot;:&quot;http://manifests.microsoft.com/win/2004/08/windows/\r\n```\r\n\r\nI can&#39;t seem to replace the `|=` with a `|` in the code above either; that just throws an error (because it iterates over null (null) again) - I think I need to read further to understand the filter language.\r\n\r\nThis is best demonstrated with two scripts that count the occurrences of each set of keys. Below, the output of searching &#39;.UserData != null&#39;:\r\n\r\n```\r\njq -c &#39;.Event[] |= select(.UserData != null) | .Event[] | keys&#39; Security.json \r\n\\\r\n| sort \\\r\n| uniq -c\r\n     75 [&quot;EventData&quot;,&quot;System&quot;,&quot;xmlns&quot;]\r\n      1 [&quot;System&quot;,&quot;UserData&quot;,&quot;xmlns&quot;]\r\n```\r\n\r\nBelow, the output of searching &#39;.EventData != null&#39;:\r\n\r\n```\r\njq -c &#39;.Event[] |= select(.EventData != null) | .Event[] | keys&#39; Security.json | sort | uniq -c\r\n    151 [&quot;EventData&quot;,&quot;System&quot;,&quot;xmlns&quot;]\r\n```\r\n\r\nI presume it&#39;s because the filter will return null for the variables until it finds the first occurrence of .UserData, at which point it will only return .UserData. It&#39;s not a strong hypothesis though, as jq will return key values for &quot;EventData&quot; after the first match for &quot;UserData&quot;.",
                "title": "How do I handle child objects properly with jq map()"
            },
            {
                "up_vote_count": 1,
                "is_accepted": true,
                "score": 1,
                "last_activity_date": 1752430913,
                "last_edit_date": 1752430913,
                "creation_date": 1752430251,
                "answer_id": 79700162,
                "question_id": 79699191,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "You really should rewrite it all to use yq. All this preprocessing with SED and removing the attribute prefixes are rather pointless, yq can do that for you if you allowed it to.\r\n\r\nIf you don&#39;t want your attributes prefixed with `+@`, specify an empty prefix using the `--xml-attribute-prefix` switch. Element content is saved under the `&quot;+content&quot;` property in json, you could change that name to simply &quot;content&quot; using `--xml-content-name`. [Check the docs.](https://mikefarah.gitbook.io/yq/usage/xml)\r\n\r\ne.g.,\r\n```\r\n$ cat input.xml\r\n&lt;Event xmlns=&quot;http://schemas.microsoft.com/win/2004/08/events/event&quot;&gt;\r\n  &lt;System&gt;\r\n    &lt;Provider Name=&quot;Microsoft-Windows-Security-Auditing&quot;&gt;\r\n      &lt;Guid&gt;{&amp;lt;GUID&amp;gt;}&lt;/Guid&gt;\r\n    &lt;/Provider&gt;\r\n  &lt;/System&gt;\r\n  &lt;EventData&gt;\r\n    &lt;Data Name=&quot;SubjectUserSid&quot;&gt;S-&amp;lt;SID&amp;gt;&lt;/Data&gt;\r\n    &lt;Data Name=&quot;SubjectUserName&quot;&gt;-&lt;/Data&gt;\r\n    &lt;Data Name=&quot;SubjectDomainName&quot;&gt;-&lt;/Data&gt;\r\n    &lt;Data Name=&quot;SubjectLogonId&quot;&gt;&amp;lt;HEX&amp;gt;&lt;/Data&gt;\r\n    &lt;Data Name=&quot;NewProcessId&quot;&gt;&amp;lt;HEX&amp;gt;&lt;/Data&gt;\r\n    &lt;Data Name=&quot;NewProcessName&quot;&gt;Registry&lt;/Data&gt;\r\n    &lt;Data Name=&quot;TokenElevationType&quot;&gt;%%2000&lt;/Data&gt;\r\n    &lt;Data Name=&quot;ProcessId&quot;&gt;0x0000000000000019&lt;/Data&gt;\r\n    &lt;Data Name=&quot;CommandLine&quot;&gt;&lt;/Data&gt;\r\n    &lt;Data Name=&quot;TargetUserSid&quot;&gt;&amp;lt;HEX&amp;gt;&lt;/Data&gt;\r\n    &lt;Data Name=&quot;TargetUserName&quot;&gt;-&lt;/Data&gt;\r\n  &lt;/EventData&gt;\r\n&lt;/Event&gt;\r\n$ yq -p xml -o json --xml-attribute-prefix &#39;&#39; --xml-content-name Content input.xml\r\n{\r\n  &quot;Event&quot;: {\r\n    &quot;xmlns&quot;: &quot;http://schemas.microsoft.com/win/2004/08/events/event&quot;,\r\n    &quot;System&quot;: {\r\n      &quot;Provider&quot;: {\r\n        &quot;Name&quot;: &quot;Microsoft-Windows-Security-Auditing&quot;,\r\n        &quot;Guid&quot;: &quot;{&lt;GUID&gt;}&quot;\r\n      }\r\n    },\r\n    &quot;EventData&quot;: {\r\n      &quot;Data&quot;: [\r\n        {\r\n          &quot;Content&quot;: &quot;S-&lt;SID&gt;&quot;,\r\n          &quot;Name&quot;: &quot;SubjectUserSid&quot;\r\n        },\r\n        {\r\n          &quot;Content&quot;: &quot;-&quot;,\r\n          &quot;Name&quot;: &quot;SubjectUserName&quot;\r\n        },\r\n        {\r\n          &quot;Content&quot;: &quot;-&quot;,\r\n          &quot;Name&quot;: &quot;SubjectDomainName&quot;\r\n        },\r\n        {\r\n          &quot;Content&quot;: &quot;&lt;HEX&gt;&quot;,\r\n          &quot;Name&quot;: &quot;SubjectLogonId&quot;\r\n        },\r\n        {\r\n          &quot;Content&quot;: &quot;&lt;HEX&gt;&quot;,\r\n          &quot;Name&quot;: &quot;NewProcessId&quot;\r\n        },\r\n        {\r\n          &quot;Content&quot;: &quot;Registry&quot;,\r\n          &quot;Name&quot;: &quot;NewProcessName&quot;\r\n        },\r\n        {\r\n          &quot;Content&quot;: &quot;%%2000&quot;,\r\n          &quot;Name&quot;: &quot;TokenElevationType&quot;\r\n        },\r\n        {\r\n          &quot;Content&quot;: &quot;0x0000000000000019&quot;,\r\n          &quot;Name&quot;: &quot;ProcessId&quot;\r\n        },\r\n        {\r\n          &quot;Name&quot;: &quot;CommandLine&quot;\r\n        },\r\n        {\r\n          &quot;Content&quot;: &quot;&lt;HEX&gt;&quot;,\r\n          &quot;Name&quot;: &quot;TargetUserSid&quot;\r\n        },\r\n        {\r\n          &quot;Content&quot;: &quot;-&quot;,\r\n          &quot;Name&quot;: &quot;TargetUserName&quot;\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}\r\n```\r\n\r\n----\r\n\r\nThen from there, apply your filters like you would with `jq` but in `yq`. It&#39;s mostly the same all around.\r\n\r\nI guess you just wanted to put all the data elements as a dictionary?\r\n\r\n```\r\n$ yq -p xml -o json --xml-attribute-prefix &#39;&#39; --xml-content-name Content &#39;\r\n.Event.EventData.Data |= (map({&quot;key&quot;:.Name, &quot;value&quot;:.Content}) | from_entries)\r\n&#39; input.xml\r\n{\r\n  &quot;Event&quot;: {\r\n    &quot;xmlns&quot;: &quot;http://schemas.microsoft.com/win/2004/08/events/event&quot;,\r\n    &quot;System&quot;: {\r\n      &quot;Provider&quot;: {\r\n        &quot;Name&quot;: &quot;Microsoft-Windows-Security-Auditing&quot;,\r\n        &quot;Guid&quot;: &quot;{&lt;GUID&gt;}&quot;\r\n      }\r\n    },\r\n    &quot;EventData&quot;: {\r\n      &quot;Data&quot;: {\r\n        &quot;SubjectUserSid&quot;: &quot;S-&lt;SID&gt;&quot;,\r\n        &quot;SubjectUserName&quot;: &quot;-&quot;,\r\n        &quot;SubjectDomainName&quot;: &quot;-&quot;,\r\n        &quot;SubjectLogonId&quot;: &quot;&lt;HEX&gt;&quot;,\r\n        &quot;NewProcessId&quot;: &quot;&lt;HEX&gt;&quot;,\r\n        &quot;NewProcessName&quot;: &quot;Registry&quot;,\r\n        &quot;TokenElevationType&quot;: &quot;%%2000&quot;,\r\n        &quot;ProcessId&quot;: &quot;0x0000000000000019&quot;,\r\n        &quot;CommandLine&quot;: null,\r\n        &quot;TargetUserSid&quot;: &quot;&lt;HEX&gt;&quot;,\r\n        &quot;TargetUserName&quot;: &quot;-&quot;\r\n      }\r\n    }\r\n  }\r\n}\r\n```",
                "title": "How do I handle child objects properly with jq map()"
            }
        ],
        "is_answered": true,
        "answer_count": 2,
        "score": 0,
        "last_activity_date": 1752430913,
        "creation_date": 1752315788,
        "last_edit_date": 1752428492,
        "question_id": 79699191,
        "body_markdown": "I&#39;m currently trying to build a pipeline to process Windows .evtx binary logs into usable JSON for easy searching and filtering on Linux, but due to going through xml, there is data that needs to be cleaned up with jq. The bash pipeline is currently this:\r\n\r\n```bash\r\n./evtx_dump.py &lt;File.evtx&gt; \\\r\n| sed -e &#39;s/version=&quot;1.1&quot;/version=&quot;1.0&quot;/g&#39; \\\r\n| yq -p xml -o json \\\r\n| sed -e &#39;s/+@//g&#39; -e &#39;s/+//g&#39; \\\r\n| jq &#39;.Events&#39; &gt; &lt;File.json&gt;\r\n```\r\n\r\nWhen processing the object through the pipeline above, it results in this output:\r\n```json\r\n{\r\n  &quot;xmlns&quot;: &quot;http://schemas.microsoft.com/win/2004/08/events/event&quot;,\r\n  &quot;System&quot;: {\r\n    &quot;Provider&quot;: {\r\n      &quot;Name&quot;: &quot;Microsoft-Windows-Security-Auditing&quot;,\r\n      &quot;Guid&quot;: &quot;{&lt;GUID&gt;}&quot;\r\n    },\r\n    &quot;EventID&quot;: {\r\n      &lt;EVENT-ID data&gt;\r\n  },\r\n  &quot;EventData&quot;: {\r\n    &quot;Data&quot;: [\r\n      {\r\n        &quot;content&quot;: &quot;S-&lt;SID&gt;&quot;,\r\n        &quot;Name&quot;: &quot;SubjectUserSid&quot;\r\n      },\r\n      {\r\n        &quot;content&quot;: &quot;-&quot;,\r\n        &quot;Name&quot;: &quot;SubjectUserName&quot;\r\n      },\r\n      {\r\n        &quot;content&quot;: &quot;-&quot;,\r\n        &quot;Name&quot;: &quot;SubjectDomainName&quot;\r\n      },\r\n      {\r\n        &quot;content&quot;: &quot;&lt;HEX&gt;&quot;,\r\n        &quot;Name&quot;: &quot;SubjectLogonId&quot;\r\n      },\r\n      {\r\n        &quot;content&quot;: &quot;&lt;HEX&gt;&quot;,\r\n        &quot;Name&quot;: &quot;NewProcessId&quot;\r\n      },\r\n      {\r\n        &quot;content&quot;: &quot;Registry&quot;,\r\n        &quot;Name&quot;: &quot;NewProcessName&quot;\r\n      },\r\n      {\r\n        &quot;content&quot;: &quot;%%2000&quot;,\r\n        &quot;Name&quot;: &quot;TokenElevationType&quot;\r\n      },\r\n      {\r\n        &quot;content&quot;: &quot;0x0000000000000019&quot;,\r\n        &quot;Name&quot;: &quot;ProcessId&quot;\r\n      },\r\n      {\r\n        &quot;Name&quot;: &quot;CommandLine&quot;\r\n      },\r\n      {\r\n        &quot;content&quot;: &quot;&lt;HEX&gt;&quot;,\r\n        &quot;Name&quot;: &quot;TargetUserSid&quot;\r\n      },\r\n      {\r\n        &quot;content&quot;: &quot;-&quot;,\r\n        &quot;Name&quot;: &quot;TargetUserName&quot;\r\n      },\r\n      {\r\n     ...\r\n]\r\n```\r\nEverything under .Event[].EventData.Data[] seems to have been organised under an array due to the conversion through XML - some of the array values also seem to have no .content (presumably because the presence of those data points indicates the result is TRUE). I&#39;m able to clean up data a little with a jq filter like this: `.Event[].EventData.Data | map( { (.Name|tostring):(.content|tostring) } ) | add`, but that only seems to work for one event and it throws errors due to the null values. I can&#39;t expand the scope of the filter to this: `.Event[] | map( { (.EventData.Data.Name|tostring):(.EventData.Data.content|tostring) } ) | add`, but that approximates the outcome I&#39;m going for.",
        "link": "https://stackoverflow.com/questions/79699191/how-do-i-handle-child-objects-properly-with-jq-map",
        "title": "How do I handle child objects properly with jq map()"
    },
    {
        "tags": [
            "shell",
            "jq"
        ],
        "answers": [
            {
                "up_vote_count": 1,
                "is_accepted": false,
                "score": 1,
                "last_activity_date": 1753047381,
                "last_edit_date": 1753047381,
                "creation_date": 1753045187,
                "answer_id": 79708374,
                "question_id": 79708368,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Save the value of `.Id` to have access to it within the loop, then compare a substring of it defined by each item&#39;s length to the whole item itself.\r\n```sh\r\n# Your example reduced to the essential parts\r\n\r\n.[] | . as {$Id} | .NetworkSettings.Networks[].DNSNames\r\n| map(select(. != $Id[:length])) | join(&quot; &quot;)\r\n```\r\n```\r\nnextcloud-aio-whiteboard\r\n```\r\n[Demo](https://play.jqlang.org/s/3C1LS-xQIuPQ6SD)\r\n\r\nOther approaches could be using a `startswith` test or checking for a substring search with `index` evaluating to `0`.",
                "title": "How to filter values from a list in JSON with jq where some Id value does not start with value"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 0,
        "last_activity_date": 1753047381,
        "creation_date": 1753044664,
        "question_id": 79708368,
        "body_markdown": "I would like to filter DNSNames where Id does not start with the DNSName.\r\n\r\nGiven the following JSON:\r\n```json\r\n[\r\n    {\r\n        &quot;Id&quot;: &quot;9580cf2dd3161c0e33d8c04a4e84384e28784af65e55c1e84899d9da797902be&quot;,\r\n        &quot;NetworkSettings&quot;: {\r\n            &quot;Networks&quot;: {\r\n                &quot;nextcloud-aio&quot;: {\r\n                    &quot;IPAddress&quot;: &quot;172.18.0.10&quot;,\r\n                    &quot;DNSNames&quot;: [\r\n                        &quot;nextcloud-aio-whiteboard&quot;,\r\n                        &quot;9580cf2dd316&quot;\r\n                    ]\r\n                }\r\n            }\r\n        }\r\n    }\r\n]\r\n```\r\nif I execute the  following query:\r\n```sh\r\njq -r &#39;.[]|&quot;\\(.NetworkSettings.Networks[].IPAddress|select(length &gt; 0) // &quot;# no ip address:&quot;) \\(if .NetworkSettings.Networks[].DNSNames != null then (.NetworkSettings.Networks[].DNSNames|join(&quot; &quot;)) else (.Name|sub(&quot;^/&quot;; &quot;&quot;)|sub(&quot;_1$&quot;; &quot;&quot;)) end)&quot;&#39;\r\n```\r\nI get the following result:\r\n```sh\r\n172.18.0.10 nextcloud-aio-whiteboard 9580cf2dd316\r\n```\r\nHow can I filter out `9580cf2dd316` based in the `Id` `9580cf2dd3161c0e33d8c04a4e84384e28784af65e55c1e84899d9da797902be` so I get the following result?\r\n```sh\r\n172.18.0.10 nextcloud-aio-whiteboard\r\n```",
        "link": "https://stackoverflow.com/questions/79708368/how-to-filter-values-from-a-list-in-json-with-jq-where-some-id-value-does-not-st",
        "title": "How to filter values from a list in JSON with jq where some Id value does not start with value"
    },
    {
        "tags": [
            "bash",
            "jq",
            "variable-expansion"
        ],
        "comments": [
            {
                "owner": {
                    "account_id": 3884753,
                    "reputation": 12739,
                    "user_id": 3216427,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5250f90e782e8210ace9b580a150781f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "joanis",
                    "link": "https://stackoverflow.com/users/3216427/joanis"
                },
                "edited": false,
                "score": 1,
                "creation_date": 1753240581,
                "post_id": 79711268,
                "comment_id": 140610649,
                "content_license": "CC BY-SA 4.0"
            },
            {
                "owner": {
                    "account_id": 1540385,
                    "reputation": 46,
                    "user_id": 1435208,
                    "user_type": "registered",
                    "profile_image": "https://i.sstatic.net/WVaZX.png?s=256",
                    "display_name": "fernan",
                    "link": "https://stackoverflow.com/users/1435208/fernan"
                },
                "reply_to_user": {
                    "account_id": 3884753,
                    "reputation": 12739,
                    "user_id": 3216427,
                    "user_type": "registered",
                    "profile_image": "https://www.gravatar.com/avatar/5250f90e782e8210ace9b580a150781f?s=256&d=identicon&r=PG&f=y&so-version=2",
                    "display_name": "joanis",
                    "link": "https://stackoverflow.com/users/3216427/joanis"
                },
                "edited": false,
                "score": 0,
                "creation_date": 1753298047,
                "post_id": 79711268,
                "comment_id": 140613089,
                "content_license": "CC BY-SA 4.0"
            }
        ],
        "answers": [
            {
                "up_vote_count": 2,
                "is_accepted": false,
                "score": 2,
                "last_activity_date": 1753244455,
                "creation_date": 1753244455,
                "answer_id": 79711304,
                "question_id": 79711268,
                "content_license": "CC BY-SA 4.0",
                "body_markdown": "Try this instead:\r\n\r\n```bash\r\njq &#39;.schemes += [inputs]&#39; &quot;$json_file&quot; &quot;$@&quot; &gt;&quot;$json_file.new&quot;\r\n```",
                "title": "Add new element to existing JSON array with jq in a shell script: problem with variable expansion"
            }
        ],
        "is_answered": true,
        "answer_count": 1,
        "score": 1,
        "last_activity_date": 1753245144,
        "creation_date": 1753240434,
        "question_id": 79711268,
        "body_markdown": "as described in [&quot;Add new element to existing JSON array with jq&quot;](https://stackoverflow.com/questions/42245288/add-new-element-to-existing-json-array-with-jq) I am using this jq form to add elements to a JSON array. \r\n\r\nThis works fine in the command line. Short minimal version here: \r\n\r\n```bash\r\njq &#39;.&quot;schemes&quot; += [{ JSON STRING HERE }]&#39; settings.json &gt; settings.json.new\r\n```\r\n\r\nLong, complete version here, I am trying to add a colorscheme to the windows terminal app: \r\n\r\n```bash\r\njq &#39;.&quot;schemes&quot; += [{\r\n  &quot;name&quot;: &quot;Grape&quot;,\r\n  &quot;black&quot;: &quot;#2d283f&quot;,\r\n  &quot;red&quot;: &quot;#ed2261&quot;,\r\n  &quot;green&quot;: &quot;#1fa91b&quot;,\r\n  &quot;yellow&quot;: &quot;#8ddc20&quot;,\r\n  &quot;blue&quot;: &quot;#487df4&quot;,\r\n  &quot;purple&quot;: &quot;#8d35c9&quot;,\r\n  &quot;cyan&quot;: &quot;#3bdeed&quot;,\r\n  &quot;white&quot;: &quot;#9e9ea0&quot;,\r\n  &quot;brightBlack&quot;: &quot;#59516a&quot;,\r\n  &quot;brightRed&quot;: &quot;#f0729a&quot;,\r\n  &quot;brightGreen&quot;: &quot;#53aa5e&quot;,\r\n  &quot;brightYellow&quot;: &quot;#b2dc87&quot;,\r\n  &quot;brightBlue&quot;: &quot;#a9bcec&quot;,\r\n  &quot;brightPurple&quot;: &quot;#ad81c2&quot;,\r\n  &quot;brightCyan&quot;: &quot;#9de3eb&quot;,\r\n  &quot;brightWhite&quot;: &quot;#a288f7&quot;,\r\n  &quot;background&quot;: &quot;#171423&quot;,\r\n  &quot;foreground&quot;: &quot;#9f9fa1&quot;,\r\n  &quot;selectionBackground&quot;: &quot;#493d70&quot;,\r\n  &quot;cursorColor&quot;: &quot;#a288f7&quot;\r\n}]&#39; ./settings.json &gt; ./settings.json.new\r\n```\r\n\r\nAs said, this works great, and the new colorscheme shows up in Windows Terminal settings. However, when trying to automate this in a shell (bash) script, `jq` chokes. \r\n\r\n```bash\r\n# usage is add_colorscheme.sh colorscheme.json\r\ncolorscheme=$1\r\njson_content=`cat ${colorscheme}`\r\njson_file=&quot;settings.json&quot;\r\njq &#39;.&quot;schemes&quot; += [${json_content}] ${json_file} &gt; ${json_file}.new\r\n```\r\n\r\nI have tried many ways to expand variables, e.g. without braces (`$json_content`), and have also tried without success with other incantations. For example, using `--argjson` in the terminal: \r\n\r\n```bash\r\njson_content=`cat file.json`\r\necho ${json_content}\r\n{ &quot;name&quot;: &quot;Grape&quot;, &quot;black&quot;: &quot;#2d283f&quot;, &quot;red&quot;: &quot;#ed2261&quot;, &quot;green&quot;: &quot;#1fa91b&quot;, &quot;yellow&quot;: &quot;#8ddc20&quot;, &quot;blue&quot;: &quot;#487df4&quot;, &quot;purple&quot;: &quot;#8d35c9&quot;, &quot;cyan&quot;: &quot;#3bdeed&quot;, &quot;white&quot;: &quot;#9e9ea0&quot;, &quot;brightBlack&quot;: &quot;#59516a&quot;, &quot;brightRed&quot;: &quot;#f0729a&quot;, &quot;brightGreen&quot;: &quot;#53aa5e&quot;, &quot;brightYellow&quot;: &quot;#b2dc87&quot;, &quot;brightBlue&quot;: &quot;#a9bcec&quot;, &quot;brightPurple&quot;: &quot;#ad81c2&quot;, &quot;brightCyan&quot;: &quot;#9de3eb&quot;, &quot;brightWhite&quot;: &quot;#a288f7&quot;, &quot;background&quot;: &quot;#171423&quot;, &quot;foreground&quot;: &quot;#9f9fa1&quot;, &quot;selectionBackground&quot;: &quot;#493d70&quot;, &quot;cursorColor&quot;: &quot;#a288f7&quot; }\r\n# but jq fails\r\njq --argjson content ${json_content} &#39;.&quot;schemes&quot; += [$content]&#39;\r\njq: invalid JSON text passed to --argjson\r\nUse jq --help for help with command-line options,\r\nor see the jq manpage, or online docs  at https://jqlang.github.io/jq\r\n```\r\n\r\nor `--arg`\r\n\r\n```bash\r\njq -n --arg content ${json_content} &#39;.&quot;schemes&quot; += [env.content]&#39; settings.json\r\njq: error: syntax error, unexpected &#39;:&#39;, expecting end of file (Unix shell quoting issues?) at &lt;top-level&gt;, line 1:\r\n&quot;name&quot;:\r\njq: 1 compile error\r\n```\r\n\r\nI have read a number of other posts [like this one](https://stackoverflow.com/questions/47105490/can-i-pass-a-string-variable-to-jq-rather-than-passing-a-file), on the topic of `jq` and variable expansions, but not sure how to even try here strings when I can&#39;t even get `--arg` nor `--argjson` to work. \r\n\r\nI have tried exchanging `-n --argjson` to `--argjson foo bar -n` to no avail. I have even read the manpage! There&#39;s nothing special about `--argjson` there that I can see. \r\n\r\nWhat am I doing wrong? Thanks for any help!\r\n\r\n**My system and context:**\r\nUbuntu 24.04.2 LTS, WSL2\r\njq: v1.7\r\n\r\ncolorscheme.json:\r\n\r\n```json\r\n{\r\n  &quot;name&quot;: &quot;Grape&quot;,\r\n  &quot;black&quot;: &quot;#2d283f&quot;,\r\n  &quot;red&quot;: &quot;#ed2261&quot;,\r\n  &quot;green&quot;: &quot;#1fa91b&quot;,\r\n  &quot;yellow&quot;: &quot;#8ddc20&quot;,\r\n  &quot;blue&quot;: &quot;#487df4&quot;,\r\n  &quot;purple&quot;: &quot;#8d35c9&quot;,\r\n  &quot;cyan&quot;: &quot;#3bdeed&quot;,\r\n  &quot;white&quot;: &quot;#9e9ea0&quot;,\r\n  &quot;brightBlack&quot;: &quot;#59516a&quot;,\r\n  &quot;brightRed&quot;: &quot;#f0729a&quot;,\r\n  &quot;brightGreen&quot;: &quot;#53aa5e&quot;,\r\n  &quot;brightYellow&quot;: &quot;#b2dc87&quot;,\r\n  &quot;brightBlue&quot;: &quot;#a9bcec&quot;,\r\n  &quot;brightPurple&quot;: &quot;#ad81c2&quot;,\r\n  &quot;brightCyan&quot;: &quot;#9de3eb&quot;,\r\n  &quot;brightWhite&quot;: &quot;#a288f7&quot;,\r\n  &quot;background&quot;: &quot;#171423&quot;,\r\n  &quot;foreground&quot;: &quot;#9f9fa1&quot;,\r\n  &quot;selectionBackground&quot;: &quot;#493d70&quot;,\r\n  &quot;cursorColor&quot;: &quot;#a288f7&quot;\r\n}\r\n```\r\n\r\nsettings.json: \r\n```json\r\n{\r\n    &quot;$help&quot;: &quot;https://aka.ms/terminal-documentation&quot;,\r\n    &quot;$schema&quot;: &quot;https://aka.ms/terminal-profiles-schema&quot;,\r\n    &quot;language&quot;: &quot;en-US&quot;,\r\n    &quot;themes&quot;: [],\r\n    &quot;schemes&quot;: []\r\n}\r\n```\r\n",
        "link": "https://stackoverflow.com/questions/79711268/add-new-element-to-existing-json-array-with-jq-in-a-shell-script-problem-with-v",
        "title": "Add new element to existing JSON array with jq in a shell script: problem with variable expansion"
    }
]