[
  {
    "context": [
      "I want to extract the receipt_handle from the RESPONSE and into a variable and check if it worked. I need the first object in the array",
      "RECEIPT_HANDLE=$(echo \"${{ steps.receive_message.outputs.receipt_handle }}\" | jq -r '.Messages[0].ReceiptHandle')"
    ],
    "utterance": "Select the ReceiptHandle field of the first object in the Messages array.",
    "expressions": [
      ".Messages[0].ReceiptHandle"
    ],
    "data": [
      {
        "input": {
          "Messages": [
            {
              "MessageId": "12345",
              "ReceiptHandle": "ABCDEF",
              "Body": "hello"
            }
          ]
        },
        "output": "ABCDEF"
      }
    ],
    "identifier": 76701305
  },
  {
    "context": [
      "What I want is `{&quot;model&quot;: &quot;test-model&quot;, &quot;prompt&quot;: &quot;primer query&quot;}` in one line",
      "I tried `jq -c` but then it gives empty output",
      "The option [`-c`](https://jqlang.github.io/jq/manual/v1.6/#Invokingjq) produces _compact output_ which means that everything will be in a single line.",
      "jq -nc \\\n  --arg model \"$model_name\" \\\n  --arg prompt \"$name\" \\\n  '{$model, $prompt}' \\\n  >> \"$dest_file\""
    ],
    "utterance": "Print a structured object with specified model and prompt values on a single line.",
    "expressions": [
      "jq -nc --arg model \"$model_name\" --arg prompt \"$name\" '{$model, $prompt}'"
    ],
    "data": [
      {
        "input": {
          "model_name": "test-model",
          "name": "primer query"
        },
        "output": "{\"model\":\"test-model\",\"prompt\":\"primer query\"}"
      }
    ],
    "identifier": 76708990
  },
  {
    "context": [
      "but i want the filter results as follows , like grouping for each array element from json response , can anyone help me with this jq filter",
      "Will give \n03e401a\n123\n------\n03e4099\n567\n------\n867\n666",
      "jq -r '.result[] | .fxid, .id, \"---\"'",
      "jq -r '.result[] | (.fxid, .id | @json), \"_________\"'"
    ],
    "utterance": "List each object's fxid and id together, separated by a line (such as '------' or '_________') after every pair.",
    "expressions": [
      ".result | map(\"\\(.fxid)\\n\\(.id)\") | join(\"\\n------\\n\")",
      ".result[] | .fxid, .id, \"---\"",
      ".result[] | (.fxid, .id | @json), \"_________\""
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "fxid": "03e401a",
              "id": "123"
            },
            {
              "fxid": "03e4099",
              "id": "567"
            },
            {
              "fxid": "867",
              "id": "666"
            }
          ]
        },
        "output": "03e401a\n123\n------\n03e4099\n567\n------\n867\n666"
      }
    ],
    "identifier": 76720656
  },
  {
    "context": [
      "I want to compare them and get a list of IPs only which has a changed \"transferIN\" key.",
      "So output should be like this:\n10.1.1.2/32\n10.1.1.4/32",
      "Assuming you want to compare items of matching positions within their respective streams, you could slurp just one file, and successively read in the other file's items as a stream using `input` while iterating over the slurped ones using `$file1[]`:",
      "<File2.json jq --slurpfile file1 File1.json -rn \\\n  '$file1[] | select(.transferIN != input.transferIN).IPs[]'\n```\n10.1.1.2/32\n10.1.1.4/32"
    ],
    "utterance": "List all IPs from the second file where the transferIN value is different from the same-position item in the first file.",
    "expressions": [
      "$file1[] | select(.transferIN != input.transferIN).IPs[]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "transferIN": 111111,
              "transferOUT": 111234,
              "IPs": [
                "10.1.1.1/32"
              ]
            },
            {
              "transferIN": 111222,
              "transferOUT": 222234,
              "IPs": [
                "10.1.1.2/32"
              ]
            },
            {
              "transferIN": 111333,
              "transferOUT": 333556,
              "IPs": [
                "10.1.1.3/32"
              ]
            },
            {
              "transferIN": 111444,
              "transferOUT": 444875,
              "IPs": [
                "10.1.1.4/32"
              ]
            }
          ],
          [
            {
              "transferIN": 111111,
              "transferOUT": 111234,
              "IPs": [
                "10.1.1.1/32"
              ]
            },
            {
              "transferIN": 111345,
              "transferOUT": 222233,
              "IPs": [
                "10.1.1.2/32"
              ]
            },
            {
              "transferIN": 111333,
              "transferOUT": 333990,
              "IPs": [
                "10.1.1.3/32"
              ]
            },
            {
              "transferIN": 111446,
              "transferOUT": 4448456,
              "IPs": [
                "10.1.1.4/32"
              ]
            }
          ]
        ],
        "output": [
          "10.1.1.2/32",
          "10.1.1.4/32"
        ]
      }
    ],
    "identifier": 76703471
  },
  {
    "context": [
      "I want to check if a name attribute in JSON objects contains a particular word.",
      "In the fetchLog function, I am using jq to query objects that contain a particular word.",
      "If bookmark.json contains the stream of JSON as shown, then you could simply use the following invocation of jq to obtain the desired result:",
      "< bookmark.json jq -r --arg keyword Networking '\n  select(.name | index($keyword))\n' ",
      "As pointed out by @pmf, `index` is case-sensitive.  If you want the check to be case-insensitive, then there are various possibilities, depending on your detailed requirements, e.g. with respect to robustness, Unicode case-folding rules, etc.  One possibility to consider would be to use `ascii_upcase`, e.g.:",
      "    ($keyword | ascii_upcase) as $k\n    | select(.name | ascii_upcase | index($k))"
    ],
    "utterance": "Filter objects to retain those whose 'name' attribute contains the word 'Networking', either case-sensitive or case-insensitive.",
    "expressions": [
      "select(.name | index($keyword))",
      "($keyword | ascii_upcase) as $k | select(.name | ascii_upcase | index($k))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Networking",
            "url": "https://www.youtube.com/watch?v=AhOU2eOpmX0&list=PLIFyRwBY_4bRLmKfP1KnZA6rZbRHtxmXi&index=7"
          },
          {
            "name": "algorithm - How are ssl certificates verified? - Stack Overflow",
            "url": "https://stackoverflow.com/questions/188266/how-are-ssl-certificates-verified"
          },
          {
            "name": "(170) What is SSL & TLS ? What is HTTPS ? What is an SSL VPN? - Practical TLS - YouTube",
            "url": "https://www.youtube.com/watch?v=HMoFvRK4HUo&list=PLIFyRwBY_4bTwRX__Zn4-letrtpSj1mzY"
          }
        ],
        "output": [
          {
            "name": "Networking",
            "url": "https://www.youtube.com/watch?v=AhOU2eOpmX0&list=PLIFyRwBY_4bRLmKfP1KnZA6rZbRHtxmXi&index=7"
          }
        ]
      }
    ],
    "identifier": 76700103
  },
  {
    "context": [
      "Is it possible to pass filter to jq filter function?",
      "def something:\n   [. | ..];\n\ndef something_else(callback):\n    callback | map(.some_key);\n\n\nsomething_else(something)"
    ],
    "utterance": "Call a user-defined function, passing another function as a filter argument and using it within the body.",
    "expressions": [
      "def something: [. | ..];\ndef something_else(callback): callback | map(.some_key);\nsomething_else(something)"
    ],
    "identifier": 76732198
  },
  {
    "context": [
      "I\u0019m trying to convert the object below using jq:\r\n\r\n```json\r\n{\r\n    \"locals\": {\r\n      \"products\": {\r\n        \"core-tower1\": {\r\n          \"core-tower1-product-a\": [\"dev\"],\r\n          \"core-tower1-product-b\": [\"dev\", \"prod\"]\r\n        },\r\n        \"core-tower2\": {\r\n          \"core-tower2-product-a\": [\"pol\", \"onb\"],\r\n          \"core-tower2-product-a\": [\"dev\", \"prod\"]\r\n        }\r\n      }\r\n    }\r\n  }\r\n```",
      "to this\r\n\r\n     \r\n```json\r\n{\r\n        \"core-tower1\": [\r\n          \"core-tower1-product-a\",\r\n          \"core-tower1-product-b\"\r\n        ]\r\n        \"core-tower2\": [\r\n          \"core-tower2-product-a\",\r\n          \"core-tower2-product-a\"\r\n        ]\r\n      }\r\n```",
      "Here\u0019s a solution with [`reduce`][1]:\r\n\r\n```sh\r\njq '\r\n    .locals.products | to_entries\r\n    | reduce .[] as $e (\r\n        {}; . + { ($e.key): $e.value | keys }\r\n    )\r\n'\r\n```",
      "If your issue is with the swallowed duplicate keys, then consider using the `--stream` option... let me assume here that you want to generally cut off the first two levels `.[2:]`, build the values array from the level directly above the scalars/leaves (i.e. the second-to-last level, `-2`), and just copy over all levels in between:\r\n```sh\r\njq --stream -n '\r\n  reduce (inputs | select(has(1))[0][2:]) as $p ({};\r\n    setpath($p | .[-2:] |= [last]; $p[-2])\r\n  )\r\n'\r\n```"
    ],
    "utterance": "Extract each top-level key under 'products' and map it to an array of its subkeys, preserving any duplicate keys that may exist.",
    "expressions": [
      ".locals.products | to_entries | reduce .[] as $e ({}; . + { ($e.key): $e.value | keys })",
      "--stream -n 'reduce (inputs | select(has(1))[0][2:]) as $p ({}; setpath($p | .[-2:] |= [last]; $p[-2]))'"
    ],
    "data": [
      {
        "input": {
          "locals": {
            "products": {
              "core-tower1": {
                "core-tower1-product-a": [
                  "dev"
                ],
                "core-tower1-product-b": [
                  "dev",
                  "prod"
                ]
              },
              "core-tower2": {
                "core-tower2-product-a": [
                  "dev",
                  "prod"
                ]
              }
            }
          }
        },
        "output": {
          "core-tower1": [
            "core-tower1-product-a",
            "core-tower1-product-b"
          ],
          "core-tower2": [
            "core-tower2-product-a",
            "core-tower2-product-a"
          ]
        }
      }
    ],
    "identifier": 76709497
  },
  {
    "context": [
      "Suppose file one:\r\n\r\n```\r\n[1, 1, 2]\r\n```\r\n\r\nand file two:\r\n\r\n```\r\n[2, 3, 3]\r\n```\r\n\r\nHow do I concatenate the arrays in the two files, otherwise leaving the contents alone?  That is, output of\r\n\r\n```\r\n[1, 1, 2, 2, 3, 3]\r\n```",
      "jq is quite flexible. Here&#39;s a solution without slurping:\r\n\r\n```\r\njq -n &#39;[inputs[]]&#39; a1 a2\r\n```"
    ],
    "utterance": "Combine the arrays contained in two files into a single array with all their elements.",
    "expressions": [
      "jq -n '[inputs[]]' one two"
    ],
    "data": [
      {
        "input": "[1, 1, 2]",
        "output": "[1, 1, 2, 2, 3, 3]"
      },
      {
        "input": "[2, 3, 3]"
      }
    ],
    "identifier": 76732975
  },
  {
    "context": [
      "When I group and add (read merge) objects based on a value I would like to have certain attributes be concatenated together instead of the default \"object on the right wins\" behavior.",
      "the addition/merge of these two objects\n[\n  {\n    \"location\": \"apc1\",\n    \"type\": \"app\",\n    \"fgrp\": \"cert-apc-1\"\n  },\n  {\n    \"location\": \"apc1\",\n    \"type\": \"ctl\",\n    \"cgrp\": \"ctl-apc1\"\n  }\n]\nto produce this\n[\n  {\n    \"location\": \"apc1\",\n    \"type\": \"app,ctl\",\n    \"fgrp\": \"cert-apc-1\",\n    \"cgrp\": \"ctl-apc1\"\n  }\n]",
      "Attempted `group_by(.location) | map(add)` but as noted it basically just keeps the last value.",
      "Going further, you could concatenate the array values using `join` with a glue string (here \",\"). Before that, prep the reparation of `.location` to match the type requirements of `join` (which only accepts arrays):\n```sh\nreduce .[] as $item ({};\n  reduce ($item | to_entries[]) as $ent (.;\n    .[$item.location][$ent.key] += [$ent.value]\n  )\n) | map(.location |= [first] | .[] |= join(\",\"))\n```",
      "Or give your function a more general-purpose character by excluding the final mapping from it, so it produces an object (not an array) with the indices as keys, thus acting more like an array-valued variant of `group_by` (also making no distinction in processing regarding the indexed field, which after all could be any index expression, not just the value of one common field):\n```sh\ndef merge_by(f):\n  reduce .[] as $item ({};\n    reduce ($item | to_entries[]) as $ent (.;\n      .[$item|f][$ent.key] += [$ent.value]\n    )\n  );\n\nmerge_by(.location)\n```",
      "Following this more functional `group_by`-based approach, you could replace `add` with a custom function that first decomposes its input array (of grouped objects) into a stream of path-value pairs, then flips the first two positions in every path array (from [position, field name] to [field name, position]), and reomposes it again. The result is a single object (the field names moved to first position) with its items containing maps of that field's values across the group (with `null` (or a shorter array) at positions where the corresponing item did not have that field). Thus, a subsequent `join` would also require the arrays to be reduced to only contain non-null `values`:\n\ndef merge: fromstream(tostream | first[:2] |= reverse)\n  | .location |= .[:1] | .[] |= (map(values) | join(\",\"));\n\ngroup_by(.location) | map(merge)"
    ],
    "utterance": "Merge objects grouped by 'location' and concatenate 'type' values using a comma, collecting all unique attributes into a single object per location.",
    "expressions": [
      "reduce .[] as $item ({};\n  reduce ($item | to_entries[]) as $ent (.;\n    .[$item.location][$ent.key] += [$ent.value]\n  )\n) | map(.location |= [first] | .[] |= join(\",\"))",
      "def merge(idx_expr; join_expr):\n  reduce .[] as $item ({};\n    reduce ($item | to_entries[]) as $ent (.;\n      .[$item | idx_expr][$ent.key] += [$ent.value]\n    )\n  ) | map(join_expr);\n\nmerge(.location; .location |= [first] | .[] |= join(\",\"))",
      "def merge: fromstream(tostream | first[:2] |= reverse)\n  | .location |= .[:1] | .[] |= (map(values) | join(\",\"));\n\ngroup_by(.location) | map(merge)"
    ],
    "data": [
      {
        "input": [
          {
            "location": "apc1",
            "type": "app",
            "fgrp": "cert-apc-1"
          },
          {
            "location": "apc1",
            "type": "ctl",
            "cgrp": "ctl-apc1"
          }
        ],
        "output": [
          {
            "location": "apc1",
            "type": "app,ctl",
            "fgrp": "cert-apc-1",
            "cgrp": "ctl-apc1"
          }
        ]
      }
    ],
    "identifier": 76714308
  },
  {
    "context": [
      "Another way to ask it, is what should I put in this command to leave the output largely unchanged (other than formatting):",
      "cat foo.json | jq '.[] | ??what here??' > foo2.json",
      "I ask because I want to manipulate each array element, then put it back together, i.e.,",
      "cat foo.json | jq '.[] | . += {\"changes\": \"here\"} | ??what here??' > foo2.json",
      "What exactly is your input? If you only use += (and not | .), it should work already:",
      "jq '.[] += {\"changes\": \"here\"}' foo.json > foo2.json",
      ". is the identify filter and does not change its input. | \"drills down\" into whatever filter you have specified to the left of it and makes it the new \"root\"."
    ],
    "utterance": "Add an object {\"changes\": \"here\"} to each element of an array while preserving the array structure.",
    "expressions": [
      ".[] += {\"changes\": \"here\"}"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1
          },
          {
            "b": 2
          },
          {
            "c": 3
          }
        ],
        "output": [
          {
            "a": 1,
            "changes": "here"
          },
          {
            "b": 2,
            "changes": "here"
          },
          {
            "c": 3,
            "changes": "here"
          }
        ]
      }
    ],
    "identifier": 76732777
  },
  {
    "context": [
      "Is there a shorter way to check the truthiness of a filter `f` than a full-fledged if-then-else like this?",
      "if f then true else false end",
      "The `not` filter also converts its input into boolean (under the same conditions, but negated), so if you want to have it shorter (and less readable), use it twice: `not|not`",
      "Even shorter (and even less readable) would be to use the input for some boolean operations, like a disjunction with itself: `. or .`",
      "But seriously, just define a function yourself (most readably employing regular `if`), and then you can use that everywhere else instead:",
      "def toboolean: if . then true else false end;"
    ],
    "utterance": "Convert any value to its boolean truthiness, returning true for any value except false and null, and false otherwise.",
    "expressions": [
      "if . then true else false end",
      "not | not",
      ". or .",
      "def toboolean: if . then true else false end; toboolean"
    ],
    "data": [
      {
        "input": [
          null,
          false,
          true,
          0,
          1,
          [],
          {},
          ""
        ],
        "output": [
          false,
          false,
          true,
          true,
          true,
          true,
          true,
          true
        ]
      }
    ],
    "identifier": 76733029
  },
  {
    "context": [
      "How do you use jq to detect and report duplicate object keys? For example, the following JSON has duplicate key on `.a`.",
      "cannot assume the dup can exist only as the top level key. The dup may exist at any level.",
      "diff -qs <(jq -c --stream . file.json) <(jq -c tostream file.json)",
      "jq -n --stream '\n\ndef bow(stream): \n  reduce stream as $word ({}; .[($word|tostring)] += 1);\n\ndef duplicates:\n   bow(.[]) | with_entries(select(.value > 1)) | keys_unsorted[];\n\n[inputs\n | select( (length == 1 and (.[0]|length==2)) or\n           (length == 2 and (.[0]|length==1)) )\n | first|first ]\n| duplicates\n'"
    ],
    "utterance": "Report all duplicate object keys at any level in the data structure.",
    "expressions": [
      "diff -qs <(jq -c --stream . file.json) <(jq -c tostream file.json)",
      "jq -n --stream '\ndef bow(stream): \n  reduce stream as $word ({}; .[($word|tostring)] += 1);\n\ndef duplicates:\n   bow(.[]) | with_entries(select(.value > 1)) | keys_unsorted[];\n\n[inputs\n | select( (length == 1 and (.[0]|length==2)) or\n           (length == 2 and (.[0]|length==1)) )\n | first|first ]\n| duplicates\n'"
    ],
    "data": [
      {
        "input": {
          "a": {
            "c": 1
          }
        },
        "output": [
          "a"
        ]
      }
    ],
    "identifier": 76732978
  },
  {
    "context": [
      "I got two json that I need to merge.",
      "color.json",
      "[{\"id\":1,\"color\":\"red\"},{\"id\":2,\"color\":\"green\"},{\"id\":3,\"color\":\"blue\"}]",
      "shape.json",
      "[\n  {\n    \"shape\": \"square\",\n    \"color\": {\n      \"id\": 1,\n      \"name\": \"red\"\n    },\n    \"texture\": \"smooth\"\n  },\n  {\n    \"shape\": \"circle\",\n    \"color\": {\n      \"id\": 2,\n      \"name\": \"green\"\n    },\n    \"texture\": \"smooth\"\n  },\n  {\n    \"shape\": \"triangle\",\n    \"color\": {\n      \"id\": 3,\n      \"name\": \"blue\"\n    },\n    \"texture\": \"smooth\"\n  },\n  {\n    \"shape\": \"triangle\",\n    \"color\": {\n      \"id\": 3,\n      \"name\": \"blue\"\n    },\n    \"texture\": \"rough\"\n  }\n]",
      "Desired output",
      "[\n  {\n    \"id\": 1,\n    \"color\": \"red\",\n    \"shapes\": [\n      {\n        \"shape\": \"square\",\n        \"texture\": \"smooth\"\n      }\n    ]\n  },\n  {\n    \"id\": 2,\n    \"color\": \"green\",\n    \"shapes\": [\n      {\n        \"shape\": \"circle\",\n        \"texture\": \"smooth\"\n      }\n    ]\n  },\n  {\n    \"id\": 3,\n    \"color\": \"blue\",\n    \"shapes\": [\n      {\n        \"shape\": \"triangle\",\n        \"texture\": \"smooth\"\n      },\n      {\n        \"shape\": \"triangle\",\n        \"texture\": \"rough\"\n      }\n    ]\n  }\n]",
      "Here's a `reduce`-based approach which simply iterates over the `shape.json` items, adding them to the `INDEX`ed object from `colors.json`. A final `map(.)` re-converts the object into an array:",
      "jq '\n  reduce input[] as $i (INDEX(.id);\n    .[$i.color.id | tostring].shapes += [$i | {shape, texture}]\n  ) | map(.)\n' color.json shape.json"
    ],
    "utterance": "For each id and color, collect all shapes with matching color.id into a shapes array containing shape and texture fields.",
    "expressions": [
      "reduce input[] as $i (INDEX(.id); .[$i.color.id | tostring].shapes += [$i | {shape, texture}]) | map(.)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": 1,
              "color": "red"
            },
            {
              "id": 2,
              "color": "green"
            },
            {
              "id": 3,
              "color": "blue"
            }
          ],
          [
            {
              "shape": "square",
              "color": {
                "id": 1,
                "name": "red"
              },
              "texture": "smooth"
            },
            {
              "shape": "circle",
              "color": {
                "id": 2,
                "name": "green"
              },
              "texture": "smooth"
            },
            {
              "shape": "triangle",
              "color": {
                "id": 3,
                "name": "blue"
              },
              "texture": "smooth"
            },
            {
              "shape": "triangle",
              "color": {
                "id": 3,
                "name": "blue"
              },
              "texture": "rough"
            }
          ]
        ],
        "output": [
          {
            "id": 1,
            "color": "red",
            "shapes": [
              {
                "shape": "square",
                "texture": "smooth"
              }
            ]
          },
          {
            "id": 2,
            "color": "green",
            "shapes": [
              {
                "shape": "circle",
                "texture": "smooth"
              }
            ]
          },
          {
            "id": 3,
            "color": "blue",
            "shapes": [
              {
                "shape": "triangle",
                "texture": "smooth"
              },
              {
                "shape": "triangle",
                "texture": "rough"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 76721501
  },
  {
    "context": [
      "I want to use jq to update the value of an item based on multiples filterings on multiples levels",
      "What I would like would be to update the list of records of a DNS entry stored in a json file based on the name of the DNS Zone Name and the name of the a_record stored.",
      "The expectation would be to being able to modify an specific entry , like the one for zone1/record1",
      "But using the following command all records are updated",
      "And using the following jq command 2 records are updated",
      "here's one way.\n```\nmap(if .dns_zone_name==\"zone1\"\n    then . += (.a_records |= map(if .name==\"record1\" then .records=[\"newRecord\"] else . end))\n    else . \n    end)\n```",
      "Using nested map and an inner assignment:\n```sh\nmap(\n  select(.dns_zone_name == \"zone1\").a_records |= map(\n    select(.name == \"record1\").records = [\"NewRecord\"]\n  )\n)\n```",
      "Using nested .[] and an outer assignment:\n```sh\n( .[]\n  | select(.dns_zone_name == \"zone1\").a_records[]\n  | select(.name == \"record1\").records\n) = [\"NewRecord\"]\n```"
    ],
    "utterance": "Update the records array of the a_record named 'record1' only within the object where dns_zone_name is 'zone1', setting it to [\"NewRecord\"]",
    "expressions": [
      "map(if .dns_zone_name==\"zone1\" then . += (.a_records |= map(if .name==\"record1\" then .records=[\"newRecord\"] else . end)) else . end)",
      "map( select(.dns_zone_name == \"zone1\").a_records |= map( select(.name == \"record1\").records = [\"NewRecord\"] ) )",
      "(.[] | select(.dns_zone_name == \"zone1\").a_records[] | select(.name == \"record1\").records) = [\"NewRecord\"]"
    ],
    "data": [
      {
        "input": [
          {
            "dns_zone_name": "zone1",
            "a_records": [
              {
                "name": "record1",
                "records": [
                  "zone1_record1_item1"
                ]
              },
              {
                "name": "record2",
                "records": [
                  "zone1_record2_item1"
                ]
              }
            ]
          },
          {
            "dns_zone_name": "zone2",
            "a_records": [
              {
                "name": "record1",
                "records": [
                  "zone2_record1_item1"
                ]
              },
              {
                "name": "record2",
                "records": [
                  "zone2_record2_item1"
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "dns_zone_name": "zone1",
            "a_records": [
              {
                "name": "record1",
                "records": [
                  "NewRecord"
                ]
              },
              {
                "name": "record2",
                "records": [
                  "zone1_record2_item1"
                ]
              }
            ]
          },
          {
            "dns_zone_name": "zone2",
            "a_records": [
              {
                "name": "record1",
                "records": [
                  "zone2_record1_item1"
                ]
              },
              {
                "name": "record2",
                "records": [
                  "zone2_record2_item1"
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 76731141
  },
  {
    "context": [
      "$ jq -n --arg 'module' 'X' '$module'",
      "jq: error: syntax error, unexpected module, expecting IDENT or __loc__ (Unix shell quoting issues?) at <top-level>, line 1:",
      "In jq 1.6 and earlier, keywords cannot be used in $-variable names.",
      "The following list of keywords is given: __loc__ and as break catch def elif else end foreach if import include label module or reduce then try",
      "The restriction was removed in the development version of jq in 2019 ... and thus will no longer exist in jq 1.7"
    ],
    "utterance": "Access a variable named module using $module as a variable name.",
    "expressions": [
      "$module"
    ],
    "identifier": 76742107
  },
  {
    "context": [
      "How can I use jq only style to remove everything before the first space meaning this part: `this.part:2`?",
      "I tried already `jq '.key |= sub(\".* \"; \"\")' but that didn't unfortunately do what I wanted to have.",
      ".key |= sub(\".*? \"; \"\")",
      ".key |= sub(\"^[^ ]* \"; \"\")",
      ".key |= .[index(\" \")+1:]"
    ],
    "utterance": "Remove all content up to and including the first space from the value of the field 'key'.",
    "expressions": [
      ".key |= sub(\".*? \"; \"\")",
      ".key |= sub(\"^[^ ]* \"; \"\")",
      ".key |= .[index(\" \")+1:]"
    ],
    "data": [
      {
        "input": {
          "key": "this.part:2 and now comes the rest"
        },
        "output": {
          "key": "and now comes the rest"
        }
      }
    ],
    "identifier": 76741732
  },
  {
    "context": [
      "Given this input...",
      "My end goal is to take the `id` and `name` values, iterate over them and use the id in a curl and then output the result of that to a separate json file named `[name]-[id].json`",
      "I am able to grab one value just fine using `jq -r '.[] | (.id)'` but can't add in `(.name)`.",
      "I have also tried `'.[] | \"\\(.id) \\(.name)\"'` - this results in an id and a name each on its own line.",
      "declare -A names=\"($(jq -r '.[]|\"[\\(.id|@uri|@sh)]=\\(.name|@sh)\"' a.json))\""
    ],
    "utterance": "Extract both id and name values from each object, pairing them together for further use.",
    "expressions": [
      ".[] | \"\\(.id) \\(.name)\"",
      ".[] | [ .id, .name ]",
      ".[] | {id, name}"
    ],
    "data": [
      {
        "input": [
          {
            "name": "steve",
            "description": "",
            "id": 2253,
            "accountGuid": "12345"
          },
          {
            "name": "mary",
            "description": "",
            "id": 2363,
            "accountGuid": "12345"
          },
          {
            "name": "chris",
            "description": "",
            "id": 2226,
            "accountGuid": "12345"
          }
        ],
        "output": [
          "2253 steve",
          "2363 mary",
          "2226 chris"
        ]
      }
    ],
    "identifier": 76741064
  },
  {
    "identifier": 76772664
  },
  {
    "context": [
      "Is there any chance to access a embedded json value inside a value?",
      "\"key\": \"{\\\"test\\\":1,\\\"check\\\":\\\"default\\\"}\"",
      "What I always do today is",
      "echo '{\"key\": \"{\\\"test\\\":1,\\\"check\\\":\\\"default\\\"}\"}' | jq -r .key | jq .test",
      "However I am curious if there is any possibility to omit the second jq pipe and to basically dense this down to one jq command."
    ],
    "utterance": "Extract the value of the embedded field 'test' located within the string value of 'key'.",
    "expressions": [
      ".key | fromjson | .test"
    ],
    "data": [
      {
        "input": {
          "key": "{\"test\":1,\"check\":\"default\"}"
        },
        "output": 1
      }
    ],
    "identifier": 76753081
  },
  {
    "context": [
      "I am trying to change the value of a key based on the length of the key.",
      "desired output -\r\n\r\n    [\r\n      {\r\n        \"kiwi\": 4\r\n      },\r\n      {\r\n        \"apple\": 5\r\n      }\r\n    ]",
      "Within `with_entries`, you only need to assign the computed value (`.key | length`) to `.value` using `=`. The value of `.key` remains unaltered.",
      "map(with_entries(.value = (.key | length)))"
    ],
    "utterance": "Replace each object's value with the length of its key for all key-value pairs in a list of objects.",
    "expressions": [
      "map(with_entries(.value = (.key | length)))",
      "map( with_entries( .value = ( .key | length ) ) )"
    ],
    "data": [
      {
        "input": [
          {
            "kiwi": 3
          },
          {
            "apple": 4
          }
        ],
        "output": [
          {
            "kiwi": 4
          },
          {
            "apple": 5
          }
        ]
      }
    ],
    "identifier": 76782370
  },
  {
    "context": [
      "I have a json object like:\r\n\r\n    {\r\n      \"Nemo\": [\r\n        3694756688,\r\n        3694756832,\r\n        3694756650\r\n      ],\r\n      \"Firefox\": [\r\n        3694756795,\r\n        3694756407,\r\n        3694756412,\r\n        3694756395\r\n      ],\r\n      \"Codium\": [\r\n        3694756035,\r\n        3694756383,\r\n        3694756378\r\n      ],\r\n      \"Terminals\": [\r\n        3694756804,\r\n        3694756802,\r\n        3694756428\r\n    }",
      "The order is important. How can i do it with jq.",
      "You can use the following filter : \r\n\r\n    .Nemo[],.Firefox[],.Codium[],.Terminals[]",
      "`keys_unsorted` gives you the keys in their original order. You can use them to iterate:\r\n```sh\r\n.[keys_unsorted[]][]\r\n```",
      "You could also just use `.[]` to iterate over the object&#39;s fields, which for current versions of jq produces the same result, but that is not guaranteed to stay that way:\r\n```sh\r\n.[][]\r\n```",
      "Or just simply ([demo][2]) thanks @pmf:\r\n\r\n```none\r\ncat your_file.json | jq \"flatten[]\"\r\n```"
    ],
    "utterance": "Extract all numbers from each named array in the order of object keys and concatenate them into a single flat sequence, preserving key order.",
    "expressions": [
      ".Nemo[], .Firefox[], .Codium[], .Terminals[]",
      ".[keys_unsorted[]][]",
      ".[][]",
      "flatten[]"
    ],
    "data": [
      {
        "input": {
          "Nemo": [
            3694756688,
            3694756832,
            3694756650
          ],
          "Firefox": [
            3694756795,
            3694756407,
            3694756412,
            3694756395
          ],
          "Codium": [
            3694756035,
            3694756383,
            3694756378
          ],
          "Terminals": [
            3694756804,
            3694756802,
            3694756428
          ]
        },
        "output": [
          3694756688,
          3694756832,
          3694756650,
          3694756795,
          3694756407,
          3694756412,
          3694756395,
          3694756035,
          3694756383,
          3694756378,
          3694756804,
          3694756802,
          3694756428
        ]
      }
    ],
    "identifier": 76749701
  },
  {
    "context": [
      "I have a json file extracted from mongodb database to be formatted into csv:",
      "Desired output:\n\n```\n\"UPDATED\",\"Brocolli\",\"bondDesc1\",100,101,6.555,6.777,691,169,25.2345,25.9999\n\"UPDATED\",\"Brocolli\",\"bondDesc2\",200,201,2.555,2.777,791,269,35.2345,35.9999\n```",
      ".request | [.method, .url] + (.body.bonds[] | [.[]]) | @csv",
      ".request | [.method, .url] + (.body.bonds[] | [\n  .bondDesc,\n  .priorPriceBid,\n  .priorPriceOffer,\n  .priorYieldBid,\n  .priorYieldOffer,\n  .updatedPriceBid,\n  .updatedPriceOffer,\n  .updatedYieldBid,\n  .updatedYieldOffer\n]) | @csv",
      ".request\n| (.body.bonds[0] | keys_unsorted) as $keys\n| [.method, .url] + (.body.bonds[] | [.[$keys[]]])\n| @csv"
    ],
    "utterance": "Produce flat CSV rows for each bond, prepending the method and url fields before bondDesc, priorPriceBid, priorPriceOffer, priorYieldBid, priorYieldOffer, updatedPriceBid, updatedPriceOffer, updatedYieldBid, and updatedYieldOffer, matching the specified column order.",
    "expressions": [
      ".request | [.method, .url] + (.body.bonds[] | [.bondDesc, .priorPriceBid, .priorPriceOffer, .priorYieldBid, .priorYieldOffer, .updatedPriceBid, .updatedPriceOffer, .updatedYieldBid, .updatedYieldOffer]) | @csv",
      ".request | [.method, .url] + (.body.bonds[] | [.[]]) | @csv",
      ".request\n| (.body.bonds[0] | keys_unsorted) as $keys\n| [.method, .url] + (.body.bonds[] | [.[$keys[]]])\n| @csv"
    ],
    "data": [
      {
        "input": {
          "_id": "8888888888",
          "unitcode": "Unit123",
          "purpose": "Validate",
          "request": {
            "url": "Brocolli",
            "method": "UPDATED",
            "body": {
              "bonds": [
                {
                  "bondDesc": "bondDesc1",
                  "priorPriceBid": 100,
                  "priorPriceOffer": 101,
                  "priorYieldBid": 6.555,
                  "priorYieldOffer": 6.777,
                  "updatedPriceBid": 691,
                  "updatedPriceOffer": 169,
                  "updatedYieldBid": 25.2345,
                  "updatedYieldOffer": 25.9999
                },
                {
                  "bondDesc": "bondDesc2",
                  "priorPriceBid": 200,
                  "priorPriceOffer": 201,
                  "priorYieldBid": 2.555,
                  "priorYieldOffer": 2.777,
                  "updatedPriceBid": 791,
                  "updatedPriceOffer": 269,
                  "updatedYieldBid": 35.2345,
                  "updatedYieldOffer": 35.9999
                }
              ]
            },
            "source": "Cloud",
            "isMultipleBond": true
          },
          "response": {
            "statusCode": 200
          }
        },
        "output": [
          "\"UPDATED\",\"Brocolli\",\"bondDesc1\",100,101,6.555,6.777,691,169,25.2345,25.9999",
          "\"UPDATED\",\"Brocolli\",\"bondDesc2\",200,201,2.555,2.777,791,269,35.2345,35.9999"
        ]
      }
    ],
    "identifier": 76751224
  },
  {
    "context": [
      "I want to print only those key-value pairs where value > 128.",
      "The expected output is",
      "{\n  \"session2\": 1024,\n  \"session3\": 258,\n  \"session5\": 32456\n}",
      "You can use map_values together with select :",
      "jq 'map_values(select(. > 128))' session_len.json",
      "To sort data by numerical value, following seems to work :",
      "jq 'to_entries |\n    map(select(.value > 128)) |\n    sort_by(.value) |\n    from_entries' session_len.json"
    ],
    "utterance": "Return all key-value pairs where the value is greater than 128.",
    "expressions": [
      "map_values(select(. > 128))",
      "to_entries | map(select(.value > 128)) | from_entries"
    ],
    "data": [
      {
        "input": {
          "session1": 128,
          "session2": 1024,
          "session3": 258,
          "session4": 128,
          "session5": 32456,
          "session6": 128
        },
        "output": {
          "session2": 1024,
          "session3": 258,
          "session5": 32456
        }
      }
    ],
    "identifier": 76796930
  },
  {
    "context": [
      "I want to merge two JSON objects that has a common key",
      "Object A\n{\n  \"extensions\": { \n    \"app_name\": \"extensions-prod\"\n  },\n  \"plugins\": { \n    \"app_name\": \"plugins-prod\" \n  }\n}",
      "Object B\n{\n  \"plugins\": { \n    \"project_name\": \"plugins-prod\" \n  }\n}",
      "Desired output:\n{\n  \"plugins\": { \n    \"project_name\": \"plugins-prod\",\n    \"app_name\": \"plugins-prod\" \n  }\n}",
      "[Edit]\nI would not know what the common key would be since the JSON objects are being generated dynamically in a CI environment.",
      "The following solution does not assume that the intersection of key names is a singleton\njq -n --argjson a \"$A\" --argjson b \"$B\" '\n\n  def i: (.[0] | unique) as $u | $u - ($u - .[1]); \n  def k: [$a, $b] | map(keys_unsorted) | i;\n  [k[] | { (.): ($b[.] + $a[.]) } ] | add\n'",
      "jq -s 'map(to_entries) |\n       add |\n       group_by(.key) |\n       map(select(length == 2) |\n           { key: first | .key,\n             value: map(.value) | add\n           }\n          ) |\n       from_entries' <<< \"$A $B\"",
      "With `in` you can find out if a given key is present in a given object. Thus, you could use `with_entries` to iterate over an object's fields, and `select` (keep) only those entries whose `.key` is present in another object. If object A is \"trimmed\" that way, it can then be (deeply) merged into object B using `*`:\n\njq -n --argjson objA \"$objA\" --argjson objB \"$objB\" \\\n  '$objB * ($objA | with_entries(select(.key | in($objB))))'\n\n",
      "jq -n --argjson objA \"$objA\" --argjson objB \"$objB\" '\n  def trim_to($o): with_entries(select(.key | in($o)));\n  ($objB | trim_to($objA)) * ($objA | trim_to($objB))\n'"
    ],
    "utterance": "Merge two objects by merging their sub-objects only at keys present in both objects, without knowing the common key in advance, so that the result contains only those merged sub-objects.",
    "expressions": [
      "jq -n --argjson a \"$A\" --argjson b \"$B\" '\n  def i: (.[0] | unique) as $u | $u - ($u - .[1]);\n  def k: [$a, $b] | map(keys_unsorted) | i;\n  [k[] | { (.): ($b[.] + $a[.]) } ] | add\n'",
      "jq -s 'map(to_entries) |\n       add |\n       group_by(.key) |\n       map(select(length == 2) |\n           { key: first | .key,\n             value: map(.value) | add\n           }\n          ) |\n       from_entries'",
      "jq -n --argjson objA \"$objA\" --argjson objB \"$objB\" '$objB * ($objA | with_entries(select(.key | in($objB))))'",
      "jq -n --argjson objA \"$objA\" --argjson objB \"$objB\" '\n  def trim_to($o): with_entries(select(.key | in($o)));\n  ($objB | trim_to($objA)) * ($objA | trim_to($objB))\n'"
    ],
    "data": [
      {
        "input": {
          "A": {
            "extensions": {
              "app_name": "extensions-prod"
            },
            "plugins": {
              "app_name": "plugins-prod"
            }
          },
          "B": {
            "plugins": {
              "project_name": "plugins-prod"
            }
          }
        },
        "output": {
          "plugins": {
            "project_name": "plugins-prod",
            "app_name": "plugins-prod"
          }
        }
      }
    ],
    "identifier": 76775778
  },
  {
    "context": [
      "What I want (default missing property with `0`) for above example:",
      "Here are examples for both: The first one updates the `.foo` field by (shallow) merging it with an object just containing values for `a`, `b`, and `c`. The second one updates the root object by (deep) merging it with an object containing values for `foo.a`, `foo.b`, and `foo.c`. Both approaches output the original root level.",
      "map(.foo |= {a:0, b:0, c:0} + .)",
      "map({foo: {a:0, b:0, c:0}} * .)",
      "Alternatively, if you want a path-based approach, you could provide a list of paths to iterate over, and set values at those paths as needed.",
      "map(reduce(\n  [\"foo\", \"a\"],\n  [\"foo\", \"b\"],\n  [\"foo\", \"c\"]\n) as $p (.; setpath($p; getpath($p) // 0)))",
      "You may also provide and set the default values individually:",
      "map(reduce(\n  [[\"foo\", \"a\"], 0],\n  [[\"foo\", \"b\"], 0],\n  [[\"foo\", \"c\"], 0]\n) as [$p, $v] (.; setpath($p; getpath($p) // $v)))",
      "In any case, use `map(...)` (or `.[] |= ...`, or `[.[] | ...]`) instead of just `.[] | ...` in order to process the top-level array's items and retain the array structure.",
      "Given your sample input, all of these approaches output the same result (with variations in field order for the latter two, path-based examples, as \u2191here the default value in some cases is \"introduced later\" than the original ones, but they are, nevertheless, logically equivalent):",
      "As I understand the problem, you want a simple way to generate the output shown in the question by setting the default values in just one place."
    ],
    "utterance": "Set missing properties 'a', 'b', and 'c' under 'foo' to 0 for every object in an array, keeping the original array structure.",
    "expressions": [
      "map(.foo |= {a:0, b:0, c:0} + .)",
      "map({foo: {a:0, b:0, c:0}} * .)",
      "map(reduce ([\"foo\", \"a\"], [\"foo\", \"b\"], [\"foo\", \"c\"]) as $p (.; setpath($p; getpath($p) // 0)))",
      "map(reduce ([[\"foo\", \"a\"], 0], [[\"foo\", \"b\"], 0], [[\"foo\", \"c\"], 0]) as [$p, $v] (.; setpath($p; getpath($p) // $v)))"
    ],
    "data": [
      {
        "input": [
          {
            "foo": {}
          },
          {
            "foo": {
              "a": 1
            }
          },
          {
            "foo": {
              "b": 4,
              "c": 23
            }
          },
          {
            "foo": {
              "a": 15,
              "b": 2,
              "c": 33
            }
          }
        ],
        "output": [
          {
            "foo": {
              "a": 0,
              "b": 0,
              "c": 0
            }
          },
          {
            "foo": {
              "a": 1,
              "b": 0,
              "c": 0
            }
          },
          {
            "foo": {
              "a": 0,
              "b": 4,
              "c": 23
            }
          },
          {
            "foo": {
              "a": 15,
              "b": 2,
              "c": 33
            }
          }
        ]
      }
    ],
    "identifier": 76791870
  },
  {
    "context": [
      "I am trying to group the duplicates from the following json by `extId`, but remove duplicates.",
      "(there are 2 'extId', I'm only interested in the one inside 'users')",
      "But using `INDEX(.extId)` removes the duplicates, so I understand that I need to group them before",
      "If you are trying to group by `.extId` while collecting the objects under `.intIDs[]`, then `group_by` has to go between the outer and the inner mappings:",
      "Alternatively, you could iterate using `reduce`, group manually on the go by collecting into an object, and restore the array using `map(.)`:"
    ],
    "utterance": "Group entries inside 'users' by their 'extId', collecting all their 'connections' (from 'intIds'), so that each group has a single entry with an array of all corresponding connections.",
    "expressions": [
      ".users | map({extId, name, connections: .intIds | map({registeredOn, leftOn, userLeftFlag})}) | group_by(.extId) | map(first + {connections: map(.connections[])})",
      "reduce .users[] as $user ({}; .[$user.extId] |= (($user | {extId, name}) + ( .connections += [$user.intIds[] | {registeredOn, leftOn, userLeftFlag}] ))) | map(.)"
    ],
    "data": [
      {
        "input": {
          "intId": "97210f2c23f45b55569f32309105f395c94",
          "extId": "39e9588ee62d1cccc711d75ff86c5570",
          "name": "generic name",
          "users": {
            "186-1": {
              "userKey": "186-1",
              "extId": "186",
              "intIds": {
                "w_eyvyfghz844o": {
                  "intId": "w_eyvyfghz844o",
                  "registeredOn": 1690289980777,
                  "leftOn": 0,
                  "userLeftFlag": false
                }
              },
              "name": "generic name 1",
              "isModerator": true,
              "isDialIn": false,
              "currentIntId": "w_eyvyfghz844o",
              "answers": {},
              "talk": {
                "totalTime": 5696194,
                "lastTalkStartedOn": 1690297856252
              },
              "emojis": [],
              "webcams": [
                {
                  "startedOn": 1690289988531,
                  "stoppedOn": 0
                }
              ],
              "totalOfMessages": 18
            },
            "95-1": {
              "userKey": "95-1",
              "extId": "95",
              "intIds": {
                "w_kegd1ecwju02": {
                  "intId": "w_kegd1ecwju02",
                  "registeredOn": 1690295357122,
                  "leftOn": 1690295379924,
                  "userLeftFlag": true
                },
                "w_nc1egwb2axbr": {
                  "intId": "w_nc1egwb2axbr",
                  "registeredOn": 1690296171797,
                  "leftOn": 0,
                  "userLeftFlag": false
                }
              },
              "name": "Generic name 2",
              "isModerator": true,
              "isDialIn": false,
              "currentIntId": "w_nc1egwb2axbr",
              "answers": {},
              "talk": {
                "totalTime": 0,
                "lastTalkStartedOn": 0
              },
              "emojis": [],
              "webcams": [],
              "totalOfMessages": 0
            },
            "95-2": {
              "userKey": "95-2",
              "extId": "95",
              "intIds": {
                "w_et8i4fc0fumu": {
                  "intId": "w_et8i4fc0fumu",
                  "registeredOn": 1690293905345,
                  "leftOn": 1690294109923,
                  "userLeftFlag": true
                }
              },
              "name": "Generic name 2",
              "isModerator": true,
              "isDialIn": false,
              "answers": {},
              "talk": {
                "totalTime": 0,
                "lastTalkStartedOn": 0
              },
              "emojis": [],
              "webcams": [],
              "totalOfMessages": 0
            }
          },
          "polls": {},
          "screenshares": [
            {
              "startedOn": 1690290408449,
              "stoppedOn": 1690290573091
            },
            {
              "startedOn": 1690294824305,
              "stoppedOn": 1690294957331
            },
            {
              "startedOn": 1690294976792,
              "stoppedOn": 1690295106468
            },
            {
              "startedOn": 1690295120270,
              "stoppedOn": 1690295742503
            },
            {
              "startedOn": 1690295747135,
              "stoppedOn": 1690297603487
            },
            {
              "startedOn": 1690297609337,
              "stoppedOn": 0
            }
          ],
          "presentationSlides": [
            {
              "presentationId": "8b8e93774c2cebfcde9582e0f9c169",
              "pageNum": 1,
              "setOn": 1690288860858
            }
          ],
          "createdOn": 1690288854908,
          "endedOn": 0
        },
        "output": [
          {
            "extId": "186",
            "name": "generic name 1",
            "connections": [
              {
                "registeredOn": 1690289980777,
                "leftOn": 0,
                "userLeftFlag": false
              }
            ]
          },
          {
            "extId": "95",
            "name": "Generic name 2",
            "connections": [
              {
                "registeredOn": 1690295357122,
                "leftOn": 1690295379924,
                "userLeftFlag": true
              },
              {
                "registeredOn": 1690296171797,
                "leftOn": 0,
                "userLeftFlag": false
              },
              {
                "registeredOn": 1690293905345,
                "leftOn": 1690294109923,
                "userLeftFlag": true
              }
            ]
          }
        ]
      }
    ],
    "identifier": 76764430
  },
  {
    "context": [
      "I want to print counts of values by range - the ranges being (lower bound included, high bound excluded); 0-1MB, 1-2MB, 2-3MB, ... 12-13MB.",
      "to_entries\n| map(.value / 1048576 | floor | [tostring, \"-\", (.+1 | tostring), \"MB\"] | add)\n| group_by(.)\n| map({\"key\": .[0], \"value\": length})\n| from_entries",
      "reduce (.[] / 1048576 | floor) as $k ({}; .\"\\($k)-\\($k+1)MB\" += 1)"
    ],
    "utterance": "Count the number of entries whose values fall into each 1MB range, producing an object where keys are of the form \"X-YMB\" indicating the range.",
    "expressions": [
      "to_entries | map(.value / 1048576 | floor | [tostring, \"-\", (.+1 | tostring), \"MB\"] | add) | group_by(.) | map({\"key\": .[0], \"value\": length}) | from_entries",
      "to_entries | map(.value / 1048576 | floor) | group_by(.) | map({\"key\": [(.[0] | tostring), \"-\", (.[0]+1 | tostring), \"MB\"] | add, \"value\": length}) | from_entries",
      "reduce (.[] / 1048576 | floor) as $k ({}; .\"\\($k)-\\($k+1)MB\" += 1)"
    ],
    "data": [
      {
        "input": {
          "session1": 128,
          "session2": 1048596,
          "session3": 3145728,
          "session4": 3145828,
          "session5": 11534338,
          "session6": 11544336,
          "session7": 2097252
        },
        "output": {
          "0-1MB": 1,
          "1-2MB": 1,
          "2-3MB": 1,
          "3-4MB": 2,
          "11-12MB": 2
        }
      }
    ],
    "identifier": 76797427
  },
  {
    "context": [
      "I want to print sum of values by range - the ranges being (lower bound included, high bound excluded); 0-1MB, 1-2MB, 2-3MB, ... 12-13MB.",
      "reduce (map(.) | sort[]) as $n ({}; .[$n / 1048576 | floor | \"\\(.)-\\(.+1)MB\"] += $n)",
      "{\n  \"0-1MB\": 128,\n  \"1-2MB\": 1048596,\n  \"2-3MB\": 2097252,\n  \"3-4MB\": 6291556,\n  \"11-12MB\": 23078674\n}"
    ],
    "utterance": "Sum the values grouped by 1MB intervals, producing keys like '0-1MB', '1-2MB', with each key containing the sum of values within that range.",
    "expressions": [
      "reduce (map(.) | sort[]) as $n ({}; .[$n / 1048576 | floor | \"\\(.)-\\(.+1)MB\"] += $n)"
    ],
    "data": [
      {
        "input": {
          "session1": 128,
          "session2": 1048596,
          "session3": 3145728,
          "session4": 3145828,
          "session5": 11534338,
          "session6": 11544336,
          "session7": 2097252
        },
        "output": {
          "0-1MB": 128,
          "1-2MB": 1048596,
          "2-3MB": 2097252,
          "3-4MB": 6291556,
          "11-12MB": 23078674
        }
      }
    ],
    "identifier": 76798065
  },
  {
    "context": [
      "Without stream, I can use the following to extract what I want:",
      "jq -rc \".results[]\" my_json.json",
      "However, if I want to do the same thing using the stream option, I am unable to get the same output.",
      "jq -rc --stream 'fromstream(1|truncate_stream(inputs | select(.[0][0] == \"results\")))' my_json.json",
      "You need to `truncate_stream` by two levels: `.results` and `.[]`. Use `inputs` (and the `-n` flag) for the input, and `fromstream` to construct the output:",
      "jq --stream -cn 'fromstream(2|truncate_stream(inputs))'",
      "If you want to specify `.results` explicitly (necessary if the input contains more than just this one field), use `select` on the input:",
      "jq --stream -cn 'fromstream(2|truncate_stream(inputs | select(.[0][0] == \"results\")))'"
    ],
    "utterance": "Output each object from the results array as a separate line using streaming mode.",
    "expressions": [
      "fromstream(2|truncate_stream(inputs))",
      "fromstream(2|truncate_stream(inputs | select(.[0][0] == \"results\")))"
    ],
    "data": [
      {
        "input": {
          "date": "2023-07-30",
          "results": [
            {
              "data": [
                {
                  "row": [
                    {
                      "key1": "row1",
                      "key2": "row1"
                    }
                  ]
                },
                {
                  "row": [
                    {
                      "key1": "row2",
                      "key2": "row2"
                    }
                  ]
                }
              ]
            },
            {
              "data": [
                {
                  "row": [
                    {
                      "key1": "row3",
                      "key2": "row3"
                    }
                  ]
                },
                {
                  "row": [
                    {
                      "key1": "row4",
                      "key2": "row4"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "data": [
            {
              "row": [
                {
                  "key1": "row1",
                  "key2": "row1"
                }
              ]
            },
            {
              "row": [
                {
                  "key1": "row2",
                  "key2": "row2"
                }
              ]
            }
          ]
        }
      },
      {
        "input": {
          "data": [
            {
              "row": [
                {
                  "key1": "row3",
                  "key2": "row3"
                }
              ]
            },
            {
              "row": [
                {
                  "key1": "row4",
                  "key2": "row4"
                }
              ]
            }
          ]
        },
        "output": {
          "data": [
            {
              "row": [
                {
                  "key1": "row3",
                  "key2": "row3"
                }
              ]
            },
            {
              "row": [
                {
                  "key1": "row4",
                  "key2": "row4"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 76797917
  },
  {
    "context": [
      "I want multiply the \"value\" field with the \"lvalue\" field an put the result in a new field \"calc\" in the corresponding array entry.",
      ".value as $val | .location[] |= (.calc = $val * .lvalue)"
    ],
    "utterance": "Add a new field 'calc' to each object in the 'location' array, equal to the product of the top-level 'value' and that object's 'lvalue'.",
    "expressions": [
      ".value as $val | .location[] |= (.calc = $val * .lvalue)"
    ],
    "data": [
      {
        "input": {
          "value": 5,
          "location": [
            {
              "city": "San Fracisco",
              "lvalue": 10
            },
            {
              "city": "Los Angeles",
              "lvalue": 20
            }
          ]
        },
        "output": {
          "value": 5,
          "location": [
            {
              "city": "San Fracisco",
              "lvalue": 10,
              "calc": 50
            },
            {
              "city": "Los Angeles",
              "lvalue": 20,
              "calc": 100
            }
          ]
        }
      }
    ],
    "identifier": 76805892
  },
  {
    "context": [
      "How could I remove `httpRequest.headers` and `httpRequest.cookies` from each item in array?",
      "map(del(.httpRequest.cookies, .httpRequest.headers, .httpResponse.headers, .httpResponse.cookies))"
    ],
    "utterance": "Remove the httpRequest.headers and httpRequest.cookies fields from each object in the input array.",
    "expressions": [
      "map(del(.httpRequest.cookies, .httpRequest.headers, .httpResponse.headers, .httpResponse.cookies))"
    ],
    "data": [
      {
        "input": [
          {
            "httpRequest": {
              "method": "POST",
              "path": "/catalog-data-rest/catalog/search.xml",
              "headers": {
                "content-length": [
                  "141"
                ],
                "content-encoding": [
                  ".*"
                ],
                "User-Agent": [
                  "Apache-HttpClient/4.5.13 (Java/11.0.19)"
                ],
                "Host": [
                  "preproduccio.gcatalegs.isisscat.intranet.gencat.cat:8443"
                ],
                "Cookie": [
                  "JSESSIONID=0000DVEWfJHnChmIF3Qm8fS7AOG:19pp48tgo"
                ],
                "Content-Type": [
                  "text/xml;charset=UTF-8"
                ],
                "Connection": [
                  "Keep-Alive"
                ],
                "Authorization": [
                  "Basic VVNVTVBJVFNUOkJ4c2w3MjU5"
                ],
                "Accept-Encoding": [
                  "gzip,deflate"
                ]
              },
              "cookies": {
                "JSESSIONID": "0000DVEWfJHnChmIF3Qm8fS7AOG:19pp48tgo"
              },
              "keepAlive": true,
              "secure": true,
              "localAddress": "127.0.0.1:1080",
              "remoteAddress": "127.0.0.1",
              "body": {
                "type": "XML",
                "xml": "<request><tableName>ET 99CCA</tableName><owner><ownerType>REF</ownerType></owner><startIndex>1</startIndex><pageSize>100</pageSize></request>",
                "rawBytes": "PHJlcXVlc3Q+PHRhYmxlTmFtZT5FVCA5OUNDQTwvdGFibGVOYW1lPjxvd25lcj48b3duZXJUeXBlPlJFRjwvb3duZXJUeXBlPjwvb3duZXI+PHN0YXJ0SW5kZXg+MTwvc3RhcnRJbmRleD48cGFnZVNpemU+MTAwPC9wYWdlU2l6ZT48L3JlcXVlc3Q+",
                "contentType": "text/xml; charset=utf-8"
              }
            },
            "httpResponse": {
              "statusCode": 200,
              "reasonPhrase": "OK",
              "headers": {
                "X-XSS-Protection": [
                  "1; mode=block"
                ],
                "X-Powered-By": [
                  "Servlet/3.0"
                ],
                "X-Frame-Options": [
                  "DENY"
                ],
                "X-Content-Type-Options": [
                  "nosniff"
                ],
                "Strict-Transport-Security": [
                  "max-age=31536000 ; includeSubDomains"
                ],
                "Set-Cookie": [
                  "JSESSIONID=0000NOyZg7ww-mcbN2YfxKE-957:19pp48tgo; Path=/; Secure; HttpOnly"
                ],
                "Pragma": [
                  "no-cache"
                ],
                "Expires": [
                  "0"
                ],
                "Date": [
                  "Mon, 17 Jul 2023 15:01:13 GMT"
                ],
                "Content-Type": [
                  "application/xml"
                ],
                "Content-Language": [
                  "en-US"
                ],
                "Cache-Control": [
                  "no-cache, no-store, max-age=0, must-revalidate"
                ]
              },
              "cookies": {
                "JSESSIONID": "0000NOyZg7ww-mcbN2YfxKE-957:19pp48tgo"
              },
              "body": {
                "type": "XML",
                "xml": "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?><resultSet><request><tableName>ET 99CCA</tableName><owner><ownerType>RE...",
                "rawBytes": "PD94bWwgdmVyc2lvbj0iMS4wIiBlb...",
                "contentType": "application/xml"
              }
            },
            "id": "8755ddd1-835c-40fe-870f-decf16242e4e",
            "priority": 0,
            "timeToLive": {
              "unlimited": true
            },
            "times": {
              "remainingTimes": 1
            }
          }
        ],
        "output": [
          {
            "httpRequest": {
              "method": "POST",
              "path": "/catalog-data-rest/catalog/search.xml",
              "keepAlive": true,
              "secure": true,
              "localAddress": "127.0.0.1:1080",
              "remoteAddress": "127.0.0.1",
              "body": {
                "type": "XML",
                "xml": "<request><tableName>ET 99CCA</tableName><owner><ownerType>REF</ownerType></owner><startIndex>1</startIndex><pageSize>100</pageSize></request>",
                "rawBytes": "PHJlcXVlc3Q+PHRhYmxlTmFtZT5FVCA5OUNDQTwvdGFibGVOYW1lPjxvd25lcj48b3duZXJUeXBlPlJFRjwvb3duZXJUeXBlPjwvb3duZXI+PHN0YXJ0SW5kZXg+MTwvc3RhcnRJbmRleD48cGFnZVNpemU+MTAwPC9wYWdlU2l6ZT48L3JlcXVlc3Q+",
                "contentType": "text/xml; charset=utf-8"
              }
            },
            "httpResponse": {
              "statusCode": 200,
              "reasonPhrase": "OK",
              "body": {
                "type": "XML",
                "xml": "<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\"?><resultSet><request><tableName>ET 99CCA</tableName><owner><ownerType>RE...",
                "rawBytes": "PD94bWwgdmVyc2lvbj0iMS4wIiBlb...",
                "contentType": "application/xml"
              }
            },
            "id": "8755ddd1-835c-40fe-870f-decf16242e4e",
            "priority": 0,
            "timeToLive": {
              "unlimited": true
            },
            "times": {
              "remainingTimes": 1
            }
          }
        ]
      }
    ],
    "identifier": 76705819
  },
  {
    "context": [
      "I want to add a new key value pair `baz` to this json using jq based on the existence of values for keys foo and bar. If foo and bar are both not null, then `baz` should be the string \"true\". If either foo or bar are null or both are null, then `baz` should be string \"false\".",
      "If the new values should indeed be strings, simply [interpolate](https://jqlang.github.io/jq/manual/#Stringinterpolation%3A%5C%28exp%29) the computed booleans:",
      "map(.baz = \"\\(.foo != null and .bar != null)\")"
    ],
    "utterance": "Add a key baz with value \"true\" if both foo and bar are not null, otherwise \"false\".",
    "expressions": [
      "map(.baz = \"\\(.foo != null and .bar != null)\")"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "fooValue",
            "bar": "barValue"
          },
          {
            "foo": null,
            "bar": null
          }
        ],
        "output": [
          {
            "foo": "fooValue",
            "bar": "barValue",
            "baz": "true"
          },
          {
            "foo": null,
            "bar": null,
            "baz": "false"
          }
        ]
      }
    ],
    "identifier": 76821746
  },
  {
    "context": [
      "I want to delete the entries in a JSON list that have the \"enabled\" key with the value `false`.",
      "The following jq cmd does select the false entries but now I want to remove those entries and keep the rest of the structure.",
      "del(.app.sig[] | select(.enabled | not))",
      ".app.sig |= map(select(.enabled))"
    ],
    "utterance": "Remove all elements from the app.sig array where enabled is false, keeping the rest of the object unchanged.",
    "expressions": [
      "del(.app.sig[] | select(.enabled | not))",
      ".app.sig |= map(select(.enabled))"
    ],
    "data": [
      {
        "input": {
          "app": {
            "id": "11111111",
            "name": "test",
            "general": {
              "allow": "sdasdass"
            },
            "settings": {
              "max": "8192"
            },
            "sig": [
              {
                "enabled": true,
                "Staging": false,
                "sId": "200101556"
              },
              {
                "enabled": false,
                "Staging": false,
                "sId": "200012071"
              },
              {
                "enabled": true,
                "Staging": false,
                "sId": "200012002"
              }
            ],
            "version": "v1"
          }
        },
        "output": {
          "app": {
            "id": "11111111",
            "name": "test",
            "general": {
              "allow": "sdasdass"
            },
            "settings": {
              "max": "8192"
            },
            "sig": [
              {
                "enabled": true,
                "Staging": false,
                "sId": "200101556"
              },
              {
                "enabled": true,
                "Staging": false,
                "sId": "200012002"
              }
            ],
            "version": "v1"
          }
        }
      }
    ],
    "identifier": 76821662
  },
  {
    "context": [
      "Assuming the answer is yes, is there a way that I can extract `results1[]` and `results2[]` on the same call to avoid reading the file twice?",
      "You can output each piece of data with it's key and post-process it:\n\n```sh\njq -r '\n    to_entries[]\n    | select(.key != \"date\")\n    | .key as $k\n    | .value[]\n    | [$k, @json]\n    | @tsv\n' my_json.json\n```",
      "outputs\n```none\nresults1\t{\"data\":[{\"row\":[{\"key1\":\"row1\",\"key2\":\"row1\"}]},{\"row\":[{\"key1\":\"row2\",\"key2\":\"row2\"}]}]}\nresults1\t{\"data\":[{\"row\":[{\"key1\":\"row3\",\"key2\":\"row3\"}]},{\"row\":[{\"key1\":\"row4\",\"key2\":\"row4\"}]}]}\nresults2\t{\"data\":[{\"row\":[{\"key3\":\"row1\",\"key4\":\"row1\"}]},{\"row\":[{\"key3\":\"row2\",\"key4\":\"row2\"}]}]}\nresults2\t{\"data\":[{\"row\":[{\"key3\":\"row3\",\"key4\":\"row3\"}]},{\"row\":[{\"key3\":\"row4\",\"key4\":\"row4\"}]}]}\n```"
    ],
    "utterance": "Extract all items from both results1 and results2 arrays in a single pass, outputting each item prefixed by its array key.",
    "expressions": [
      "to_entries[] | select(.key != \"date\") | .key as $k | .value[] | [$k, @json] | @tsv"
    ],
    "data": [
      {
        "input": {
          "date": "2023-07-30",
          "results1": [
            {
              "data": [
                {
                  "row": [
                    {
                      "key1": "row1",
                      "key2": "row1"
                    }
                  ]
                },
                {
                  "row": [
                    {
                      "key1": "row2",
                      "key2": "row2"
                    }
                  ]
                }
              ]
            },
            {
              "data": [
                {
                  "row": [
                    {
                      "key1": "row3",
                      "key2": "row3"
                    }
                  ]
                },
                {
                  "row": [
                    {
                      "key1": "row4",
                      "key2": "row4"
                    }
                  ]
                }
              ]
            }
          ],
          "results2": [
            {
              "data": [
                {
                  "row": [
                    {
                      "key3": "row1",
                      "key4": "row1"
                    }
                  ]
                },
                {
                  "row": [
                    {
                      "key3": "row2",
                      "key4": "row2"
                    }
                  ]
                }
              ]
            },
            {
              "data": [
                {
                  "row": [
                    {
                      "key3": "row3",
                      "key4": "row3"
                    }
                  ]
                },
                {
                  "row": [
                    {
                      "key3": "row4",
                      "key4": "row4"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": "results1\t{\"data\":[{\"row\":[{\"key1\":\"row1\",\"key2\":\"row1\"}]},{\"row\":[{\"key1\":\"row2\",\"key2\":\"row2\"}]}]}\nresults1\t{\"data\":[{\"row\":[{\"key1\":\"row3\",\"key2\":\"row3\"}]},{\"row\":[{\"key1\":\"row4\",\"key2\":\"row4\"}]}]}\nresults2\t{\"data\":[{\"row\":[{\"key3\":\"row1\",\"key4\":\"row1\"}]},{\"row\":[{\"key3\":\"row2\",\"key4\":\"row2\"}]}]}\nresults2\t{\"data\":[{\"row\":[{\"key3\":\"row3\",\"key4\":\"row3\"}]},{\"row\":[{\"key3\":\"row4\",\"key4\":\"row4\"}]}]}"
      }
    ],
    "identifier": 76803755
  },
  {
    "context": [
      "I would like to get field parent in JSON object and first, last fields in nested JSON array above.",
      "How do I use `jq` to get values for parent field and each child first and last name fields?",
      ".parent, (.children[] | .first, .last)"
    ],
    "utterance": "Output the value of the parent field followed by the first and last fields of each object in the children array.",
    "expressions": [
      ".parent, (.children[] | .first, .last)"
    ],
    "data": [
      {
        "input": {
          "parent": "John Smith",
          "dob": "August 6, 2020",
          "children": [
            {
              "first": "Bob",
              "last": "Smith"
            },
            {
              "first": "John",
              "last": "Smith"
            }
          ]
        },
        "output": [
          "John Smith",
          "Bob",
          "Smith",
          "John",
          "Smith"
        ]
      }
    ],
    "identifier": 76843139
  },
  {
    "context": [
      "I have several services which have the same name prefix and I need to select their image fields and update them",
      "I want to change my docker-compose file service images via yq tool.",
      "I can not get the `image` key underneath",
      "(.services[] | select(key == \"app_sandbox*\")).image = \"some-image:latest\""
    ],
    "utterance": "Update the image field to 'some-image:latest' for all services whose names start with 'app_sandbox'.",
    "expressions": [
      "(.services[] | select(key == \"app_sandbox*\")).image = \"some-image:latest\""
    ],
    "data": [
      {
        "input": {
          "version": "3.4",
          "services": {
            "app_sandbox_zeta": {
              "image": "some-image:not-latest"
            },
            "app_sandbox_sigma": {
              "image": "some-image:not-latest"
            },
            "general_app": "...",
            "some_app": "..."
          }
        },
        "output": {
          "version": "3.4",
          "services": {
            "app_sandbox_zeta": {
              "image": "some-image:latest"
            },
            "app_sandbox_sigma": {
              "image": "some-image:latest"
            },
            "general_app": "...",
            "some_app": "..."
          }
        }
      }
    ],
    "identifier": 76826665
  },
  {
    "context": [
      "if ! jq --argjson data \"$extracted_content\" '. += $data' \"$TO\" > \"$TO.tmp\"; then",
      "You can pass variable extracted_content (via `declare`) and then escape the dollar (\\$) sign (for `extracted_content` and `data`):",
      "if ! jq --argjson data \"\\$extracted_content\" '. += \\$data' \"$TO\" > \"$TO.tmp\"; then",
      "Write the code you want to run remotely in a function, then tell the shell to serialize that function with `declare -f` just the same as how you serialize the data the function uses with `declare -p`.",
      "jq --argjson data \"$extracted_content\" '. += $data' \"$TO\" > \"$TO.tmp\" || {"
    ],
    "utterance": "Merge the contents of a variable containing a JSON object into an existing file using the += operator, passing the variable as an argument.",
    "expressions": [
      "jq --argjson data \"$extracted_content\" '. += $data' \"$TO\" > \"$TO.tmp\"",
      "jq --argjson data \"\\$extracted_content\" '. += \\$data' \"$TO\" > \"$TO.tmp\""
    ],
    "identifier": 76835075
  },
  {
    "context": [
      "Now I want to list where conditions is matching with type as `google_project_iam_binding` and delete or update.",
      "With below jq I was able to get the details.",
      "jq '.resource_changes[] | select(any(.change.actions[]; .==\"delete\" or .==\"update\"))'",
      "With below jq select getting an error.",
      "jq '.resource_changes[] | select((.type == \"google_project_iam_binding\") and (.change.actions[]; .==\"delete\" or .==\"update\"))'"
    ],
    "utterance": "List all resource_changes elements where type is google_project_iam_binding and change.actions includes delete or update.",
    "expressions": [
      ".resource_changes[] | select(.type == \"google_project_iam_binding\" and any(.change.actions[]; . == \"delete\" or . == \"update\"))"
    ],
    "data": [
      {
        "input": {
          "resource_changes": [
            {
              "address": "module.gke-cluster.module.gke.random_shuffle.available_zones",
              "module_address": "module.gke-cluster.module.gke",
              "mode": "managed",
              "type": "random_shuffle",
              "name": "available_zones",
              "provider_name": "registry.terraform.io/hashicorp/random",
              "change": {
                "actions": [
                  "delete",
                  "create"
                ]
              }
            },
            {
              "address": "module.serviceproject.module.project-cfg.google_project_iam_binding.roles[\"roles/cloudkms.admin\"]",
              "module_address": "module.serviceproject.module.project-cfg",
              "mode": "managed",
              "type": "google_project_iam_binding",
              "name": "roles",
              "index": "roles/cloudkms.admin",
              "provider_name": "registry.terraform.io/hashicorp/google",
              "change": {
                "actions": [
                  "delete",
                  "update"
                ]
              }
            }
          ]
        },
        "output": {
          "address": "module.serviceproject.module.project-cfg.google_project_iam_binding.roles[\"roles/cloudkms.admin\"]",
          "module_address": "module.serviceproject.module.project-cfg",
          "mode": "managed",
          "type": "google_project_iam_binding",
          "name": "roles",
          "index": "roles/cloudkms.admin",
          "provider_name": "registry.terraform.io/hashicorp/google",
          "change": {
            "actions": [
              "delete",
              "update"
            ]
          }
        }
      }
    ],
    "identifier": 76823338
  },
  {
    "context": [
      "Change \"status\" from 10 to 100 where is max value for \"sitem\"",
      "You can get there in two steps: First, compute the max value of all `.sitem` values and store it in a variable, then iterate through all items and change `.status` if its `.sitem` matches the stored max value.",
      "max_by(.sitem | tonumber).sitem as $max",
      "map(.status = if .sitem == $max then \"100\" else \"10\" end)",
      "\u2026| max_by(.sitem).sitem as $max | to_entries | map(.value + { sindex: \"\\(1+.key)\", status: (if .value.sitem == $max then \"100\" else \"10\" end) })"
    ],
    "utterance": "Update each element's status to 100 if its sitem is the maximum value; otherwise, set status to 10.",
    "expressions": [
      "max_by(.sitem | tonumber).sitem as $max | map(.status = if .sitem == $max then \"100\" else \"10\" end)",
      "to_entries | max_by(.value.sitem | tonumber).value.sitem as $max | map(.value + {sindex: \"\\(1+.key)\", status: (if .value.sitem == $max then \"100\" else \"10\" end)})"
    ],
    "data": [
      {
        "input": [
          {
            "main": [
              {
                "drink": "cola",
                "sitem": "10"
              },
              {
                "drink": "pepsi",
                "sitem": "20"
              }
            ]
          }
        ],
        "output": [
          {
            "drink": "cola",
            "sitem": "10",
            "sindex": "1",
            "status": "10"
          },
          {
            "drink": "pepsi",
            "sitem": "20",
            "sindex": "2",
            "status": "100"
          }
        ]
      }
    ],
    "identifier": 76834777
  },
  {
    "context": [
      "Actually I don't care about the `day` and want to group my records by `id` and sum the `count`. Expected result:",
      "{'id':'123','count':65}",
      "{'id':'456','count':77}",
      "{'id':'789','count':44}",
      "Use `group_by` to group the objects.",
      "jq -cs 'group_by(.id)[] | {id: .[0].id, count: map(.count) | add}' < file.json",
      "If the input is large, and you don't want to `--slurp` (or `-s`) all items into memory (only effective if there are at least some duplicate IDs), you can take a `reduce`-based approach which iterates over the `inputs` collecting only the aggregated values:",
      "jq -cn '\n  reduce inputs as {$count, $id} ({}; .[$id] += $count)\n  | to_entries[] | {id: .key, count: .value}\n'"
    ],
    "utterance": "Group records by id and sum the count values for each id, ignoring the day field.",
    "expressions": [
      "group_by(.id)[] | {id: .[0].id, count: map(.count) | add}",
      "reduce inputs as {$count, $id} ({}; .[$id] += $count) | to_entries[] | {id: .key, count: .value}"
    ],
    "data": [
      {
        "input": [
          {
            "count": 42,
            "day": "2023-06-22",
            "id": "123"
          },
          {
            "count": 12,
            "day": "2023-06-22",
            "id": "456"
          },
          {
            "count": 23,
            "day": "2023-06-23",
            "id": "123"
          },
          {
            "count": 44,
            "day": "2023-06-23",
            "id": "789"
          },
          {
            "count": 65,
            "day": "2023-06-21",
            "id": "456"
          }
        ],
        "output": [
          {
            "id": "123",
            "count": 65
          },
          {
            "id": "456",
            "count": 77
          },
          {
            "id": "789",
            "count": 44
          }
        ]
      }
    ],
    "identifier": 76842785
  },
  {
    "context": [
      "How, with jq, can I get at the value of the \"v\" label, which here is \"Backlog\"?",
      ".labels[] | select(startswith(\"v::\"))[3:]",
      ".labels[] | select(startswith($scope))[$scope|length:]",
      ".labels[] | scan(\"v::(.*)\")[]"
    ],
    "utterance": "Extract the value that comes after 'v::' from the labels array, such as 'Backlog'.",
    "expressions": [
      ".labels[] | select(startswith(\"v::\"))[3:]",
      "jq --arg scope 'v::' '.labels[] | select(startswith($scope))[$scope|length:]'",
      ".labels[] | scan(\"v::(.*)\")[]"
    ],
    "data": [
      {
        "input": {
          "labels": [
            "AI::Assessed",
            "Pri::1 - High",
            "Type::Investigation",
            "v::Backlog"
          ]
        },
        "output": "Backlog"
      }
    ],
    "identifier": 76879777
  },
  {
    "context": [
      "how to bring this together into json arrays?",
      "some issues I still have to solve which I don't find a solution for:\n1. The filenames are not spread into separate arrays.\n2. the `time` field should not have the escaped quoted strings. I'd like to have a solution that iterates over all fields and would expand these contents out of of the quotes like here as example `\"time\": \"2021-09-14T22:33:40Z\"`\n3. `description` value is spread over multiple lines and I'd like to see them merged into one value but that's not what happens as of now, so should look like that: `\"description\": \"Here is number \\\"two\\\"  best of all`. The single quotes should not be kept.",
      "So at the end the outcome should be rather like that:\n```\n[\n  {\n    \"filename\": \"content/1.yaml\",\n    \"time\": \"2020-09-14T22:33:40Z\",\n    \"id\": \"ed1d4321\",\n    \"name\": \"One\",\n    \"description\": \"Here is number \\\"one\\\"  this is good\"\n  },\n  {\n    \"filename\": \"content/2yaml\",\n    \"time\": \"2021-09-14T22:33:40Z\",\n    \"id\": \"eg134841\",\n    \"name\": \"Two\",\n    \"description\": \"Here is number \\\"two\\\"  best of all\",\n    \"newkey\": \"value\"\n  }\n]\n```",
      "Start with `jq --slurp --raw-input`:",
      "split(\"\\n\")\n# join lines starting with whitespace with previous line\n| reduce .[] as $l (\n    null;\n    if $l | startswith(\" \") then .[-1] += $l else . += [$l] end\n)\n# split on first colon, returning an array of objects like {key: X, value: Y}\n| map(capture(\"^(?<key>[^:]+):\\\\s*(?<value>.*)$\"))\n# combine these simple objects into bigger objects but begin a new objects when encountering \"filename\"\n| reduce .[] as $e (null; \n    if $e.key == \"filename\" then . += [{}] else . end\n    | .[-1][$e.key] = $e.value\n)",
      "The output is this:\n```\n[\n  {\n    \"filename\": \"content/1.yaml\",\n    \"time\": \"\\\"2020-09-14T22:33:40Z\\\"\",\n    \"id\": \"ed1d4321\",\n    \"name\": \"One\",\n    \"description\": \"'Here is number \\\"one\\\"  this is good'\"\n  },\n  {\n    \"filename\": \"content/2yaml\",\n    \"time\": \"\\\"2021-09-14T22:33:40Z\\\"\",\n    \"id\": \"eg134841\",\n    \"name\": \"Two\",\n    \"description\": \"'Here is number \\\"two\\\"  best of all'\",\n    \"newkey\": \"value\"\n  }\n]\n```",
      "def objectify:\n  capture(\"(?<key>[^:]+): *(?<value>.*)\")\n  | .value = (.value | (fromjson? // .))\n  | [.]\n  | from_entries;\n\ngsub(\"\\n  *\"; \" \")        # join dangling text\n| . / \"\\n\"                # split\n| map(select(length>0))   # ignore \"\"\n| map(objectify)          # {key, value}\n| add"
    ],
    "utterance": "Transform a set of text files each with key-value pairs (and multiline values) to an array, where each item contains all fields and the filename; multiline values are merged, quotes and single quotes are stripped from values.",
    "expressions": [
      "jq --slurp --raw-input '\nsplit(\"\\n\")\n| reduce .[] as $l (\n    null;\n    if $l | startswith(\" \") then .[-1] += $l else . += [$l] end\n)\n| map(capture(\"^(?<key>[^:]+):\\\\s*(?<value>.*)$\"))\n| reduce .[] as $e (null; \n    if $e.key == \"filename\" then . += [{}] else . end\n    | .[-1][$e.key] = $e.value\n)'",
      "jq -Rs '\ndef objectify:\n  capture(\"(?<key>[^:]+): *(?<value>.*)\")\n  | .value = (.value | (fromjson? // .))\n  | [.]\n  | from_entries;\ngsub(\"\\n  *\"; \" \")        # join dangling text\n| . / \"\\n\"\n| map(select(length>0))\n| map(objectify)\n| add'"
    ],
    "data": [
      {
        "input": "# for file in $(ls content/*yaml); do echo filename: $file; cat $file; done\nfilename: content/1.yaml\ntime: \"2020-09-14T22:33:40Z\"\nid: ed1d4321\nname: One\ndescription: 'Here is number \"one\"\n  this is good'\nfilename: content/2yaml\ntime: \"2021-09-14T22:33:40Z\"\nid: eg134841\nname: Two\ndescription: 'Here is number \"two\"\n  best of all'\nnewkey: value",
        "output": [
          {
            "filename": "content/1.yaml",
            "time": "2020-09-14T22:33:40Z",
            "id": "ed1d4321",
            "name": "One",
            "description": "Here is number \"one\"  this is good"
          },
          {
            "filename": "content/2yaml",
            "time": "2021-09-14T22:33:40Z",
            "id": "eg134841",
            "name": "Two",
            "description": "Here is number \"two\"  best of all",
            "newkey": "value"
          }
        ]
      }
    ],
    "identifier": 76744674
  },
  {
    "context": [
      "I have this jq query where i am adding path as a key so later i can get the value for the path but this is giving the error",
      "gojq.Parse(\".data[]|{.id: .id, name: .name, disk_capacity: .disks[].capacityGB,  disk_name: .disks[]|.name,}\")",
      "i am able to solve this like below",
      "gojq.Parse(`.data[]|{\".id\": .id, \".name\": .name, \".disks[].capacityGB\": .disks[].capacityGB,  \".disks[]|.name\": .disks[]|.name,}`)"
    ],
    "utterance": "Create an object for each item where the keys are JSON path-like strings such as \".id\" and values are the corresponding item fields, using quoted keys that contain special characters.",
    "expressions": [
      ".data[] | { \".id\": .id, \".name\": .name, \".disks[].capacityGB\": .disks[].capacityGB, \".disks[]|.name\": .disks[]|.name }"
    ],
    "identifier": 76878039
  },
  {
    "context": [
      "I want in each round of a loop of 10 rounds, the key in the value of \"counter\" (which is 0 now) to get changed to the number of the loop.",
      "The key can be changed using the following JQ filter:",
      "jq '.counter |= with_entries(.key = \"5\")' input.json",
      "Then, using a bash loop where we append all 10 objects to a new file, use:",
      "jq --arg counter \"$round\" '.counter |= with_entries(.key = $counter)' input.json",
      "If you don't really need bash, you can use range(10) to let JQ do the looping, use the same filter as above ...",
      "jq 'range(10) as $n | .counter |= with_entries(.key = \"\\($n)\")' input.json"
    ],
    "utterance": "Change the key inside the counter object from \"0\" to the current loop number, overwriting it with each iteration.",
    "expressions": [
      ".counter |= with_entries(.key = $counter)",
      "range(10) as $n | .counter |= with_entries(.key = \"\\($n)\")"
    ],
    "data": [
      {
        "input": {
          "A": {
            "i": "user_defined",
            "j": 678,
            "k": 1.75,
            "l": 6.7,
            "m": 1.2
          },
          "W": "10",
          "counter": {
            "0": {
              "p": 34,
              "q": "returned",
              "r": 98,
              "s": "wait",
              "t": "done",
              "u": "8.9"
            }
          },
          "z": "th"
        },
        "output": {
          "A": {
            "i": "user_defined",
            "j": 678,
            "k": 1.75,
            "l": 6.7,
            "m": 1.2
          },
          "W": "10",
          "counter": {
            "8": {
              "p": 34,
              "q": "returned",
              "r": 98,
              "s": "wait",
              "t": "done",
              "u": "8.9"
            }
          },
          "z": "th"
        }
      }
    ],
    "identifier": 76883696
  },
  {
    "context": [
      "But when the text I replace **contains variables**, I get an error",
      "How can I modify the replaced text to carry variables and replace them correctly? Looking forward to your reply.",
      "Use\n```\nDATA='[{\"name\": \"'$NAME'\", \"age\": 22}]'\n```\n\nTo make sure the double quotes around the key are preserved, then your jq filter works just fine:",
      "jq --argjson newdata \"$DATA\" '.persons = $newdata' sample.json"
    ],
    "utterance": "Replace the value of the 'persons' key with an array containing one object whose 'name' property is set to the value of a shell variable and 'age' is 22.",
    "expressions": [
      "jq --argjson newdata \"$DATA\" '.persons = $newdata' sample.json"
    ],
    "data": [
      {
        "input": {
          "persons": [
            {
              "name": "test1",
              "age": 20
            },
            {
              "name": "test2",
              "age": 21
            }
          ]
        },
        "output": {
          "persons": [
            {
              "name": "namevar",
              "age": 22
            }
          ]
        }
      }
    ],
    "identifier": 76899286
  },
  {
    "context": [
      "I have this JSON data from a OCI Bucket upload and I want to extract a specific part of it.",
      "Expected output",
      "{\r\n  \"a\": \"1\",\r\n  \"b\": \"2\"\r\n}",
      "This will read the first JSON entity from the input and then terminate",
      "jq -n 'input'",
      "This will read the full JSON input into an array and then return the first item of the array",
      "jq -s 'first'"
    ],
    "utterance": "Extract only the first object from input containing two separate objects.",
    "expressions": [
      "jq -n 'input'",
      "jq -s 'first'"
    ],
    "data": [
      {
        "input": [
          {
            "a": "1",
            "b": "2"
          },
          {
            "A": "1",
            "B": "2"
          }
        ],
        "output": {
          "a": "1",
          "b": "2"
        }
      }
    ],
    "identifier": 76905302
  },
  {
    "context": [
      "So it has venues in it with some details. Now I&#39;d need to format the file to look like this:",
      "Basically it would have a running integer as the key for each venue and the details inside it.",
      "You can use `with_entries` to get the index of an object, add 1 and convert to string to use that as the index.",
      "Then update the .value with a custom object were you get the keys you&#39;d like, something like:",
      "with_entries(.key = (.key + 1 | tostring) | .value = (.value.venue | { \r\n    name,\r\n    county: .city.country.name,\r\n    city: .city.name,\r\n    stateCode: .city.stateCode,\r\n    setlistfmId: .id\r\n}))"
    ],
    "utterance": "Reformat a list of venue objects into an object with integer string keys starting from 1, and for each value include name, country, city, state, stateCode, setlistfmId, and an integer id.",
    "expressions": [
      "to_entries | with_entries(.key = (.key + 1 | tostring) | .value = (.value.venue | { id: (.key | tonumber), name, country: .city.country.name, city: .city.name, state: .city.state, stateCode: .city.stateCode, setlistfmId: .id }))"
    ],
    "data": [
      {
        "input": [
          {
            "venue": {
              "id": "63d706ff",
              "name": "Joe Robbie Stadium",
              "city": {
                "id": "4164167",
                "name": "Miami Gardens",
                "state": "Florida",
                "stateCode": "FL",
                "coords": {
                  "lat": 25.9420377,
                  "long": -80.2456045
                },
                "country": {
                  "code": "US",
                  "name": "United States"
                }
              }
            }
          }
        ],
        "output": {
          "1": {
            "id": 1,
            "name": "Joe Robbie Stadium",
            "country": "United States",
            "city": "Miami Gardens",
            "state": "Florida",
            "stateCode": "FL",
            "setlistfmId": "63d706ff"
          }
        }
      }
    ],
    "identifier": 76899217
  },
  {
    "context": [
      "How can I make iterating array after split and create csv output",
      "And I would like to expect this csv...\n>     topinfo;1;1;item1\n>     topinfo;1;2;details item 1\n>     topinfo;1;3;details sdfdfdfd\n>     topinfo;1;4;details gbgfgghmhjmh\n>     topinfo;1;5;details 5348786\n>     \n>     topinfo;2;1;item2\n>     topinfo;2;2;details item 2\n>     topinfo;2;3;details sdfdfdfd\n>     topinfo;2;4;details gbgfgghmhjmh\n>     topinfo;2;5;details 9784561",
      "Nesting iterations and variable bindings:\n```sh\n.[].body                                                   # top-level iteration\n| to_entries[] as {key: $i, value: {$title, $longText}}    # collect values\n| $longText / \"|\"                                          # split at \"|\"\n| map(select(. != \"\"))                                     # remove empty items(?)\n| (                                                        # open grouping context\n    to_entries[] as {key: $j, $value}                      # collect values\n    | [$title, $i+1, $j+1, $value]                         # prepare output line\n    | join(\";\")                                            # join to string\n  ), \"\"                                                    # add empty line\n```"
    ],
    "utterance": "For each object in the array, output each pipe-separated item in the 'longText' field as a line in semicolon-separated format: title;body index;item index;item value.",
    "expressions": [
      ".[].body\n| to_entries[] as {key: $i, value: {$title, $longText}}\n| $longText / \"|\"\n| map(select(. != \"\"))\n| (to_entries[] as {key: $j, value: $value}\n   | [$title, ($i+1), ($j+1), $value]\n   | join(\";\")), \"\""
    ],
    "data": [
      {
        "input": [
          {
            "body": [
              {
                "title": "topinfo",
                "longText": "item1|details item 1|details sdfdfdfd ||details gbgfgghmhjmh||details 5348786"
              },
              {
                "title": "topinfo",
                "longText": "item2|details item 2|details sdfdfdfd ||details gbgfgghmhjmh||details 9784561"
              }
            ]
          }
        ],
        "output": [
          "topinfo;1;1;item1",
          "topinfo;1;2;details item 1",
          "topinfo;1;3;details sdfdfdfd ",
          "topinfo;1;4;details gbgfgghmhjmh",
          "topinfo;1;5;details 5348786",
          "",
          "topinfo;2;1;item2",
          "topinfo;2;2;details item 2",
          "topinfo;2;3;details sdfdfdfd ",
          "topinfo;2;4;details gbgfgghmhjmh",
          "topinfo;2;5;details 9784561",
          ""
        ]
      }
    ],
    "identifier": 76849848
  },
  {
    "context": [
      "az vmss identity show -g group-name -n vmss-name -o json | jq '.userAssignedIdentities | with_entries(select(.key | contains(\"$test\")))'",
      "jq: error: $test is not defined at <top-level>, line 1:",
      "az vmss identity show -g group-name -n vmss-name -o json | jq --arg test \"$test\" '.userAssignedIdentities | with_entries(select(.key | contains($test)))'"
    ],
    "utterance": "Filter the userAssignedIdentities object to include only entries whose key contains the value of the variable test.",
    "expressions": [
      ".userAssignedIdentities | with_entries(select(.key | contains($test)))"
    ],
    "identifier": 76928274
  },
  {
    "context": [
      "I would like to format them and save it back using cli. Currently I am doing format document option in vscode but that i have to do one by one file.",
      "The above command displays it but do not know how to save it back to the same file. Also i would like to do it for entire folder.",
      "for file in *.json; do\n  jq . < \"$file\" > \"$file.out\" && mv \"$file.out\" \"$file\"\ndone"
    ],
    "utterance": "Format all files with the .json extension in the current directory so their content is pretty-printed and overwrite each file with the formatted content.",
    "expressions": [
      "for file in *.json; do jq . < \"$file\" > \"$file.out\" && mv \"$file.out\" \"$file\"; done"
    ],
    "identifier": 76920821
  },
  {
    "context": [
      "Id like to re-arrange it to look like this.",
      "So far, I can get to the object below but am unsure of how to merge the two \"shared\" keys",
      "Here's a `reduce`-based approach which iterates over the entries, and successively assigns each item to its intended path in the result object:",
      "reduce .json.result.entry[] as $entry ({};\n  .[$entry.\"@location\"][$entry.\"@name\"] = $entry\n)"
    ],
    "utterance": "Convert a list where each object contains '@location' and '@name' into a nested object, grouping by '@location' as the top-level key and '@name' as the second-level key, with objects as values.",
    "expressions": [
      "reduce .json.result.entry[] as $entry ({}; .[$entry.\"@location\"][$entry.\"@name\"] = $entry)"
    ],
    "data": [
      {
        "input": {
          "json": {
            "@code": "19",
            "@status": "success",
            "result": {
              "@count": "7003",
              "@total-count": "7003",
              "entry": [
                {
                  "@location": "shared",
                  "@name": "bgp_routers",
                  "static": {
                    "member": [
                      "core-1",
                      "core-2",
                      "core-3",
                      "supercore"
                    ]
                  }
                },
                {
                  "@location": "shared",
                  "@name": "web_servers",
                  "description": "req-5",
                  "static": {
                    "member": [
                      "web001",
                      "web002",
                      "web004"
                    ]
                  }
                },
                {
                  "@location": "remote-site-1",
                  "@name": "web_servers-2",
                  "description": "req-100",
                  "static": {
                    "member": [
                      "web001",
                      "web003",
                      "web004"
                    ]
                  }
                }
              ]
            }
          }
        },
        "output": {
          "shared": {
            "bgp_routers": {
              "@location": "shared",
              "@name": "bgp_routers",
              "static": {
                "member": [
                  "core-1",
                  "core-2",
                  "core-3",
                  "supercore"
                ]
              }
            },
            "web_servers": {
              "@location": "shared",
              "@name": "web_servers",
              "description": "req-5",
              "static": {
                "member": [
                  "web001",
                  "web002",
                  "web004"
                ]
              }
            }
          },
          "remote-site-1": {
            "web_servers-2": {
              "@location": "remote-site-1",
              "@name": "web_servers-2",
              "description": "req-100",
              "static": {
                "member": [
                  "web001",
                  "web003",
                  "web004"
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 76914159
  },
  {
    "context": [
      "I am calling a curl request and receiving the data as an Array of Json Objects. I want to use this array of JSON Objects as a value in other JSON. This second JSON will be sent as a Request Body of an api call.",
      "I am contructing the new json with the help of jq and I am parsing the array of JSON as --arg. So because of this the array gets parsed as string so my question is how can I pass the array in the JSON so that it does not get escape characters i.e. does not get parsed as string.",
      "If your input is initially interpreted as raw string data (by using the `--raw-input`, `--rawfile`, `--arg`, or `--args` options), you can still use the `fromjson` filter from within your jq code on JSON-encoded strings to parse them but a valid encoding is still required."
    ],
    "utterance": "Embed an array of objects as a field value in a new object, ensuring the array is parsed as structured data, not as an escaped string.",
    "expressions": [
      "{ array: ($array | fromjson) }"
    ],
    "data": [
      {
        "input": {
          "array": "[{\"id\":1, \"term\":\"term1\"}, {\"id\":2, \"term\":\"term2\"}, {\"id\":3, \"term\":\"term3\"}]"
        },
        "output": {
          "array": [
            {
              "id": 1,
              "term": "term1"
            },
            {
              "id": 2,
              "term": "term2"
            },
            {
              "id": 3,
              "term": "term3"
            }
          ]
        }
      }
    ],
    "identifier": 76913125
  },
  {
    "context": [
      "What I also need to do is output \"no certificates\" when the above array is empty.",
      "(.Certificates[] | .) // \"no certificates\"",
      "(.Certificates[] | \" -subject: \\(.Data.Subject)\") // \"no certificates\""
    ],
    "utterance": "For the Certificates array, print each element's subject as ' -subject: [subject]'; if the array is empty, print 'no certificates'.",
    "expressions": [
      "(.Certificates[] | \" -subject: \\(.Data.Subject)\") // \"no certificates\""
    ],
    "data": [
      {
        "input": {
          "Certificates": [],
          "Chains": [],
          "Keys": []
        },
        "output": "no certificates"
      },
      {
        "input": {
          "Certificates": [
            {
              "Data": {
                "Subject": "CN=mydomain.com"
              }
            }
          ],
          "Chains": [],
          "Keys": []
        },
        "output": " -subject: CN=mydomain.com"
      }
    ],
    "identifier": 76960613
  },
  {
    "context": [
      "I am trying to convert json output to a table format using jq.",
      "My desired output\n\n```\nCost | UsageDate \n----------------\n15.87  | 20230818 \n17.00  | 20230818\n16.27  | 20230818 \n```",
      "Use `.columns[:2]` and `.rows[][:2]` if you only want the first two columns.",
      "jq -r '.properties\n  | (.columns | map(.name) | join(\" | \") | ., gsub(\".\"; \"-\"))\n  , (.rows[] | join(\" | \"))\n'"
    ],
    "utterance": "Display a table with only the 'Cost' and 'UsageDate' fields and corresponding values for each row.",
    "expressions": [
      ".properties | [.columns[:2] | map(.name) | join(\" | \")], (.rows[][:2] | join(\" | \")) | .[]"
    ],
    "data": [
      {
        "input": {
          "eTag": null,
          "id": "providers/Microsoft.Billing/billingAccounts/8000000/providers/Microsoft.CostManagement/query/7acd05b7-5aff-49df-b7db-4d7f111eecf1",
          "location": null,
          "name": "7acd05b7-5aff-49df-b7db-4d7f111eecf1",
          "properties": {
            "columns": [
              {
                "name": "Cost",
                "type": "Number"
              },
              {
                "name": "UsageDate",
                "type": "Number"
              },
              {
                "name": "CostStatus",
                "type": "String"
              },
              {
                "name": "Currency",
                "type": "String"
              }
            ],
            "nextLink": null,
            "rows": [
              [
                15.87,
                20230818,
                "Cost",
                "USD"
              ],
              [
                17.0,
                20230819,
                "Cost",
                "USD"
              ],
              [
                16.27,
                20230820,
                "Cost",
                "USD"
              ]
            ]
          },
          "type": "Microsoft.CostManagement/query"
        },
        "output": "Cost | UsageDate\n15.87 | 20230818\n17 | 20230819\n16.27 | 20230820"
      }
    ],
    "identifier": 76931778
  },
  {
    "context": [
      "note that `topLevelObject` is guaranteed to exist but `leafNode` might not, in which case I want to insert it",
      "UPDATED_JSON=$(jq '. ' ../some_file.json)",
      "UPDATED_JSON=$(echo \"$UPDATED_JSON\" | jq -r '.topLevelObject.leafNode = false')"
    ],
    "utterance": "Set the field leafNode to false in topLevelObject, creating leafNode if it does not already exist.",
    "expressions": [
      ".topLevelObject.leafNode = false"
    ],
    "identifier": 76966282
  },
  {
    "context": [
      "Now I need to change this condition so instead of having the second condition to look into the name, every store will have a \"type_identifier\" which is a string. And basically what I want is to have something like:",
      "( [.stores[] | select( .type_identifier in [\"type1\",\"type2\", \"type2\"...] )] | length == 1 )",
      "The list of available \"types\" is another field of the same object along with the list of stores, how can I read the list directly from this property?",
      "(\n   [ \"type1\", \"type2\", \"type3\" ] |\n   map( { (.): true } ) |\n   add\n) as $lkup |\n\n.stores |\n( map( select( .is_open ) ) | length > 1 )\n   and\n( map( select( $lkup[ .type_identifier ] ) ) | length == 1 )",
      "You could also use INDEX.",
      "(\n   [ \"type1\", \"type2\", \"type3\" ] |\n   INDEX( .[]; . )\n) as $lkup |\n\n.stores |\n( map( select( .is_open ) ) | length > 1 )\n   and\n( map( select( $lkup[ .type_identifier ] ) ) | length == 1 )"
    ],
    "utterance": "Check if more than one store is open and exactly one store has a type_identifier in a given list of types, where the list is another property of the input.",
    "expressions": [
      "(.types | map({ (.): true }) | add) as $lkup | .stores | (map(select(.is_open)) | length > 1) and (map(select($lkup[.type_identifier])) | length == 1)",
      "(.types | INDEX(.[]; .)) as $lkup | .stores | (map(select(.is_open)) | length > 1) and (map(select($lkup[.type_identifier])) | length == 1)"
    ],
    "data": [
      {
        "input": {
          "types": [
            "type1",
            "type2",
            "type3"
          ],
          "stores": [
            {
              "name": "Store A",
              "is_open": true,
              "type_identifier": "type1"
            },
            {
              "name": "Store B",
              "is_open": true,
              "type_identifier": "type4"
            },
            {
              "name": "Store C",
              "is_open": false,
              "type_identifier": "type2"
            }
          ]
        },
        "output": false
      },
      {
        "input": {
          "types": [
            "type1",
            "type2"
          ],
          "stores": [
            {
              "name": "Store A",
              "is_open": true,
              "type_identifier": "type1"
            },
            {
              "name": "Store B",
              "is_open": true,
              "type_identifier": "type3"
            }
          ]
        },
        "output": true
      }
    ],
    "identifier": 76940632
  },
  {
    "context": [
      "I want to separately handle stdout and stderr to change the `severity` field accordingly.",
      "exec /entrypoint.sh \\\r\n    2&gt; &gt;( jq -R --unbuffered 'split(\"\\n\")|{service:\"foo\", msg:.[0], severity:\"stderr\"}' > /dev/stderr) \\\r\n    >  >( jq -R --unbuffered 'split(\"\\n\")|{service:\"foo\", msg:.[0], severity:\"stdout\"}' > /dev/stdout)"
    ],
    "utterance": "Transform each line from stdout and stderr into objects containing 'service: foo', the original line as 'msg', and 'severity' set to either 'stdout' or 'stderr' based on the output stream.",
    "expressions": [
      "jq -R --unbuffered 'split(\"\\n\")|{service:\"foo\", msg:.[0], severity:\"stdout\"}'",
      "jq -R --unbuffered 'split(\"\\n\")|{service:\"foo\", msg:.[0], severity:\"stderr\"}'"
    ],
    "identifier": 76944425
  },
  {
    "context": [
      "The expected or required output is - \n\n    [\n     {\n       \"foo\": 1,\n       \"bar\": 2,\n       \"quux\": 3\n     },\n     {\n       \"foo\": 4,\n       \"bar\": 5,\n       \"quux\": 6\n     },\n     {\n       \"foo\": 7,\n       \"bar\": 8,\n       \"quux\": 9\n     }\n    ]",
      "step 1 - \n  \n    $ echo -e \"foo,bar,quux\\n1,2,3\\n4,5,6\\n7,8,9\" > foo.csv",
      "$ jq -R 'split(\",\")' foo.csv | jq -cs",
      "Next i copied the code from  [jq cookbook][2] in to `csv2json.jq` and executed below command. \n\n    $ jq -cR 'split(\",\")' foo.csv | jq -csf csv2json.jq",
      "But i am not getting expected output, I am getting below output - \n\n    [[\"foo\",\"bar\",\"quux\"],[\"1\",\"2\",\"3\"],[\"4\",\"5\",\"6\"],[\"7\",\"8\",\"9\"]]"
    ],
    "utterance": "Convert CSV data with header row to an array of objects, each object keyed by column name with numeric values.",
    "expressions": [
      "jq -R -s 'split(\"\\n\") | map(split(\",\")) | (.[0] as $keys | .[1:] | map([ $keys, . ] | transpose | map({ (.[0]): (.[1]|tonumber) }) | add))' foo.csv"
    ],
    "data": [
      {
        "input": "foo,bar,quux\n1,2,3\n4,5,6\n7,8,9",
        "output": [
          {
            "foo": 1,
            "bar": 2,
            "quux": 3
          },
          {
            "foo": 4,
            "bar": 5,
            "quux": 6
          },
          {
            "foo": 7,
            "bar": 8,
            "quux": 9
          }
        ]
      }
    ],
    "identifier": 76952578
  },
  {
    "context": [
      "I want to update (or insert as a new entry if it doesn't already exist) a key=value with bash and jq:",
      "jq --arg name \"Serilog.WriteTo[0].Name\" --arg value \"Pluto\" '.$name = $value' appsettings.json.tpl > appsettings.json",
      "But I got this result:",
      "jq: error: try .[\"field\"] instead of .field for unusually named fields",
      "But the right result should be like as with this syntax:",
      "jq --arg value \"Pluto\" '.Serilog.WriteTo[0].Name = $value' appsettings.json.tpl > appsettings.json",
      "You *could* inject code from shell by presetting a shell variable with `.Serilog.WriteTo[0].Name`, and then having it expanded by the shell by wrapping the code inside double quotes, but this is generally regarded bad practice, and introduces other risks on various levels.",
      "Better provide the insert location as data, i.e. in a format that jq filters can operate with. One example could be setpath which expects the path to be an array of strings (for object fields) and numbers (for array indices).",
      "Using --argjson (providing the formatted array) for the path:",
      "jq --argjson path '[\"Serilog\", \"WriteTo\", 0, \"Name\"]' --arg value 'Pluto' 'setpath($path; $value)' input.json",
      "With an empty input, all of these produce",
      "{\n  \"Serilog\": {\n    \"WriteTo\": [\n      {\n        \"Name\": \"Pluto\"\n      }\n    ]\n  }\n}"
    ],
    "utterance": "Set or update the value at the path Serilog \u2192 WriteTo \u2192 [0] \u2192 Name to Pluto, creating intermediate objects or arrays if needed.",
    "expressions": [
      "setpath([\"Serilog\", \"WriteTo\", 0, \"Name\"]; \"Pluto\")",
      "setpath($path; $value)"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "Serilog": {
            "WriteTo": [
              {
                "Name": "Pluto"
              }
            ]
          }
        }
      }
    ],
    "identifier": 76977329
  },
  {
    "context": [
      "Given this input:\n\n{\n    \"a\": 42,\n    \"b\": false,\n    \"c\": null\n}\n",
      "I expected the expression `(.a, .b, .c, .d) // -1` to return this:\n\n42\n-1\n-1\n-1\n",
      "But in fact it returns this instead:\n\n42",
      "**Note:** The expression `(.a, .b, .c, .d) | . // -1` returns the expected output.",
      "> [...]Note: `some_generator // defaults_here` is not the same as `some_generator | . // defaults_here`. The latter will produce default values for all non-`false`, non-`null` values of the left-hand side, while the former will not. [...]",
      "In `(false, null, 1) | . // 42` the left-hand side of `//` is `.`, which always produces just one value, while in `(false, null, 1) // 42` the left-hand side is a generator of three values, and since it produces a value other `false` and `null`, the default `42` is not produced."
    ],
    "utterance": "Output the values of keys a, b, c, and d, using -1 as the default for missing or null/false keys, so the result is 42, -1, -1, -1.",
    "expressions": [
      "(.a, .b, .c, .d) | . // -1"
    ],
    "data": [
      {
        "input": {
          "a": 42,
          "b": false,
          "c": null
        },
        "output": [
          42,
          -1,
          -1,
          -1
        ]
      }
    ],
    "identifier": 76984368
  },
  {
    "context": [
      "I\u2019d like each `things` object outputted with its path on a new line (for later newline delimited JSON usage down the pipeline), e.g. with the above it would output:",
      "{ \"path\": \"data/<userId1>/things/<thingId1>\", \"value\": { \"subfield1\": \"blah1\", \"subfield3\": \"foobar\" } }",
      "{ \"path\": \"users/<userId1>\", \"value\": { \"name\": \"user1\", \"email\": \"foo@bar.com\" } }",
      "Here\u2019s a generic approach that can be used with jq\u2019s streaming parser, or with \"JSON Machine\" as described elsewhere on this page.",
      "First, start with:\n```\n< input.json jq -cn --stream '\n  def pathValue($n):\n    if $n == 1 \n    then to_entries[]\n    | {path: .key, value}\n    else to_entries[]\n    | (.value|pathValue($n-1)) as $pv\n    | {path: (.key + \"/\" + $pv.path), value: $pv.value}\n    end;\n\n  fromstream(1|truncate_stream(inputs))\n  | pathValue(3)\n'```",
      "For the first example, this produces:\n\n```\n{\"path\":\"<userId1>/things/<thingId1>\",\"value\":{\"subfield1\":\"blah1\",\"subfield3\":\"foobar\"}}\n{\"path\":\"<userId1>/things/<thingId2>\",\"value\":{\"subfield2\":\"blah2\"}}\n{\"path\":\"<userId2>/things/<thingId1>\",\"value\":{\"subfield4\":\"blah3\"}}\n{\"path\":\"<userId2>/things/<thingId2>\",\"value\":{\"subfield3\":\"blah4\"}}\n\n```",
      "For the second example, you\u2019d call `pathValue(1)`."
    ],
    "utterance": "Output each object at a configurable path depth together with its slash-separated path as a key-value object per line.",
    "expressions": [
      "< input.json jq -cn --stream '\n  def pathValue($n):\n    if $n == 1 \n    then to_entries[]\n    | {path: .key, value}\n    else to_entries[]\n    | (.value|pathValue($n-1)) as $pv\n    | {path: (.key + \"/\" + $pv.path), value: $pv.value}\n    end;\n\n  fromstream(1|truncate_stream(inputs))\n  | pathValue(3)\n'"
    ],
    "data": [
      {
        "input": {
          "data": {
            "<userId1>": {
              "things": {
                "<thingId1>": {
                  "subfield1": "blah1",
                  "subfield3": "foobar"
                },
                "<thingId2>": {
                  "subfield2": "blah2"
                }
              }
            },
            "<userId2>": {
              "things": {
                "<thingId1>": {
                  "subfield4": "blah3"
                },
                "<thingId2>": {
                  "subfield3": "blah4"
                }
              }
            }
          }
        },
        "output": [
          {
            "path": "<userId1>/things/<thingId1>",
            "value": {
              "subfield1": "blah1",
              "subfield3": "foobar"
            }
          },
          {
            "path": "<userId1>/things/<thingId2>",
            "value": {
              "subfield2": "blah2"
            }
          },
          {
            "path": "<userId2>/things/<thingId1>",
            "value": {
              "subfield4": "blah3"
            }
          },
          {
            "path": "<userId2>/things/<thingId2>",
            "value": {
              "subfield3": "blah4"
            }
          }
        ]
      },
      {
        "input": {
          "users": {
            "<userId1>": {
              "name": "user1",
              "email": "foo@bar.com"
            },
            "<userId2>": {
              "name": "user2"
            },
            "<userId3>": {
              "email": "hello@world.com"
            }
          }
        },
        "output": [
          {
            "path": "<userId1>",
            "value": {
              "name": "user1",
              "email": "foo@bar.com"
            }
          },
          {
            "path": "<userId2>",
            "value": {
              "name": "user2"
            }
          },
          {
            "path": "<userId3>",
            "value": {
              "email": "hello@world.com"
            }
          }
        ]
      }
    ],
    "identifier": 76905501
  },
  {
    "context": [
      "I have the following json file for my parameters:",
      "[ { \"ParameterKey\": \"Key1\", \"ParameterValue\": \"value1\" }, { \"ParameterKey\": \"Key2\", \"ParameterValue\": \"$ENV_VALUE2\" } ]",
      "I use the following `jq` command to convert to the `--parameter-overrides` syntax:",
      "jq -r '.[] | .ParameterValue |= (env[.[1:]] // .) | [.ParameterKey, .ParameterValue] | join(\"=\")' myfile.json",
      "EDITED:\n\nBased on the answer from @knittl, I'm using the following as a solution:\n\nparameter_overrides=$(jq -r '.[] | .ParameterValue |= (env[.[1:]] // .) | [.ParameterKey, .ParameterValue] | join(\"=\") | @sh' myfile.json | tr \"\\n\" \" \")"
    ],
    "utterance": "Convert an array of objects with ParameterKey and ParameterValue to a list of key=value pairs, replacing any ParameterValue that starts with '$' using the matching environment variable.",
    "expressions": [
      ".[] | .ParameterValue |= (env[.[1:]] // .) | [.ParameterKey, .ParameterValue] | join(\"=\")",
      ".[] | .ParameterValue |= (env[.[1:]] // .) | [.ParameterKey, .ParameterValue] | join(\"=\") | @sh"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "Key1",
            "ParameterValue": "value1"
          },
          {
            "ParameterKey": "Key2",
            "ParameterValue": "$ENV_VALUE2"
          }
        ],
        "output": [
          "Key1=value1",
          "Key2=value2"
        ]
      }
    ],
    "identifier": 76984135
  },
  {
    "context": [
      "I am trying to write a jq expression such that the output is the following in a csv file (not adding escape characters here for simplicity):",
      "\"account_id\", \"account_status\", \"name\", \"email\", \"Product 1\", \"Product 2\", \"Product 3\"",
      "\"123\", \"active\", \"john doe\", \"johndoe@anywhere.com\", \",,,\"",
      "\"345\", \"active\", \"jane doe\", \"janedoe@anywhere.com\", \"acme1.com, acme2.com, acme3.com, acme4.com\", \"acme4.com\", \"acme5.com\"",
      "You only want to apply the `join` to the products, not all the columns. You need to apply it to each product separately.",
      "jq -r '[\"account_id\", \"account_status\", \"name\", \"email\", \"product 1\", \"product 2\", \"product 3\"], (.data[] | [.account_id, .account_status, .name, .email, ([.product_access[] | select(.key == \"product1\").url] | join(\",\")), ([.product_access[] | select(.key == \"product2\").url] | join(\",\")), ([.product_access[] | select(.key == \"product3\").url] | join(\",\")) ] ) | @csv'",
      "Try this :",
      "jq -r '[\"account_id\", \"account_status\", \"name\", \"email\", \"product 1\", \"product 2\", \"product 3\"], (.data[] | [.account_id, .account_status, .name, .email, (\"product1\",\"product2\",\"product3\") as $prod | [(.product_access[] | select(.key == $prod).url)] | join(\",\") ] ) | @csv' input.json"
    ],
    "utterance": "Output account_id, account_status, name, email, and for product1/product2/product3 columns, join all their .url values into single CSV cells per row.",
    "expressions": [
      "[\"account_id\", \"account_status\", \"name\", \"email\", \"product 1\", \"product 2\", \"product 3\"], (.data[] | [.account_id, .account_status, .name, .email, ([.product_access[] | select(.key == \"product1\").url] | join(\",\")), ([.product_access[] | select(.key == \"product2\").url] | join(\",\")), ([.product_access[] | select(.key == \"product3\").url] | join(\",\")) ] ) | @csv",
      "[\"account_id\", \"account_status\", \"name\", \"email\", \"product 1\", \"product 2\", \"product 3\"], (.data[] | [.account_id, .account_status, .name, .email, (\"product1\",\"product2\",\"product3\") as $prod | [(.product_access[] | select(.key == $prod).url)] | join(\",\") ] ) | @csv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "account_id": "123",
              "account_status": "active",
              "name": "john doe",
              "email": "johndoe@anywhere.com",
              "product_access": []
            },
            {
              "account_id": "345",
              "account_status": "active",
              "name": "jane doe",
              "email": "janedoe@anywhere.com",
              "last_active": "2023-08-23T13:03:27.811473590Z",
              "product_access": [
                {
                  "name": "Product 1",
                  "key": "product1",
                  "url": "acme1.com"
                },
                {
                  "name": "Product 1",
                  "key": "product1",
                  "url": "acme2.com"
                },
                {
                  "name": "Product 1",
                  "key": "product1",
                  "url": "acme3.com"
                },
                {
                  "name": "Product 2",
                  "key": "product2",
                  "url": "acme4.com",
                  "last_active": "2023-08-23T13:03:27.811473590Z"
                },
                {
                  "name": "Product 3",
                  "key": "product3",
                  "url": "acme5.com"
                },
                {
                  "name": "Product 1",
                  "key": "product1",
                  "url": "acme4.com",
                  "last_active": "2023-08-17T18:21:52.472085713Z"
                }
              ]
            }
          ]
        },
        "output": [
          [
            "account_id",
            "account_status",
            "name",
            "email",
            "product 1",
            "product 2",
            "product 3"
          ],
          [
            "123",
            "active",
            "john doe",
            "johndoe@anywhere.com",
            "",
            "",
            ""
          ],
          [
            "345",
            "active",
            "jane doe",
            "janedoe@anywhere.com",
            "acme1.com,acme2.com,acme3.com,acme4.com",
            "acme4.com",
            "acme5.com"
          ]
        ]
      }
    ],
    "identifier": 76972248
  },
  {
    "context": [
      "I have tried to use jq but the response is still sorted differently.",
      "Here is the jq command I have tried to use :",
      "jq '[0].IpPermissions |= sort_by(.IpRanges[].CidrIp) | .[0].IpPermissionsEgress |= sort_by(.IpRanges[].CidrIp)'",
      "If you're just trying to sort items in the `IpRanges` fields, you could do this:",
      ".[].IpPermissions[].IpRanges |= sort_by(.CidrIp)",
      "You should be able to then compare for deep equality. You'll probably want to do this for all arrays that may be ordered differently.",
      "| jq '.[][][].IpRanges |= sort_by(.CidrIp)'"
    ],
    "utterance": "Sort all IpRanges arrays by the CidrIp field to ensure consistent ordering for comparison.",
    "expressions": [
      ".[].IpPermissions[].IpRanges |= sort_by(.CidrIp)",
      ".[][][].IpRanges |= sort_by(.CidrIp)"
    ],
    "data": [
      {
        "input": [
          {
            "IpPermissions": [
              {
                "IpProtocol": "-1",
                "IpRanges": [
                  {
                    "CidrIp": "10.192.55.56/32"
                  },
                  {
                    "CidrIp": "10.111.11.0/26"
                  }
                ],
                "FromPort": null,
                "ToPort": null
              }
            ]
          }
        ],
        "output": [
          {
            "IpPermissions": [
              {
                "IpProtocol": "-1",
                "IpRanges": [
                  {
                    "CidrIp": "10.111.11.0/26"
                  },
                  {
                    "CidrIp": "10.192.55.56/32"
                  }
                ],
                "FromPort": null,
                "ToPort": null
              }
            ]
          }
        ]
      }
    ],
    "identifier": 76994251
  },
  {
    "context": [
      "The desired output would be\n\n    {\n       \"fields\": [\n          \"apple\",\n          \"Banana__c\"\n       ],\n       \"Brand\": \"Kroger\",\n       \"fruitNames\": {\n          \"apple\": \"Apple\",\n          \"Banana__c\": \"Banana\"\n       }\n    }",
      "The following should work:\n\n    jq '.result[].fields | {\"fields\": map(.name), \"Brand\": \"Kroger\",\n        \"fruitNames\": map({(.name): .displayName}) | add}' test.json",
      "Here's one way using `from_entries`:\n.result[].fields | map(.value = .displayName)\n| {fields: map(.name), Brand: \"Kroger\", fruitNames: from_entries}",
      "Or even another way:\n\n.result[].fields |\n      {\n       \"fields\": map(.name),\n       \"Brand\": \"Kroger\",\n       \"fruitNames\": (reduce .[] as $f ({}; . + {($f.name): $f.displayName}))\n      }"
    ],
    "utterance": "Create an object with a fields array containing all field names, a Brand key set to Kroger, and a fruitNames object mapping each field name to its displayName.",
    "expressions": [
      ".result[].fields | {\"fields\": map(.name), \"Brand\": \"Kroger\", \"fruitNames\": map({(.name): .displayName}) | add}",
      ".result[].fields | map(.value = .displayName) | {fields: map(.name), Brand: \"Kroger\", fruitNames: from_entries}",
      ".result[].fields | {\"fields\": map(.name), \"Brand\": \"Kroger\", \"fruitNames\": (reduce .[] as $f ({}; . + {($f.name): $f.displayName}))}"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "name": "Fields",
              "listFields": [
                [
                  "apple"
                ],
                [
                  "Banana__c"
                ]
              ],
              "fields": [
                {
                  "name": "apple",
                  "displayName": "Apple",
                  "color": "red",
                  "price": 20
                },
                {
                  "name": "Banana__c",
                  "displayName": "Banana",
                  "color": "yellow",
                  "price": 18
                }
              ]
            }
          ],
          "success": true
        },
        "output": {
          "fields": [
            "apple",
            "Banana__c"
          ],
          "Brand": "Kroger",
          "fruitNames": {
            "apple": "Apple",
            "Banana__c": "Banana"
          }
        }
      }
    ],
    "identifier": 76984525
  },
  {
    "context": [
      "My question is how to pull the role of a user, or null if they have no roles.",
      "How do I get from this to returning the role itself if true, or null if false so that for this example I would return:",
      "\"example-role\"",
      "\"example-role\"",
      "null",
      "\"example-role\"",
      "This should generate expected output :",
      ".aggregations.user_data.buckets[]\n|.response_status.buckets\n|map(.roles.buckets|map(select(has(\"key\")).key))\n|flatten\n|first",
      ".aggregations.user_data.buckets[]\n|.response_status.buckets\n|map(.roles.buckets|map(.key // empty))\n|flatten|first",
      ".aggregations.user_data.buckets[].response_status.buckets\n| first(.[].roles.buckets[].key, null)"
    ],
    "utterance": "For each user, return their role if it exists, or null if the user has no roles.",
    "expressions": [
      ".aggregations.user_data.buckets[] | .response_status.buckets | map(.roles.buckets|map(select(has(\"key\")).key)) | flatten | first",
      ".aggregations.user_data.buckets[] | .response_status.buckets | map(.roles.buckets|map(.key // empty)) | flatten | first",
      ".aggregations.user_data.buckets[].response_status.buckets | first(.[].roles.buckets[].key, null)"
    ],
    "data": [
      {
        "input": {
          "took": 755,
          "timed_out": false,
          "_shards": {
            "total": 3,
            "successful": 3,
            "skipped": 0,
            "failed": 0
          },
          "hits": {
            "total": {
              "value": 10000,
              "relation": "gte"
            },
            "max_score": null,
            "hits": []
          },
          "aggregations": {
            "user_data": {
              "doc_count_error_upper_bound": 0,
              "sum_other_doc_count": 0,
              "buckets": [
                {
                  "key": "user1",
                  "doc_count": 872721,
                  "response_status": {
                    "buckets": {
                      "success": {
                        "from": 200,
                        "to": 300,
                        "doc_count": 872709,
                        "roles": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 0,
                          "buckets": [
                            {
                              "key": "example-role",
                              "doc_count": 872709
                            }
                          ]
                        }
                      },
                      "failure": {
                        "from": 400,
                        "to": 500,
                        "doc_count": 0,
                        "roles": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 0,
                          "buckets": []
                        }
                      }
                    }
                  }
                },
                {
                  "key": "user2",
                  "doc_count": 2286,
                  "response_status": {
                    "buckets": {
                      "success": {
                        "from": 200,
                        "to": 300,
                        "doc_count": 2285,
                        "roles": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 2285,
                          "buckets": [
                            {
                              "key": "example-role",
                              "doc_count": 2285
                            }
                          ]
                        }
                      },
                      "failure": {
                        "from": 400,
                        "to": 500,
                        "doc_count": 1,
                        "roles": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 1,
                          "buckets": [
                            {
                              "key": "example-role",
                              "doc_count": 1
                            }
                          ]
                        }
                      }
                    }
                  }
                },
                {
                  "key": "user4",
                  "doc_count": 872721,
                  "response_status": {
                    "buckets": {
                      "success": {
                        "from": 200,
                        "to": 300,
                        "doc_count": 872709,
                        "roles": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 0,
                          "buckets": []
                        }
                      },
                      "failure": {
                        "from": 400,
                        "to": 500,
                        "doc_count": 0,
                        "roles": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 0,
                          "buckets": []
                        }
                      }
                    }
                  }
                },
                {
                  "key": "user4",
                  "doc_count": 1,
                  "response_status": {
                    "buckets": {
                      "success": {
                        "from": 200,
                        "to": 300,
                        "doc_count": 0,
                        "roles": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 0,
                          "buckets": []
                        }
                      },
                      "failure": {
                        "from": 400,
                        "to": 500,
                        "doc_count": 1,
                        "roles": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 0,
                          "buckets": [
                            {
                              "key": "example-role",
                              "doc_count": 1
                            }
                          ]
                        }
                      }
                    }
                  }
                }
              ]
            }
          }
        },
        "output": [
          "example-role",
          "example-role",
          null,
          "example-role"
        ]
      }
    ],
    "identifier": 76924368
  },
  {
    "context": [
      "I always get `parse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 17, column 96`. Seems like I need somehow to get an escaped answer from CURL.",
      "You convert the `curl` output to a non-JSON string with `jq -r`",
      "echo interprets the C-style escape sequences present in the JSON",
      "The following should fix those problems:",
      "printf '%s\\n' \"$response\" | jq",
      "generated_message_id=$( printf '%s\\n' \"$response\" | jq -r '.generated_message_id' )",
      "If you don't need `$response` in the following part of the script, you should do it in a single step :",
      "curl ... | jq -r '.generated_message_id'"
    ],
    "utterance": "Extract the value of the generated_message_id field from the API response that may contain escaped characters or multiple lines.",
    "expressions": [
      "printf '%s\\n' \"$response\" | jq -r '.generated_message_id'",
      "curl -s -X 'POST' -H 'accept: application/json' '.../api/generated_message/action/generate' | jq -r '.generated_message_id'"
    ],
    "identifier": 76995284
  },
  {
    "context": [
      "Sample Json",
      "{\n  \"product\": [\n    {\n      \"versions\": \"1.0\",\n      \"components\": [\n        {\n          \"name\": \"JVM\",\n          \"version\": \"11.0.16\"\n        },\n        {\n          \"name\": \"TOMCAT\",\n          \"version\": \"9.0.56\"\n        }\n      ]\n    },\n    {\n      \"versions\": \"1.1\",\n      \"components\": [\n        {\n          \"name\": \"JVM\",\n          \"version\": \"11.0.16\"\n        },\n        {\n          \"name\": \"TOMCAT\",\n          \"version\": \"9.0.56\"\n        }\n      ]\n    }\n  ]\n}",
      "\"If you want to include the `versions` from the product themself, you can loop over the components after showing `.versions`, for example the following filter\n.product[] | .versions, (.components[] | \"\\t\\(.name): \\(.version)\")\"",
      "Outputs\n1.0\n\tJVM: 11.0.16\n\tTOMCAT: 9.0.56\n1.1\n\tJVM: 11.0.16\n\tTOMCAT: 9.0.56"
    ],
    "utterance": "List each product's version followed by its components' name and version indented on new lines",
    "expressions": [
      ".product[] | .versions, (.components[] | \"\\t\\(.name): \\(.version)\")"
    ],
    "data": [
      {
        "input": {
          "product": [
            {
              "versions": "1.0",
              "components": [
                {
                  "name": "JVM",
                  "version": "11.0.16"
                },
                {
                  "name": "TOMCAT",
                  "version": "9.0.56"
                }
              ]
            },
            {
              "versions": "1.1",
              "components": [
                {
                  "name": "JVM",
                  "version": "11.0.16"
                },
                {
                  "name": "TOMCAT",
                  "version": "9.0.56"
                }
              ]
            }
          ]
        },
        "output": [
          "1.0",
          "\tJVM: 11.0.16",
          "\tTOMCAT: 9.0.56",
          "1.1",
          "\tJVM: 11.0.16",
          "\tTOMCAT: 9.0.56"
        ]
      }
    ],
    "identifier": 76993197
  },
  {
    "context": [
      "I want to query all unique genres and count the number of movies, where the output looks like this:\r\n\r\n{\r\n   \"Horror\":1,\r\n   \"Thriller\":2,\r\n   \"Mystery\":1,\r\n   \"Drama\":1,\r\n   \"History\":1,\r\n   \"War\":1\r\n}",
      "Edit: I also need to be able to handle movies without genres. These can be ignored.",
      "reduce (.[].genres[].tag|values) as $genre ({}; .[$genre] += 1)",
      "map(.genres[].tag | values)\r\n| group_by(.)\r\n| map({ key:first, value:length })\r\n| from_entries"
    ],
    "utterance": "List each unique genre tag and count the number of movies associated with each, ignoring null tags and movies without genres.",
    "expressions": [
      "reduce (.[].genres[].tag | values) as $genre ({}; .[$genre] += 1)",
      "map(.genres[].tag | values) | group_by(.) | map({ key:first, value:length }) | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "title": "X",
            "genres": [
              {
                "tag": "Horror"
              },
              {
                "tag": "Thriller"
              },
              {
                "tag": "Mystery"
              }
            ]
          },
          {
            "title": "Zero Dark Thirty",
            "genres": [
              {
                "tag": "Thriller"
              },
              {
                "tag": "Drama"
              },
              {
                "tag": "History"
              },
              {
                "tag": "War"
              }
            ]
          }
        ],
        "output": {
          "Horror": 1,
          "Thriller": 2,
          "Mystery": 1,
          "Drama": 1,
          "History": 1,
          "War": 1
        }
      },
      {
        "input": [
          {
            "title": "Some movie",
            "genres": [
              {
                "tag": null
              }
            ]
          },
          {
            "title": "Some other movies",
            "genres": [
              {
                "tag": "Comedy"
              },
              {
                "tag": "Drama"
              }
            ]
          }
        ],
        "output": {
          "Comedy": 1,
          "Drama": 1
        }
      }
    ],
    "identifier": 76995730
  },
  {
    "context": [
      "I need to write a command via jq which is:\r\n1. compares old and new config json files (old-o-ru.conf and new-o-ru.conf).\r\n2. Copies the value of the element from the old config to the new one, if the new one has this element and their types match.\r\n3. Unaffected elements in the new config should remain.",
      "there is no \"int\" field in old.conf\r\nthere is no \"float\" field in new.conf",
      "**Expected output**:\r\n{\r\n    \"ru_conf\": {\r\n        \"network\": {\r\n            \"interface\": \"str\",\r\n            \"mac_address\": \"str\",\r\n            \"setup\": true,\r\n            \"interfaces\": [\"str1\", \"str2\"],\r\n            \"numbers\": [0, 0, 0],\r\n            \"int\": 0,\r\n            \"partitions\": [\r\n                {\r\n                  \"dev1\": \"str\",\r\n                  \"threshold\": 0\r\n                }\r\n            ]\r\n        }\r\n    }\r\n}",
      "Also tried this:\r\njq \\\r\n --argjson a \"$(cat ./new.conf)\" \\\r\n --argjson b \"$(cat ./old.conf)\" \\\r\n -n '\r\n   $a | .ru_conf | keys_unsorted as $whitelist \r\n | $b | .ru_conf | with_entries( select(.key | IN($whitelist[])) ) as $update\r\n | $a | .ru_conf += $update '\r\n...But the second command does not support type comparison and nesting",
      "How can I achieve the required result?"
    ],
    "utterance": "Update the configuration by copying values from the old config to the new config only when the key exists in the new config and the types match, preserving any elements exclusive to the new config.",
    "expressions": [
      "jq -s '.[0] as $new | .[1] as $old | def merge(old; new):\n  if (old | type) == (new | type) then\n    if (old | type) == \"object\" then\n      reduce (new | keys_unsorted[]) as $k (\n        {}; \n        . + {\n          ($k): \n            if (old[$k] != null) then merge(old[$k]; new[$k]) else new[$k] end\n        }\n      )\n    else if (old | type) == \"array\" then\n      (old, new)[1]\n    else\n      old\n    end\n  else\n    new\n  end;\n\nmerge($old.ru_conf; $new.ru_conf) | {ru_conf: .}' new.conf old.conf"
    ],
    "data": [
      {
        "input": {
          "old.conf": {
            "ru_conf": {
              "network": {
                "interface": "eth1",
                "mac_address": "FF:FF:FF:FF:FF:FF",
                "setup": true,
                "interfaces": [
                  "eth0",
                  "eth1"
                ],
                "numbers": [
                  1,
                  2,
                  3
                ],
                "float": 1111.1111,
                "partitions": [
                  {
                    "dev1": "/mnt/data/",
                    "threshold": 20
                  }
                ]
              }
            }
          },
          "new.conf": {
            "ru_conf": {
              "network": {
                "interface": "str",
                "mac_address": "str",
                "setup": false,
                "interfaces": [
                  "str1",
                  "str2"
                ],
                "numbers": [
                  0,
                  0,
                  0
                ],
                "int": 0,
                "partitions": [
                  {
                    "dev1": "str",
                    "threshold": 0
                  }
                ]
              }
            }
          }
        },
        "output": {
          "ru_conf": {
            "network": {
              "interface": "eth1",
              "mac_address": "FF:FF:FF:FF:FF:FF",
              "setup": true,
              "interfaces": [
                "eth0",
                "eth1"
              ],
              "numbers": [
                1,
                2,
                3
              ],
              "int": 0,
              "partitions": [
                {
                  "dev1": "/mnt/data/",
                  "threshold": 20
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 76962746
  },
  {
    "context": [
      "\"I'm am trying convert json into yaml\"",
      "\"Input json\\n{\\n  \\\"name\\\": \\\"Fruit\\\",\\n  \\\"values\\\": [\\n    \\\"banana\\\"\\n  ]\\n}\\n\"",
      "\"Output Yaml\\n{\\nFruit : banana\\n}\\n\"",
      "\"If you only want to take the first value, then several equivalent solutions exist:\"",
      "\"{ (.name): .values[0] }\""
    ],
    "utterance": "Map the value of the 'name' key to the first element in the 'values' array as a key-value pair.",
    "expressions": [
      "{ (.name): .values[0] }"
    ],
    "data": [
      {
        "input": {
          "name": "Fruit",
          "values": [
            "banana"
          ]
        },
        "output": {
          "Fruit": "banana"
        }
      }
    ],
    "identifier": 77017183
  },
  {
    "context": [
      "I am in the process of needing to pass the contents of 2 JSON files through a jq query.",
      "So I made the decision that the input from different files would basically be JSON Lines (ndjson) input. Something like the following, which should emulate 2 JSON files, I believe.\n\n{\n  KEY1: [VALUE1, VALUE2],\n  KEY2: [VALUE3]\n}\n{\n  KEY1: [VALUE4],\n  KEY3: [VALUE5]\n}\n",
      "From there I started to build my jq filter (which assumes the above format). This filter correctly merges the two files together.",
      "Here is a more detail set of input: https://jqplay.org/s/Tle2W8PIgQj",
      "Now, I am stuck figuring out whether I made the right assumption above and how to correctly input the 2 files into the jq command",
      "But I am getting the following error\njq: error (at mappings.json:1): string (\"{\") has no keys",
      "So I am wondering what the correct way of inputting file content for use with the built-in `inputs`. And was I correct in my way of emulating 2 input files when building my jq filter?"
    ],
    "utterance": "Combine the contents of two separate files, each containing a JSON object, as if they were provided as multiple top-level objects (ndjson style), allowing filters designed for multiple inputs to operate as intended.",
    "expressions": [
      ". , inputs | <filter>"
    ],
    "data": [
      {
        "input": [
          {
            "KEY1": [
              "VALUE1",
              "VALUE2"
            ],
            "KEY2": [
              "VALUE3"
            ]
          },
          {
            "KEY1": [
              "VALUE4"
            ],
            "KEY3": [
              "VALUE5"
            ]
          }
        ]
      }
    ],
    "identifier": 77004829
  },
  {
    "context": [
      "For the GPU nodes, I tried:\r\n```\r\ncurl --insecure --silent --header \"authorization: Bearer ${ATKN}\" --request GET https://weka01:14000/api/v2/processes | jq -r '.data[] | select(.hostname | startswith(\"startstring\") and contains(\"-c\")|not)'\r\n```\r\nwhich gets me both the GPU and weka nodes.",
      "Operator precedence:\r\n\r\n```\r\nselect(.hostname | startswith(\"startstring\") and (contains(\"-c\")|not))\r\n```"
    ],
    "utterance": "Select objects where the hostname starts with 'startstring' and does not contain '-c'.",
    "expressions": [
      ".data[] | select(.hostname | startswith(\"startstring\") and (contains(\"-c\") | not))"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "hostname": "startstring-r1-n3"
            },
            {
              "hostname": "startstring-r2-c17-n2"
            },
            {
              "hostname": "weka01"
            }
          ]
        },
        "output": [
          {
            "hostname": "startstring-r1-n3"
          }
        ]
      }
    ],
    "identifier": 77022681
  },
  {
    "context": [
      "while the format is mostly JSON, all the key/value pairs within the body object have escaped double quotes.",
      "You can use the [`fromjson` function](https://jqlang.github.io/jq/manual/#convert-to-from-json) for parsing JSON-encoded values. In your case, that would be",
      "jq '.Messages | .[] | .Body | fromjson'"
    ],
    "utterance": "Parse the string in the Body field, which is itself a JSON object with escaped quotes, into an object.",
    "expressions": [
      ".Messages | .[] | .Body | fromjson"
    ],
    "data": [
      {
        "input": {
          "Messages": [
            {
              "Body": "{\r\n    \\\"Origin\\\":\\\"AutoScalingGroup\\\",\r\n    \\\"LifecycleHookName\\\":\\\"termination_lifecycle_hook\\\",\r\n    \\\"Destination\\\":\\\"EC2\\\",\r\n    \\\"AccountId\\\":\\\"<redacted>\\\",\r\n    \\\"RequestId\\\":\\\"65e1eaeb-1bde-42ef-93b5-ac14987a2848\\\",\r\n    \\\"LifecycleTransition\\\":\\\"autoscaling:EC2_INSTANCE_TERMINATING\\\",\r\n    \\\"AutoScalingGroupName\\\":\\\"test-um-prod-20230822043811258400000005\\\",\r\n    \\\"Service\\\":\\\"AWS Auto Scaling\\\",\r\n    \\\"Time\\\":\\\"2023-08-29T20:42:36.581Z\\\",\r\n    \\\"EC2InstanceId\\\":\\\"i-02ca28b1a415a4d48\\\",\r\n    \\\"LifecycleActionToken\\\":\\\"1e7f23b9-4a9a-4cad-9051-6039d815e9b1\\\"\r\n    }",
              "ReceiptHandle": "AQEBN8E7SCNS44lemWqlfMVvOl9EfGo7Yb5b+VhF5jXlw2i41pwQJFvfaAFwBEquO8SOsGyaIUfFiE9qEUQoQOgyUoz5a+Rx/yD9jq2qfz/gRcSwhfCAPHyBvhjJdIGmlyKtNnTzuL183Wti4BO4G+Z7bLzn/WiIT+JrSfn/VofI34HnB0w0Om3UYTnd6OoXuCu2WxzasyMeFcImuCYdt+5+tMzauEtsL7EVdSZwpW3S4oatkuxfzzyxHsP4X0IIKt6fwIzHzCRhi9kmo5QnZAQCnjHo+RBNZXWU9wbk3SToE3nCdLJhbups5SOHAUHLO1PwdVb7RvKMmYYdHfzoTQBLeWJ1w7MEMrhANC9uOu7cVzS0hAAc9qPLzzoV1TkIBn/0Q597cl6dNyfkWpPQEOKtUg==",
              "MD5OfBody": "fa2bc63f28d96c532288b09831a8b73f",
              "MessageId": "4c5b0c2c-9085-4bde-8de3-49ae3f63afd4"
            }
          ]
        },
        "output": {
          "Origin": "AutoScalingGroup",
          "LifecycleHookName": "termination_lifecycle_hook",
          "Destination": "EC2",
          "AccountId": "<redacted>",
          "RequestId": "65e1eaeb-1bde-42ef-93b5-ac14987a2848",
          "LifecycleTransition": "autoscaling:EC2_INSTANCE_TERMINATING",
          "AutoScalingGroupName": "test-um-prod-20230822043811258400000005",
          "Service": "AWS Auto Scaling",
          "Time": "2023-08-29T20:42:36.581Z",
          "EC2InstanceId": "i-02ca28b1a415a4d48",
          "LifecycleActionToken": "1e7f23b9-4a9a-4cad-9051-6039d815e9b1"
        }
      }
    ],
    "identifier": 77004832
  },
  {
    "context": [
      "If there is no asset object -> Create asset object, put house set to true and colour orange in the element. If there is asset object already -> check if house is set to something else AND check colour is SET to something else, if that is the case then set house back to true and colour to orange. If there is asset class already in place, but house and colour key is not present in the object, then add house to true and colour to orange",
      "So you _always_ want to have an asset with house=true and colour=orange in your output, potentially overwriting any existing values, but keeping other properties?",
      "then simply merge the `asset` object with the desired properties. There is no logic involved:",
      "jq '.spec.asset += {house:true, colour:\"orange\"}'"
    ],
    "utterance": "Ensure the asset object under spec always contains house set to true and colour set to orange, overwriting existing values or creating the object if necessary, while preserving other asset properties.",
    "expressions": [
      ".spec.asset += {house:true, colour:\"orange\"}"
    ],
    "data": [
      {
        "input": {
          "name": "Paul",
          "country": "USA",
          "spec": {
            "asset": {
              "yard": true
            }
          }
        },
        "output": {
          "name": "Paul",
          "country": "USA",
          "spec": {
            "asset": {
              "yard": true,
              "house": true,
              "colour": "orange"
            }
          }
        }
      },
      {
        "input": {
          "name": "Paul",
          "country": "USA",
          "spec": {}
        },
        "output": {
          "name": "Paul",
          "country": "USA",
          "spec": {
            "asset": {
              "house": true,
              "colour": "orange"
            }
          }
        }
      },
      {
        "input": {
          "name": "Paul",
          "country": "USA",
          "spec": {
            "asset": {
              "house": false,
              "colour": "black"
            }
          }
        },
        "output": {
          "name": "Paul",
          "country": "USA",
          "spec": {
            "asset": {
              "house": true,
              "colour": "orange"
            }
          }
        }
      }
    ],
    "identifier": 77020143
  },
  {
    "context": [
      "I'd like to invert the keys and values of some data where the values are arrays, such that every unique element of the value arrays becomes a key in the output, whose value is an array containing every input key whose value contained that element originally.",
      "I'd like to get the following output:",
      "reduce .[] as {$Id, $Contents} ({}; .[$Contents[]] += [$Id])",
      "You could also use `group_by`:\n\n```\nmap({ Id, Content: .Contents[] })\n| group_by(.Content)\n| map({ key: first.Content, value: map(.Id) })\n| from_entries\n```"
    ],
    "utterance": "Invert the mapping so each unique value from each Contents array becomes a key, with its value an array of every Id whose Contents included it.",
    "expressions": [
      "reduce .[] as {$Id, $Contents} ({}; .[$Contents[]] += [$Id])",
      "map({ Id, Content: .Contents[] })\n| group_by(.Content)\n| map({ key: first.Content, value: map(.Id) })\n| from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "Id": "abc",
            "Contents": [
              "foo",
              "bar"
            ]
          },
          {
            "Id": "def",
            "Contents": [
              "foo",
              "baz",
              "ding"
            ]
          },
          {
            "Id": "ghi",
            "Contents": [
              "bar",
              "dang",
              "baz"
            ]
          }
        ],
        "output": {
          "foo": [
            "abc",
            "def"
          ],
          "bar": [
            "abc",
            "ghi"
          ],
          "baz": [
            "def",
            "ghi"
          ],
          "ding": [
            "def"
          ],
          "dang": [
            "ghi"
          ]
        }
      }
    ],
    "identifier": 77026555
  },
  {
    "context": [
      "I have a json file in the format [...] I want to convert this object into this format [...]",
      "so far i&#39;ve tried multiple ways using to_entries and map functions in jq to create the contents inside the output variable",
      "A simple solution is readily obtained if the following stream-oriented \"coalesce\" function is used:",
      "The solution is now simply:\ncoalesce(to_entries[]\n         | .key as $key\n         | .value[]\n         | {(.name): {($key): .value}})\n| {output: [.]}\n",
      "It doesn&#39;t win a beauty contest, but it works:\n\nwith_entries(.value |= from_entries)\n| with_entries(.key as $key | .value[] |= {($key):.})\n| reduce .[] as $item ({}; . * $item)\n| {output: to_entries | map({(.key):.value})}",
      "With a single call to `with_entries`:\n\nwith_entries(.key as $key | .value |= (from_entries | map_values({($key):.})))\n| reduce .[] as $item ({}; . * $item)\n| {output: to_entries | map({(.key):.value})}",
      "This generates what&#39;s expected :\n\n{ output:\n    to_entries |\n    map(.key as $key|.value|map(.nn=.name|.name=$key)) |\n    add |\n    group_by(.nn) |\n    map({(first|.nn) : from_entries})\n}"
    ],
    "utterance": "Group the given objects so that each variable name becomes a key, with values aggregated from each top-level key under their corresponding variable name, formatted under an 'output' array.",
    "expressions": [
      "def coalesce(s): reduce (s | to_entries[]) as {key: $k, value: $v} ({}; .[$k] += $v); coalesce(to_entries[] | .key as $key | .value[] | {(.name): {($key): .value}}) | {output: [.]}",
      "with_entries(.value |= from_entries) | with_entries(.key as $key | .value[] |= {($key):.}) | reduce .[] as $item ({}; . * $item) | {output: to_entries | map({(.key):.value})}",
      "with_entries(.key as $key | .value |= (from_entries | map_values({($key):.}))) | reduce .[] as $item ({}; . * $item) | {output: to_entries | map({(.key):.value})}",
      "{ output: to_entries | map(.key as $key | .value | map(.nn=.name|.name=$key)) | add | group_by(.nn) | map({(first|.nn) : from_entries}) }"
    ],
    "data": [
      {
        "input": {
          "hello": [
            {
              "name": "var1",
              "value": "1234"
            },
            {
              "name": "var2",
              "value": "2356"
            },
            {
              "name": "var3",
              "value": "2356"
            }
          ],
          "hi": [
            {
              "name": "var1",
              "value": "3412"
            },
            {
              "name": "var2",
              "value": "2563"
            },
            {
              "name": "var3",
              "value": "4256"
            }
          ],
          "bye": [
            {
              "name": "var1",
              "value": "1294"
            },
            {
              "name": "var2",
              "value": "8356"
            },
            {
              "name": "var3",
              "value": "5356"
            }
          ]
        },
        "output": {
          "output": [
            {
              "var1": {
                "hello": "1234",
                "hi": "3412",
                "bye": "1294"
              }
            },
            {
              "var2": {
                "hello": "2356",
                "hi": "2563",
                "bye": "8356"
              }
            },
            {
              "var3": {
                "hello": "2356",
                "hi": "4256",
                "bye": "5356"
              }
            }
          ]
        }
      }
    ],
    "identifier": 77012572
  },
  {
    "context": [
      "I used jq to convert the GeoJSON to [newline delimited GeoJSON](https://www.dropbox.com/scl/fi/eswd7pnomn4kkgmnqafow/cm.gejsonl?rlkey=hmuo10eebok3g0b2csoti6jgf&dl=0) with jq like this:\n\ntype cm.geojson | jq -c \".features[]\" > cm.geojsonl",
      "cat cm.geojson | jq -c '.features[]' > converted.json",
      "If you convert the geojson exactly this way, it will load"
    ],
    "utterance": "Extract each object from the features array in a GeoJSON file and output them as separate lines.",
    "expressions": [
      ".features[]",
      "jq -c '.features[]'"
    ],
    "identifier": 77062299
  },
  {
    "context": [
      "I have this jq output from a CLI command\n\n    [\"test-KEY\",\"test-PASSWORD\"]",
      "Assigned that output to a bash variable in this manner\n\n    secret_list=`mycli | jq`",
      "My expectation is to iterate through that array. What am I doing wrong?",
      "mycli | jq -r '.[]' | while read -r secret; do\n  echo \"$secret\"\ndone"
    ],
    "utterance": "Extract each string element from the output array so that each element can be processed individually in a shell loop.",
    "expressions": [
      ".[]",
      "-r '.[]'"
    ],
    "data": [
      {
        "input": [
          "test-KEY",
          "test-PASSWORD"
        ],
        "output": [
          "test-KEY",
          "test-PASSWORD"
        ]
      }
    ],
    "identifier": 77084321
  },
  {
    "context": [
      "I want to merge the elements of this array so that the following output is desired:",
      "[{interface: map(.interface) | transpose | map(add)}]",
      "If it is by the value of `.name`, you could iterate over the items using `reduce`, and collect the matching fields in an object.",
      "[{interface: (reduce .[].interface[] as $i ({}; .[$i.name] += $i) | map(.))}]",
      "For the sample data given, both output:\n[\n  {\n    \"interface\": [\n      {\n        \"name\": \"ethernet-1/1\",\n        \"ifindex\": 16382,\n        \"admin-state\": \"disable\"\n      },\n      {\n        \"name\": \"ethernet-1/2\",\n        \"ifindex\": 49150,\n        \"admin-state\": \"disable\"\n      }\n    ]\n  }\n]"
    ],
    "utterance": "Merge objects in the 'interface' arrays of each top-level element so all properties are combined for each interface by name.",
    "expressions": [
      "[{interface: map(.interface) | transpose | map(add)}]",
      "[{interface: (reduce .[].interface[] as $i ({}; .[$i.name] += $i) | map(.))}]"
    ],
    "data": [
      {
        "input": [
          {
            "interface": [
              {
                "name": "ethernet-1/1",
                "ifindex": 16382
              },
              {
                "name": "ethernet-1/2",
                "ifindex": 49150
              }
            ]
          },
          {
            "interface": [
              {
                "name": "ethernet-1/1",
                "admin-state": "disable"
              },
              {
                "name": "ethernet-1/2",
                "admin-state": "disable"
              }
            ]
          }
        ],
        "output": [
          {
            "interface": [
              {
                "name": "ethernet-1/1",
                "admin-state": "disable",
                "ifindex": 16382
              },
              {
                "name": "ethernet-1/2",
                "admin-state": "disable",
                "ifindex": 49150
              }
            ]
          }
        ]
      }
    ],
    "identifier": 77058435
  },
  {
    "context": [
      "I am having following json source that I am trying to normalize into one specific field for all values that contain `true` or `false`.",
      "At the same time there is a special key `e` that I want to copy over to specific keys.",
      "That's the json:",
      "{\n  \"an\": {\n    \"e\": false\n  },\n  \"at\": {\n    \"c\": {\n      \"e\": false\n    }\n  },\n  \"b\": {\n    \"s\": true\n  },\n  \"e\": {\n    \"d\": true,\n    \"e\": true,\n    \"f\": true,\n    \"n\": true,\n    \"p\": true,\n    \"r\": true,\n    \"s\": true\n  },\n  \"l\": {\n    \"f\": \"info\"\n  },\n  \"m\": {\n    \"b\": true\n  },\n  \"ma\": {\n    \"mo\": \"pov\",\n    \"s\": true\n  },\n  \"r\": {\n    \"mo\": \"pov\",\n    \"s\": true\n  }\n}",
      "That's the output I am aiming for. The `val` key should be basically in the second hierarchy at the same place. The keys and values have been basically anonymized.",
      "I basically wanted to collect these fields all into a val field on the same place.",
      "should be copied the field value from `an.e` to `an.val`:",
      "Same for keys \n  `at.c.e` to `at.val`\n  `b.s` to `b.val`\n  `m.b` to `m.val`\n  `ma.s` to `ma.val`\n  `r.s` to `r.val`",
      "key `e` has the issue the it contains multiple subfields with `true` or `false`\nThat's why following copy scheme basically merged main and subkey together:\n  `e.d` to `ed.val`\n  `e.e` to `ee.val`\n  `e.f` to `ef.val`\n  `e.n` to `en.val`\n  `e.p` to `ep.val`\n  `e.r` to `er.val`\n  `e.s` to `es.val`"
    ],
    "utterance": "Copy all fields with true or false values to a sibling key named \"val\" at the correct place, and for the object under key \"e\", copy each true/false field to a new top-level object named by combining \"e\" and the subkey, each containing {\"val\": <value>}.",
    "expressions": [
      "def merge_val(obj):\n  obj + (if (obj.e|type == \"boolean\") then {val: obj.e}\n         elif (obj.s|type == \"boolean\") then {val: obj.s}\n         elif (obj.b|type == \"boolean\") then {val: obj.b}\n         else {} end);\n\n. as $in |\nreduce ([\n    \"an\",\n    \"at\",\n    \"b\",\n    \"l\",\n    \"m\",\n    \"ma\",\n    \"r\"\n    ][] | .) as $k ({};\n    . + if $in[$k] == null then {}\n         elif ($in[$k].c? and ($in[$k].c.e|type == \"boolean\")) then\n           {($k): ($in[$k] + {val: $in[$k].c.e})}\n         else {($k): merge_val($in[$k])} end\n  )\n|\n. +\n($in.e as $e |\n  reduce ($e|to_entries[] | select(.value == true or .value == false)) as $item ({};\n    . + { (\"e\" + $item.key): {val: $item.value} }\n  ))\n|\n. + {e: $in.e}\n"
    ],
    "data": [
      {
        "input": {
          "an": {
            "e": false
          },
          "at": {
            "c": {
              "e": false
            }
          },
          "b": {
            "s": true
          },
          "e": {
            "d": true,
            "e": true,
            "f": true,
            "n": true,
            "p": true,
            "r": true,
            "s": true
          },
          "l": {
            "f": "info"
          },
          "m": {
            "b": true
          },
          "ma": {
            "mo": "pov",
            "s": true
          },
          "r": {
            "mo": "pov",
            "s": true
          }
        },
        "output": {
          "an": {
            "e": false,
            "val": false
          },
          "at": {
            "c": {
              "e": false
            },
            "val": false
          },
          "b": {
            "s": true,
            "val": true
          },
          "e": {
            "d": true,
            "e": true,
            "f": true,
            "n": true,
            "p": true,
            "r": true,
            "s": true
          },
          "ed": {
            "val": true
          },
          "ee": {
            "val": true
          },
          "ef": {
            "val": true
          },
          "en": {
            "val": true
          },
          "ep": {
            "val": true
          },
          "er": {
            "val": true
          },
          "es": {
            "val": true
          },
          "l": {
            "f": "info"
          },
          "m": {
            "b": true,
            "val": true
          },
          "ma": {
            "mo": "pov",
            "s": true,
            "val": true
          },
          "r": {
            "mo": "pov",
            "s": true,
            "val": true
          }
        }
      }
    ],
    "identifier": 77000924
  },
  {
    "context": [
      "2. I want to choose keys \"a\" and \"c\" based on the fact that they both have \"3\" in their respective child arrays. How do I go about that? I can get the child arrays with \"3\" in them with jq -r '.x[] | select(index(\"3\") >= 0)' file.json but I need access to the parent key.",
      "2. `jq -r '.x | with_entries(select(.value | index(\"3\"))) | keys[]'` seems to do the trick.",
      "You could iterate over the (sorted) `keys` (use `keys_unsorted` instead if you want the original order), and use `IN` (which is just a shortcut to `any` using `==` as comparator) to `select` by containedness.\n```sh\njq '.x | keys[] as $k | select(IN(.[$k][]; \"3\")) | $k' file.json\n```\n```\na\nc\n```",
      "Now, say, you only want the said keys alone ([demo][2]):\n\n```\nFILTER: .x[] |= select(index(\"3\") >= 0) | .[] | keys\n\nRESULT: [\"a\",\"c\"]\n```"
    ],
    "utterance": "List the keys whose child arrays contain the value \"3\".",
    "expressions": [
      ".x | with_entries(select(.value | index(\"3\"))) | keys[]",
      ".x | keys[] as $k | select(IN(.[$k][]; \"3\")) | $k",
      ".x[] |= select(index(\"3\") >= 0) | .[] | keys"
    ],
    "data": [
      {
        "input": {
          "x": {
            "a": [
              "2",
              "3"
            ],
            "b": [
              "1",
              "2"
            ],
            "c": [
              "3",
              "4"
            ]
          }
        },
        "output": [
          "a",
          "c"
        ]
      }
    ],
    "identifier": 77093338
  },
  {
    "context": [
      ".[] | select((try .free catch empty) == true).name",
      ".[] | select((try .free) == true).name",
      ".[] | select(.free? == true).name",
      ".[] | select(.free?).name",
      ".[] | select(type == \"object\" and .free == true).name",
      ".[] | select(objects.free == true).name",
      ".[] | select(objects.free).name",
      "\"But my JSON has some elements without this \\\"free\\\" key\"",
      "\"Then my commands fails with parse error: Invalid numeric literal at line 2, column 4\"",
      "\"Your idea of using `has` is good, but it would, again, only work on objects (and `null`), and therefore fail just the same on other types (like the string under `.id`).\""
    ],
    "utterance": "List the names of all node sub-objects where the free field is true, even when other keys or non-object values are present at the top level.",
    "expressions": [
      ".[] | select((try .free catch empty) == true).name",
      ".[] | select((try .free) == true).name",
      ".[] | select(.free? == true).name",
      ".[] | select(.free?).name",
      ".[] | select(type == \"object\" and .free == true).name",
      ".[] | select(objects.free == true).name",
      ".[] | select(objects.free).name"
    ],
    "data": [
      {
        "input": {
          "id": "foo",
          "node1": {
            "name": "host001",
            "free": true
          },
          "node2": {
            "name": "host002",
            "free": false
          },
          "node3": {
            "name": "host003",
            "free": false
          },
          "node4": {
            "name": "host004",
            "free": true
          }
        },
        "output": [
          "host001",
          "host004"
        ]
      }
    ],
    "identifier": 77037579
  },
  {
    "context": [
      "I want to sort my JSON file using `jq` by **Id** & **Order**. How can I do that and generate a new JSON with sorted data?",
      "Sort by `.Id` and sort all inner `.Media` arrays by `.Order`:",
      "```\r\n.value |= (sort_by(.Id) | .[].Media |= sort_by(.Order))\r\n```",
      "Without parentheses:",
      "```\r\n.value |= sort_by(.Id) | .value[].Media |= sort_by(.Order)\r\n```",
      "With `map`:",
      "```\r\n.value |= (sort_by(.Id) | map(.Media |= sort_by(.Order)))\r\n```"
    ],
    "utterance": "Sort the top-level array by Id and, within each object, sort the Media array by Order.",
    "expressions": [
      ".value |= (sort_by(.Id) | .[].Media |= sort_by(.Order))",
      ".value |= sort_by(.Id) | .value[].Media |= sort_by(.Order)",
      ".value |= (sort_by(.Id) | map(.Media |= sort_by(.Order)))"
    ],
    "data": [
      {
        "input": {
          "@odata.context": "https://api.myserver.com/v2/$metadata#Property(Id,PhotosChangeTimestamp,ModificationTimestamp,PhotosCount)",
          "@odata.count": 2,
          "value": [
            {
              "Id": "SOMETHING_9999",
              "ModificationTimestamp": "2023-09-01T19:20:19.712Z",
              "PhotosChangeTimestamp": "2023-09-01T19:20:19.712Z",
              "Media": [
                {
                  "MediaKey": "RAN13042846",
                  "MediaType": "Image",
                  "Order": 2,
                  "ImageWidth": 2560,
                  "ImageHeight": 1707,
                  "ImageSizeDescription": "2560x1707",
                  "MediaURL": "https://myserver.com/images/SOMETHING_9999/4f1900bf-4ad3-4cee-aa06-1374424875b7.jpeg",
                  "MediaModificationTimestamp": "2023-09-01T19:19:28.792Z"
                },
                {
                  "MediaKey": "RAN13042852",
                  "MediaType": "Image",
                  "Order": 1,
                  "ImageWidth": 2560,
                  "ImageHeight": 1707,
                  "ImageSizeDescription": "2560x1707",
                  "MediaURL": "https://myserver.com/images/SOMETHING_9999/10924c28-3c0b-4967-9080-0216f6b9b3d8.jpeg",
                  "MediaModificationTimestamp": "2023-09-01T19:19:28.787Z"
                }
              ],
              "PhotosCount": 2
            },
            {
              "Id": "SOMETHING_9988",
              "ModificationTimestamp": "2023-09-01T19:20:19.712Z",
              "PhotosChangeTimestamp": "2023-09-01T19:20:19.712Z",
              "Media": [
                {
                  "MediaKey": "RAN13042846",
                  "MediaType": "Image",
                  "Order": 2,
                  "ImageWidth": 2560,
                  "ImageHeight": 1707,
                  "ImageSizeDescription": "2560x1707",
                  "MediaURL": "https://myserver.com/images/SOMETHING_9999/4f1900bf-4ad3-4cee-aa06-1374424875b7.jpeg",
                  "MediaModificationTimestamp": "2023-09-01T19:19:28.792Z"
                },
                {
                  "MediaKey": "RAN13042844",
                  "MediaType": "Image",
                  "Order": 1,
                  "ImageWidth": 2560,
                  "ImageHeight": 1707,
                  "ImageSizeDescription": "2560x1707",
                  "MediaURL": "https://myserver.com/images/SOMETHING_9999/4f1900bf-4ad3-4cee-aa06-1374424876b9.jpeg",
                  "MediaModificationTimestamp": "2023-09-01T19:19:28.792Z"
                }
              ],
              "PhotosCount": 2
            }
          ]
        },
        "output": {
          "@odata.context": "https://api.myserver.com/v2/$metadata#Property(Id,PhotosChangeTimestamp,ModificationTimestamp,PhotosCount)",
          "@odata.count": 2,
          "value": [
            {
              "Id": "SOMETHING_9988",
              "ModificationTimestamp": "2023-09-01T19:20:19.712Z",
              "PhotosChangeTimestamp": "2023-09-01T19:20:19.712Z",
              "Media": [
                {
                  "MediaKey": "RAN13042844",
                  "MediaType": "Image",
                  "Order": 1,
                  "ImageWidth": 2560,
                  "ImageHeight": 1707,
                  "ImageSizeDescription": "2560x1707",
                  "MediaURL": "https://myserver.com/images/SOMETHING_9999/4f1900bf-4ad3-4cee-aa06-1374424876b9.jpeg",
                  "MediaModificationTimestamp": "2023-09-01T19:19:28.792Z"
                },
                {
                  "MediaKey": "RAN13042846",
                  "MediaType": "Image",
                  "Order": 2,
                  "ImageWidth": 2560,
                  "ImageHeight": 1707,
                  "ImageSizeDescription": "2560x1707",
                  "MediaURL": "https://myserver.com/images/SOMETHING_9999/4f1900bf-4ad3-4cee-aa06-1374424875b7.jpeg",
                  "MediaModificationTimestamp": "2023-09-01T19:19:28.792Z"
                }
              ],
              "PhotosCount": 2
            },
            {
              "Id": "SOMETHING_9999",
              "ModificationTimestamp": "2023-09-01T19:20:19.712Z",
              "PhotosChangeTimestamp": "2023-09-01T19:20:19.712Z",
              "Media": [
                {
                  "MediaKey": "RAN13042852",
                  "MediaType": "Image",
                  "Order": 1,
                  "ImageWidth": 2560,
                  "ImageHeight": 1707,
                  "ImageSizeDescription": "2560x1707",
                  "MediaURL": "https://myserver.com/images/SOMETHING_9999/10924c28-3c0b-4967-9080-0216f6b9b3d8.jpeg",
                  "MediaModificationTimestamp": "2023-09-01T19:19:28.787Z"
                },
                {
                  "MediaKey": "RAN13042846",
                  "MediaType": "Image",
                  "Order": 2,
                  "ImageWidth": 2560,
                  "ImageHeight": 1707,
                  "ImageSizeDescription": "2560x1707",
                  "MediaURL": "https://myserver.com/images/SOMETHING_9999/4f1900bf-4ad3-4cee-aa06-1374424875b7.jpeg",
                  "MediaModificationTimestamp": "2023-09-01T19:19:28.792Z"
                }
              ],
              "PhotosCount": 2
            }
          ]
        }
      }
    ],
    "identifier": 77054869
  },
  {
    "context": [
      "I want to output the name of all pods, its containers, and the containers mount points & names, and in the end only selecting mounts whose volumes have the key `persistentVolumeClaim`, e.g.:",
      "pod1;container1;mount1;/path1;claim1",
      "pod1;container2;mount1;/path3;claim1",
      "Now I need to join the `volumes` array with each `volumeMounts` array in `containers` and afterwards select for only those with the `persistentVolumeClaim` key.",
      "While traversing, you could store all parts needed into variables for reference. This includes creating a lookup index using the names under `.volumes` as keys, realized here as object using `INDEX`.",
      ".items[] | .metadata.name as $meta\n| .spec | INDEX(.volumes[]; .name) as $volumes\n| .containers[] | .name as $name\n| .volumeMounts[] | select($volumes[.name].persistentVolumeClaim.claimName)\n| [$meta, $name, .name, .mountPath] | join(\";\")",
      "Output:",
      "pod1;container1;mount1;/path1",
      "pod1;container2;mount1;/path3",
      "Here's a solution which builds an index per item, then transforms the data into structured objects, and finally creates an array to join:",
      ".items[]\n| INDEX(.spec.volumes[]; .name) as $index\n| { pod: .metadata.name }\n+ (\n    .spec.containers[]\n    | {\n        container: .name,\n        mount: JOIN($index; .volumeMounts[]; .name; {name: first.name, path: first.mountPath, claim: .[1].persistentVolumeClaim.claimName})\n    } | select(.mount.claim)\n)\n| [ .pod, .container, .mount[] ]\n| join(\";\")",
      "Output:",
      "pod1;container1;mount1;/path1;claim1",
      "pod1;container2;mount1;/path3;claim1"
    ],
    "utterance": "List all pod names, container names, mount names, mount paths, and claim names for mounts where the corresponding volume has a persistentVolumeClaim.",
    "expressions": [
      ".items[]\n| .metadata.name as $meta\n| .spec | INDEX(.volumes[]; .name) as $volumes\n| .containers[] | .name as $name\n| .volumeMounts[] | select($volumes[.name].persistentVolumeClaim.claimName)\n| [$meta, $name, .name, .mountPath, $volumes[.name].persistentVolumeClaim.claimName] | join(\";\")",
      ".items[]\n| INDEX(.spec.volumes[]; .name) as $index\n| .spec.containers[]\n| .volumeMounts[]\n| select($index[.name].persistentVolumeClaim.claimName)\n| [. as $m | {pod: input.items[0].metadata.name, container: input.items[0].spec.containers[0].name, mount: $m.name, path: $m.mountPath, claim: $index[$m.name].persistentVolumeClaim.claimName}] | .[] | [ .pod, .container, .mount, .path, .claim ] | join(\";\")"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "pod1"
              },
              "spec": {
                "containers": [
                  {
                    "name": "container1",
                    "volumeMounts": [
                      {
                        "mountPath": "/path1",
                        "name": "mount1"
                      },
                      {
                        "mountPath": "/path2",
                        "name": "mount2"
                      }
                    ]
                  },
                  {
                    "name": "container2",
                    "volumeMounts": [
                      {
                        "mountPath": "/path3",
                        "name": "mount1"
                      }
                    ]
                  }
                ],
                "volumes": [
                  {
                    "name": "mount1",
                    "persistentVolumeClaim": {
                      "claimName": "claim1"
                    }
                  },
                  {
                    "name": "mount2",
                    "emptyDir": {}
                  }
                ]
              }
            }
          ]
        },
        "output": [
          "pod1;container1;mount1;/path1;claim1",
          "pod1;container2;mount1;/path3;claim1"
        ]
      }
    ],
    "identifier": 77092168
  },
  {
    "context": [
      "However my application (Spring Boot Apache Camel) gives me this error: \"Function IN/1 does not exist\".",
      "If I use \"in\" instead of \"IN\" I get: \"has() is not applicable to STRING\".",
      "Use the equivalent `select(IN($colors[]; .id))` or `select(any($colors[] == .id; .))` (this is how the filter is defined in [`builtin.jq`](https://github.com/jqlang/jq/blob/7a72f58d2e92254652162ec7ca1b3074e3a22c35/src/builtin.jq#L277))"
    ],
    "utterance": "Select items where .id matches any value in a referenced array $colors, as a workaround for missing IN/1 function.",
    "expressions": [
      ".links[] | select(.from == \"product1\") | .to as $colors | [.hits[] | select(any($colors[] == .id; .)) | .name]"
    ],
    "identifier": 77102884
  },
  {
    "context": [
      "How can I get the color names associated to product1 ([\"green\", \"blue\"]) using a jq expression?",
      "However, I don't want to hardcode (\"color1\",\"color2\") but instead refer to $colors.",
      "(.links | map(select(.from == \"product1\").to)) as $colors\n| .hits | map(select(IN(.id; $colors[])).name)",
      "Build an INDEX from color ids to names, then select the required products and look up the color by id:\n\n(INDEX(.hits[]; .id) | map_values(.name)) as $colors\n| .links\n| map(select(.from == \"product1\") | $colors[.to])",
      "Or with a single JOIN + INDEX:\n\nJOIN(\n  INDEX(.hits[]; .id);\n  .links[] | select(.from == \"product1\");\n  .to;\n  last.name)",
      "[.links[] | select(.from == \"product1\") | .to] as $colors | [.hits[] | select(.id | IN($colors[])) | .name]"
    ],
    "utterance": "Get the names of colors associated with product1 using the links from product to color.",
    "expressions": [
      "(.links | map(select(.from == \"product1\").to)) as $colors | .hits | map(select(IN(.id; $colors[])).name)",
      "(INDEX(.hits[]; .id) | map_values(.name)) as $colors | .links | map(select(.from == \"product1\") | $colors[.to])",
      "JOIN(\n  INDEX(.hits[]; .id);\n  .links[] | select(.from == \"product1\");\n  .to;\n  last.name)",
      "[.links[] | select(.from == \"product1\") | .to] as $colors | [.hits[] | select(.id | IN($colors[])) | .name]"
    ],
    "data": [
      {
        "input": {
          "links": [
            {
              "from": "product1",
              "to": "color1"
            },
            {
              "from": "product1",
              "to": "color2"
            },
            {
              "from": "product2",
              "to": "color3"
            }
          ],
          "hits": [
            {
              "id": "color1",
              "name": "green"
            },
            {
              "id": "color2",
              "name": "blue"
            },
            {
              "id": "color3",
              "name": "yellow"
            }
          ]
        },
        "output": [
          "green",
          "blue"
        ]
      }
    ],
    "identifier": 77100152
  },
  {
    "identifier": 77114292
  },
  {
    "context": [
      "I want to only include milestones which:\n- have 100% progress\n- don't include the word \"withdrawn\" within the title\n- have issues associated with them.\n\nAlso, if the milestone title contains either ` ` or `, `, then I need to split the title. Each split will be its own key with identical values.",
      "[ \n  .data.repository \n  | .nameWithOwner as $repo \n  | .milestones.nodes[] \n  | select(\n      .progressPercentage == 100 and \n      (.title | contains(\"withdrawn\") | not) and \n      .issues.nodes[]\n    )\n  | \n  { \n    (.title | splits(\",? \")): (\n        { $repo, milestone: .number } + \n        (.issues.nodes[] | { issue: .number, labels: [ .labels.nodes[].name ] }))\n  }\n] \n| add",
      ".data.repository\n| .nameWithOwner as $repo\n| .milestones.nodes\n| map( # create a new array containing the milestones\nselect(.progressPercentage == 100) | select(.title | contains(\"withdrawn\") | not) | select(.issues.nodes | length > 0) # filter interesting milestone nodes\n  | {\n    (.title | splits(\",? \")): [ # one object per title part, each object containing an array\n        { $repo, milestone: .number } # base milestone data, plus \u2026\n        + (.issues.nodes[] | {\n          issue: .number,\n          labels: [.labels.nodes[].name] # collect all label names in an array\n        })\n    ]\n  })\n| add # merge all objects of the array into a single object",
      "If your input contains multiple objects and you want the final output to be a single object, use `-s` (`--slurp`) in combination with `map(\u2026)`:\n\njq -s 'map( # -s reads everything as one big array, `map` transforms the elements of this array\n  .data.repository\n  | .nameWithOwner as $repo\n  | .milestones.nodes\n  | map( # create a new array containing the milestones\n    select(.progressPercentage == 100) | select(.title | contains(\"withdrawn\") | not) | select(.issues.nodes | length > 0) # filter interesting milestone nodes\n    | {\n      (.title | splits(\",? \")): [ # one object per title part containing an array\n          { $repo, milestone: .number } # base milestone data, plus \u2026\n          + (.issues.nodes[] | {\n            issue: .number,\n            labels: [.labels.nodes[].name] # collect all label names in an array\n          })\n      ]\n    }\n  )\n)\n| add # merge all objects of the array into a single object\n'"
    ],
    "utterance": "Extract milestones with 100% progress, excluding those whose title includes 'withdrawn', only if they have issues; for each such milestone, split the title by spaces or a comma and space, and use each split as a key with associated repo, milestone number, issue number, and labels as value.",
    "expressions": [
      "[ \n  .data.repository \n  | .nameWithOwner as $repo \n  | .milestones.nodes[] \n  | select(\n      .progressPercentage == 100 and \n      (.title | contains(\"withdrawn\") | not) and \n      .issues.nodes[]\n    )\n  | \n  { \n    (.title | splits(\",? \")): (\n        { $repo, milestone: .number } + \n        (.issues.nodes[] | { issue: .number, labels: [ .labels.nodes[].name ] }))\n  }\n] \n| add",
      ".data.repository\n| .nameWithOwner as $repo\n| .milestones.nodes\n| map(\n  select(.progressPercentage == 100) | select(.title | contains(\"withdrawn\") | not) | select(.issues.nodes | length > 0)\n    | {\n      (.title | splits(\",? \")): [\n          { $repo, milestone: .number }\n          + (.issues.nodes[] | {\n            issue: .number,\n            labels: [.labels.nodes[].name]\n          })\n      ]\n    })\n| add",
      "map(\n  .data.repository\n  | .nameWithOwner as $repo\n  | .milestones.nodes\n  | map(\n    select(.progressPercentage == 100) | select(.title | contains(\"withdrawn\") | not) | select(.issues.nodes | length > 0)\n    | {\n      (.title | splits(\",? \")): [\n          { $repo, milestone: .number }\n          + (.issues.nodes[] | {\n            issue: .number,\n            labels: [.labels.nodes[].name]\n          })\n      ]\n    }\n  )\n)\n| add"
    ],
    "data": [
      {
        "input": {
          "data": {
            "repository": {
              "nameWithOwner": "cov-lineages/pango-designation",
              "milestones": {
                "pageInfo": {
                  "hasNextPage": true,
                  "endCursor": "Y3Vyc29yOnYyOpHOAGviZA=="
                },
                "nodes": [
                  {
                    "number": 1,
                    "title": "C.1, EXAMPLE_SPLIT",
                    "progressPercentage": 100,
                    "issues": {
                      "nodes": [
                        {
                          "number": 2,
                          "labels": {
                            "nodes": [
                              {
                                "name": "proposed"
                              },
                              {
                                "name": "designated"
                              }
                            ]
                          }
                        }
                      ]
                    }
                  },
                  {
                    "number": 2,
                    "title": "B.1.429",
                    "progressPercentage": 100,
                    "issues": {
                      "nodes": [
                        {
                          "number": 3,
                          "labels": {
                            "nodes": [
                              {
                                "name": "proposed"
                              },
                              {
                                "name": "designated"
                              }
                            ]
                          }
                        }
                      ]
                    }
                  }
                ]
              }
            }
          }
        },
        "output": {
          "C.1": {
            "repo": "cov-lineages/pango-designation",
            "milestone": 1,
            "issue": 2,
            "labels": [
              "proposed",
              "designated"
            ]
          },
          "EXAMPLE_SPLIT": {
            "repo": "cov-lineages/pango-designation",
            "milestone": 1,
            "issue": 2,
            "labels": [
              "proposed",
              "designated"
            ]
          },
          "B.1.429": {
            "repo": "cov-lineages/pango-designation",
            "milestone": 2,
            "issue": 3,
            "labels": [
              "proposed",
              "designated"
            ]
          }
        }
      }
    ],
    "identifier": 76982456
  },
  {
    "context": [
      "I have a json which looks simplified like:\n\n```\n{\n  \"a\": \"aaa\",\n  \"b\": \"bbb\",\n  \"types\": \"{2,4,5,10,13}\",\n  \"c\": \"ccc\"  \n}\n```\n\nThe wanted output from jq should be\n\n\n```\n2\n4\n5\n10\n13\n```",
      "Use `.types` to traverse to that key, then `scan` the string for consecutive digits with a regex. Use the `-r` flag to output raw text:\n```sh\njq -r '.types | scan(\"\\\\d+\")' input.json\n```\n```json\n2\n4\n5\n10\n13\n```\n[Demo](https://jqplay.org/s/-tUnwFiK6fm)"
    ],
    "utterance": "Extract each number from the string value of the 'types' key and output them one per line.",
    "expressions": [
      ".types | scan(\"\\d+\")"
    ],
    "data": [
      {
        "input": {
          "a": "aaa",
          "b": "bbb",
          "types": "{2,4,5,10,13}",
          "c": "ccc"
        },
        "output": [
          "2",
          "4",
          "5",
          "10",
          "13"
        ]
      }
    ],
    "identifier": 77106088
  },
  {
    "context": [
      "expected `$DATA` to be an array of objects with two properties `project, repo`",
      "then I want to loop through each object in the `$DATA` array and extract the value for each property and store it in a variable.",
      "then print the variables to stdout.",
      "# from echo $DATA, this seems to be correct.",
      "[{\"project\": \"some_proj_name\", \"repo\": \"repo_name\" }, {...} ...]"
    ],
    "utterance": "Extract each object's 'project' and 'repo' properties from an array.",
    "expressions": [
      ".[] | {project, repo}",
      ".[] | .project",
      ".[] | .repo"
    ],
    "data": [
      {
        "input": [
          {
            "project": "some_proj_name",
            "repo": "repo_name"
          },
          {
            "project": "other_proj",
            "repo": "other_repo"
          }
        ],
        "output": [
          {
            "project": "some_proj_name",
            "repo": "repo_name"
          },
          {
            "project": "other_proj",
            "repo": "other_repo"
          }
        ]
      }
    ],
    "identifier": 77114902
  },
  {
    "context": [
      "I would like to get only data from \"keyTwo\" which is \"my_data_two\"",
      "`feedData` is a JSON object, so you can convert it with `fromjson`:",
      "`jq -r '.getFeedFromMyTeam[] | .recipients[] as $t | [.OpenedAt,$t.receiverId,$t.receiverName,.senderId,(.feedData | fromjson | .keyTwo)] | @csv' file.json`",
      "`| [.OpenedAt,$t.receiverId,$t.receiverName,.senderId,(.feedData|fromjson.keyTwo)] | @csv'`"
    ],
    "utterance": "Extract the value of keyTwo from the feedData field within each getFeedFromMyTeam entry and output it as a CSV column alongside OpenedAt, recipient receiverId, receiverName, and senderId.",
    "expressions": [
      ".getFeedFromMyTeam[] | .recipients[] as $t | [.OpenedAt, $t.receiverId, $t.receiverName, .senderId, (.feedData | fromjson | .keyTwo)] | @csv",
      ".getFeedFromMyTeam[] | .recipients[] as $t | [.OpenedAt, $t.receiverId, $t.receiverName, .senderId, (.feedData|fromjson.keyTwo)] | @csv"
    ],
    "data": [
      {
        "input": {
          "getFeedFromMyTeam": [
            {
              "OpenedAt": 1693321311,
              "feedData": "{\"keyOne\":\"my_data_one\",\"keyTwo\":\"my_data_two\"}",
              "feedId": "123456789",
              "recipients": [
                {
                  "receiverId": "johns",
                  "receiverName": "John Smith"
                }
              ],
              "senderId": "janed",
              "senderName": "Jane Doe"
            }
          ],
          "hasMore": true,
          "paginationToken": "100"
        },
        "output": "1693321311,\"johns\",\"John Smith\",\"janed\",\"my_data_two\""
      }
    ],
    "identifier": 77104936
  },
  {
    "context": [
      "Then, output just the IPS:",
      "ansible-inventory \\\n    --inventory /tmp/inventory.yml \\\n    --list \\\n        | jq --raw-output '\n            ._meta[] \n            | to_entries[] \n            | .value.ansible_host\n          '",
      "The query can be simplified",
      "ansible-inventory -i inventory.yml --list | jq -r '._meta[][].ansible_host'"
    ],
    "utterance": "Retrieve a flat list of all values of ansible_host for all hosts in the inventory output.",
    "expressions": [
      "._meta[] | to_entries[] | .value.ansible_host",
      "._meta[][].ansible_host"
    ],
    "data": [
      {
        "input": {
          "_meta": {
            "hostvars": {
              "host1": {
                "ansible_host": "8.8.8.8"
              },
              "host2": {
                "ansible_host": "8.8.4.4"
              },
              "host3": {
                "ansible_host": "1.1.1.1"
              },
              "otherhost": {
                "ansible_host": "192.168.1.1"
              }
            }
          }
        },
        "output": [
          "8.8.8.8",
          "8.8.4.4",
          "1.1.1.1",
          "192.168.1.1"
        ]
      }
    ],
    "identifier": 77115828
  },
  {
    "context": [
      "cat package-lock.json | jq 'del(.packages.\"foo/bar\")' > package-lock-new.json",
      "cat package-lock.json | jq --arg ROOT \"$ROOT\" 'del(.$ROOT.\"foo/bar\")' > package-lock-new.json",
      "cat package-lock.json | jq --arg BAR \"$BAR\" 'del(.packages.\"foo/$BAR\".version)' > package-lock-new.json",
      "You have to concatenate the literal part with the variable, and make it a key identifier:",
      "# using string interpolation",
      "jq --arg BAR \"$BAR\" 'del(.packages.\"foo/\\($BAR)\".version)'",
      "# using string addition",
      "jq --arg BAR \"$BAR\" 'del(.packages[\"foo/\" + $BAR].version)'"
    ],
    "utterance": "Delete the 'version' field from the object at the path .packages.\"foo/$BAR\", where $BAR is a variable that may contain special characters such as a slash.",
    "expressions": [
      "del(.packages[\"foo/\" + $BAR].version)",
      "del(.packages.\"foo/\\($BAR)\".version)"
    ],
    "data": [
      {
        "input": {
          "packages": {
            "foo/bar": {
              "name": "P1",
              "version": 1
            }
          }
        },
        "output": {
          "packages": {
            "foo/bar": {
              "name": "P1"
            }
          }
        }
      }
    ],
    "identifier": 77129356
  },
  {
    "context": [
      "I would like to produce a list of all unique key path from a given JSON, each one in a line.",
      "For example, from this input JSON:\n\n    {\n       \"results\":[\n          {\n             \"id\":306,\n             \"name\":\"First Company\",\n             \"branches\":[\n                {\n                   \"id\":4191,\n                   \"city\":\"San Francisco\",\n                   \"customers\":[\n                      {\n                         \"id\":446,\n                         \"name\":\"Big Tech 1\"\n                      },\n                      {\n                         \"id\":447,\n                         \"name\":\"Big Tech 2\"\n                      }\n                   ]\n                },\n                {\n                   \"id\":4192,\n                   \"city\":\"Miami\",\n                   \"customers\":[\n                      {\n                         \"id\":448,\n                         \"name\":\"Insurance Tech 1\"\n                      },\n                      {\n                         \"id\":449,\n                         \"name\":\"Health Tech 2\"\n                      }\n                   ]\n                }\n             ]\n          }\n       ]\n    }\n\nI would like to produce this output:\n\n      results\n      results.id\n      results.name\n      results.branches\n      results.branches.id\n      results.branches.city\n      results.branches.customers\n      results.branches.customers.id\n      results.branches.customers.name",
      "With `paths` function, filtering out array indices of object keys and collecting unique paths:\n\n    jq '[paths(.) | map(select(type != \"number\")) | join(\".\")] | unique[]' test.json",
      "You could `map` the `paths` to only contain `strings`, then drop the duplicates using `unique`, and `join` the items by providing a delimiter:\n```sh\njq -r '[paths | map(strings)] | unique[] | join(\".\")'\n```"
    ],
    "utterance": "Produce a list of all unique key paths in the data, separated by dots, with each path on its own line.",
    "expressions": [
      "[paths(.) | map(select(type != \"number\")) | join(\".\")] | unique[]",
      "-r '[paths | map(strings)] | unique[] | join(\".\")'"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "id": 306,
              "name": "First Company",
              "branches": [
                {
                  "id": 4191,
                  "city": "San Francisco",
                  "customers": [
                    {
                      "id": 446,
                      "name": "Big Tech 1"
                    },
                    {
                      "id": 447,
                      "name": "Big Tech 2"
                    }
                  ]
                },
                {
                  "id": 4192,
                  "city": "Miami",
                  "customers": [
                    {
                      "id": 448,
                      "name": "Insurance Tech 1"
                    },
                    {
                      "id": 449,
                      "name": "Health Tech 2"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "results",
          "results.id",
          "results.name",
          "results.branches",
          "results.branches.id",
          "results.branches.city",
          "results.branches.customers",
          "results.branches.customers.id",
          "results.branches.customers.name"
        ]
      }
    ],
    "identifier": 77133925
  },
  {
    "context": [
      "I would like to produce a list of all values from any given JSON. The special requirement is that for values in nested attributes, all the values of parent's attributes must be repeated in the line. No keys must be printed.",
      "For example, from this input JSON: ... I would like to produce this output ... The JSON above is just an example and generic JSON with arbitrary depth of nesting of JSON objects must be assumed, which suggests that the processing must be recursive. If *null* appears they must be printed as well.",
      "jq -r '\n  .results[] | [.id, .name] + (\n    .branches[] | [.id, .city] + (\n      .customers[] | [.id, .name]\n    )\n  ) | @tsv\n'",
      "Here's a simple solution that does not depend on the structure of the JSON\n\ndef unroll:\n    if type == \"object\" \n    then [.[] | scalars] + ((.[] | iterables | unroll) // [] ) \n    elif type == \"array\" \n    then (.[] | unroll)\n    else [.] \n    end;\n    \nunroll | @tsv"
    ],
    "utterance": "Produce a flat list where each line contains all scalar values from the root to each leaf in the structure, with parent values repeated for paths to nested values, without printing any keys, for structures of arbitrary depth.",
    "expressions": [
      ".results[] | [.id, .name] + (.branches[] | [.id, .city] + (.customers[] | [.id, .name])) | @tsv",
      "def unroll:\n    if type == \"object\" \n    then [.[] | scalars] + ((.[] | iterables | unroll) // [] ) \n    elif type == \"array\" \n    then (.[] | unroll)\n    else [.] \n    end;\nunroll | @tsv"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "id": 306,
              "name": "First Company",
              "branches": [
                {
                  "id": 4191,
                  "city": "Seattle",
                  "customers": [
                    {
                      "id": 446,
                      "name": "Big Tech 1"
                    },
                    {
                      "id": 447,
                      "name": "Big Tech 2"
                    }
                  ]
                },
                {
                  "id": 4192,
                  "city": "Oakland",
                  "customers": [
                    {
                      "id": 448,
                      "name": "Health Tech 1"
                    },
                    {
                      "id": 449,
                      "name": "Health Tech 2"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "306\tFirst Company\t4191\tSeattle\t446\tBig Tech 1",
          "306\tFirst Company\t4191\tSeattle\t447\tBig Tech 2",
          "306\tFirst Company\t4192\tOakland\t448\tHealth Tech 1",
          "306\tFirst Company\t4192\tOakland\t449\tHealth Tech 2"
        ]
      }
    ],
    "identifier": 77134418
  },
  {
    "context": [
      "These daily files should be merged into one json after filtering for the necessary info:",
      "- url (from name)",
      "- date (first value in \"uniqueSessions.distinct_count\")",
      "- number of page visits: (second value in \"uniqueSessions.distinct_count\")",
      "So far, I managed to boil down the files to the needed data elements as separate JSON objects using:  `type *.json | jq \".items[] | {url: .name, date: .metrics[][0][0], load: .metrics[][0][1]}\"`",
      "however, if I try to wrap it in square brackets (as tutorials suggest) to get a valid JSON,  I get one file with a bunch of arrays starting and ending where they did in the original files.",
      "How can I make this into one JSON instead of as many arrays as many source files?",
      "For multiple input files, you can create another array around all of them using the `--slurp` (or `-s` option), then use `map` on that:",
      "jq -s 'map(.items[] | {...})' *.json",
      "Adding `|jq -s` to what you already have should work: ",
      "type *.json | \njq \".items[] | {url: .name, date: .metrics[][0][0], load: .metrics[][0][1]}\" |\njq -s "
    ],
    "utterance": "Combine all daily files so that the result is a single array of objects, each containing the page URL, the corresponding date, and load value, extracted as: url from name, date as the first value in uniqueSessions.distinct_count, and load as the second value in uniqueSessions.distinct_count.",
    "expressions": [
      "jq -s 'map(.items[] | {url: .name, date: .metrics[\"uniqueSessions.distinct_count\"][0][0], load: .metrics[\"uniqueSessions.distinct_count\"][0][1]})' *.json",
      "type *.json | jq \".items[] | {url: .name, date: .metrics[][0][0], load: .metrics[][0][1]}\" | jq -s"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "name": "page1.htm",
              "earliestTimestamp": 1675222177839,
              "cursor": {
                "@class": ".IngestionOffsetCursor",
                "ingestionTime": 1675292168217,
                "offset": 1
              },
              "metrics": {
                "uniqueSessions.distinct_count": [
                  [
                    1675292400000,
                    4.0
                  ]
                ]
              }
            },
            {
              "name": "page2.htm",
              "earliestTimestamp": 1675260035165,
              "cursor": {
                "@class": ".IngestionOffsetCursor",
                "ingestionTime": 1675292168217,
                "offset": 2
              },
              "metrics": {
                "uniqueSessions.distinct_count": [
                  [
                    1675292400000,
                    1.0
                  ]
                ]
              }
            }
          ],
          "canLoadMore": false,
          "totalHits": 12,
          "totalRepresentedItemCount": 12,
          "totalRetainedItemCount": 12,
          "adjustedTimeframe": {
            "windowSize": 86400000,
            "to": 1675292400000
          }
        },
        "output": [
          {
            "url": "page1.htm",
            "date": 1675292400000,
            "load": 4.0
          },
          {
            "url": "page2.htm",
            "date": 1675292400000,
            "load": 1.0
          }
        ]
      }
    ],
    "identifier": 77120085
  },
  {
    "context": [
      "Need to return payload.* json path where condition payload.*.*.cities.name = city_x matches.",
      "This keeps all those fields under `.payload` that have at least one path `.[].cities[].name` that is resolvable and evaluates to `\"city_x\"`. Consequently, other fields are removed.",
      ".payload |= with_entries(select(IN(.value[].cities?[]?.name; \"city_x\")))",
      "Here's an approach that will keep only those books that have `cities[].name` somewhere in their descendants that equals `city_x`",
      ".payload[] |= select( [ .. | if (type == \"object\" and has(\"cities\"))  then (.cities[] | .name == \"city_x\")  else false  end ] | any )",
      "A little more modular approach ([demo][2]):",
      "def criteria($city): [ .. | if (type == \"object\" and has(\"cities\")) then (.cities[] | .name == $city) else false end ] | any;  .payload[] |= select( criteria(\"city_x\") )"
    ],
    "utterance": "Return all items under payload where any descendant object contains a cities array with a city named city_x.",
    "expressions": [
      ".payload |= with_entries(select(IN(.value[].cities?[]?.name; \"city_x\")))",
      ".payload[] |= select( [ .. | if (type == \"object\" and has(\"cities\")) then (.cities[] | .name == \"city_x\") else false end ] | any )",
      "def criteria($city): [ .. | if (type == \"object\" and has(\"cities\")) then (.cities[] | .name == $city) else false end ] | any; .payload[] |= select( criteria(\"city_x\") )"
    ],
    "data": [
      {
        "input": {
          "payload": {
            "book1": {
              "isbn": "123-456-2221",
              "author": {
                "lastname": "Doe",
                "firstname": "Jane"
              },
              "editor": {
                "lastname": "Smith",
                "firstname": "Jane"
              },
              "title": "The Ultimate Database Study Guide",
              "category": [
                "Non-Fiction",
                "Technology"
              ],
              "sellerid1": {
                "name": "sellerid1",
                "cities": [
                  {
                    "name": "city_a",
                    "sellcount": 100
                  },
                  {
                    "name": "city_y",
                    "sellcount": 200
                  }
                ]
              },
              "sellerid2": {
                "name": "sellerid2",
                "cities": [
                  {
                    "name": "city_a",
                    "sellcount": 10
                  },
                  {
                    "name": "city_b",
                    "sellcount": 15
                  }
                ]
              }
            },
            "book2": {
              "isbn": "123-456-222",
              "author": {
                "lastname": "Doe",
                "firstname": "Jane"
              },
              "editor": {
                "lastname": "Smith",
                "firstname": "Jane"
              },
              "title": "C programming guide",
              "category": [
                "Programming",
                "Technology"
              ],
              "sellerid3": {
                "name": "sellerid3",
                "cities": [
                  {
                    "name": "city_a",
                    "sellcount": 100
                  },
                  {
                    "name": "city_b",
                    "sellcount": 200
                  }
                ]
              },
              "sellerid4": {
                "name": "sellerid4",
                "cities": [
                  {
                    "name": "city_a",
                    "sellcount": 10
                  },
                  {
                    "name": "city_x",
                    "sellcount": 15
                  }
                ]
              }
            }
          }
        },
        "output": {
          "payload": {
            "book2": {
              "isbn": "123-456-222",
              "author": {
                "lastname": "Doe",
                "firstname": "Jane"
              },
              "editor": {
                "lastname": "Smith",
                "firstname": "Jane"
              },
              "title": "C programming guide",
              "category": [
                "Programming",
                "Technology"
              ],
              "sellerid3": {
                "name": "sellerid3",
                "cities": [
                  {
                    "name": "city_a",
                    "sellcount": 100
                  },
                  {
                    "name": "city_b",
                    "sellcount": 200
                  }
                ]
              },
              "sellerid4": {
                "name": "sellerid4",
                "cities": [
                  {
                    "name": "city_a",
                    "sellcount": 10
                  },
                  {
                    "name": "city_x",
                    "sellcount": 15
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 77101024
  },
  {
    "context": [
      "I would like to group this by country and in two levels, one having the H1 and H2 entries, and the other having the H3 and H4 entries. Furthermore, I would like that ids and levels to be encapsulated in an object called \"entities\" like follows:",
      "Provide `group_by` with two criteria: one is simply the value of `.country`, the other is the containedness of `.level` in a given set of values (here, using `IN` with `H1` and `H2`, which evaluates to a boolean). After the grouping, use a `map` to rectify the shapes of the individual groups as desired.",
      ".hits |= (\n  group_by(.country, IN(.level; \"H1\", \"H2\")) \n  | map((first | {country}) + {entities: map({id, level})})\n)",
      "we can accommodate an arbitrary complex grouping criteria as follows ([demo][3]):\n```jq\ndef transform:\n  if    . == \"H1\" then 1\n  elif  . == \"H2\" then 1\n  elif  . == \"H3\" then 2\n  elif  . == \"H4\" then 2\n  else  3\n  end;\n\n.hits |= [\n group_by(.country, (.level | transform)) []\n | { country : first.country, entities: [.[] | del(.country) ] }\n]\n```"
    ],
    "utterance": "Group 'hits' entries first by country, then into two sets: those where level is H1 or H2, and those where level is H3 or H4; for each group, output the country and an 'entities' array with id and level.",
    "expressions": [
      ".hits |= (\n  group_by(.country, IN(.level; \"H1\", \"H2\")) \n  | map((first | {country}) + {entities: map({id, level})})\n)",
      ".hits |= [\n  group_by(.country, (.level == \"H1\" or .level == \"H2\")) []\n  | { country : first.country, entities: [.[] | { level, id }] }\n]",
      "def transform:\n  if    . == \"H1\" then 1\n  elif  . == \"H2\" then 1\n  elif  . == \"H3\" then 2\n  elif  . == \"H4\" then 2\n  else  3\n  end;\n\n.hits |= [\n group_by(.country, (.level | transform)) []\n | { country : first.country, entities: [.[] | del(.country) ] }\n]"
    ],
    "data": [
      {
        "input": {
          "hits": [
            {
              "country": "PT",
              "level": "H2",
              "id": "id1"
            },
            {
              "country": "PT",
              "level": "H1",
              "id": "id2"
            },
            {
              "country": "CZ",
              "level": "H2",
              "id": "id3"
            },
            {
              "country": "IT",
              "level": "H2",
              "id": "id4"
            },
            {
              "country": "PT",
              "level": "H3",
              "id": "id5"
            },
            {
              "country": "PT",
              "level": "H3",
              "id": "id6"
            },
            {
              "country": "PT",
              "level": "H4",
              "id": "id7"
            }
          ]
        },
        "output": {
          "hits": [
            {
              "country": "CZ",
              "entities": [
                {
                  "id": "id3",
                  "level": "H2"
                }
              ]
            },
            {
              "country": "IT",
              "entities": [
                {
                  "id": "id4",
                  "level": "H2"
                }
              ]
            },
            {
              "country": "PT",
              "entities": [
                {
                  "id": "id5",
                  "level": "H3"
                },
                {
                  "id": "id6",
                  "level": "H3"
                },
                {
                  "id": "id7",
                  "level": "H4"
                }
              ]
            },
            {
              "country": "PT",
              "entities": [
                {
                  "id": "id1",
                  "level": "H2"
                },
                {
                  "id": "id2",
                  "level": "H1"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 77108105
  },
  {
    "context": [
      "I want to filter this with `jq` so that:",
      "1. Endpoints that are not tagged as public are removed;",
      "2. Other parts of the OpenAPI spec are left as they are;",
      "3. Optionally, the `public` tag is removed.",
      "Here&#39;s a solution that works regardless of the name of the HTTP verb ([demo][1]):",
      "```jq\r\n  (.paths[][] |= select( [.tags[] | . == \"public\"] | any ) ) \r\n| (.paths[]   |= select( (. | length) > 0 )) \r\n| (.paths[][].tags[] |= select( . != \"public\" )) \r\n```",
      "paths |= with_entries(select(.value.get?.tags[] | contains(\"public\")))",
      "paths |= with_entries(select(.value.get?.tags[] | contains(\"public\")) | .value.get.tags |= map(select(. != \"public\")))"
    ],
    "utterance": "Keep only endpoints whose operations are tagged with \"public\", leaving the rest of the spec unchanged, and optionally remove the \"public\" tag from each operation's tags array.",
    "expressions": [
      ".paths |= with_entries(select(.value.get?.tags[] | contains(\"public\")))",
      ".paths |= with_entries(select(.value.get?.tags[] | contains(\"public\")) | .value.get.tags |= map(select(. != \"public\")))",
      "(.paths[][] |= select([.tags[] | . == \"public\"] | any)) | (.paths[] |= select((. | length) > 0)) | (.paths[][].tags[] |= select(. != \"public\"))",
      "(.paths[][] |= select([.tags[] | . == \"public\"] | any)) | (.paths[] |= select((. | length) > 0))"
    ],
    "data": [
      {
        "input": {
          "openapi": "3.0.3",
          "info": {
            "title": "Test OpenAPI specification",
            "version": "1.0.0"
          },
          "servers": [
            {
              "url": "example.com"
            }
          ],
          "paths": {
            "/public": {
              "get": {
                "operationId": "publicOperation",
                "summary": "Public operation",
                "description": "This is a public operation that should appear in the public-facing OpenAPI spec",
                "tags": [
                  "System",
                  "public"
                ],
                "parameters": [],
                "security": [
                  {
                    "Authorization": []
                  }
                ],
                "responses": {
                  "200": {
                    "description": "Successful response",
                    "content": {
                      "application/json": {
                        "schema": {
                          "type": "string",
                          "enum": [
                            "OK"
                          ]
                        }
                      }
                    }
                  },
                  "default": {
                    "$ref": "#/components/responses/error"
                  }
                }
              }
            },
            "/private": {
              "get": {
                "operationId": "privateOperation",
                "summary": "Private operation",
                "description": "This is a private operation that should not appear in the public OpenAPI",
                "tags": [
                  "System",
                  "private"
                ],
                "parameters": [],
                "security": [
                  {
                    "Authorization": []
                  }
                ],
                "responses": {
                  "200": {
                    "description": "Successful response",
                    "content": {
                      "application/json": {
                        "schema": {
                          "type": "string",
                          "enum": [
                            "OK"
                          ]
                        }
                      }
                    }
                  },
                  "default": {
                    "$ref": "#/components/responses/error"
                  }
                }
              }
            },
            "/neither": {
              "get": {
                "operationId": "neitherPublicNorPrivate",
                "summary": "Neither public nor private",
                "description": "This operation is not tagged as either public or private and it should not appear in the pulic-facing OpenAPI spec",
                "tags": [
                  "System"
                ],
                "parameters": [],
                "security": [
                  {
                    "Authorization": []
                  }
                ],
                "responses": {
                  "200": {
                    "description": "Successful response",
                    "content": {
                      "application/json": {
                        "schema": {
                          "type": "string",
                          "enum": [
                            "OK"
                          ]
                        }
                      }
                    }
                  },
                  "default": {
                    "$ref": "#/components/responses/error"
                  }
                }
              }
            }
          },
          "components": {
            "securitySchemes": {
              "Authorization": {
                "type": "http",
                "scheme": "bearer"
              }
            },
            "responses": {
              "error": {
                "description": "Error response",
                "content": {
                  "application/json": {
                    "schema": {
                      "type": "object",
                      "properties": {
                        "message": {
                          "type": "string"
                        },
                        "code": {
                          "type": "string"
                        },
                        "issues": {
                          "type": "array",
                          "items": {
                            "type": "object",
                            "properties": {
                              "message": {
                                "type": "string"
                              }
                            },
                            "required": [
                              "message"
                            ],
                            "additionalProperties": false
                          }
                        }
                      },
                      "required": [
                        "message",
                        "code"
                      ],
                      "additionalProperties": false
                    }
                  }
                }
              }
            }
          }
        },
        "output": {
          "openapi": "3.0.3",
          "info": {
            "title": "Test OpenAPI specification",
            "version": "1.0.0"
          },
          "servers": [
            {
              "url": "example.com"
            }
          ],
          "paths": {
            "/public": {
              "get": {
                "operationId": "publicOperation",
                "summary": "Public operation",
                "description": "This is a public operation that should appear in the public-facing OpenAPI spec",
                "tags": [
                  "System"
                ],
                "parameters": [],
                "security": [
                  {
                    "Authorization": []
                  }
                ],
                "responses": {
                  "200": {
                    "description": "Successful response",
                    "content": {
                      "application/json": {
                        "schema": {
                          "type": "string",
                          "enum": [
                            "OK"
                          ]
                        }
                      }
                    }
                  },
                  "default": {
                    "$ref": "#/components/responses/error"
                  }
                }
              }
            }
          },
          "components": {
            "securitySchemes": {
              "Authorization": {
                "type": "http",
                "scheme": "bearer"
              }
            },
            "responses": {
              "error": {
                "description": "Error response",
                "content": {
                  "application/json": {
                    "schema": {
                      "type": "object",
                      "properties": {
                        "message": {
                          "type": "string"
                        },
                        "code": {
                          "type": "string"
                        },
                        "issues": {
                          "type": "array",
                          "items": {
                            "type": "object",
                            "properties": {
                              "message": {
                                "type": "string"
                              }
                            },
                            "required": [
                              "message"
                            ],
                            "additionalProperties": false
                          }
                        }
                      },
                      "required": [
                        "message",
                        "code"
                      ],
                      "additionalProperties": false
                    }
                  }
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 77096165
  }
]