[
  {
    "context": [
      "I want to clear all values from \"`dependencies`\" by using `jq`:",
      "Here is the expected output:\r\n\r\n    {\r\n      \"name\": \"hello\",\r\n      \"dependencies\": {\r\n        \"progress\": \"\",\r\n        \"tar\": \"\"\r\n      }\r\n    }",
      "It only converts the object to an array, but I want it still as object and only clear all values inside all keys.",
      "$ echo $json_string | jq '.dependencies |= map_values(\"\")'",
      "jq '.dependencies[] = \"\"' <<< \"$json_string\""
    ],
    "utterance": "Set all values in the dependencies object to an empty string, keeping its keys unchanged.",
    "expressions": [
      ".dependencies |= map_values(\"\")",
      ".dependencies[] = \"\""
    ],
    "data": [
      {
        "input": {
          "name": "hello",
          "dependencies": {
            "progress": "^2.0.0",
            "tar": "^6.2.1"
          }
        },
        "output": {
          "name": "hello",
          "dependencies": {
            "progress": "",
            "tar": ""
          }
        }
      }
    ],
    "identifier": 79626225
  },
  {
    "context": [
      "ISSUE 1 : (NOT SOLVE YET)\r\n\r\n`.[] | select(.[\"NetworkInterfaces\"] | .[] | select(.[\"NetworkInterfaceId\"] | IN(\"eni-1\", \"eni-3\") | not)) | .[\"InstanceId\"] // empty` => return ```\"i-1\"\r\n\"i-2\"\r\n\"i-3\"\r\n\"i-3\"``` which is NOT what I want. I would like it returns only ```\"i-3\"```. How do I fix this query?"
    ],
    "utterance": "Return the InstanceId of objects whose all NetworkInterfaceId values are not 'eni-1' or 'eni-3'.",
    "expressions": [
      ".[] | select((.[\"NetworkInterfaces\"][] | .[\"NetworkInterfaceId\"] | IN(\"eni-1\", \"eni-3\")) | not) | .[\"InstanceId\"]",
      ".[] | select(all(.NetworkInterfaces[]; .NetworkInterfaceId | IN(\"eni-1\", \"eni-3\") | not)) | .InstanceId"
    ],
    "data": [
      {
        "input": [
          {
            "NetworkInterfaces": [
              {
                "NetworkInterfaceId": "eni-1"
              },
              {
                "NetworkInterfaceId": "eni-2"
              }
            ],
            "InstanceId": "i-1"
          },
          {
            "NetworkInterfaces": [
              {
                "NetworkInterfaceId": "eni-3"
              },
              {
                "NetworkInterfaceId": "eni-4"
              }
            ],
            "InstanceId": "i-2"
          },
          {
            "NetworkInterfaces": [
              {
                "NetworkInterfaceId": "eni-5"
              },
              {
                "NetworkInterfaceId": "eni-6"
              }
            ],
            "InstanceId": "i-3"
          }
        ],
        "output": "i-3"
      }
    ],
    "identifier": 79617276
  },
  {
    "context": [
      "Using jq, I want to assign an incrementing number `num` to each element in the order they appear in the input, but keep the same number for elements that share a `ref` value with other elements.",
      "So considering this input,\n[\n  {\"ref\": \"e13bb9\", \"name\": \"One\"},\n  {\"ref\": \"11b8cc\", \"name\": \"Two\"},\n  {\"ref\": \"e13bb9\", \"name\": \"Three\"}\n]\nI would want the following output:\n[\n  {\"ref\": \"e13bb9\", \"name\": \"One\", \"num\": 0},\n  {\"ref\": \"11b8cc\", \"name\": \"Two\", \"num\": 1},\n  {\"ref\": \"e13bb9\", \"name\": \"Three\", \"num\": 0}\n]",
      "I tried to use `group_by(.ref)` to group the elements with the same `ref` together, but that does not preserve the order in which they occur in the input",
      "reduce .[] as $x ( {index: {}, result: [], n: -1};\n   $x.ref as $ref\n   | if .index[$ref]\n     then .result += [ $x + {num: .index[$ref]} ]\n     else .n += 1\n     | .index[$ref] = .n \n     | .result += [ $x + {num: .n} ]\n     end\n)\n| .result",
      "reduce .[] as $i ({};\n  .num |= (.[$i.ref] //= length) | .arr += [$i + {num: .num[$i.ref]}]\n) | .arr",
      "[\n  {\n    \"ref\": \"e13bb9\",\n    \"name\": \"One\",\n    \"num\": 0\n  },\n  {\n    \"ref\": \"11b8cc\",\n    \"name\": \"Two\",\n    \"num\": 1\n  },\n  {\n    \"ref\": \"e13bb9\",\n    \"name\": \"Three\",\n    \"num\": 0\n  }\n]"
    ],
    "utterance": "Assign an incrementing number num to each element in input order, so elements with the same ref value receive the same num as the first occurrence of that ref.",
    "expressions": [
      "reduce .[] as $x ( {index: {}, result: [], n: -1};\n   $x.ref as $ref\n   | if .index[$ref]\n     then .result += [ $x + {num: .index[$ref]} ]\n     else .n += 1\n     | .index[$ref] = .n \n     | .result += [ $x + {num: .n} ]\n     end\n)\n| .result",
      "reduce .[] as $i ({};\n  .num |= (.[$i.ref] //= length) | .arr += [$i + {num: .num[$i.ref]}]\n) | .arr"
    ],
    "data": [
      {
        "input": [
          {
            "ref": "e13bb9",
            "name": "One"
          },
          {
            "ref": "11b8cc",
            "name": "Two"
          },
          {
            "ref": "e13bb9",
            "name": "Three"
          }
        ],
        "output": [
          {
            "ref": "e13bb9",
            "name": "One",
            "num": 0
          },
          {
            "ref": "11b8cc",
            "name": "Two",
            "num": 1
          },
          {
            "ref": "e13bb9",
            "name": "Three",
            "num": 0
          }
        ]
      }
    ],
    "identifier": 79497997
  },
  {
    "context": [
      ".[] | select(.[\"PublicIpAddress\"] | IN(\"i1.i2.i3\",\"i10.i11.i12\")) | .[\"InstanceId\"] // empty",
      "Now I want to pass \"i1.i2.i3\",\"i10.i11.i12\" as a shell script variable but I don't know how.",
      "jq \\\n  --compact-output \\\n  --raw-output \\\n  \".[] | select(.[\\\"PublicIpAddress\\\"] | IN($input)) | .[\\\"InstanceId\\\"]\" \\\n  \"$data\"",
      "Use the `--args` flag with `jq`, and append all shell parameters with `$@`. This way, you can access them all using the `$ARGS.positional` array.",
      ".[] | select(IN(.PublicIpAddress; $ARGS.positional[])).InstanceId"
    ],
    "utterance": "List the InstanceId for all objects whose PublicIpAddress matches any of a set of given input values.",
    "expressions": [
      ".[] | select(IN(.PublicIpAddress; $ARGS.positional[])).InstanceId"
    ],
    "data": [
      {
        "input": [
          {
            "PublicIpAddress": "i1.i2.i3",
            "InstanceId": "o1.o2.o3"
          },
          {
            "PublicIpAddress": "i4.i5.i6",
            "InstanceId": "o4.o5.o6"
          },
          {
            "PublicIpAddress": "i7.i8.i9",
            "InstanceId": "o7.o8.o9"
          },
          {
            "PublicIpAddress": "i10.i11.i12",
            "InstanceId": "o10.o11.o12"
          }
        ],
        "output": [
          "o1.o2.o3",
          "o10.o11.o12"
        ]
      }
    ],
    "identifier": 79616141
  },
  {
    "context": [
      "How do I get the price for the actual hour? I have no clue how to insert the value of **$HOUR** into the jq query instead of the \"**6**\"",
      "As `HOUR` is a number, you can use `--argjson` instead of `--arg`. The (only) benefit is that you won't have to do the conversion from string to number yourself:",
      "jq --argjson hour \"$HOUR\" '.energy.todayHours[$hour].priceIncludingVat' < \"$JSON\""
    ],
    "utterance": "Output the value of 'priceIncludingVat' for the hour specified by the HOUR variable.",
    "expressions": [
      ".energy.todayHours[$hour].priceIncludingVat"
    ],
    "identifier": 79419250
  },
  {
    "context": [
      "Given the simplified input:\n\n```\n[\n  [ \"gpu\" ],\n  [ \"disk\" ]\n]\n```",
      "I would like to select the arrays for which the first element is `\"gpu\"`.",
      "I can do it with a simple condition:\n\n```sh\nmap(select(.[0] == \"gpu\"))\n```",
      "But I don't understand what's wrong when I try to use the `IN` builtin instead:\n\n```sh\nmap(select(.[0] | IN([\"gpu\"]))\n```",
      "Instead, compare `.[0]` with `\"gpu\"`:\n```sh\nmap(select(.[0] | IN(\"gpu\")))\n```",
      "```json\n[\n  [\n    \"gpu\"\n  ]\n]\n```"
    ],
    "utterance": "Select all arrays where the first element is equal to \"gpu\".",
    "expressions": [
      "map(select(.[0] == \"gpu\"))",
      "map(select(.[0] | IN(\"gpu\")))"
    ],
    "data": [
      {
        "input": [
          [
            "gpu"
          ],
          [
            "disk"
          ]
        ],
        "output": [
          [
            "gpu"
          ]
        ]
      }
    ],
    "identifier": 79259166
  },
  {
    "context": [
      "Now I tried to iterate over every json key and value in bash and output the corresponding string:",
      "jq 'to_entries[] | \"\\(.key)\\t\\(.value)\"' test.json | while IFS=$'\\t' read -r key value; do",
      "But the output is not split into key and value pairs:",
      "The problem seems to be that jq inserts the \\t character literally",
      "So how do I advise `jq` to output an actual tab character so that it can be split correctly by my bash `while read`?"
    ],
    "utterance": "Output each top-level key and value pair separated by an actual tab character (ASCII 0x09), not a literal \\t, so the output can be split into key and value in bash using read with IFS set to tab.",
    "expressions": [
      "to_entries[] | \"\t\" as $tab | \"\t\" | \"\t\" | \"\\(.key)\\u0009\\(.value)\"",
      "to_entries[] | \"\\(.key)\\t\\(.value)\" | @sh | gsub(\"\\\\t\"; \"\\t\") | fromjson",
      "to_entries[] | \"\\(.key)\\u0009\\(.value)\""
    ],
    "data": [
      {
        "input": {
          "api01": {
            "before": {
              "path": "api01",
              "user": "admin"
            }
          },
          "server01": {
            "before": {
              "path": "server01",
              "user": "admin"
            }
          },
          "server11": {
            "before": {
              "path": "server11",
              "user": "admin"
            }
          },
          "staging01": {
            "after": {
              "path": "/home/admin/test/user/dotfiles",
              "user": "git"
            },
            "before": {
              "path": "staging01",
              "user": "admin"
            }
          }
        },
        "output": [
          "api01\t{\"before\":{\"path\":\"api01\",\"user\":\"admin\"}}",
          "server01\t{\"before\":{\"path\":\"server01\",\"user\":\"admin\"}}",
          "server11\t{\"before\":{\"path\":\"server11\",\"user\":\"admin\"}}",
          "staging01\t{\"after\":{\"path\":\"/home/admin/test/user/dotfiles\",\"user\":\"git\"},\"before\":{\"path\":\"staging01\",\"user\":\"admin\"}}"
        ]
      }
    ],
    "identifier": 79643490
  },
  {
    "context": [
      "I would like to filter DNSNames where Id does not start with the DNSName.",
      "How can I filter out `9580cf2dd316` based in the `Id` `9580cf2dd3161c0e33d8c04a4e84384e28784af65e55c1e84899d9da797902be` so I get the following result?",
      ".[] | . as {$Id} | .NetworkSettings.Networks[].DNSNames | map(select(. != $Id[:length])) | join(\" \")",
      "Other approaches could be using a `startswith` test or checking for a substring search with `index` evaluating to `0`."
    ],
    "utterance": "Filter DNSNames to exclude any entry that matches the prefix of Id up to the DNSName length.",
    "expressions": [
      ".[] | . as {$Id} | .NetworkSettings.Networks[].DNSNames | map(select(. != $Id[:length])) | join(\" \")",
      ".[] | . as {$Id} | .NetworkSettings.Networks[].DNSNames | map(select(!$Id|startswith(.))) | join(\" \")"
    ],
    "data": [
      {
        "input": [
          {
            "Id": "9580cf2dd3161c0e33d8c04a4e84384e28784af65e55c1e84899d9da797902be",
            "NetworkSettings": {
              "Networks": {
                "nextcloud-aio": {
                  "IPAddress": "172.18.0.10",
                  "DNSNames": [
                    "nextcloud-aio-whiteboard",
                    "9580cf2dd316"
                  ]
                }
              }
            }
          }
        ],
        "output": "nextcloud-aio-whiteboard"
      }
    ],
    "identifier": 79708368
  },
  {
    "context": [
      "I want to transform this JSON\n{\n    \"property\": \"value\",\n    \"array1\": [\n        {\n            \"name\": \"A\",\n            \"propertyA1\": \"1\",\n            \"propertyA2\": \"2\"\n        },\n        {\n            \"name\": \"B\",\n            \"propertyB1\": \"1\",\n            \"array2\": [\n                {\n                    \"name\": \"C\",\n                    \"propertyC1\": \"1\",\n                    \"propertyC2\": \"2\"\n                }\n            ]\n        }\n    ]\n}\ninto that using a JQ filter.\n{\n    \"property\": \"value\",\n    \"array1\": {\n        \"A\": {\n            \"propertyA1\": \"1\",\n            \"propertyA2\": \"2\"\n        },\n        \"B\" : {\n            \"propertyB1\": \"1\",\n            \"array2\": {\n                \"C\" : {\n                    \"propertyC1\": \"1\",\n                    \"propertyC2\": \"2\"\n                }\n            }\n        }\n    }\n}",
      "The difficulty is to make this work recursively. Moreover, only arrays who\npossess an object with a property `name` should be considered.",
      "You basically want to turn each array into an object with each item's `.name` field turned into a key. You could use `from_entries` which requires each key and value as `.name` (or `.key`) and `.value` fields, so all you have to do is to set up a `.value` without the `.name` field. `walk` the document tree to apply this to each `array`.",
      "walk(arrays |= (map(.value = del(.name)) | from_entries))"
    ],
    "utterance": "Recursively convert array properties containing objects with a 'name' field into objects keyed by 'name', removing the 'name' property from the resulting values.",
    "expressions": [
      "walk(arrays |= (map(.value = del(.name)) | from_entries))"
    ],
    "data": [
      {
        "input": {
          "property": "value",
          "array1": [
            {
              "name": "A",
              "propertyA1": "1",
              "propertyA2": "2"
            },
            {
              "name": "B",
              "propertyB1": "1",
              "array2": [
                {
                  "name": "C",
                  "propertyC1": "1",
                  "propertyC2": "2"
                }
              ]
            }
          ]
        },
        "output": {
          "property": "value",
          "array1": {
            "A": {
              "propertyA1": "1",
              "propertyA2": "2"
            },
            "B": {
              "propertyB1": "1",
              "array2": {
                "C": {
                  "propertyC1": "1",
                  "propertyC2": "2"
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 79229599
  },
  {
    "context": [
      "I am trying to get some specific text from logcat. It could be repeating multiple times.",
      "I only care about what is within specificword. Note, the brackets could be empty, such as:",
      "And received something like the following:",
      "specificword=[SpecificWord(displayTimestamp=2024-06-01T00:00:00Z, LanguageCode=US English, ScreenId=ABC0-0, EventTime=2025-01-29T19:20:16.521Z)]",
      "specificword=[]",
      "Assuming:",
      "- The text of intetest may contain commas and matched (and possibly nested) square brackets.",
      "- The text may be empty.",
      "Then would you please try:",
      "grep -Po 'specificword=(\\[(?>[^][]|(?1))*\\])' test.txt"
    ],
    "utterance": "Extract each occurrence of 'specificword=[...]' (including nested brackets and empty brackets) from text lines.",
    "expressions": [
      "grep -Po 'specificword=(\\[(?>[^][]|(?1))*\\])'"
    ],
    "data": [
      {
        "input": "stateEventTime=2025-01-09T17:22:05.635Z)], specificword=[SpecificWord(displayTimestamp=2024-06-01T00:00:00Z, LanguageCode=US English, ScreenId=ABC0-0, EventTime=2025-01-29T19:20:16.521Z)], specificword=[], foo[](bar,baz), specificword=[this is some(of the possible[text]), including commas and paired [square] brackets]",
        "output": [
          "specificword=[SpecificWord(displayTimestamp=2024-06-01T00:00:00Z, LanguageCode=US English, ScreenId=ABC0-0, EventTime=2025-01-29T19:20:16.521Z)]",
          "specificword=[]",
          "specificword=[this is some(of the possible[text]), including commas and paired [square] brackets]"
        ]
      }
    ],
    "identifier": 79410149
  },
  {
    "context": [
      "I have JSON data that looks like this:\r\n[\r\n {\r\n  \"class\": \"class1\",\r\n  \"year\": \"year1\",\r\n  \"subject\": [ ... ]\r\n },\r\n ...\r\n]",
      "and I want an outcome of this:\r\n[\r\n {\r\n  \"year\": \"year1\"\r\n   \"subject\": [\r\n    { \"name\": \"maths\", \"unit\": \"vect\", \"amount\": 5.88 },\r\n    { \"name\": \"electronics\", \"unit\": \"laws\", \"amount\": 2.3 }\r\n   ]\r\n ...\r\n]",
      "Here\u2019s a somewhat simplified approach without variables, and using `map` to keep the outer array:\r\nmap({year, subject} | .subject[] |= (.module | {name, unit}) + {amount})"
    ],
    "utterance": "For each item, extract 'year' and a list of subjects where each subject includes only name, unit, and amount.",
    "expressions": [
      "map({year, subject} | .subject[] |= (.module | {name, unit}) + {amount})"
    ],
    "data": [
      {
        "input": [
          {
            "class": "class1",
            "year": "year1",
            "subject": [
              {
                "id": 7654,
                "type": "subject",
                "module": {
                  "id": 765,
                  "number": 654,
                  "name": "maths",
                  "unit": "vect"
                },
                "amount": 5.88
              },
              {
                "id": 7612,
                "type": "subject",
                "module": {
                  "id": 747,
                  "number": 234,
                  "name": "electronics",
                  "unit": "laws"
                },
                "amount": 2.3
              }
            ]
          },
          {
            "class": "class1",
            "year": "year2",
            "subject": [
              {
                "id": 8634,
                "type": "subject",
                "module": {
                  "id": 465,
                  "number": 253,
                  "name": "electronics",
                  "unit": "laws"
                },
                "amount": 12.51
              },
              {
                "id": 7654,
                "type": "subject",
                "module": {
                  "id": 765,
                  "number": 654,
                  "name": "maths",
                  "unit": "vect"
                },
                "amount": 4.44
              }
            ]
          }
        ],
        "output": [
          {
            "year": "year1",
            "subject": [
              {
                "name": "maths",
                "unit": "vect",
                "amount": 5.88
              },
              {
                "name": "electronics",
                "unit": "laws",
                "amount": 2.3
              }
            ]
          },
          {
            "year": "year2",
            "subject": [
              {
                "name": "electronics",
                "unit": "laws",
                "amount": 12.51
              },
              {
                "name": "maths",
                "unit": "vect",
                "amount": 4.44
              }
            ]
          }
        ]
      }
    ],
    "identifier": 79616915
  },
  {
    "context": [
      "I want to round any number in a JSON-Document, but I do not know where in the documents numbers are (but they are not keys).",
      "From this source:\r\n{\r\n  \"a\": -4e-12,\r\n  \"b\": {\r\n    \"c\": 0.999999999999997,\r\n    \"d\": 101.12222222222\r\n  }\r\n}",
      "I'd expect a result like:\r\n{\r\n  \"a\": 0,\r\n  \"b\": {\r\n    \"c\": 1,\r\n    \"d\": 101.12\r\n  }\r\n}",
      "You can walk through the json object, and if it is a number, multiply by 100, round, and then divide by 100. This will give two decimal positions (not two significant figures).",
      "jq 'walk(if type == \"number\" then (.* 100 | round / 100) else . end)' data.json",
      "Using the `QUERY |= TRANSFORM` pattern to obtain two decimal positions:",
      "jq '( .. | numbers ) |= ( . * 100 | round / 100 )'",
      "Or if you don't want negative zeroes,",
      "jq '( .. | numbers ) |= ( . * 100 | round / 100 + 0 )'"
    ],
    "utterance": "Round all numbers in a document to two decimal places, regardless of their location.",
    "expressions": [
      "walk(if type == \"number\" then (.* 100 | round / 100) else . end)",
      "( .. | numbers ) |= ( . * 100 | round / 100 )",
      "( .. | numbers ) |= ( . * 100 | round / 100 + 0 )"
    ],
    "data": [
      {
        "input": {
          "a": -4e-12,
          "b": {
            "c": 0.999999999999997,
            "d": 101.12222222222
          }
        },
        "output": {
          "a": 0,
          "b": {
            "c": 1,
            "d": 101.12
          }
        }
      }
    ],
    "identifier": 79426318
  },
  {
    "context": [
      "I need to extract the \"label\" and \"timestamp\" information for each block.",
      "You can directly extract, decode, and format the required fields from the data key while retrieving the data. This minimizes post-processing.",
      "jq -r '.resultSet[] | .data | fromjson | .'",
      "jq '.resultSet[] |\n    {\n      \"label\": (.data | fromjson | .label),\n      \"timestamp\": .timestamp\n    }\n'"
    ],
    "utterance": "Extract the label and timestamp fields from each entry, decoding the label from the nested data key.",
    "expressions": [
      ".resultSet[] | { \"label\": (.data | fromjson | .label), \"timestamp\": .timestamp }"
    ],
    "data": [
      {
        "input": {
          "resultSet": [
            {
              "identifier": "BVC9GYvsAwswBTfv4C2eziRZmZ6fUzrmMuvqv1VPdWG3",
              "dataContractIdentifier": "GWRSAVFMjXx8HpQFaNJMqBV7MBgMK4br5UESsB4S31Ec",
              "revision": 1,
              "txHash": "03CFE8DAB06ECCCDB1430F149041775263F85DF335046C0421449AA73A46B4DA",
              "deleted": false,
              "data": "{\"label\":\"BFWookie\",\"records\":{\"identity\":\"Ea8acQwhQbbdaTLytoTiedEkTA89A8dyFpn9jTivr4Ht\"},\"preorderSalt\":\"hwebwVCxW+MwBmIqhoYIibGd7s7GOihv+MU6ae8Jj70=\",\"subdomainRules\":{\"allowSubdomains\":false},\"normalizedLabel\":\"bfw00k1e\",\"parentDomainName\":\"dash\",\"normalizedParentDomainName\":\"dash\"}",
              "timestamp": "2024-10-23T05:40:07.923Z",
              "isSystem": false,
              "owner": "Ea8acQwhQbbdaTLytoTiedEkTA89A8dyFpn9jTivr4Ht"
            }
          ]
        },
        "output": {
          "label": "BFWookie",
          "timestamp": "2024-10-23T05:40:07.923Z"
        }
      }
    ],
    "identifier": 79221915
  },
  {
    "context": [
      "I need to delete a field `.xxx` from an object at any depth of the tree where another field `.myfield` matches a regex.",
      "You can use `(.myfield | test(\"my regexp\"))` in a conditional just as you can use `.myfield == \"my content\"`.",
      "walk(if type == \"object\" and (.myfield | type) == \"string\" and (.myfield | test(\"my regexp\")) then del(.xxx) else . end)"
    ],
    "utterance": "Delete the field .xxx from every object at any depth where .myfield is a string that matches the regular expression \"my regexp\".",
    "expressions": [
      "walk(if type == \"object\" and (.myfield | type) == \"string\" and (.myfield | test(\"my regexp\")) then del(.xxx) else . end)"
    ],
    "data": [
      {
        "input": {
          "structure": {
            "test-match": {
              "myfield": "content that matches my regexp",
              "xxx": "this should be deleted"
            },
            "test-nomatch": {
              "myfield": "content that DOES NOT match the active expression",
              "xxx": "this should not be deleted"
            },
            "test-invalid": {
              "state": "no myfield exists at all",
              "xxx": "this should not be deleted"
            }
          }
        },
        "output": {
          "structure": {
            "test-match": {
              "myfield": "content that matches my regexp"
            },
            "test-nomatch": {
              "myfield": "content that DOES NOT match the active expression",
              "xxx": "this should not be deleted"
            },
            "test-invalid": {
              "state": "no myfield exists at all",
              "xxx": "this should not be deleted"
            }
          }
        }
      }
    ],
    "identifier": 79230976
  },
  {
    "context": [
      "I see the string literal of the variable (valorAPoner) but  I need the value of the variable.",
      "jq -r '.Authentication.ExternalProvider.LdapUserAndDomain |= \"$valorAPoner\"' $i > \"$tmp\" && mv \"$tmp\" $i.json;"
    ],
    "utterance": "Set the value of Authentication.ExternalProvider.LdapUserAndDomain to the content of a shell variable in a loop over files.",
    "expressions": [
      "jq --arg v \"$valorAPoner\" '.Authentication.ExternalProvider.LdapUserAndDomain = $v' \"$i\" > \"$tmp\" && mv \"$tmp\" \"$i.json\""
    ],
    "identifier": 79171538
  },
  {
    "context": [
      "I\u2019d like to get a csv/prettyprint output from the following `json`.",
      "Something along the lines of:",
      "id,name,address\n101121,hostnamefromgateway,192.168.30.130\n101128,micetro-central,10.244.134.219\n101144,testingdhcp,191.168.200.242\n101103,test,{}\n101037,external.com,[]\n101038,hey.dbacevic.com,[]\n...",
      "Is there a way to achieve what I need while only resorting to CLI and not some third party UI websites?",
      "Here\u2019s an approach using `jq` with `@csv`:",
      "jq -r '.data[] | [.id, .name, ._embedded.addresses[0].address] | @csv'",
      "To add a header line, prepend it statically, e.g. as '[\"id\", \"name\", \"address\"], (.data[] | [.id, .name, ._embedded.addresses[0].address]) | @csv'.",
      "To print literally '{}' or '[]' if traversing the path '._embedded.addresses[0].address' fails at some point, you could use the '//' operator to provide alternatives, and '@json' to transform such empty container into a JSON-encoded string. Replace the traversal with '(._embedded.addresses[0].address // ._embedded.addresses // ._embedded | strings // @json)'."
    ],
    "utterance": "Produce a CSV with columns id, name, and the first item's address from _embedded.addresses, with empty objects or arrays rendered as '{}' or '[]' for missing address data.",
    "expressions": [
      "[\"id\", \"name\", \"address\"], (.data[] | [.id, .name, (._embedded.addresses[0].address // ._embedded.addresses // ._embedded | strings // @json)]) | @csv"
    ],
    "data": [
      {
        "input": {
          "count": 28,
          "data": [
            {
              "id": 100920,
              "name": "bam",
              "_embedded": {
                "addresses": [
                  {
                    "address": "10.244.134.115"
                  }
                ]
              }
            },
            {
              "id": 101037,
              "name": "external.com",
              "_embedded": {
                "addresses": []
              }
            },
            {
              "id": 101020,
              "name": "something",
              "_embedded": {}
            }
          ]
        },
        "output": "id,name,address\n100920,bam,10.244.134.115\n101037,external.com,[]\n101020,something,{}\n"
      }
    ],
    "identifier": 79641106
  },
  {
    "context": [
      "How would return an array sorted by some non-alphabetic arbitrary order (e.g dogs, birds and then cats)?",
      "It's easier (and faster) to use an object for the order:\n\n    jq --argjson order '{\"dog\":0, \"bird\":1, \"cat\":2}' \\\n        '. | sort_by($order[.entityType])'",
      "But if you insist:\n\n    jq --argjson order '[\"dog\", \"bird\", \"cat\"]' \\\n        '. | sort_by(.entityType as $type | ($order | index($type)))'",
      "If you want to keep your `order` argument an array, sort by turning it into an implicit boolean array of matches. Note that `false` will be ordered before `true`, so use `!=` to \"mismatch\" the items.\n```sh\njq --argjson order '[\"dog\", \"bird\", \"cat\"]' 'sort_by(.entityType != $order[])'\n```",
      "Alternatively, provide the order as single arguments using the `--args` option and the `$ARGS.positional` array:\n```sh\njq 'sort_by(.entityType != $ARGS.positional[])' data.json --args dog bird cat\n```",
      "If the order is defined by an array, then for efficiency it would typically be worthwhile converting the array to a dictionary along the lines suggested by @choroba:\n```\n< input.json jq --argjson order '[\"dog\", \"bird\", \"cat\"]' '\n   INDEX( $order | to_entries[]; .value ) as $dict\n   | sort_by( $dict[.entityType] )\n'\n```"
    ],
    "utterance": "Return the array sorted by entityType, in the order: dog, bird, cat.",
    "expressions": [
      ". | sort_by($order[.entityType])",
      ". | sort_by(.entityType as $type | ($order | index($type)))",
      "sort_by(.entityType != $order[])",
      "sort_by(.entityType != $ARGS.positional[])",
      "INDEX($order | to_entries[]; .value) as $dict | sort_by($dict[.entityType])"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "entityType": "cat"
          },
          {
            "id": 2,
            "entityType": "dog"
          },
          {
            "id": 3,
            "entityType": "bird"
          },
          {
            "id": 4,
            "entityType": "cat"
          }
        ],
        "output": [
          {
            "id": 2,
            "entityType": "dog"
          },
          {
            "id": 3,
            "entityType": "bird"
          },
          {
            "id": 1,
            "entityType": "cat"
          },
          {
            "id": 4,
            "entityType": "cat"
          }
        ]
      }
    ],
    "identifier": 79267652
  },
  {
    "context": [
      "I am working on a `jq` utility on Linux to process JSON file and convert it into a CSV format. I have the following JSON with multi-level hierarchy which I want to flatten into CSV:",
      "I would like to see the CSV in the following output: ",
      "taskId, jobs.runId, jobs.startTime, jobs.endTime, jobs.status, jobs.fileDetails.path, jobs.fileDetails.transferDirection",
      "Descend into the respective parts of the document, and create an array of values, which can then be passed to `@csv`. Use the `-r` flag to strip the JSON encoding.",
      ".jobActivityLog[] | . as {$taskId} | .jobs[] | .fileDetails[] as $fd | [\n  $taskId, .runId, .startTime, .endTime, .status,\n  $fd.path, $fd.transferDirection\n] | @csv"
    ],
    "utterance": "Extract rows containing taskId, jobs.runId, jobs.startTime, jobs.endTime, jobs.status, jobs.fileDetails.path, and jobs.fileDetails.transferDirection from nested log structure as CSV records.",
    "expressions": [
      ".jobActivityLog[] | . as {$taskId} | .jobs[] | .fileDetails[] as $fd | [ $taskId, .runId, .startTime, .endTime, .status, $fd.path, $fd.transferDirection ] | @csv"
    ],
    "data": [
      {
        "input": {
          "totalJobCount": 13,
          "jobActivityLog": [
            {
              "taskId": "gNngdUm4p0WfBDKHJqQ2S8",
              "jobs": [
                {
                  "runId": 63750,
                  "startedBy": "svc-ctmagent",
                  "startTime": "2025-05-04T19:03:48Z",
                  "endTime": "2025-05-04T19:03:50Z",
                  "status": "SUCCESS",
                  "logLocation": "26.1.1/../data/taskLogs/2025-05-04/1000007899913.log",
                  "messageText": "Job completed normally",
                  "successFiles": 1,
                  "failedFiles": 0,
                  "fileDetails": [
                    {
                      "path": "/in/finance/ALL_GL_AHCS/2025/05/04/XlaTransaction_ALL_20250504T1902314697.zip",
                      "size": 17172,
                      "lastModified": "2025-05-04T19:02:32Z",
                      "startTime": "2025-05-04T19:03:49Z",
                      "status": "SUCCESS",
                      "duration": 390,
                      "transferDirection": "UPLOAD"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": "\"gNngdUm4p0WfBDKHJqQ2S8\",63750,\"2025-05-04T19:03:48Z\",\"2025-05-04T19:03:50Z\",\"SUCCESS\",\"/in/finance/ALL_GL_AHCS/2025/05/04/XlaTransaction_ALL_20250504T1902314697.zip\",\"UPLOAD\""
      }
    ],
    "identifier": 79607007
  },
  {
    "context": [
      "echo \"$response\" | jq -e --arg TAG \"$TAG\" '.[]|select(.tags[].name==$TAG)' > /dev/null",
      "echo $response | jq -e . >/dev/null 2>&1  ; echo ${PIPESTATUS[1]}"
    ],
    "utterance": "Check if any object in the array has a tag with the specified name equal to the given value.",
    "expressions": [
      ".[]|select(.tags[].name==$TAG)"
    ],
    "identifier": 79208308
  },
  {
    "context": [
      "How to make `jq` ignore the duplicated items when it already existed in the array?",
      "jq '.bundleDependencies |= unique'",
      "If `bundleDependencies` is already populated, you can use this:",
      "jq \".bundleDependencies = ((.dependencies + .devDependencies | keys) + .bundleDependencies | unique)\""
    ],
    "utterance": "Ensure bundleDependencies contains only unique values, even after adding dependencies and devDependencies multiple times",
    "expressions": [
      ".bundleDependencies |= unique",
      ".bundleDependencies = ((.dependencies + .devDependencies | keys) + .bundleDependencies | unique)"
    ],
    "data": [
      {
        "input": {
          "name": "hello",
          "dependencies": {
            "progress": "^2.0.0",
            "tar": "^6.2.1"
          },
          "devDependencies": {
            "node-fetch": "~2.6.1",
            "yargs": "^16.2.0"
          },
          "bundleDependencies": [
            "progress",
            "tar",
            "node-fetch",
            "yargs",
            "node-fetch",
            "yargs"
          ]
        },
        "output": {
          "name": "hello",
          "dependencies": {
            "progress": "^2.0.0",
            "tar": "^6.2.1"
          },
          "devDependencies": {
            "node-fetch": "~2.6.1",
            "yargs": "^16.2.0"
          },
          "bundleDependencies": [
            "node-fetch",
            "progress",
            "tar",
            "yargs"
          ]
        }
      }
    ],
    "identifier": 79628235
  },
  {
    "context": [
      "I would like to filter it using jq get a `\"connection.(value?)\": \"connection.(value?).connected\"` report using only command-line tools:",
      "{ \"7MXYADN-WDXFLSC-3JBG57R-JHZXXYP-ZROJDED-YFQYNCL-WTHPSOQ-KHOLXAP\": false, \"QYMGEAI-FXM6I6W-FQ574FL-XABEKPV-VK5M42T-AQ7TERD-VVEJ2F7-SFSRYQG\": false }",
      "Use [`with_entries`][1] to update the `.value` of the object to the value of `.connected`:",
      ".connections | with_entries(.value = .value.connected)",
      "You can use `map_values` :",
      "jq '.connections | map_values(.connected)' input.json",
      "Here's how to tweak your original code (incase you were wondering):",
      "jq '[{ key: .connections | keys[], value: .connections[].connected }] | from_entries'"
    ],
    "utterance": "Produce an object mapping each connection key to its corresponding connected value.",
    "expressions": [
      ".connections | with_entries(.value = .value.connected)",
      ".connections | map_values(.connected)",
      "[{ key: .connections | keys[], value: .connections[].connected }] | from_entries"
    ],
    "data": [
      {
        "input": {
          "connections": {
            "7MXYADN-WDXFLSC-3JBG57R-JHZXXYP-ZROJDED-YFQYNCL-WTHPSOQ-KHOLXAP": {
              "address": "",
              "at": "0001-01-01T00:00:00Z",
              "clientVersion": "",
              "connected": false,
              "crypto": "",
              "inBytesTotal": 0,
              "isLocal": false,
              "outBytesTotal": 0,
              "paused": false
            },
            "QYMGEAI-FXM6I6W-FQ574FL-XABEKPV-VK5M42T-AQ7TERD-VVEJ2F7-SFSRYQG": {
              "address": "",
              "at": "0001-01-01T00:00:00Z",
              "clientVersion": "",
              "connected": false,
              "crypto": "",
              "inBytesTotal": 0,
              "isLocal": false,
              "outBytesTotal": 0,
              "paused": false
            }
          }
        },
        "output": {
          "7MXYADN-WDXFLSC-3JBG57R-JHZXXYP-ZROJDED-YFQYNCL-WTHPSOQ-KHOLXAP": false,
          "QYMGEAI-FXM6I6W-FQ574FL-XABEKPV-VK5M42T-AQ7TERD-VVEJ2F7-SFSRYQG": false
        }
      }
    ],
    "identifier": 79418315
  },
  {
    "context": [
      "The problem I'm facing is that some MACs contain upper, some lower case letters, and I don't know ahead of time which machine uses which scheme. \nI can't figure out how to make the `==` case insensitive.",
      "To fix this, you can use `// \"\"` [doc link](https://jqlang.github.io/jq/manual/#alternative-operator) to default to the empty string, and *then* pass that through `ascii_downcase`:\n\n```\ngovc object.collect -json -type m / config.hardware.device \\\n  | jq -r '\n      .\n      | select(.ChangeSet[].Val.VirtualDevice[].MacAddress // \"\" | ascii_downcase == \"00:50:56:bc:5e:3c\")\n      | [.Obj.Type, .Obj.Value]\n      | join(\":\"))\n    '\n  | xargs govc ls -L\n```",
      "Each `\u2026[]` in `.ChangeSet[].Val.VirtualDevice[].MacAddress` creates a stream of potentially more than one result... If you want to reduce this stream to a binary decision (zero or one items only), use an aggregate function that performs this conversion. For example, if you want `select` to return with one item if at least one of them passes the test, use the `any` [function](https://jqlang.github.io/jq/manual/#any).",
      "select(any(\n  .ChangeSet[].Val.VirtualDevice[].MacAddress | strings;\n  ascii_downcase == \"00:50:56:bc:5e:3c\"\n))\n| [.Obj.Type, .Obj.Value]\n| join(\":\")",
      "Assuming that normalizing MacAddress to ascii_downcase would be sufficient,   one approach would be to add a pre-processing filter using `walk` like so:\n```\nwalk(if type == \"object\" and has(\"MacAddress\") \n     then .MacAddress |= ascii_downcase end)\n```"
    ],
    "utterance": "Filter the input so that only objects where any VirtualDevice MacAddress matches 00:50:56:bc:5e:3c, case-insensitively, are selected.",
    "expressions": [
      ". | select(.ChangeSet[].Val.VirtualDevice[].MacAddress // \"\" | ascii_downcase == \"00:50:56:bc:5e:3c\") | [.Obj.Type, .Obj.Value] | join(\":\")",
      "select(any(\n  .ChangeSet[].Val.VirtualDevice[].MacAddress | strings;\n  ascii_downcase == \"00:50:56:bc:5e:3c\"\n))\n| [.Obj.Type, .Obj.Value]\n| join(\":\")"
    ],
    "data": [
      {
        "input": {
          "Obj": {
            "Type": "VirtualMachine",
            "Value": "vm-666"
          },
          "ChangeSet": [
            {
              "Val": {
                "VirtualDevice": [
                  {},
                  {
                    "MacAddress": "00:50:56:bc:5e:3c"
                  }
                ]
              }
            }
          ]
        },
        "output": "VirtualMachine:vm-666"
      }
    ],
    "identifier": 79176022
  },
  {
    "context": [
      "I have a template JSON file like this:",
      "I need to replace the \"value\" of the \"body_t\" (which is set to TEST in the template).",
      "If you want to keep the original structure, I'd use:",
      "map(.fields[] |= (select(.name == \"body_t\").value |= \"Some value\"))",
      "[\n  {\n    \"fields\": [\n      {\n        \"name\": \"body_t\",\n        \"value\": \"Some value\"\n      }\n    ],\n    \"id\": \"abc123\"\n  }\n]"
    ],
    "utterance": "Replace the value field of the object with name equal to body_t inside fields while keeping the overall document structure.",
    "expressions": [
      "map(.fields[] |= (select(.name == \"body_t\").value |= \"Some value\"))"
    ],
    "data": [
      {
        "input": [
          {
            "fields": [
              {
                "name": "body_t",
                "value": "TEST"
              }
            ],
            "id": "abc123"
          }
        ],
        "output": [
          {
            "fields": [
              {
                "name": "body_t",
                "value": "Some value"
              }
            ],
            "id": "abc123"
          }
        ]
      }
    ],
    "identifier": 79204098
  },
  {
    "context": [
      "swaymsg -mt subscribe '[\"window\"]' | \n    jq 'select(.change == \"new\") | \n    select(.container.window_properties.class == \"frontend\")' |\n    while read -r _; do\n        echo WORKS          \n    done ",
      "swaymsg -m -t subscribe '[\"window\"]' \\\n  | stdbuf -o L jq -c 'select(.change == \"focus\")' \\\n  | while read -r string; do\n    echo $string | jq\ndone",
      "Key things here are `stdbuf -o L` , which makes the following `jq` command's output line buffered, and `jq -c` which makes jq output an object all onto one line. With this, the `read` command picks up the entire object into `$string`, which can be further manipulated in later steps."
    ],
    "utterance": "Filter for window events where the change equals 'new' and the window class equals 'frontend'.",
    "expressions": [
      "select(.change == \"new\") | select(.container.window_properties.class == \"frontend\")"
    ],
    "identifier": 79256227
  },
  {
    "context": [
      "I need to generate CSV output which shows the name of a disk, together with a list of mount points, if any. I can generate this for simple cases, but the problem is that there's a recursive children list, containing additional mountpoints, which I don't know how to handle.",
      "the blockdevices object contains a list, but only entries of type disk are relevant",
      "Any mountpoints can contain null entries, but it seems like the array is always present",
      ".blockdevices[] | select(.type == \"disk\") | [ \n    .name, \n    (.. | (.mountpoints? // []) | flatten[] | values) \n]"
    ],
    "utterance": "List each disk's name with all non-null mountpoints from itself and its recursive children as a CSV-style array, considering only entries where type is disk.",
    "expressions": [
      ".blockdevices[] | select(.type == \"disk\") | [ .name, (.. | (.mountpoints? // []) | flatten[] | values) ]"
    ],
    "data": [
      {
        "input": {
          "blockdevices": [
            {
              "type": "disk",
              "name": "sda",
              "etc": "ignore",
              "mountpoints": [
                null
              ]
            },
            {
              "type": "loop",
              "etc": "ignore everything"
            },
            {
              "type": "disk",
              "name": "sdb",
              "etc": "ignore",
              "mountpoints": [
                null
              ],
              "children": [
                {
                  "name": "ignore",
                  "etc": "ignore",
                  "mountpoints": [
                    "foo1"
                  ]
                },
                {
                  "name": "ignore",
                  "etc": "ignore",
                  "mountpoints": [
                    null
                  ],
                  "children": [
                    {
                      "name": "ignore",
                      "etc": "ignore",
                      "mountpoints": [
                        "foo2"
                      ]
                    },
                    {
                      "name": "ignore",
                      "etc": "ignore",
                      "mountpoints": [
                        "foo3"
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          [
            "sda"
          ],
          [
            "sdb",
            "foo1",
            "foo2",
            "foo3"
          ]
        ]
      }
    ],
    "identifier": 79206926
  },
  {
    "context": [
      "What I'd like to do instead would be something like this: \nprocess_matching_and_others(\n  [\"deep\",\"path\",\"matching\"]; callback_x; callback_y\n)\nBut I don't know how to achieve something similar, because the callbacks require an argument that's passed on invocation of the callbacks by traverse_and_invoke_callbacks",
      "Key to the solution is, that filters always receive an input (accessible as `.`), so it's simply not necessary to pass a parameterized function. You can pass any callback function that processes the output of the calling function:",
      "def process_matching_and_others(path_list; filter_for_matching; filter_for_others):\n  reduce paths(objects) as $p (\n    .;\n    if $p[:path_list | length] == path_list\n    then getpath($p) |= matching\n    else getpath($p) |= others\n    end\n  )\n;",
      "process_matching_and_others(\n  [\"deep\",\"path\",\"matching\"];\n  if has(\"x\") then .x = \"changed\" else . end;\n  if has(\"y\") then del(.y) else . end\n)"
    ],
    "utterance": "Selectively traverse the data; for nodes matching the path [\"deep\",\"path\",\"matching\"], set their x property to \"changed\" if present; for all other nodes, if they have a y property, delete it.",
    "expressions": [
      "def process_matching_and_others(path_list; filter_for_matching; filter_for_others):\n  reduce paths(objects) as $p (\n    .;\n    if $p[:path_list | length] == path_list\n    then getpath($p) |= matching\n    else getpath($p) |= others\n    end\n  )\n;\nprocess_matching_and_others(\n  [\"deep\",\"path\",\"matching\"];\n  if has(\"x\") then .x = \"changed\" else . end;\n  if has(\"y\") then del(.y) else . end\n)"
    ],
    "data": [
      {
        "input": {
          "deep": {
            "path": {
              "matching": {
                "m": {
                  "x": "change it",
                  "y": "don't touch"
                },
                "n": {
                  "nn": {
                    "x": "change it",
                    "y": "don't touch"
                  }
                }
              },
              "other_a": {
                "a": {
                  "x": "don't touch",
                  "y": "delete it"
                }
              },
              "other_b": {
                "b": {
                  "bb": {
                    "x": "don't touch",
                    "y": "delete it"
                  }
                }
              },
              "other_list": [
                "a",
                "b",
                "c"
              ]
            }
          },
          "another_other": [
            {
              "a": {
                "x": "don't touch",
                "y": "delete it"
              }
            },
            {
              "a": {
                "x": "don't touch",
                "y": "delete it"
              }
            }
          ]
        },
        "output": {
          "deep": {
            "path": {
              "matching": {
                "m": {
                  "x": "changed",
                  "y": "don't touch"
                },
                "n": {
                  "nn": {
                    "x": "changed",
                    "y": "don't touch"
                  }
                }
              },
              "other_a": {
                "a": {
                  "x": "don't touch"
                }
              },
              "other_b": {
                "b": {
                  "bb": {
                    "x": "don't touch"
                  }
                }
              },
              "other_list": [
                "a",
                "b",
                "c"
              ]
            }
          },
          "another_other": [
            {
              "a": {
                "x": "don't touch"
              }
            },
            {
              "a": {
                "x": "don't touch"
              }
            }
          ]
        }
      }
    ],
    "identifier": 79638468
  },
  {
    "context": [
      "When you invoked `jq`, `$qa_assigned_from_to_me` is a variable of type `string`. It's not going to be evaluated like you're expecting and `jq` does not have a mechanism to evaluate a string as a jq expression.",
      "For a perhaps slightly easier and far less hacky approach, you could put the contents of the filter into a file, formatted to be used as a module which you could import into your main program and invoke where needed.",
      "$ cat filter.jq",
      "def filter: (.fromString == \"Person A\" and .toString == \"Person B\");",
      "$ jq 'include \"filter\"; [ .values | sort_by(.id) | reverse | .[].items[] | select( .field == \"assignee\" and ( filter ) ) ] | first | .fromString' input.json",
      "The contents of `filter.jq` is what you would generate, and put into a function (\"filter\" in this case). Then include the file and use the function."
    ],
    "utterance": "Retrieve the first entry where fromString is \"Person A\" and toString is \"Person B\", after sorting and reversing by id.",
    "expressions": [
      "include \"filter\"; [ .values | sort_by(.id) | reverse | .[].items[] | select( .fromString == \"Person A\" and .toString == \"Person B\" ) ] | first | .fromString"
    ],
    "data": [
      {
        "input": {
          "values": [
            {
              "id": "1",
              "items": [
                {
                  "fromString": "Person A",
                  "toString": "Person B"
                }
              ]
            },
            {
              "id": "2",
              "items": [
                {
                  "fromString": "Person B",
                  "toString": "Person A"
                }
              ]
            },
            {
              "id": "3",
              "items": [
                {
                  "fromString": "Person C",
                  "toString": "Person D"
                }
              ]
            }
          ]
        },
        "output": "Person A"
      }
    ],
    "identifier": 79622181
  },
  {
    "context": [
      "I have the following json input:",
      "I\u2019d like to replace the values of all `x` keys that are ***not*** descendants of `to_exclude` by `anything`.",
      "Instead of applying a function to `.to_exclude` using `.to_exclude |= \u2026`, apply it to all keys after filtering them using a simple `select`. For example:",
      ".[keys[] | select(. != \"to_exclude\")] |= \u2026",
      "To exclude a list of keys, you could also use array subtraction:",
      ".[keys - [\"to_exclude\"] | .[]] |= \u2026"
    ],
    "utterance": "Replace the values of all x keys not under to_exclude with 'anything'.",
    "expressions": [
      ".[keys[] | select(. != \"to_exclude\")] |= (.. |= (if type == \"object\" and has(\"x\") then .x = \"anything\" else . end))",
      ".[keys - [\"to_exclude\"] | .[]] |= (.. |= (if type == \"object\" and has(\"x\") then .x = \"anything\" else . end))"
    ],
    "data": [
      {
        "input": {
          "to_exclude": {
            "x": "something",
            "aa": {
              "x": "something",
              "aaa": {
                "x": "something"
              }
            }
          },
          "a": {
            "x": "something else",
            "aa": {
              "x": "something else",
              "aaa": {
                "x": "something else"
              }
            }
          },
          "b": {
            "x": "something else",
            "bb": {
              "x": "something else",
              "bbb": {
                "x": "something else"
              }
            }
          },
          "...": {
            "x": "something else",
            "......": {
              "x": "something else",
              ".........": {
                "x": "something else"
              }
            }
          }
        },
        "output": {
          "to_exclude": {
            "x": "something",
            "aa": {
              "x": "something",
              "aaa": {
                "x": "something"
              }
            }
          },
          "a": {
            "x": "anything",
            "aa": {
              "x": "anything",
              "aaa": {
                "x": "anything"
              }
            }
          },
          "b": {
            "x": "anything",
            "bb": {
              "x": "anything",
              "bbb": {
                "x": "anything"
              }
            }
          },
          "...": {
            "x": "anything",
            "......": {
              "x": "anything",
              ".........": {
                "x": "anything"
              }
            }
          }
        }
      }
    ],
    "identifier": 79636342
  },
  {
    "identifier": 79257584
  },
  {
    "context": [
      "cat $report | jq -r '.\"earl:testSubject\".metadata.\"${fields[$i]}\"' >> report.txt",
      "cat $report | jq -r '.\"earl:testSubject\".metadata.\"dc:identifier\"' >> report.txt",
      "When I run it, I get a lot of \"null\" back from the jq call. But if I run: ...this will return the data I expect. Do i need to construct the call differently?"
    ],
    "utterance": "Retrieve the value at the path earl:testSubject.metadata.[field] in each report, where [field] is replaced with the name, such as 'dc:identifier' or 'schema:accessibilityFeature'.",
    "expressions": [
      ".\"earl:testSubject\".metadata[\"${field}\"]",
      ".\"earl:testSubject\".metadata.\"dc:identifier\"",
      ".\"earl:testSubject\".metadata.\"schema:accessibilityFeature\""
    ],
    "identifier": 79696130
  },
  {
    "context": [
      "I want to add `bundleDependencies` from the `dependencies`'s keys by using `jq`.",
      "Here is the expected output:\n{\n  \"name\": \"hello\",\n  \"dependencies\": {\n    \"progress\": \"^2.0.0\",\n    \"tar\": \"^6.2.1\"\n  },\n  \"bundleDependencies\": [\"progress\", \"tar\"]\n}",
      "Don't iterate over the keys, just take the array:\n.bundleDependencies = (.dependencies | keys)",
      "Note: `keys` sorts the array. Use `keys_unsorted` to prevent that."
    ],
    "utterance": "Add a field bundleDependencies whose value is an array containing the keys of dependencies.",
    "expressions": [
      ".bundleDependencies = (.dependencies | keys)",
      ".bundleDependencies = (.dependencies | keys_unsorted)"
    ],
    "data": [
      {
        "input": {
          "name": "hello",
          "dependencies": {
            "progress": "^2.0.0",
            "tar": "^6.2.1"
          }
        },
        "output": {
          "name": "hello",
          "dependencies": {
            "progress": "^2.0.0",
            "tar": "^6.2.1"
          },
          "bundleDependencies": [
            "progress",
            "tar"
          ]
        }
      }
    ],
    "identifier": 79624707
  },
  {
    "context": [
      "Everything under .Event[].EventData.Data[] seems to have been organised under an array due to the conversion through XML - some of the array values also seem to have no .content (presumably because the presence of those data points indicates the result is TRUE). I'm able to clean up data a little with a jq filter like this: `.Event[].EventData.Data | map( { (.Name|tostring):(.content|tostring) } ) | add`, but that only seems to work for one event and it throws errors due to the null values.",
      "Finally - I've figured out the way to handle this correctly, and it *is* listed in the documentation - the [character '?' ...]\n\n```\njq -c '.Event[].EventData?.Data[]? |= {(.Name): .content} | .Event[] | keys' Security.json\n```\n\nThis allows jq to iterate over values that are not arrays or objects (i.e. null) and continue processing."
    ],
    "utterance": "Convert each Data array under all Event.EventData to an object mapping Name to content, safely handling cases where EventData or content may be null.",
    "expressions": [
      ".Event[] | .EventData?.Data? | map({ (.Name|tostring): (.content|tostring) }) | add"
    ],
    "data": [
      {
        "input": [
          {
            "System": {
              "Provider": {
                "Name": "Microsoft-Windows-Security-Auditing",
                "Guid": "{<GUID>}"
              },
              "EventID": {
                "content": "4688"
              }
            },
            "EventData": {
              "Data": [
                {
                  "content": "S-1-5-18",
                  "Name": "SubjectUserSid"
                },
                {
                  "content": "-",
                  "Name": "SubjectUserName"
                },
                {
                  "content": "-",
                  "Name": "SubjectDomainName"
                },
                {
                  "content": "<HEX>",
                  "Name": "SubjectLogonId"
                },
                {
                  "content": "<HEX>",
                  "Name": "NewProcessId"
                },
                {
                  "content": "Registry",
                  "Name": "NewProcessName"
                },
                {
                  "content": "%%2000",
                  "Name": "TokenElevationType"
                },
                {
                  "content": "0x0000000000000019",
                  "Name": "ProcessId"
                },
                {
                  "Name": "CommandLine"
                },
                {
                  "content": "<HEX>",
                  "Name": "TargetUserSid"
                },
                {
                  "content": "-",
                  "Name": "TargetUserName"
                }
              ]
            }
          },
          {
            "System": {},
            "UserData": {}
          }
        ],
        "output": [
          {
            "SubjectUserSid": "S-1-5-18",
            "SubjectUserName": "-",
            "SubjectDomainName": "-",
            "SubjectLogonId": "<HEX>",
            "NewProcessId": "<HEX>",
            "NewProcessName": "Registry",
            "TokenElevationType": "%%2000",
            "ProcessId": "0x0000000000000019",
            "CommandLine": null,
            "TargetUserSid": "<HEX>",
            "TargetUserName": "-"
          },
          null
        ]
      }
    ],
    "identifier": 79699191
  },
  {
    "context": [
      "What I want is the opposite. Assuming the things in b.json are always exist in a.json; a.json, b.json and the result respectively:",
      "Using the following definitions, `$a | subtract_json($b)` produces the desired result, where $a and $b represent the values in a.json and b.json respectively:"
    ],
    "utterance": "Remove from the first object all key-value pairs and array elements that are present in the second object, including recursively in nested objects and arrays.",
    "expressions": [
      "def relevant_paths:\n  paths\n  | select( .[-1] | type != \"number\")  ;\n  \ndef is_scalar: type | IN(\"object\", \"array\") | not;\n\ndef subtract_json($y):\n  . as $x\n  | reduce ($y | relevant_paths) as $p ( $x;\n      if (getpath($p)|type == \"array\") and\n         ($y|getpath($p)|type == \"array\")\n      then setpath($p;  getpath($p) - ($y|getpath($p)) )\n      elif (getpath($p)|is_scalar) and \n           ($y|getpath($p)|is_scalar)\n      then delpaths( [$p] )\n      end);"
    ],
    "data": [
      {
        "input": {
          "a": {
            "background": {
              "service_worker": "js/background.js",
              "type": "module"
            },
            "manifest_version": 3,
            "permissions": [
              "storage",
              "unlimitedStorage"
            ]
          },
          "b": {
            "background": {
              "type": "module"
            },
            "permissions": [
              "unlimitedStorage"
            ]
          }
        },
        "output": {
          "background": {
            "service_worker": "js/background.js"
          },
          "manifest_version": 3,
          "permissions": [
            "storage"
          ]
        }
      }
    ],
    "identifier": 79305157
  },
  {
    "context": [
      "\"But what I want to do is use the other elements for the search and replace:\"",
      "\"It's not working because once you've accessed `.text` you've lost the parent context. `.search_for` and `.replace_with` are resolved *relative to `.text`*, rather than relative to the parent object.\"",
      "\"To fix this you can stash them in variables before accessing `.text`:\"",
      "jq '.example | .search_for as $s | .replace_with as $r | .text | sub($s; $r)' test.json"
    ],
    "utterance": "Replace a substring in the value of .example.text, where the substring to replace and its replacement are taken from .example.search_for and .example.replace_with.",
    "expressions": [
      ".example | .search_for as $s | .replace_with as $r | .text | sub($s; $r)"
    ],
    "data": [
      {
        "input": {
          "example": {
            "search_for": "https://a-url-using-a-shortener.com",
            "replace_with": "https://my.site.com",
            "text": "I want to have the full URL, not https://a-url-using-a-shortener.com"
          }
        },
        "output": "I want to have the full URL, not https://my.site.com"
      }
    ],
    "identifier": 79626804
  },
  {
    "context": [
      "When I apply \r\n\r\n    cat example1 | jq '{created: .attributes[] | select(.objectTypeAttribute.name==\"Created\").objectAttributeValues[0].value,\r\n    updated:.attributes[] | select(.objectTypeAttribute.name==\"Updated\").objectAttributeValues[0].value}'\r\n\r\non the first everything works fine and I get expected result\r\n\r\n    {\r\n      \"created\": \"create time 1\",\r\n      \"updated\": \"update time 1\"\r\n    }\r\n\r\n, however applying \r\n\r\n    cat example2 | jq '{created: .attributes[] | select(.objectTypeAttribute.name==\"Created\").objectAttributeValues[0].value,\r\n    updated:.attributes[] | select(.objectTypeAttribute.name==\"Updated\").objectAttributeValues[0].value}'\r\n\r\nI get no result at all, the result i would expect is\r\n\r\n    {\r\n      \"created\": \"create time 2\",\r\n      \"created\": \"NULL\"\r\n    }",
      "It seems you'll need additional parenthesis, as otherwise `//` binds stronger than the `|` and you're piping *all* `attributes` through an expression that always returns a value.\r\n\r\n```jq\r\n{\r\n    created: ((.attributes[] | select(.objectTypeAttribute.name==\"Created\").objectAttributeValues[0].value) // null),\r\n    updated: ((.attributes[] | select(.objectTypeAttribute.name==\"Updated\").objectAttributeValues[0].value) // null),\r\n}\r\n```",
      "An imo simpler solution is to build the objects dynamically with the specified key names and values, using `from_entries`:\r\n```jq\r\n.attributes | map({\r\n    key: .objectTypeAttribute.name | ascii_downcase,\r\n    value: .objectAttributeValues[0].value\r\n}) | from_entries\r\n```",
      "An alternative approach could be to use `INDEX` to implode the `.attributes` array into an object, extract the two keys you are interested in (which will default to `null` if non-existent), and adjust their values:\r\n```sh\r\n.attributes | INDEX(.objectTypeAttribute.name)\r\n| {Created, Updated} | .[] |= .objectAttributeValues[0].value\r\n```"
    ],
    "utterance": "Extract the values for 'Created' and 'Updated' attributes as keys, defaulting to null if either attribute is missing.",
    "expressions": [
      "{\n    created: ((.attributes[] | select(.objectTypeAttribute.name==\"Created\").objectAttributeValues[0].value) // null),\n    updated: ((.attributes[] | select(.objectTypeAttribute.name==\"Updated\").objectAttributeValues[0].value) // null),\n}",
      ".attributes | map({\n    key: .objectTypeAttribute.name | ascii_downcase,\n    value: .objectAttributeValues[0].value\n}) | from_entries",
      ".attributes | map({\n    (.objectTypeAttribute.name | ascii_downcase): .objectAttributeValues[0].value\n}) | add",
      ".attributes | INDEX(.objectTypeAttribute.name)\n| {Created, Updated} | .[] |= .objectAttributeValues[0].value"
    ],
    "data": [
      {
        "input": {
          "label": "Example1",
          "attributes": [
            {
              "objectTypeAttribute": {
                "name": "Created"
              },
              "objectAttributeValues": [
                {
                  "value": "create time 1"
                }
              ]
            },
            {
              "objectTypeAttribute": {
                "name": "Updated"
              },
              "objectAttributeValues": [
                {
                  "value": "update time 1"
                }
              ]
            }
          ]
        },
        "output": {
          "created": "create time 1",
          "updated": "update time 1"
        }
      },
      {
        "input": {
          "label": "Example2",
          "attributes": [
            {
              "objectTypeAttribute": {
                "name": "Created"
              },
              "objectAttributeValues": [
                {
                  "value": "create time 2"
                }
              ]
            }
          ]
        },
        "output": {
          "created": "create time 2",
          "updated": null
        }
      }
    ],
    "identifier": 79629191
  },
  {
    "context": [
      "Match first object which has an array that contains exactly same values (it&#39;s should always be length of 2)",
      "# Should match:\r\n# { id: 366, size: [1920, 1080] }",
      "Construct the array, compare it to `.size`, and use `first` to only get the first match:",
      "jq --argjson width 1920 --argjson height 1080 '\r\n  first(.[] | select(.size == [$width, $height]).id)\r\n'",
      "jq --argjson size '[1920, 1080]' '\r\n  first(.[] | select(.size == $size).id)\r\n'"
    ],
    "utterance": "Find the first object whose size array is exactly [1920, 1080], and return its id.",
    "expressions": [
      "first(.[] | select(.size == [$width, $height]).id)",
      "first(.[] | select(.size == $size).id)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 242,
            "size": [
              500,
              500
            ]
          },
          {
            "id": 234,
            "size": [
              500,
              1920
            ]
          },
          {
            "id": 168,
            "size": [
              234,
              1080
            ]
          },
          {
            "id": 315,
            "size": [
              1080,
              1920
            ]
          },
          {
            "id": 366,
            "size": [
              1920,
              1080
            ]
          },
          {
            "id": 367,
            "size": [
              1920,
              1080
            ]
          }
        ],
        "output": 366
      }
    ],
    "identifier": 79101157
  },
  {
    "context": [
      "I want to pass a \"array\" to the while loop so I don't have to repeat the column names",
      "COLUMNS=(\"SOURCE_FILE\" \"EXIF_CONTAINER\" \"EXIF_CODEC\" \"EXIF_ENCODER\")",
      "jq -r '.[] | \"\\(.SOURCE_FILE),\\(.EXIF_CONTAINER),\\(.EXIF_CODEC),\\(.EXIF_ENCODER)\"'",
      "Change\njq -r '.[] | \"\\(.SOURCE_FILE),\\(.EXIF_CONTAINER),\\(.EXIF_CODEC),\\(.EXIF_ENCODER)\"'\ninto\njq -r '.[] | [.[$ARGS.positional[]]] | join(\",\")' --args \"${COLUMNS[@]}\""
    ],
    "utterance": "Output each object as a CSV line, using a variable list of column names supplied as arguments.",
    "expressions": [
      ".[] | [.[$ARGS.positional[]]] | join(\",\")"
    ],
    "identifier": 79153399
  },
  {
    "context": [
      "I need to convert this csv to the following format:",
      "You can use `jq` with raw input option (`-R`) and `-s` to slurp the entire file as a single string. Then you split that into array of lines. You access test lines by `$lines[1:-1]` (we skip 1-st row) and for each test line, split it by `;` and map the fields to the desired keys.",
      "Since in your data `\"0\"` represents a successful test (status `true`), you can convert the status using `(.[0] == \"0\")`. Then deal with summary line (use `-1` index to get it regardles of line count) and you should be good.",
      "Combining the above should give you this monster:",
      "jq -R -s '\n  (split(\"\\n\") | map(select(length > 0))) as $lines |\n  {\n    testName: $lines[0],\n    tests: ($lines[1:-1] | map(\n      (split(\";\") | {\n        name: .[1],\n        status: (.[0] == \"0\"),\n        duration: .[2]\n      })\n    )),\n    summary: ($lines[-1] | split(\";\") | {\n      success: (.[0] | tonumber),\n      failed: (.[1] | tonumber),\n      rating: (.[2] | tonumber),\n      duration: .[3]\n    })\n  }\n' input.csv",
      "Here is a stream (reading `inputs` line by line without storing the whole input file in memory) and regex-based (using `capture`) approach:",
      "jq -R 'reduce (inputs | capture((\n  \"^(?<status>0|1);(?<name>[^;]*)\",\n  \"^(?<success>\\d+);(?<failed>\\d+);(?<rating>\\d+(\\.\\d+)?)\"\n) + \";(?<duration>\\d+ms)$\")) as $i ({testName: .}; if $i.name\n  then .tests += [$i | .status |= . == \"0\"]\n  else .summary = ($i | (.success, .failed, .rating) |= tonumber)\nend)'"
    ],
    "utterance": "Transform a CSV file\u2014with first and last lines being header and summary\u2014into an object with the header as testName, an array of test objects with fields name, status (boolean: 0 = true), and duration, and a summary object with success, failed, rating, and duration fields.",
    "expressions": [
      "jq -R -s '\n  (split(\"\\n\") | map(select(length > 0))) as $lines |\n  {\n    testName: $lines[0],\n    tests: ($lines[1:-1] | map(\n      (split(\";\") | {\n        name: .[1],\n        status: (.[0] == \"0\"),\n        duration: .[2]\n      })\n    )),\n    summary: ($lines[-1] | split(\";\") | {\n      success: (.[0] | tonumber),\n      failed: (.[1] | tonumber),\n      rating: (.[2] | tonumber),\n      duration: .[3]\n    })\n  }\n'",
      "jq -R 'reduce (inputs | capture((\n  \"^(?<status>0|1);(?<name>[^;]*)\",\n  \"^(?<success>\\d+);(?<failed>\\d+);(?<rating>\\d+(\\.\\d+)?)\"\n) + \";(?<duration>\\d+ms)$\")) as $i ({testName: .}; if $i.name\n  then .tests += [$i | .status |= . == \"0\"]\n  else .summary = ($i | (.success, .failed, .rating) |= tonumber)\nend)'"
    ],
    "data": [
      {
        "input": "Asserts Samples\n1;expecting command finishes successfully (bash exe);7ms\n1;expecting command finishes successfully (loading bin, execute);27ms\n0;expecting command fails (bash exe, execute);23ms\n0;expecting command prints some message (bash exe);12ms\n0;expecting command prints some message (loading bin, execute);26ms\n5;2;71.43;136ms",
        "output": {
          "testName": "Asserts Samples",
          "tests": [
            {
              "name": "expecting command finishes successfully (bash exe)",
              "status": false,
              "duration": "7ms"
            },
            {
              "name": "expecting command finishes successfully (loading bin, execute)",
              "status": false,
              "duration": "27ms"
            },
            {
              "name": "expecting command fails (bash exe, execute)",
              "status": true,
              "duration": "23ms"
            },
            {
              "name": "expecting command prints some message (bash exe)",
              "status": true,
              "duration": "12ms"
            },
            {
              "name": "expecting command prints some message (loading bin, execute)",
              "status": true,
              "duration": "26ms"
            }
          ],
          "summary": {
            "success": 5,
            "failed": 2,
            "rating": 71.43,
            "duration": "136ms"
          }
        }
      }
    ],
    "identifier": 79101481
  },
  {
    "context": [
      "The (x, y) pairs are in separate arrays. Is there a one-liner that will achieve the below?",
      "An example of output data that Datagraph can parse (manually created): ... [{ \"pair\": \"btcusd\", \"x\": 1254700800000, \"y\": 0.00076394 }, ...]",
      "You can run\n\n```\njq '\n  to_entries |\n  map(\n    .key as $pair |\n    .value.x as $xs |\n    .value.y as $ys |\n    [range(0; $xs | length) | {pair: $pair, x: $xs[.], y: $ys[.]}]\n  ) | add\n' input.json\n```\nto get \n\n```\n[\n  {\n    \"pair\": \"btcusd\",\n    \"x\": 1254700800000,\n    \"y\": 0.00076394\n  },\n  ...\n]",
      "You're looking for something like this:\n``` none\nto_entries | map({pair: .key} + (.value | transpose[] | {x: .[0], y: .[1]}))\n```"
    ],
    "utterance": "Combine separate x and y arrays from each pair into an array of objects with fields pair, x, and y, so each object joins the corresponding x and y values under their pair name.",
    "expressions": [
      "to_entries | map({pair: .key} + (.value | transpose[] | {x: .[0], y: .[1]})) | add",
      "to_entries | map(.key as $pair | .value.x as $xs | .value.y as $ys | [range(0; $xs | length) | {pair: $pair, x: $xs[.], y: $ys[.]}]) | add"
    ],
    "data": [
      {
        "input": {
          "btcusd": {
            "x": [
              1254700800000,
              1254787200000,
              1254873600000,
              1730419200000
            ],
            "y": [
              0.00076394,
              0.00076394,
              0.00088456,
              69513.1578978095
            ]
          },
          "xaubtc": {
            "x": [
              1254700800000,
              1254787200000,
              1254873600000,
              1719446400000
            ],
            "y": [
              1316202.8431552218,
              1359727.2037070976,
              1176008.410961382,
              0.037321851310868535
            ]
          }
        },
        "output": [
          {
            "pair": "btcusd",
            "x": 1254700800000,
            "y": 0.00076394
          },
          {
            "pair": "btcusd",
            "x": 1254787200000,
            "y": 0.00076394
          },
          {
            "pair": "btcusd",
            "x": 1254873600000,
            "y": 0.00088456
          },
          {
            "pair": "btcusd",
            "x": 1730419200000,
            "y": 69513.1578978095
          },
          {
            "pair": "xaubtc",
            "x": 1254700800000,
            "y": 1316202.8431552218
          },
          {
            "pair": "xaubtc",
            "x": 1254787200000,
            "y": 1359727.2037070976
          },
          {
            "pair": "xaubtc",
            "x": 1254873600000,
            "y": 1176008.410961382
          },
          {
            "pair": "xaubtc",
            "x": 1719446400000,
            "y": 0.037321851310868535
          }
        ]
      }
    ],
    "identifier": 79152067
  },
  {
    "context": [
      "How do I turn a recursive object `{ id, name: { data }, children: self[] }` into array of something like `{ id: id, name: name.data | join(&#39;/&#39;) }` ?",
      "For example, I&#39;d like to convert given following data ... into: ... {\"id\": \"1\", \"name\": \"foo\"}, {\"id\": \"2\", \"name\": \"bar\"}, {\"id\": \"4\", \"name\": \"bar/melon\"}, {\"id\": \"5\", \"name\": \"bar/melon/soda\"}, {\"id\": \"3\", \"name\": \"baz\"}, {\"id\": \"6\", \"name\": \"baz/my data\"},",
      "My attempt is ... but this yields name of the single layer (i.e. `foo`, `bar`, `melon`, ...).",
      "Otherwise, using a recursive function will get expected result:",
      "jq -c 'def down($parents):\n           ($parents + .name.data) as $pass |\n           { id: .id, name: $pass }, (.children[]|down($pass + \"/\"));\n       .[] | down(\"\")' input.json"
    ],
    "utterance": "For each node, output its id and the concatenated path from the root to that node, joining name.data fields with slashes.",
    "expressions": [
      "def down($parents):\n  ($parents + .name.data) as $pass |\n  { id: .id, name: $pass },\n  (.children[]? | down($pass + \"/\"));\n.[] | down(\"\")"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "name": {
              "data": "foo"
            },
            "children": []
          },
          {
            "id": "2",
            "name": {
              "data": "bar"
            },
            "children": [
              {
                "id": "4",
                "name": {
                  "data": "melon"
                },
                "children": [
                  {
                    "id": "5",
                    "name": {
                      "data": "soda"
                    },
                    "children": []
                  }
                ]
              }
            ]
          },
          {
            "id": "3",
            "name": {
              "data": "baz"
            },
            "children": [
              {
                "id": "6",
                "name": {
                  "data": "my data"
                },
                "children": []
              }
            ]
          }
        ],
        "output": [
          {
            "id": "1",
            "name": "foo"
          },
          {
            "id": "2",
            "name": "bar"
          },
          {
            "id": "4",
            "name": "bar/melon"
          },
          {
            "id": "5",
            "name": "bar/melon/soda"
          },
          {
            "id": "3",
            "name": "baz"
          },
          {
            "id": "6",
            "name": "baz/my data"
          }
        ]
      }
    ],
    "identifier": 79423019
  },
  {
    "context": [
      "Given the JSON below, I am struggling for a jq query that will eliminate any items in places[].fThings[] or places.sThings[] that are not a partial string match to any of the strings found in toDo[]. It should be noted not all places will have fThings or sThings present. While it most likely be one or the other, *both or neither* could be present. The output should be the same as the input with the non-matching *Things items filtered out. Empty arrays are fine to return.",
      ". as {$toDo}\n| (.places[.[\"fThings\", \"sThings\"] | arrays[]) |= select(inside($toDo[]))"
    ],
    "utterance": "Remove from each object in 'places' all items in 'fThings' or 'sThings' arrays that are not a partial string match for any value in the 'toDo' array, allowing for empty arrays and preserving objects without those fields.",
    "expressions": [
      ". as {$toDo} | (.places[.[\"fThings\", \"sThings\"] | arrays[]]) |= select(any($toDo[]; contains(.)))"
    ],
    "data": [
      {
        "input": {
          "places": [
            {
              "location": "wapc1",
              "type": "pcs,cstrl,refdoc",
              "fGroup": "cert-apc-1",
              "fThings": [
                "pcs_app#2.1#bp",
                "pcs_app#2.0#bp",
                "pcs_app#2.1#bp",
                "pcs_app#2.1#cc",
                "pcs_app#2.1#ex_acct",
                "pcs_app#2.1#repr"
              ]
            },
            {
              "location": "wapc2",
              "type": "pcs,cstrl",
              "fGroup": "cert-apc-2",
              "fThings": [
                "pcs_app#2.1#mts",
                "pcs_app#2.1#mts",
                "pcs_app#2.1#mta",
                "pcs_app#2.1#mtr",
                "pcs_app#2.1#mop",
                "pcs_app#2.1#mor",
                "pcs_app#2.1#mov"
              ]
            },
            {
              "location": "wapc3",
              "type": "pcs,prx,cstrl",
              "fGroup": "cert-apc-3",
              "fThings": [
                "pcs_app#2.1#d2c",
                "pcs_app#2.1#ci",
                "pcs_app#2.1#co",
                "pcs_app#2.1#gr",
                "pcs_app#2.1#repr",
                "pcs_app#2.1#refr",
                "pcs_app#2.1#gf",
                "pcs_app#2.1#dq"
              ],
              "aThings": [
                "prx"
              ]
            },
            {
              "location": "wapc4",
              "type": "pcs,prx,cstrl",
              "fGroup": "cert-apc-4",
              "fThings": [
                "pcs_app#2.1#mtr",
                "pcs_app#2.1#mtstat",
                "pcs_app#2.1#mop"
              ],
              "aThings": [
                "prx"
              ]
            },
            {
              "location": "wwc1",
              "type": "bsrv",
              "sGroup": [
                "cert-bs-1"
              ],
              "sThings": [
                "ci_svc#1.35.0",
                "config_svc#1",
                "erec_svc#1.27",
                "hm_svc#1.34.0",
                "ri_svc#1.0.0"
              ]
            },
            {
              "location": "wwc2",
              "type": "bsrv",
              "sGroup": [
                "cert-bs-2"
              ],
              "sThings": [
                "erec_svc#1.27",
                "profile_svc#1.7",
                "mor_svc#1.33.0",
                "mta_svc#1.31.0",
                "mtr_svc#1.39.0",
                "mtstat_svc#1.35.0",
                "ri_svc#1.0.0"
              ]
            },
            {
              "location": "wwc3",
              "type": "bsrv,r-bsrv",
              "sGroup": [
                "cert-bs-3",
                "cert-rs"
              ],
              "sThings": [
                "co_svc#1.36.0",
                "d2c_svc#1.34.0",
                "erec_svc#1.27",
                "gr_svc#1.19.0",
                "profile_svc#1.7",
                "config_svc#1"
              ]
            },
            {
              "location": "wwc4",
              "type": "bsrv,r-bsrv",
              "sGroup": [
                "cert-bs-4",
                "cert-rs"
              ],
              "sThings": [
                "erec_svc#1.27",
                "profile_svc#1.7",
                "mtstat_svc#1.35.0",
                "config_svc#1",
                "bp_svc#1.46"
              ]
            }
          ],
          "toDo": [
            "bp_svc#1.46##1.46.0-2410.0-03",
            "config_svc#1##1.12-2410.0-05",
            "erec_svc#1.27##1.27-2410.0-03",
            "pcs_app#2.1#bp##2.1-2410.0-05",
            "pcs_app#2.1#ci##2.1-2410.0-05",
            "pcs_app#2.1#co##2.1-2410.0-05",
            "pcs_app#2.1#cc##2.1-2410.0-05",
            "pcs_app#2.1#dq##2.1-2410.0-05",
            "pcs_app#2.1#d2c##2.1-2410.0-05",
            "pcs_app#2.1#df##2.1-2410.0-05"
          ]
        },
        "output": {
          "places": [
            {
              "location": "wapc1",
              "type": "pcs,cstrl,refdoc",
              "fGroup": "cert-apc-1",
              "fThings": [
                "pcs_app#2.1#bp",
                "pcs_app#2.1#bp",
                "pcs_app#2.1#cc"
              ]
            },
            {
              "location": "wapc2",
              "type": "pcs,cstrl",
              "fGroup": "cert-apc-2",
              "fThings": []
            },
            {
              "location": "wapc3",
              "type": "pcs,prx,cstrl",
              "fGroup": "cert-apc-3",
              "fThings": [
                "pcs_app#2.1#d2c",
                "pcs_app#2.1#ci",
                "pcs_app#2.1#co",
                "pcs_app#2.1#dq"
              ],
              "aThings": [
                "prx"
              ]
            },
            {
              "location": "wapc4",
              "type": "pcs,prx,cstrl",
              "fGroup": "cert-apc-4",
              "fThings": [],
              "aThings": [
                "prx"
              ]
            },
            {
              "location": "wwc1",
              "type": "bsrv",
              "sGroup": [
                "cert-bs-1"
              ],
              "sThings": [
                "config_svc#1",
                "erec_svc#1.27"
              ]
            },
            {
              "location": "wwc2",
              "type": "bsrv",
              "sGroup": [
                "cert-bs-2"
              ],
              "sThings": [
                "erec_svc#1.27"
              ]
            },
            {
              "location": "wwc3",
              "type": "bsrv,r-bsrv",
              "sGroup": [
                "cert-bs-3",
                "cert-rs"
              ],
              "sThings": [
                "erec_svc#1.27",
                "config_svc#1"
              ]
            },
            {
              "location": "wwc4",
              "type": "bsrv,r-bsrv",
              "sGroup": [
                "cert-bs-4",
                "cert-rs"
              ],
              "sThings": [
                "erec_svc#1.27",
                "config_svc#1",
                "bp_svc#1.46"
              ]
            }
          ],
          "toDo": [
            "bp_svc#1.46##1.46.0-2410.0-03",
            "config_svc#1##1.12-2410.0-05",
            "erec_svc#1.27##1.27-2410.0-03",
            "pcs_app#2.1#bp##2.1-2410.0-05",
            "pcs_app#2.1#ci##2.1-2410.0-05",
            "pcs_app#2.1#co##2.1-2410.0-05",
            "pcs_app#2.1#cc##2.1-2410.0-05",
            "pcs_app#2.1#dq##2.1-2410.0-05",
            "pcs_app#2.1#d2c##2.1-2410.0-05",
            "pcs_app#2.1#df##2.1-2410.0-05"
          ]
        }
      }
    ],
    "identifier": 79163698
  },
  {
    "context": [
      "I have this json:\n[\n  {\n    \"first\": 12355,\n    \"second\": \"abc\"\n  },\n  {\n    \"first\": 89010,\n    \"second\": \"def\"\n  },\n  {\n    \"first\": 23423,\n    \"second\": \"hij\"\n  },\n  {\n    \"first\": 23456,\n    \"second\": \"klm\"\n  },\n  {\n    \"first\": 11111,\n    \"second\": \"nop\"\n  }\n]\n\nAnd I would like (a generic form) that merges them into 1 object where the value of each key is merged into an array of the corresponding values:",
      "{\n    \"first\" : [12355,89010,23423,23456,11111],\n    \"second\" : [\"abc\",\"def\",\"hij\",\"klm\",\"nop\"]\n}",
      "I'd use `to_entries` (to access keys and values) as part of the iteration:\n\nreduce (.[] | to_entries[]) as $e ({}; .[$e.key] += [$e.value])",
      "Here's another way using `group_by` to bring the matching items together:\n\nmap(to_entries[]) | group_by(.key) | map({(first.key): map(.value)}) | add",
      "Or for simplicity, consider using `transpose`, e.g.\nmap([.[]]) | transpose | {first: first, second: .[1]}"
    ],
    "utterance": "Combine an array of objects into a single object where each key maps to an array of its values across all objects.",
    "expressions": [
      "reduce (.[] | to_entries[]) as $e ({}; .[$e.key] += [$e.value])",
      "map(to_entries[]) | group_by(.key) | map({(first.key): map(.value)}) | add",
      "map([.[]]) | transpose | {first: first, second: .[1]}"
    ],
    "data": [
      {
        "input": [
          {
            "first": 12355,
            "second": "abc"
          },
          {
            "first": 89010,
            "second": "def"
          },
          {
            "first": 23423,
            "second": "hij"
          },
          {
            "first": 23456,
            "second": "klm"
          },
          {
            "first": 11111,
            "second": "nop"
          }
        ],
        "output": {
          "first": [
            12355,
            89010,
            23423,
            23456,
            11111
          ],
          "second": [
            "abc",
            "def",
            "hij",
            "klm",
            "nop"
          ]
        }
      }
    ],
    "identifier": 79156798
  },
  {
    "context": [
      "\"I have \\\"2024-12-01 00:00:00\\\" in local TZ (Europe/Berlin) and want to parse/convert this into RFC3339 for Go time.Parse which would be \\\"2024-12-01T00:00:00+01:00\\\".\"",
      "\"I've tried various variants of strptime(\"%Y-%m-%d %H:%M:%S\") | strflocaltime(\"%Y-%m-%dT%H:%M:%S%z\") but I can't get the timezone out in a suitable format since RFC 3339 insists on the ':':\"",
      "\"Use %:z instead of %z. (You can also shorten %Y-%m-%d to %F and %H:%M:%S to %T): gojq -nr '\"2024-12-01 00:00:00\" | strptime(\"%F %T\") | strflocaltime(\"%FT%T%:z\")'\"",
      "\"2024-12-01T00:00:00+01:00\""
    ],
    "utterance": "Convert the string '2024-12-01 00:00:00' in local Europe/Berlin time to RFC3339 format with a colon in the timezone offset.",
    "expressions": [
      "\"\\\"2024-12-01 00:00:00\\\" | strptime(\\\"%F %T\\\") | strflocaltime(\\\"%FT%T%:z\\\")\"",
      "\"\\\"2024-12-01 00:00:00\\\" | strptime(\\\"%F %T\\\") | strflocaltime(\\\"%FT%T%z\\\") | sub(\\\\\"\\\\+(?<d>[0-9][0-9])\\\\\";\\\\\"Z\\\\(.d):\\\\\")\""
    ],
    "data": [
      {
        "input": "2024-12-01 00:00:00",
        "output": "2024-12-01T00:00:00+01:00"
      }
    ],
    "identifier": 79241351
  },
  {
    "context": [
      "this is the filter I\u2019m using\n\n    cat data.json | jq -r '\\(.src_ip),\\(.src_port),\\(.dest_ip),\\(.dst_port),\\(.proto),\\(.ndpi.proto),\\(.ndpi.category),\\(.ndpi.hostname),\\(.duration),\\(.vlan_id),\\(.xfer.src2dst_bytes),\\(.xfer.dst2src_bytes),\\(.ndpi.flow_risk.\"35\".risk),\\(.ndpi.flow_risk.\"35\".severity)'",
      "that is related to the number (in this case 35). This number can be different (from 01 to 50) and I don\u2019t know how to filter to search for different numbers.",
      "is there any chance to use something like wildcards with jQ? \n\nI mean how can I do this to accept multiple numbers? (for ex: searching from 01 to 50?)",
      "\"As an example, you can use something along the lines of .ndpi.flow_risk | to_entries[] | select(.key | tonumber | . <= 50 and . >= 0).value | \"\\(.risk),\\(.severity)\" to get for those last two pieces of information\"",
      "\"To access all keys, just use .[]. However, you presumably want to reference the same keys both times you've used 35 in the example. For that, iterate before creating (the relevant part of) the output string, and reference the iteration value (context):\n\njq -r '\u2026 ,\\(.ndpi.flow_risk[] | \"\\(.risk),\\(.severity)\")'\"",
      "\"To access a specific range, use range to create them, turn it into a string using tostring, and proceed as above (\"0\" + prepends the zero, and [-2:] reduces it to the last two characters):\n\njq -r '\u2026 ,\\(.ndpi.flow_risk[range (50)+1 | (\"0\" + tostring)[-2:]] | \"\\(.risk),\\(.severity)\")'\""
    ],
    "utterance": "Extract the risk and severity fields for all flow_risk keys from 01 to 50.",
    "expressions": [
      ".ndpi.flow_risk | to_entries[] | select(.key | tonumber >= 1 and tonumber <= 50) | \"\\(.value.risk),\\(.value.severity)\"",
      ".ndpi.flow_risk[range(1;51)| (\"0\" + tostring)[-2:]] | select(.) | \"\\(.risk),\\(.severity)\""
    ],
    "data": [
      {
        "input": {
          "src_ip": "x.x.x.x",
          "dest_ip": "x1.x1.x1.x1",
          "src_port": 48318,
          "dst_port": 443,
          "ip": 4,
          "proto": "TCP",
          "ndpi": {
            "flow_risk": {
              "35": {
                "risk": "Susp Entropy",
                "severity": "Medium",
                "risk_score": {
                  "total": 210,
                  "client": 165,
                  "server": 45
                }
              }
            },
            "confidence": {
              "1": "Match by port"
            },
            "proto": "TLS",
            "proto_id": "91",
            "proto_by_ip": "Unknown",
            "proto_by_ip_id": 0,
            "encrypted": 1,
            "breed": "Safe",
            "category_id": 5,
            "category": "Web"
          },
          "detection_completed": 1,
          "check_extra_packets": 0,
          "flow_id": 0,
          "first_seen": 1733074272.824,
          "last_seen": 1733074282.757,
          "duration": 9.933,
          "vlan_id": 0,
          "bidirectional": 1,
          "xfer": {
            "data_ratio": -0.958,
            "data_ratio_str": "Download",
            "src2dst_packets": 1268,
            "src2dst_bytes": 86239,
            "src2dst_goodput_bytes": 2551,
            "dst2src_packets": 2693,
            "dst2src_bytes": 4042956,
            "dst2src_goodput_bytes": 3865218
          },
          "iat": {
            "flow_min": 1,
            "flow_avg": 6.1,
            "flow_max": 4005,
            "flow_stddev": 108.3,
            "c_to_s_min": 0,
            "c_to_s_avg": 7.4,
            "c_to_s_max": 4005,
            "c_to_s_stddev": 137.8,
            "s_to_c_min": 0,
            "s_to_c_avg": 1.4,
            "s_to_c_max": 35,
            "s_to_c_stddev": 2.2
          },
          "pktlen": {
            "c_to_s_min": 66,
            "c_to_s_avg": 68.0,
            "c_to_s_max": 514,
            "c_to_s_stddev": 28.8,
            "s_to_c_min": 66,
            "s_to_c_avg": 1501.3,
            "s_to_c_max": 1506,
            "s_to_c_stddev": 76.6
          },
          "tcp_flags": {
            "cwr_count": 0,
            "ece_count": 0,
            "urg_count": 0,
            "ack_count": 3961,
            "psh_count": 1323,
            "rst_count": 0,
            "syn_count": 0,
            "fin_count": 0,
            "src2dst_cwr_count": 0,
            "src2dst_ece_count": 0,
            "src2dst_urg_count": 0,
            "src2dst_ack_count": 1268,
            "src2dst_psh_count": 7,
            "src2dst_rst_count": 0,
            "src2dst_syn_count": 0,
            "src2dst_fin_count": 0,
            "dst2src_cwr_count": 0,
            "dst2src_ece_count": 0,
            "dst2src_urg_count": 0,
            "dst2src_ack_count": 2693,
            "dst2src_psh_count": 1316,
            "dst2src_rst_count": 0,
            "dst2src_syn_count": 0,
            "dst2src_fin_count": 0
          },
          "c_to_s_init_win": 0,
          "s_to_c_init_win": 0
        },
        "output": [
          "Susp Entropy,Medium"
        ]
      }
    ],
    "identifier": 79245004
  },
  {
    "context": [
      "But how do I \"create\" rows/items for each item in `Fqdns` arrays?",
      "reduce .[][] as $i ({}; .[$i.FqdnList | splits(\";\")] += [$i.Ip])",
      "[.[][] | {name: .FqdnList | splits(\";\"), value: .Ip}]"
    ],
    "utterance": "Produce a mapping of each FQDN from the FqdnList to a list of corresponding IP addresses, or output a flat list of {name, value} pairs for each FQDN and IP, by splitting FqdnList on semicolons and associating with the Ip field.",
    "expressions": [
      "reduce .[][] as $i ({}; .[$i.FqdnList | splits(\";\")] += [$i.Ip])",
      "[.[][] | {name: .FqdnList | splits(\";\"), value: .Ip}]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "InstanceId": "i-11111111111111111",
              "ClusterName": "vpn",
              "Ip": "192.168.0.1",
              "FqdnList": "vpn.example.com",
              "Proxy": null
            }
          ],
          [
            {
              "InstanceId": "i-22222222222222222",
              "ClusterName": "sql",
              "Ip": "192.168.0.2",
              "FqdnList": "db.example.com;sql.example.com",
              "Proxy": "nginx"
            }
          ],
          [
            {
              "InstanceId": "i-33333333333333333",
              "ClusterName": "nginx",
              "Ip": "192.168.0.3",
              "FqdnList": "nginx.example.com;db.example.com;sql.example.com",
              "Proxy": null
            }
          ],
          [
            {
              "InstanceId": "i-44444444444444444",
              "ClusterName": "vpn",
              "Ip": "192.168.0.4",
              "FqdnList": "vpn.example.com",
              "Proxy": null
            }
          ],
          [
            {
              "InstanceId": "i-55555555555555555",
              "ClusterName": "nginx",
              "Ip": "192.168.0.5",
              "FqdnList": "nginx.example.com;db.example.com;sql.example.com",
              "Proxy": null
            }
          ]
        ],
        "output": {
          "vpn.example.com": [
            "192.168.0.1",
            "192.168.0.4"
          ],
          "db.example.com": [
            "192.168.0.3",
            "192.168.0.5"
          ],
          "sql.example.com": [
            "192.168.0.3",
            "192.168.0.5"
          ],
          "nginx.example.com": [
            "192.168.0.3",
            "192.168.0.5"
          ]
        }
      },
      {
        "input": [
          [
            {
              "InstanceId": "i-11111111111111111",
              "ClusterName": "vpn",
              "Ip": "192.168.0.1",
              "FqdnList": "vpn.example.com",
              "Proxy": null
            }
          ],
          [
            {
              "InstanceId": "i-22222222222222222",
              "ClusterName": "sql",
              "Ip": "192.168.0.2",
              "FqdnList": "db.example.com;sql.example.com",
              "Proxy": "nginx"
            }
          ],
          [
            {
              "InstanceId": "i-33333333333333333",
              "ClusterName": "nginx",
              "Ip": "192.168.0.3",
              "FqdnList": "nginx.example.com;db.example.com;sql.example.com",
              "Proxy": null
            }
          ],
          [
            {
              "InstanceId": "i-44444444444444444",
              "ClusterName": "vpn",
              "Ip": "192.168.0.4",
              "FqdnList": "vpn.example.com",
              "Proxy": null
            }
          ],
          [
            {
              "InstanceId": "i-55555555555555555",
              "ClusterName": "nginx",
              "Ip": "192.168.0.5",
              "FqdnList": "nginx.example.com;db.example.com;sql.example.com",
              "Proxy": null
            }
          ]
        ],
        "output": [
          {
            "name": "vpn.example.com",
            "value": "192.168.0.1"
          },
          {
            "name": "nginx.example.com",
            "value": "192.168.0.3"
          },
          {
            "name": "db.example.com",
            "value": "192.168.0.3"
          },
          {
            "name": "sql.example.com",
            "value": "192.168.0.3"
          },
          {
            "name": "vpn.example.com",
            "value": "192.168.0.4"
          },
          {
            "name": "nginx.example.com",
            "value": "192.168.0.5"
          },
          {
            "name": "db.example.com",
            "value": "192.168.0.5"
          },
          {
            "name": "sql.example.com",
            "value": "192.168.0.5"
          }
        ]
      }
    ],
    "identifier": 79413461
  },
  {
    "context": [
      "I\u2019d like to get the set of objects where the LastMofified dates are different.",
      "jq -s '\n  map(.AppCoreDetails) | transpose\n  | {AppCoreDetails: map(select(first != last)[0])}\n'",
      "jq -s 'map(.AppCoreDetails) | {AppCoreDetails: [JOIN(\n  INDEX(last[]; .ApplicationName); first[]; .ApplicationName; select(first != last)[0]\n)]}'",
      "Given the two sample inputs, both approaches output\n{\n  \"AppCoreDetails\": [\n    {\n      \"ApplicationName\": \"APP_Config_V1\",\n      \"LastModified\": \"2023-08-25 12:23:26\"\n    }\n  ]\n}"
    ],
    "utterance": "Find the application entries where ApplicationName matches between two server responses but LastModified dates differ.",
    "expressions": [
      "map(.AppCoreDetails) | transpose | {AppCoreDetails: map(select(first != last)[0])}",
      "map(.AppCoreDetails) | {AppCoreDetails: [JOIN(INDEX(last[]; .ApplicationName); first[]; .ApplicationName; select(first != last)[0])]}"
    ],
    "data": [
      {
        "input": [
          {
            "Node": "ESB1",
            "AppCoreDetails": [
              {
                "ApplicationName": "APP_Config_V1",
                "LastModified": "2023-08-25 12:23:26"
              },
              {
                "ApplicationName": "APP_Intervals_V1",
                "LastModified": "2022-11-23 14:46:58"
              }
            ]
          },
          {
            "Node": "ESB2",
            "AppCoreDetails": [
              {
                "ApplicationName": "APP_Config_V1",
                "LastModified": "2023-08-25 12:03:30"
              },
              {
                "ApplicationName": "APP_Intervals_V1",
                "LastModified": "2022-11-23 14:46:58"
              }
            ]
          }
        ],
        "output": {
          "AppCoreDetails": [
            {
              "ApplicationName": "APP_Config_V1",
              "LastModified": "2023-08-25 12:23:26"
            }
          ]
        }
      }
    ],
    "identifier": 79246132
  },
  {
    "context": [
      "I would like to create a csv file which would retain only the last \"title\" occurrence in each branch, but also memorize all the path to get to it and its destination page.",
      "Given your sample JSON input, you can use jq to",
      "- find all objects with an empty array under `.kids` (the leaves)",
      "- extract their paths and slice it to each occurrence of `\"kids\"` (the levels)",
      "- realize the data under these paths using `getpath`, then compose from it an array of values (the records)",
      "- and encode this array into a CSV output line using `@csv` (and `jq -r`)",
      "path(.. | objects | select(.kids == [])) as $p",
      "| [getpath($p | .[:.[[\"kids\"]][], length])]",
      "| [reverse[].title, last.destpageposfrom1]",
      "| @csv"
    ],
    "utterance": "For each leaf node, output a CSV row with the sequence of titles from the leaf up to the root, in order, along with the leaf's destpageposfrom1 value.",
    "expressions": [
      "path(.. | objects | select(.kids == [])) as $p\n| [getpath($p | .[:.[[\"kids\"]][], length])]\n| [reverse[].title, last.destpageposfrom1]\n| @csv"
    ],
    "data": [
      {
        "input": {
          "version": 2,
          "parameters": {
            "decodelevel": "generalized"
          },
          "outlines": [
            {
              "dest": [
                "4 0 R",
                "/Fit"
              ],
              "destpageposfrom1": 1,
              "kids": [
                {
                  "dest": [
                    "10 0 R",
                    "/Fit"
                  ],
                  "destpageposfrom1": 2,
                  "kids": [
                    {
                      "dest": [
                        "10 0 R",
                        "/Fit"
                      ],
                      "destpageposfrom1": 2,
                      "kids": [],
                      "object": "177 0 R",
                      "open": true,
                      "title": "Piece 1"
                    },
                    {
                      "dest": [
                        "15 0 R",
                        "/Fit"
                      ],
                      "destpageposfrom1": 3,
                      "kids": [],
                      "object": "178 0 R",
                      "open": true,
                      "title": "Piece 2"
                    }
                  ],
                  "object": "176 0 R",
                  "open": true,
                  "title": "Author 1"
                },
                {
                  "dest": [
                    "38 0 R",
                    "/Fit"
                  ],
                  "destpageposfrom1": 4,
                  "kids": [
                    {
                      "dest": [
                        "38 0 R",
                        "/Fit"
                      ],
                      "destpageposfrom1": 4,
                      "kids": [],
                      "object": "180 0 R",
                      "open": true,
                      "title": "Piece 3"
                    },
                    {
                      "dest": [
                        "45 0 R",
                        "/Fit"
                      ],
                      "destpageposfrom1": 5,
                      "kids": [
                        {
                          "dest": [
                            "45 0 R",
                            "/Fit"
                          ],
                          "destpageposfrom1": 5,
                          "kids": [],
                          "object": "182 0 R",
                          "open": true,
                          "title": "Movement 1"
                        },
                        {
                          "dest": [
                            "53 0 R",
                            "/Fit"
                          ],
                          "destpageposfrom1": 6,
                          "kids": [],
                          "object": "183 0 R",
                          "open": true,
                          "title": "Movement 2"
                        },
                        {
                          "dest": [
                            "58 0 R",
                            "/Fit"
                          ],
                          "destpageposfrom1": 7,
                          "kids": [],
                          "object": "184 0 R",
                          "open": true,
                          "title": "Movement 3"
                        }
                      ],
                      "object": "181 0 R",
                      "open": true,
                      "title": "Piece 4"
                    },
                    {
                      "dest": [
                        "79 0 R",
                        "/Fit"
                      ],
                      "destpageposfrom1": 8,
                      "kids": [],
                      "object": "185 0 R",
                      "open": true,
                      "title": "Piece 5"
                    }
                  ],
                  "object": "179 0 R",
                  "open": true,
                  "title": "Author 2"
                }
              ],
              "object": "175 0 R",
              "open": true,
              "title": "Contents"
            }
          ]
        },
        "output": [
          "\"Piece 1\",\"Author 1\",\"Contents\",2",
          "\"Piece 2\",\"Author 1\",\"Contents\",3",
          "\"Piece 3\",\"Author 2\",\"Contents\",4",
          "\"Movement 1\",\"Piece 4\",\"Author 2\",\"Contents\",5",
          "\"Movement 2\",\"Piece 4\",\"Author 2\",\"Contents\",6",
          "\"Movement 3\",\"Piece 4\",\"Author 2\",\"Contents\",7",
          "\"Piece 5\",\"Author 2\",\"Contents\",8"
        ]
      }
    ],
    "identifier": 79636504
  },
  {
    "context": [
      "I am trying to create a jq that is dynamic in returning data.",
      "User Story: I have data with many fields and not named like I want. I want to be able to based on the data and schema transform the data.",
      "schema is what it seems to be mad about.",
      "I have tested that .schema is available",
      "Try this:",
      "{\n  transformedArray: (\n    [.inputArray[] as $item |\n      reduce .schema[] as $s (\n        {}; \n        . + { ($s.new): $item[$s.input] }\n      )\n    ]\n  )\n}"
    ],
    "utterance": "Transform each object in inputArray, renaming fields as specified by schema, where each new field name in schema.new maps to the corresponding value from the key in schema.input.",
    "expressions": [
      "{\n  transformedArray: (\n    [.inputArray[] as $item |\n      reduce .schema[] as $s (\n        {}; \n        . + { ($s.new): $item[$s.input] }\n      )\n    ]\n  )\n}"
    ],
    "data": [
      {
        "input": {
          "inputArray": [
            {
              "objective_id": "ac-1_obj.a-1",
              "description": "an access control policy is developed and documented;",
              "framework_id": 1,
              "domain_id": "ac",
              "domaintitle": "Access Control",
              "id": 0,
              "control_id": "ac-1",
              "controltitle": "Policy and Procedures"
            },
            {
              "objective_id": "ac-1_obj.a-2",
              "description": "the access control policy is disseminated to {{ insert: param, ac-01_odp.01 }};",
              "framework_id": 1,
              "domain_id": "ac",
              "domaintitle": "Access Control",
              "id": 0,
              "control_id": "ac-1",
              "controltitle": "Policy and Procedures"
            },
            {
              "objective_id": "ac-1_obj.a-3",
              "description": "access control procedures to facilitate the implementation of the access control policy and associated controls are developed and documented;",
              "framework_id": 1,
              "domain_id": "ac",
              "domaintitle": "Access Control",
              "id": 0,
              "control_id": "ac-1",
              "controltitle": "Policy and Procedures"
            }
          ],
          "schema": [
            {
              "new": "objective",
              "input": "objective_id"
            },
            {
              "new": "framework",
              "input": "framework_id"
            },
            {
              "new": "control",
              "input": "control_id"
            },
            {
              "new": "title",
              "input": "controltitle"
            },
            {
              "new": "description",
              "input": "description"
            }
          ]
        },
        "output": {
          "transformedArray": [
            {
              "objective": "ac-1_obj.a-1",
              "framework": 1,
              "control": "ac-1",
              "title": "Policy and Procedures",
              "description": "an access control policy is developed and documented;"
            },
            {
              "objective": "ac-1_obj.a-2",
              "framework": 1,
              "control": "ac-1",
              "title": "Policy and Procedures",
              "description": "the access control policy is disseminated to {{ insert: param, ac-01_odp.01 }};"
            },
            {
              "objective": "ac-1_obj.a-3",
              "framework": 1,
              "control": "ac-1",
              "title": "Policy and Procedures",
              "description": "access control procedures to facilitate the implementation of the access control policy and associated controls are developed and documented;"
            }
          ]
        }
      }
    ],
    "identifier": 79099839
  },
  {
    "context": [
      "I try adding another select statement for the second condition, which I expect to narrow down to one entry.  But I get the same two entries:",
      "Loop over the `.Configs` first:",
      "jq --arg node \"host-inf-4\" '.[] | select (.SchedulerNodeName == $node).Configs[] | select(.PXType == \"data\").ID' /path/to/json",
      "# \"[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk\""
    ],
    "utterance": "Get the ID values of all entries where SchedulerNodeName is \"host-inf-4\" and the PXType in Configs is \"data\".",
    "expressions": [
      ".[] | select(.SchedulerNodeName == \"host-inf-4\").Configs[] | select(.PXType == \"data\").ID",
      "jq --arg node \"host-inf-4\" '.[] | select(.SchedulerNodeName == $node).Configs[] | select(.PXType == \"data\").ID'"
    ],
    "data": [
      {
        "input": {
          "1dfasdavsdfsvhoho028": {
            "Configs": {
              "[datastore-21] adsadaiuhwiorgwipo/_00ca/hipeghwerwjks.vmdk": {
                "Type": "zeroedthick",
                "Size": 32,
                "ID": "[datastore--21] adsadaiuhwiorgwipo/_00ca/hipeghwerwjks.vmdk",
                "PoolID": "",
                "Path": "/dev/sdc",
                "Iops": 0,
                "Vpus": 0,
                "PXType": "kvdb",
                "State": "Pending Add",
                "labels": {
                  "datastore": "vsanDatastore"
                },
                "AttachOptions": {
                  "ext": ".vmdk"
                },
                "Provisioner": "",
                "EncryptionKeyInfo": ""
              },
              "[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk": {
                "Type": "lazyzeroedthick",
                "Size": 150,
                "ID": "[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk",
                "PoolID": "a471iidfisaj8i8124asdadsoif8ie82",
                "Path": "/dev/sdb",
                "Iops": 0,
                "Vpus": 0,
                "PXType": "data",
                "State": "In Use",
                "labels": {
                  "datastore": "vsanDatastore"
                },
                "AttachOptions": {
                  "ext": ".vmdk"
                },
                "Provisioner": "",
                "EncryptionKeyInfo": ""
              }
            },
            "NodeID": "16a-8243r20-8fihqwc8-adew-2343ase",
            "ReservedInstanceID": "",
            "SchedulerNodeName": "host-inf-4",
            "NodeIndex": 12,
            "CreateTimestamp": "2024-11-22T00:27:38.432162311Z",
            "InstanceID": "42sdada08ihjpb3fe-6b-4873-0ya7-be80079acasca",
            "Zone": "default",
            "State": "In Use",
            "labels": {
              "px/metadata-node": "true"
            }
          },
          "asdada-42764533fff2": {
            "Configs": null,
            "NodeID": "1",
            "ReservedInstanceID": "",
            "SchedulerNodeName": "host-wkr-19",
            "NodeIndex": 19,
            "CreateTimestamp": "0001-01-01T00:00:00Z",
            "InstanceID": "asda0098q921",
            "Zone": "default",
            "State": "In Use",
            "labels": {
              "px/metadata-node": "false"
            }
          }
        },
        "output": "[datastore-21] ukisvljrosoowpg/_00mb/jjgowhohgiyfiaaawjo.vmdk"
      }
    ],
    "identifier": 79253065
  },
  {
    "context": [
      "I want to combine the two scripts so that for each element of the said array I do a jq invocation with the values of the keys: {base_file, ack_file}",
      "ie, in FP lingo, I want to flatmap the jq invocation demonstrated earlier to the elements of the array as constructed by the latter jq invocation. Have no idea how though.",
      "jq can only read the contents of named files if the filenames are provided on the command line,\nso your construction of '{base_file, ack_file}' objects won't help.",
      "However I believe your approach can be made to work by using the bash `while read` idiom\nalong the following lines:",
      "'cat \"$SUCCESS_FILE\" |\n jq -R '.,  (.[:-5] + \"_acknowledgement.json\")' |\n while read base_file ack_file ; do jq -s add \"$base_file\" \"$ack_file\" |\n     jq '.'\n done'",
      "where '.' in the last-most invocation of jq above is just a place-holder\nfor your main program."
    ],
    "utterance": "For each pair of base and acknowledgement file paths listed in SUCCESS_FILE, run a script that reads both files, merges their contents, and processes the result.",
    "expressions": [
      "cat \"$SUCCESS_FILE\" |\n jq -R '.,  (.[:-5] + \"_acknowledgement.json\")' |\n while read base_file ack_file ; do jq -s add \"$base_file\" \"$ack_file\" | jq '{ success: .result == \"ok\", event_type, start_time, end_time }'; done"
    ],
    "identifier": 79135225
  },
  {
    "context": [
      "I want to extract a CSV file out of this, I have tried several options I found by Googling, but none work. My objective is to get something like the following:\n\n    \"1.2.3.4\",\"name4\",\"test\",\"\"\n    \"1.2.3.5\",\"name5\",\"prod\",\"opt1,opt2\"\n    \"1.2.3.6\",\"name6\",\"qa\",\"\"\n    \"1.2.3.7\",\"name7\",\"staging\",\"opt3,opt4\"\n    \"1.2.3.8\",\"name8\",\"dev\",\"opt5\"\n    \"1.2.3.9\",\"name9\",\"prod\",\"opt6,opt7\"",
      "jq --raw-output '.hosts[] | [.name, .env, .options] | @csv' my_data.json\n\nThis is my result, but as seen is not complete. How do I add the key to every object?",
      "jq --raw-output '.hosts | keys_unsorted[] as $k | [$k, .[$k].name, .[$k].env, .[$k].options] | @csv' my_data.json\n\nWill return the desired output:\n\n    \"1.2.3.4\",\"name4\",\"test\",\"\"\n    \"1.2.3.5\",\"name5\",\"prod\",\"opt1,opt2\"\n    \"1.2.3.6\",\"name6\",\"qa\",\"\"\n    \"1.2.3.7\",\"name7\",\"statging\",\"opt3,opt4\"\n    \"1.2.3.8\",\"name8\",\"dev\",\"opt5\"\n    \"1.2.3.9\",\"name9\",\"prod\",\"opt6,opt7\"",
      ".hosts | to_entries[]\n| [.key, (.value | .name, .env, .options)] | @csv"
    ],
    "utterance": "Output each host's IP, name, env, and options as CSV rows including the IP address as the first column.",
    "expressions": [
      ".hosts | keys_unsorted[] as $k | [$k, .[$k].name, .[$k].env, .[$k].options] | @csv",
      ".hosts | to_entries[] | [.key, (.value | .name, .env, .options)] | @csv"
    ],
    "data": [
      {
        "input": {
          "hosts": {
            "1.2.3.4": {
              "name": "name4",
              "env": "test",
              "options": ""
            },
            "1.2.3.5": {
              "name": "name5",
              "env": "prod",
              "options": "opt1,opt2"
            },
            "1.2.3.6": {
              "name": "name6",
              "env": "qa",
              "options": ""
            },
            "1.2.3.7": {
              "name": "name7",
              "env": "staging",
              "options": "opt3,opt4"
            },
            "1.2.3.8": {
              "name": "name8",
              "env": "dev",
              "options": "opt5"
            },
            "1.2.3.9": {
              "name": "name9",
              "env": "prod",
              "options": "opt6,opt7"
            }
          }
        },
        "output": [
          "\"1.2.3.4\",\"name4\",\"test\",\"\"",
          "\"1.2.3.5\",\"name5\",\"prod\",\"opt1,opt2\"",
          "\"1.2.3.6\",\"name6\",\"qa\",\"\"",
          "\"1.2.3.7\",\"name7\",\"staging\",\"opt3,opt4\"",
          "\"1.2.3.8\",\"name8\",\"dev\",\"opt5\"",
          "\"1.2.3.9\",\"name9\",\"prod\",\"opt6,opt7\""
        ]
      }
    ],
    "identifier": 79134544
  },
  {
    "context": [
      "It seems you want to get rid of all CSV escapes, and use semicolons as delimiters. In that case you could use `join` instead of `@csv`.",
      "Assuming the following input (from looking at your own attempt), you\u2019d get:",
      "jq -r '\n  [\"Group\",\"Area\",\"Total\"], (.[]\n    | .MetaData as $meta | .Data[]\n    | [$meta[1,2].Nombre, (.Valor | tostring | sub(\"\\\\.\"; \",\"))]\n  ) | join(\";\")\n'"
    ],
    "utterance": "Output table with columns Group, Area, Total using semicolons as delimiters and replace the decimal point with a comma in the Total field.",
    "expressions": [
      "[\"Group\",\"Area\",\"Total\"], (.[] | .MetaData as $meta | .Data[] | [$meta[1,2].Nombre, (.Valor | tostring | sub(\"\\\\.\"; \",\"))]) | join(\";\")"
    ],
    "data": [
      {
        "input": [
          {
            "MetaData": [
              {
                "Nombre": ""
              },
              {
                "Nombre": "A"
              },
              {
                "Nombre": 2
              }
            ],
            "Data": [
              {
                "Valor": 11.76
              },
              {
                "Valor": 11.84
              }
            ]
          }
        ],
        "output": "Group;Area;Total\nA;2;11,76\nA;2;11,84"
      }
    ],
    "identifier": 79311905
  },
  {
    "context": [
      "I want to get the below command output in table format using Linux commands:",
      "Current output:",
      "\"arn:aws:sts::accountnum:assumed-role/role/user@com\"",
      "\"2024-11-29T06:48:05Z\"",
      "\"Success\"",
      "For CSV output, change your second jq invocation to:",
      "jq \u2018 [.userIdentity.arn, .eventTime, .responseElements.ConsoleLogin]\n| @csv\u2019",
      "You might want to combine the two invocations into one, and/or use `@tsv` or `join(\"|\")` instead of `@csv`."
    ],
    "utterance": "Produce tabular output with arn, event time, and ConsoleLogin status fields for each event, with fields separated by commas or tabs.",
    "expressions": [
      ".Events[].CloudTrailEvent | fromjson | [.userIdentity.arn, .eventTime, .responseElements.ConsoleLogin] | @csv",
      ".Events[].CloudTrailEvent | fromjson | [.userIdentity.arn, .eventTime, .responseElements.ConsoleLogin] | @tsv",
      ".Events[].CloudTrailEvent | fromjson | [.userIdentity.arn, .eventTime, .responseElements.ConsoleLogin] | join(\"|\")"
    ],
    "identifier": 79237305
  },
  {
    "context": [
      "in the following example I have two arrays (timestamp and values) that are related by the same index, so timestamps[0] is related to values[0], timestamps[1] is related to values[1], ...",
      "I need to print each one in a row like this:",
      "1730135460000 15",
      "1730137620000 23",
      "But instead I am getting:",
      "1730135460000 1730137620000 15 23",
      "Put just the arrays (don't destructure them with `.[]`) into an outer array, and use `transpose` to zip them. Then, you can iterate over the result array to get the individual sub-arrays.",
      "jq -r '[.timestamps, .values] | transpose[] | @tsv'",
      "1730135460000\t15",
      "1730137620000\t23"
    ],
    "utterance": "Print each pair of elements at the same index from the 'timestamps' and 'values' arrays as rows with both values separated by a space.",
    "expressions": [
      "[.timestamps, .values] | transpose[] | @tsv"
    ],
    "data": [
      {
        "input": {
          "timestamps": [
            "1730135460000",
            "1730137620000"
          ],
          "values": [
            "15",
            "23"
          ]
        },
        "output": "1730135460000\t15\n1730137620000\t23"
      }
    ],
    "identifier": 79134868
  },
  {
    "context": [
      "And I need to write a `jq` dynamic filter (the depth of the json is not predictible) that produce the exact same output in every situations.",
      "Processing this JSON with the BASH function produce this output : \n\nsuccess = true\nresult[0].duplex = full\nresult[0].mac_list[0].mac = 00:00:00:2F:8E:AB\nresult[0].mac_list[0].hostname = firewall-net90d\nresult[0].mac_list[0] = {\"mac\":00:00:00:2F:8E:AB,\"hostname\":firewall-net90d}\nresult[0].mac_list = [{\"mac\":00:00:00:2F:8E:AB,\"hostname\":firewall-net90d}]\nresult[0].name = Ethernet 1\n...etc...",
      "With `paths` you won\u2019t get the exact traversal order of your expected output. If this is not important, here\u2019s one approach using your attempt with `paths`:",
      "paths as $p |\n\"\\([$p[] | \".\" + strings // \"[\\(.)]\" ] | add[1:]) = \\(getpath($p))\"",
      "To retain the order, write a postfix-recursive function that nests the way you want it. For example:",
      "def f($p): f($p + (getpath($p) | iterables | keys_unsorted[] |[.])),\n\"\\([$p[] | \".\" + strings // \"[\\(.)]\" ] | add[1:] | values) = \\(getpath($p))\";\nf([])"
    ],
    "utterance": "Produce for every key, value, and container in a nested structure an assignment line using fully bracketed paths (e.g., result[0].mac_list[0].mac = 00:00:...), at every depth and array element, recursively, matching the output and path formatting of a specified bash function.",
    "expressions": [
      "paths as $p | \"\\([$p[] | \".\" + strings // \"[\\(.)]\" ] | add[1:]) = \\(getpath($p))\"",
      "def f($p): f($p + (getpath($p) | iterables | keys_unsorted[] |[.])), \"\\([$p[] | \".\" + strings // \"[\\(.)]\" ] | add[1:] | values) = \\(getpath($p))\"; f([])"
    ],
    "data": [
      {
        "input": {
          "success": true,
          "result": [
            {
              "duplex": "full",
              "mac_list": [
                {
                  "mac": "00:00:00:2F:8E:AB",
                  "hostname": "firewall-net90d"
                }
              ],
              "name": "Ethernet 1",
              "link": "up",
              "id": 1,
              "mode": "1000BaseT-FD",
              "speed": "1000",
              "rrd_id": "1"
            },
            {
              "duplex": "half",
              "name": "Ethernet 2",
              "link": "down",
              "id": 2,
              "mode": "10BaseT-HD",
              "speed": "10",
              "rrd_id": "2"
            },
            {
              "duplex": "half",
              "name": "Ethernet 3",
              "link": "down",
              "id": 3,
              "mode": "10BaseT-HD",
              "speed": "10",
              "rrd_id": "3"
            },
            {
              "duplex": "half",
              "name": "Ethernet 4",
              "link": "down",
              "id": 4,
              "mode": "10BaseT-HD",
              "speed": "10",
              "rrd_id": "4"
            },
            {
              "duplex": "full",
              "name": "NBAplug",
              "link": "up",
              "id": 5,
              "mode": "1000BaseT-FD",
              "speed": "1000",
              "rrd_id": "nbaplug"
            },
            {
              "duplex": "auto",
              "mac_list": [
                {
                  "mac": "00:00:00:43:B3:73",
                  "hostname": "00:00:00:43:B3:73"
                },
                {
                  "mac": "00:00:00:1A:66:60",
                  "hostname": "00:00:00:1A:66:60"
                },
                {
                  "mac": "00:00:00:09:00:13",
                  "hostname": "00:00:00:09:00:13"
                },
                {
                  "mac": "00:00:00:80:29:7C",
                  "hostname": "abcd-PLAYER"
                },
                {
                  "mac": "00:00:00:09:00:12",
                  "hostname": "firewall-net101f-cluster"
                },
                {
                  "mac": "00:00:00:A0:EF:82",
                  "hostname": "00:00:00:A0:EF:82"
                }
              ],
              "name": "Sfp lan",
              "link": "up",
              "id": 9999,
              "mode": "10000-FD",
              "speed": "10000",
              "rrd_id": "sfp_lan"
            }
          ]
        },
        "output": "success = true\nresult[0].duplex = full\nresult[0].mac_list[0].mac = 00:00:00:2F:8E:AB\nresult[0].mac_list[0].hostname = firewall-net90d\nresult[0].mac_list[0] = {\"mac\":00:00:00:2F:8E:AB,\"hostname\":firewall-net90d}\nresult[0].mac_list = [{\"mac\":00:00:00:2F:8E:AB,\"hostname\":firewall-net90d}]\nresult[0].name = Ethernet 1\nresult[0].link = up\nresult[0].id = 1\nresult[0].mode = 1000BaseT-FD\nresult[0].speed = 1000\nresult[0].rrd_id = 1\nresult[0] = {\"duplex\":full,\"mac_list\":[{\"mac\":00:00:00:2F:8E:AB,\"hostname\":firewall-net90d}],\"name\":Ethernet 1,\"link\":up,\"id\":1,\"mode\":1000BaseT-FD,\"speed\":1000,\"rrd_id\":1}\nresult[1].duplex = half\nresult[1].name = Ethernet 2\nresult[1].link = down\nresult[1].id = 2\nresult[1].mode = 10BaseT-HD\nresult[1].speed = 10\nresult[1].rrd_id = 2\nresult[1] = {\"duplex\":half,\"name\":Ethernet 2,\"link\":down,\"id\":2,\"mode\":10BaseT-HD,\"speed\":10,\"rrd_id\":2}\nresult[2].duplex = half\nresult[2].name = Ethernet 3\nresult[2].link = down\nresult[2].id = 3\nresult[2].mode = 10BaseT-HD\nresult[2].speed = 10\nresult[2].rrd_id = 3\nresult[2] = {\"duplex\":half,\"name\":Ethernet 3,\"link\":down,\"id\":3,\"mode\":10BaseT-HD,\"speed\":10,\"rrd_id\":3}\nresult[3].duplex = half\nresult[3].name = Ethernet 4\nresult[3].link = down\nresult[3].id = 4\nresult[3].mode = 10BaseT-HD\nresult[3].speed = 10\nresult[3].rrd_id = 4\nresult[3] = {\"duplex\":half,\"name\":Ethernet 4,\"link\":down,\"id\":4,\"mode\":10BaseT-HD,\"speed\":10,\"rrd_id\":4}\nresult[4].duplex = full\nresult[4].name = NBAplug\nresult[4].link = up\nresult[4].id = 5\nresult[4].mode = 1000BaseT-FD\nresult[4].speed = 1000\nresult[4].rrd_id = nbaplug\nresult[4] = {\"duplex\":full,\"name\":NBAplug,\"link\":up,\"id\":5,\"mode\":1000BaseT-FD,\"speed\":1000,\"rrd_id\":nbaplug}\nresult[5].duplex = auto\nresult[5].mac_list[0].mac = 00:00:00:43:B3:73\nresult[5].mac_list[0].hostname = 00:00:00:43:B3:73\nresult[5].mac_list[0] = {\"mac\":00:00:00:43:B3:73,\"hostname\":00:00:00:43:B3:73}\nresult[5].mac_list[1].mac = 00:00:00:1A:66:60\nresult[5].mac_list[1].hostname = 00:00:00:1A:66:60\nresult[5].mac_list[1] = {\"mac\":00:00:00:1A:66:60,\"hostname\":00:00:00:1A:66:60}\nresult[5].mac_list[2].mac = 00:00:00:09:00:13\nresult[5].mac_list[2].hostname = 00:00:00:09:00:13\nresult[5].mac_list[2] = {\"mac\":00:00:00:09:00:13,\"hostname\":00:00:00:09:00:13}\nresult[5].mac_list[3].mac = 00:00:00:80:29:7C\nresult[5].mac_list[3].hostname = abcd-PLAYER\nresult[5].mac_list[3] = {\"mac\":00:00:00:80:29:7C,\"hostname\":abcd-PLAYER}\nresult[5].mac_list[4].mac = 00:00:00:09:00:12\nresult[5].mac_list[4].hostname = firewall-net101f-cluster\nresult[5].mac_list[4] = {\"mac\":00:00:00:09:00:12,\"hostname\":firewall-net101f-cluster}\nresult[5].mac_list[5].mac = 00:00:00:A0:EF:82\nresult[5].mac_list[5].hostname = 00:00:00:A0:EF:82\nresult[5].mac_list[5] = {\"mac\":00:00:00:A0:EF:82,\"hostname\":00:00:00:A0:EF:82}\nresult[5].mac_list = [{\"mac\":00:00:00:43:B3:73,\"hostname\":00:00:00:43:B3:73},{\"mac\":00:00:00:1A:66:60,\"hostname\":00:00:00:1A:66:60},{\"mac\":00:00:00:09:00:13,\"hostname\":00:00:00:09:00:13},{\"mac\":00:00:00:80:29:7C,\"hostname\":abcd-PLAYER},{\"mac\":00:00:00:09:00:12,\"hostname\":firewall-net101f-cluster},{\"mac\":00:00:00:A0:EF:82,\"hostname\":00:00:00:A0:EF:82}]\nresult[5].name = Sfp lan\nresult[5].link = up\nresult[5].id = 9999\nresult[5].mode = 10000-FD\nresult[5].speed = 10000\nresult[5].rrd_id = sfp_lan\nresult[5] = {\"duplex\":auto,\"mac_list\":[{\"mac\":00:00:00:43:B3:73,\"hostname\":00:00:00:43:B3:73},{\"mac\":00:00:00:1A:66:60,\"hostname\":00:00:00:1A:66:60},{\"mac\":00:00:00:09:00:13,\"hostname\":00:00:00:09:00:13},{\"mac\":00:00:00:80:29:7C,\"hostname\":abcd-PLAYER},{\"mac\":00:00:00:09:00:12,\"hostname\":firewall-net101f-cluster},{\"mac\":00:00:00:A0:EF:82,\"hostname\":00:00:00:A0:EF:82}],\"name\":Sfp lan,\"link\":up,\"id\":9999,\"mode\":10000-FD,\"speed\":10000,\"rrd_id\":sfp_lan}\nresult = [{\"duplex\":full,\"mac_list\":[{\"mac\":00:00:00:2F:8E:AB,\"hostname\":firewall-net90d}],\"name\":Ethernet 1,\"link\":up,\"id\":1,\"mode\":1000BaseT-FD,\"speed\":1000,\"rrd_id\":1},{\"duplex\":half,\"name\":Ethernet 2,\"link\":down,\"id\":2,\"mode\":10BaseT-HD,\"speed\":10,\"rrd_id\":2},{\"duplex\":half,\"name\":Ethernet 3,\"link\":down,\"id\":3,\"mode\":10BaseT-HD,\"speed\":10,\"rrd_id\":3},{\"duplex\":half,\"name\":Ethernet 4,\"link\":down,\"id\":4,\"mode\":10BaseT-HD,\"speed\":10,\"rrd_id\":4},{\"duplex\":full,\"name\":NBAplug,\"link\":up,\"id\":5,\"mode\":1000BaseT-FD,\"speed\":1000,\"rrd_id\":nbaplug},{\"duplex\":auto,\"mac_list\":[{\"mac\":00:00:00:43:B3:73,\"hostname\":00:00:00:43:B3:73},{\"mac\":00:00:00:1A:66:60,\"hostname\":00:00:00:1A:66:60},{\"mac\":00:00:00:09:00:13,\"hostname\":00:00:00:09:00:13},{\"mac\":00:00:00:80:29:7C,\"hostname\":abcd-PLAYER},{\"mac\":00:00:00:09:00:12,\"hostname\":firewall-net101f-cluster},{\"mac\":00:00:00:A0:EF:82,\"hostname\":00:00:00:A0:EF:82}],\"name\":Sfp lan,\"link\":up,\"id\":9999,\"mode\":10000-FD,\"speed\":10000,\"rrd_id\":sfp_lan}]"
      }
    ],
    "identifier": 79115246
  },
  {
    "context": [
      "And I wanted to get the name of the fish with the version equal to current_fish_version.",
      ".current_fish_version as $version\n| .fish[]\n| select(.version == $version)\n| .name"
    ],
    "utterance": "Get the name of the fish where version is equal to current_fish_version.",
    "expressions": [
      ".current_fish_version as $version | .fish[] | select(.version == $version) | .name"
    ],
    "data": [
      {
        "input": {
          "fish": [
            {
              "name": "pike",
              "version": 1
            },
            {
              "name": "haddock",
              "version": 2
            }
          ],
          "current_fish_version": 2
        },
        "output": "haddock"
      }
    ],
    "identifier": 79659475
  },
  {
    "context": [
      "I would like to transform \"SysID\" into key and \"Name\" as the value of it in array:",
      "reduce .[] as $i ({}; .[$i.SysID] += [$i.Name])",
      "When called with [`--slurp`][2] to wrap those object into an array.",
      "jq 'group_by(.SysID)|map({(.[0].SysID): map(.Name)})|add'"
    ],
    "utterance": "Group objects by SysID, making each SysID a key whose value is an array of all associated Name values.",
    "expressions": [
      "reduce .[] as $i ({}; .[$i.SysID] += [$i.Name])",
      "group_by(.SysID) | map({(.[0].SysID): map(.Name)}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "SysID": "12345",
            "Name": "abc"
          },
          {
            "SysID": "12345",
            "Name": "def"
          },
          {
            "SysID": "23456",
            "Name": "hij"
          },
          {
            "SysID": "23456",
            "Name": "klm"
          },
          {
            "SysID": "23456",
            "Name": "nop"
          }
        ],
        "output": {
          "12345": [
            "abc",
            "def"
          ],
          "23456": [
            "hij",
            "klm",
            "nop"
          ]
        }
      }
    ],
    "identifier": 79118603
  },
  {
    "context": [
      "I want to apply one function to all descendants of a particular node in a tree, and a different function to all other nodes, in the following way:",
      "if path_matches(.deep.path.matching) then change_x else delete_y end",
      "With this input ...",
      "the output should be:",
      "One way could be to iterate over all `paths` (matching my added condition), then check for your path condition, and use `setpath` or `delpaths` accordingly:",
      "reduce paths(objects | has(\"x\") and has(\"y\")) as $p (.;\n  if $p[:3] == [\"deep\",\"path\",\"matching\"]\n  then setpath($p + [\"x\"]; \"changed\")\n  else delpaths([$p + [\"y\"]]) end\n)"
    ],
    "utterance": "Change all 'x' values under 'deep.path.matching' to \"changed\", and delete all 'y' values in other objects where both 'x' and 'y' keys are present.",
    "expressions": [
      "reduce paths(objects | has(\"x\") and has(\"y\")) as $p (.;\n  if $p[:3] == [\"deep\",\"path\",\"matching\"]\n  then setpath($p + [\"x\"]; \"changed\")\n  else delpaths([$p + [\"y\"]]) end\n)"
    ],
    "data": [
      {
        "input": {
          "deep": {
            "path": {
              "matching": {
                "m": {
                  "x": "change it",
                  "y": "don't touch"
                },
                "n": {
                  "nn": {
                    "x": "change it",
                    "y": "don't touch"
                  }
                }
              },
              "other_a": {
                "a": {
                  "x": "don't touch",
                  "y": "delete it"
                }
              },
              "other_b": {
                "b": {
                  "bb": {
                    "x": "don't touch",
                    "y": "delete it"
                  }
                }
              }
            }
          },
          "another_other": {
            "x": "don't touch",
            "y": "delete it"
          }
        },
        "output": {
          "deep": {
            "path": {
              "matching": {
                "m": {
                  "x": "changed",
                  "y": "don't touch"
                },
                "n": {
                  "nn": {
                    "x": "changed",
                    "y": "don't touch"
                  }
                }
              },
              "other_a": {
                "a": {
                  "x": "don't touch"
                }
              },
              "other_b": {
                "b": {
                  "bb": {
                    "x": "don't touch"
                  }
                }
              }
            }
          },
          "another_other": {
            "x": "don't touch"
          }
        }
      }
    ],
    "identifier": 79637297
  },
  {
    "context": [
      "Basically I can't work with more than one key out of the json file. I need to work with more than one. How would a solution look like?"
    ],
    "utterance": "Extract both 'path' and 'path_with_namespace' values from each object in the array.",
    "expressions": [
      ".[] | {path, path_with_namespace}",
      ".[] | [.path, .path_with_namespace]"
    ],
    "data": [
      {
        "input": [
          {
            "path": "path1",
            "path_with_namespace": "path_with_namespace1"
          },
          {
            "path": "path2",
            "path_with_namespace": "path_with_namespace2"
          }
        ],
        "output": [
          {
            "path": "path1",
            "path_with_namespace": "path_with_namespace1"
          },
          {
            "path": "path2",
            "path_with_namespace": "path_with_namespace2"
          }
        ]
      }
    ],
    "identifier": 79133886
  },
  {
    "context": [
      "And, in the even that some fields, like `comments` isn't null, I need to strip out newlines and tabs. If it is null, then keep it null",
      "Since you want to keep the nulls, you could use ? on the RHS:",
      "map(.comments |= ( (gsub(\"\\r\\n\"; \"\") | gsub(\"\\t\"; \"\"))? // null ))   |",
      "And for brevity, you could combine the two calls to gsub:",
      "gsub(\"(\\r\\n)|\\t\"; \"\")"
    ],
    "utterance": "For each object, remove all newlines and tabs from the comments field if it is present and non-null; otherwise, leave comments as null.",
    "expressions": [
      "map(.comments |= ((gsub(\"\\r\\n\"; \"\") | gsub(\"\\t\"; \"\"))? // null))",
      "map(.comments |= ((gsub(\"(\\r\\n)|\\t\"; \"\"))? // null))"
    ],
    "data": [
      {
        "input": [
          {
            "alert_timestamp": "2024-10-23T08:49:08Z",
            "odin_timestamp": "2024-10-23T08:50:10Z",
            "alert_url": null,
            "comments": "A\tcomment\nwith newlines\r\nand\ttabs",
            "owner": null,
            "updated_date": null,
            "clear_timestamp": "2024-10-23T09:27:39Z",
            "outage_duration_in_minutes": 38.52,
            "published_on": "DEFAULT",
            "atr_exec_id": null,
            "atr_status": null
          },
          {
            "alert_timestamp": "2024-10-23T08:49:08Z",
            "odin_timestamp": "2024-10-23T08:50:10Z",
            "alert_url": null,
            "comments": null,
            "owner": null,
            "updated_date": null,
            "clear_timestamp": "2024-10-23T09:27:39Z",
            "outage_duration_in_minutes": 38.52,
            "published_on": "DEFAULT",
            "atr_exec_id": null,
            "atr_status": null
          }
        ],
        "output": [
          {
            "alert_timestamp": "2024-10-23T08:49:08Z",
            "odin_timestamp": "2024-10-23T08:50:10Z",
            "alert_url": null,
            "comments": "Acommentwith newlinesandtabs",
            "owner": null,
            "updated_date": null,
            "clear_timestamp": "2024-10-23T09:27:39Z",
            "outage_duration_in_minutes": 38.52,
            "published_on": "DEFAULT",
            "atr_exec_id": null,
            "atr_status": null
          },
          {
            "alert_timestamp": "2024-10-23T08:49:08Z",
            "odin_timestamp": "2024-10-23T08:50:10Z",
            "alert_url": null,
            "comments": null,
            "owner": null,
            "updated_date": null,
            "clear_timestamp": "2024-10-23T09:27:39Z",
            "outage_duration_in_minutes": 38.52,
            "published_on": "DEFAULT",
            "atr_exec_id": null,
            "atr_status": null
          }
        ]
      }
    ],
    "identifier": 79135057
  },
  {
    "context": [
      "I need to update or create the \"release\" tag with given version under given environment.",
      "It can be empty file with just empty object { }",
      "It can have empty \"environemnts\" array",
      "It can have some entries in environment array but not the one we want to update",
      "jq --arg release 1.2 '.environments += [{\"name\":\"prod\",\"release\":$release}]\n                      | del(.environments[]\n                            | select(.name == \"prod\" and .release != $release))'",
      ".environments |= [\n  INDEX(.[]?; .name) | .prod = {name: \"prod\", release: \"2.0\"} | .[]\n]"
    ],
    "utterance": "Update or create an object with name equal to prod, setting its release to a given value, in the environments array; if the array or object does not exist, create them.",
    "expressions": [
      "jq --arg release 1.2 '.environments += [{\"name\":\"prod\",\"release\":$release}] | del(.environments[] | select(.name == \"prod\" and .release != $release))'",
      ".environments |= [INDEX(.[]?; .name) | .prod = {name: \"prod\", release: \"2.0\"} | .[]]"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "environments": [
            {
              "name": "prod",
              "release": "2.0"
            }
          ]
        }
      },
      {
        "input": {
          "environments": []
        },
        "output": {
          "environments": [
            {
              "name": "prod",
              "release": "2.0"
            }
          ]
        }
      },
      {
        "input": {
          "environments": [
            {
              "name": "test",
              "release": "2.0"
            }
          ]
        },
        "output": {
          "environments": [
            {
              "name": "test",
              "release": "2.0"
            },
            {
              "name": "prod",
              "release": "2.0"
            }
          ]
        }
      },
      {
        "input": {
          "environments": [
            {
              "name": "test",
              "release": "2.0"
            },
            {
              "name": "prod",
              "release": "1.0"
            }
          ]
        },
        "output": {
          "environments": [
            {
              "name": "test",
              "release": "2.0"
            },
            {
              "name": "prod",
              "release": "2.0"
            }
          ]
        }
      }
    ],
    "identifier": 79098307
  },
  {
    "context": [
      "The jq command fails in the call to `startswith` - as if `startswith` only accepted string literals. If I change `startswith(.first_name)` to `startswith(\"John\")` then the expression compiles and works as expected.",
      "Generally speaking, to reference a value at a later time (when it has gone out of context), bind a variable to it when it's still in context, and use that instead later:\n```sh\nif .first_name as $fn | .last_name | startswith($fn) then \u2026\n```",
      ". as $obj | {name: (if $obj.last_name | startswith($obj.first_name) then \u2026)}",
      "{\n  name: (\n    if startswith(.last_name; .first_name)\n    then .last_name else \"\\(.first_name) \\(.last_name)\"\n    end\n  )\n}"
    ],
    "utterance": "For each object, output an object with property 'name', using only the last name if it starts with the first name, otherwise concatenating first and last name with a space.",
    "expressions": [
      "{ name: (if .first_name as $fn | .last_name | startswith($fn) then .last_name else .first_name + \" \" + .last_name end) }",
      ". as $obj | { name: (if $obj.last_name | startswith($obj.first_name) then $obj.last_name else $obj.first_name + \" \" + $obj.last_name end) }",
      "def startswith($whole; $part): $whole | startswith($part);\n{\n  name: (\n    if startswith(.last_name; .first_name)\n    then .last_name else \"\\(.first_name) \\(.last_name)\"\n    end\n  )\n}"
    ],
    "data": [
      {
        "input": {
          "first_name": "John",
          "last_name": "Johnson"
        },
        "output": {
          "name": "Johnson"
        }
      },
      {
        "input": {
          "first_name": "Jane",
          "last_name": "Smith"
        },
        "output": {
          "name": "Jane Smith"
        }
      }
    ],
    "identifier": 79269732
  },
  {
    "context": [
      "I can do a query where dev is eth0 and not the default gateway:",
      "$ jq '. [] | if .dev == \"eth0\" and .dst != \"default\" then . else empty end' ip_routes.json",
      "If I try to select specific properties in the output their association with the object is lost:",
      "jq '. [] | if .dev == \"eth0\" and .dst != \"default\" then .dev, .prefsrc  else empty end' ip_routes.json",
      "How do get something like this?",
      "[",
      "  {",
      "    \"eth0\",",
      "    \"10.1.201.74\"",
      "  }",
      "  ,",
      "  {",
      "    \"eth0\",",
      "    \"10.1.202.74\"",
      "  }",
      "]",
      "Getting an array of objects using {dev, prefsrc}:",
      "map(select(.dev == \"eth0\" and .dst != \"default\") | {dev, prefsrc})",
      "[",
      "  {",
      "    \"dev\": \"eth0\",",
      "    \"prefsrc\": \"10.1.201.74\"",
      "  },",
      "  {",
      "    \"dev\": \"eth0\",",
      "    \"prefsrc\": \"10.1.202.74\"",
      "  }",
      "]",
      "Getting an array of arrays using [.dev, .prefsrc]:",
      "map(select(.dev == \"eth0\" and .dst != \"default\") | [.dev, .prefsrc])",
      "[",
      "  [",
      "    \"eth0\",",
      "    \"10.1.201.74\"",
      "  ],",
      "  [",
      "    \"eth0\",",
      "    \"10.1.202.74\"",
      "  ]",
      "]"
    ],
    "utterance": "Extract all items where dev equals eth0 and dst is not default, returning only dev and prefsrc properties for each matching item.",
    "expressions": [
      ". | map(select(.dev == \"eth0\" and .dst != \"default\") | {dev, prefsrc})",
      ". | map(select(.dev == \"eth0\" and .dst != \"default\") | [.dev, .prefsrc])"
    ],
    "data": [
      {
        "input": [
          {
            "dst": "default",
            "gateway": "10.1.201.1",
            "dev": "eth0"
          },
          {
            "dst": "10.1.201.0/24",
            "dev": "eth0",
            "prefsrc": "10.1.201.74"
          },
          {
            "dst": "10.1.202.0/24",
            "dev": "eth0",
            "prefsrc": "10.1.202.74"
          },
          {
            "dst": "10.244.0.0/24",
            "dev": "cni0",
            "prefsrc": "10.244.0.1"
          },
          {
            "dst": "10.244.0.0/22",
            "dev": "cni0",
            "scope": "link",
            "flags": []
          }
        ],
        "output": [
          {
            "dev": "eth0",
            "prefsrc": "10.1.201.74"
          },
          {
            "dev": "eth0",
            "prefsrc": "10.1.202.74"
          }
        ]
      },
      {
        "input": [
          {
            "dst": "default",
            "gateway": "10.1.201.1",
            "dev": "eth0"
          },
          {
            "dst": "10.1.201.0/24",
            "dev": "eth0",
            "prefsrc": "10.1.201.74"
          },
          {
            "dst": "10.1.202.0/24",
            "dev": "eth0",
            "prefsrc": "10.1.202.74"
          },
          {
            "dst": "10.244.0.0/24",
            "dev": "cni0",
            "prefsrc": "10.244.0.1"
          },
          {
            "dst": "10.244.0.0/22",
            "dev": "cni0",
            "scope": "link",
            "flags": []
          }
        ],
        "output": [
          [
            "eth0",
            "10.1.201.74"
          ],
          [
            "eth0",
            "10.1.202.74"
          ]
        ]
      }
    ],
    "identifier": 79306616
  },
  {
    "context": [
      "`jq -nR '[inputs | split(\" +\"; null).[3]] | reverse.[] | \"bkt --ttl '1h' -- aws s3 cp s3://REDACTED/(.) - | tac\"' -r | bash | head`",
      "jq -nR '[inputs | split(\" +\"; null).[3]] | reverse.[] | \"bkt --ttl '1h' -- aws s3 cp s3://REDACTED/(.) - | tail -10\"' -r | bash | head",
      "'[inputs | split(\" +\"; null).[3]] | reverse.[] | \"bkt --ttl '1h' -- aws s3 get-object --bucket: REDACTED --key \\(.) --range=bytes=2000 | tail -10\"' -r"
    ],
    "utterance": "Generate commands for each S3 object name (extracted from column 4 of each line), ordering them in reverse, so each command downloads the object and outputs only its last 10 lines.",
    "expressions": [
      "[inputs | split(\" +\"; null).[3]] | reverse.[] | \"bkt --ttl '1h' -- aws s3 cp s3://REDACTED/(.) - | tail -10\""
    ],
    "identifier": 79275641
  },
  {
    "context": [
      "Properties in those files are in random order.",
      "That parameter for .\\jq does work, but nested objects are not affected:",
      "But is there any way that will sort properties also inside these objects (even if that would flatten them)?",
      "`jq` does have an option that sorts all the keys inside the objects (see the [manual](https://jqlang.org/manual/)):",
      "--sort-keys / -S:\n\n        Output the fields of each object with the keys in sorted order.",
      "So you can just use the following command:\n\njq --sort-keys .",
      "Or, in WinMerge syntax:\n\nQueryJSON --sort-keys \".\""
    ],
    "utterance": "Sort all properties at every object level by key, including nested objects.",
    "expressions": [
      "jq --sort-keys .",
      "QueryJSON --sort-keys \".\""
    ],
    "data": [
      {
        "input": {
          "Id": 1,
          "Addresses": [
            {
              "Street": "Street 1",
              "PostalCode": 12345
            },
            {
              "Street": "Street 2",
              "PostalCode": 12345
            }
          ],
          "Person": {
            "FirstName": "Mike",
            "LastName": "Boe"
          }
        }
      },
      {
        "input": {
          "Id": 2,
          "Person": {
            "FirstName": "John",
            "LastName": "Boe"
          },
          "Addresses": [
            {
              "Street": "Street 3",
              "PostalCode": 12345
            },
            {
              "Street": "Street 2",
              "PostalCode": 12345
            }
          ]
        }
      }
    ],
    "identifier": 79184922
  },
  {
    "context": [
      "Is there anyway to extract a list with all packages which contain the string `fence-agents`?",
      "loop: \"{{ ansible_facts.packages | select('search', regex) }}\"",
      "vars:\n  regex: 'fence-agents*'"
    ],
    "utterance": "Extract all package names containing the substring 'fence-agents'.",
    "expressions": [
      "to_entries | map(select(.key | test(\"fence-agents\"))) | map(.key)"
    ],
    "identifier": 79275125
  },
  {
    "context": [
      "i want to \"ungroup\" it into a csv-like output ",
      "a1\tb1\td1.1",
      "a1\tb1\td1.2",
      "a2\tb2\td2.1",
      "a2\tb2\td2.2",
      "a2\tb2\td2.3",
      ".[] | .user as $user | .data[] | [$user.foo, $user.bar, .beq] | @tsv",
      ".[] | [.user | .foo, .bar] + (.data[] | [.beq]) | @tsv"
    ],
    "utterance": "Produce a table with each row containing the values of user.foo, user.bar, and each inner data.beq.",
    "expressions": [
      ".[] | .user as $user | .data[] | [$user.foo, $user.bar, .beq] | @tsv",
      ".[] | [.user | .foo, .bar] + (.data[] | [.beq]) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "user": {
              "foo": "a1",
              "bar": "b1"
            },
            "data": [
              {
                "baz": "c1.1",
                "beq": "d1.1"
              },
              {
                "baz": "c1.2",
                "beq": "d1.2"
              }
            ]
          },
          {
            "user": {
              "foo": "a2",
              "bar": "b2"
            },
            "data": [
              {
                "baz": "c2.1",
                "beq": "d2.1"
              },
              {
                "baz": "c2.2",
                "beq": "d2.2"
              },
              {
                "baz": "c2.3",
                "beq": "d2.3"
              }
            ]
          }
        ],
        "output": [
          "a1\tb1\td1.1",
          "a1\tb1\td1.2",
          "a2\tb2\td2.1",
          "a2\tb2\td2.2",
          "a2\tb2\td2.3"
        ]
      }
    ],
    "identifier": 79469366
  },
  {
    "context": [
      "I need to insert whole hierary or update final entry for \"count\". My input arguments are: itemName, binId and new count.",
      "So for \"itemA\", \"b1\" and count 68. I need to set .items -> (item with name: \"itemA\") -> (bin with bin_id 68) -> count = 68.",
      "jq --arg name itemA --arg bin_id b1 --arg count 68 '\n  .items |= [INDEX(.[]?; .name) | .[$name] |= ({$name, bins}\n    | .bins |= [INDEX(.[]?; .bin_id) | .[$bin_id] |= {$bin_id, $count} | .[]]\n  ) | .[]]\n'",
      "jq --arg name itemA --arg bin_id b1 --arg count 68 '\n  def f(a;b;c): .[a] |= [INDEX(.[]?; .[b|keys[]]) | .[b[]] |= b+c | .[]];\n  f(\"items\"; {$name}; f(\"bins\"; {$bin_id}; {$count}))\n'",
      "jq 'def f(v): .[v[0]] |= if v | length < 3 then v[1] else\n  [INDEX(.[]?; .[v[1]]) | .[v[2]] |= {(v[1]): v[2]} + f(v[3:]) | .[]]\nend; f($ARGS.positional)' --args items name itemA bins bin_id b1 count 68",
      "For an empty input, all of them produce:\n{\n  \"items\": [\n    {\n      \"name\": \"itemA\",\n      \"bins\": [\n        {\n          \"bin_id\": \"b1\",\n          \"count\": \"68\"\n        }\n      ]\n    }\n  ]\n}",
      "And for the sample input, they output:\n{\n  \"items\": [\n    {\n      \"name\": \"itemA\",\n      \"bins\": [\n        {\n          \"bin_id\": \"b1\",\n          \"count\": \"68\"\n        },\n        {\n          \"bin_id\": \"b2\",\n          \"count\": \"22\"\n        }\n      ]\n    },\n    {\n      \"name\": \"itemB\",\n      \"bins\": [\n        {\n          \"bin_id\": \"b5\",\n          \"count\": \"55\"\n        }\n      ]\n    }\n  ]\n}",
      "You can use `select` to get the object to update:\n\njq --arg i itemA --arg b b1 --arg c 68 '(\n    .items[]? | \n    select(.name==$i).bins[] |\n    select(.bin_id==$b)\n    ).count=$c'"
    ],
    "utterance": "Set the count property of the bin with bin_id 'b1' within the item named 'itemA' to 68, inserting intermediate objects and arrays if necessary.",
    "expressions": [
      ".items |= [INDEX(.[]?; .name) | .[$name] |= ({$name, bins}\n    | .bins |= [INDEX(.[]?; .bin_id) | .[$bin_id] |= {$bin_id, $count} | .[]]\n  ) | .[]]",
      "def f(a;b;c): .[a] |= [INDEX(.[]?; .[b|keys[]]) | .[b[]] |= b+c | .[]];\n  f(\"items\"; {$name}; f(\"bins\"; {$bin_id}; {$count}))",
      "def f(v): .[v[0]] |= if v | length < 3 then v[1] else\n  [INDEX(.[]?; .[v[1]]) | .[v[2]] |= {(v[1]): v[2]} + f(v[3:]) | .[]]\nend; f($ARGS.positional)",
      "(.items[]? | select(.name==$i).bins[] | select(.bin_id==$b)).count=$c"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "name": "itemA",
              "bins": [
                {
                  "bin_id": "b1",
                  "count": "11"
                },
                {
                  "bin_id": "b2",
                  "count": "22"
                }
              ]
            },
            {
              "name": "itemB",
              "bins": [
                {
                  "bin_id": "b5",
                  "count": "55"
                }
              ]
            }
          ]
        },
        "output": {
          "items": [
            {
              "name": "itemA",
              "bins": [
                {
                  "bin_id": "b1",
                  "count": "68"
                },
                {
                  "bin_id": "b2",
                  "count": "22"
                }
              ]
            },
            {
              "name": "itemB",
              "bins": [
                {
                  "bin_id": "b5",
                  "count": "55"
                }
              ]
            }
          ]
        }
      },
      {
        "input": {},
        "output": {
          "items": [
            {
              "name": "itemA",
              "bins": [
                {
                  "bin_id": "b1",
                  "count": "68"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 79103668
  },
  {
    "context": [
      "I have the following json format. It&#39;s basically a representation of the calendar:",
      "I&#39;d like to sort it such that both the months and the days will be in numeric order. The below input is the output of `jq -S`, but as you see it&#39;s sorted like: 1,10,2, and I&#39;d like to sort it like 1,2,10. How can I do that with jq?",
      "Input:",
      "{\r\n    \"1\":{\"1\":{\"foo\":\"bar\"},\"10\":{\"foo\":\"bar\"},\"2\":{\"foo\":\"bar\"}},\r\n    \"10\":{\"1\":{\"foo\":\"bar\"},\"10\":{\"foo\":\"bar\"},\"2\":{\"foo\":\"bar\"}},\r\n    \"2\":{\"1\":{\"foo\":\"bar\"},\"10\":{\"foo\":\"bar\"},\"2\":{\"foo\":\"bar\"}}\r\n}",
      "Expected output:",
      "{\r\n    \"1\":{\"1\":{\"foo\":\"bar\"},\"2\":{\"foo\":\"bar\"},\"10\":{\"foo\":\"bar\"}},\r\n    \"2\":{\"1\":{\"foo\":\"bar\"},\"2\":{\"foo\":\"bar\"},\"10\":{\"foo\":\"bar\"}},\r\n    \"10\":{\"1\":{\"foo\":\"bar\"},\"2\":{\"foo\":\"bar\"},\"10\":{\"foo\":\"bar\"}}\r\n}",
      "using `jq`, you can turn the items of an object into an array of key-value pairs using `to_entries`, sort that array by the numeric representation of each `.key` using `sort_by` and `to_number`, and then re-compose the object based on that array using `from_entries`, which `jq` will perform in the order of the array. Finally, apply this function composition to both the root node `.` and its children `.[]`.",
      "(.[], .) |= (to_entries | sort_by(.key | tonumber) | from_entries)"
    ],
    "utterance": "Sort both top-level and nested object keys in ascending numeric order.",
    "expressions": [
      "(.[], .) |= (to_entries | sort_by(.key | tonumber) | from_entries)"
    ],
    "data": [
      {
        "input": {
          "1": {
            "1": {
              "foo": "bar"
            },
            "10": {
              "foo": "bar"
            },
            "2": {
              "foo": "bar"
            }
          },
          "10": {
            "1": {
              "foo": "bar"
            },
            "10": {
              "foo": "bar"
            },
            "2": {
              "foo": "bar"
            }
          },
          "2": {
            "1": {
              "foo": "bar"
            },
            "10": {
              "foo": "bar"
            },
            "2": {
              "foo": "bar"
            }
          }
        },
        "output": {
          "1": {
            "1": {
              "foo": "bar"
            },
            "2": {
              "foo": "bar"
            },
            "10": {
              "foo": "bar"
            }
          },
          "2": {
            "1": {
              "foo": "bar"
            },
            "2": {
              "foo": "bar"
            },
            "10": {
              "foo": "bar"
            }
          },
          "10": {
            "1": {
              "foo": "bar"
            },
            "2": {
              "foo": "bar"
            },
            "10": {
              "foo": "bar"
            }
          }
        }
      }
    ],
    "identifier": 79538297
  },
  {
    "context": [
      "aws dms describe-replication-tasks --filter Name=replication-task-id,Values=TASKNAME --output json | jq '.ReplicationTasks | .[] | .TableMappings |= fromjson | .ReplicationTaskSettings |= fromjson | delpaths([ [\"ReplicationTaskArn\"],[\"ReplicationTaskStartDate\"],[\"ReplicationTaskStats\"],[\"Status\"],[\"StopReason\"],[\"ReplicationTaskCreationDate\"],[\"ReplicationTaskSettings\",\"Logging\",\"CloudWatchLogGroup\"],[\"ReplicationTaskSettings\",\"Logging\",\"CloudWatchLogStream\"],[\"RecoveryCheckpoint\"]]) | .TableMappings |= tostring |.ReplicationTaskSettings |= tostring' > TASKNAME.json",
      "your jq command works perfectly [in PowerShell]"
    ],
    "utterance": "Transform DMS replication task data so that TableMappings and ReplicationTaskSettings fields are parsed and stringified appropriately, and remove several specific fields in each object.",
    "expressions": [
      ".ReplicationTasks | .[] | .TableMappings |= fromjson | .ReplicationTaskSettings |= fromjson | delpaths([ [\"ReplicationTaskArn\"],[\"ReplicationTaskStartDate\"],[\"ReplicationTaskStats\"],[\"Status\"],[\"StopReason\"],[\"ReplicationTaskCreationDate\"],[\"ReplicationTaskSettings\",\"Logging\",\"CloudWatchLogGroup\"],[\"ReplicationTaskSettings\",\"Logging\",\"CloudWatchLogStream\"],[\"RecoveryCheckpoint\"]]) | .TableMappings |= tostring | .ReplicationTaskSettings |= tostring"
    ],
    "identifier": 79295075
  },
  {
    "context": [
      "I can get one and two together, but not startTime: with `jq -r '.data[] | \"\\(.startTime)\", (.data[] | \"\\(.one), \\(.two)\" )'`",
      "What I'm failing at is outputting something like this:\n\nstartTime, one, two\n\nwhich in the case of the data above would give me three lines of output.",
      "You're looking for something like this:\n```\n.data[] | [.startTime] + (.data[] | [.one, .two]) | join(\", \")"
    ],
    "utterance": "For each object in the top-level data array, print the startTime together with each nested object's one and two values on the same line.",
    "expressions": [
      ".data[] | .data[] | [$.startTime, .one, .two] | join(\", \")",
      ".data[] | [.startTime] + (.data[] | [.one, .two]) | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "startTime": "2024-12-31T00:00:00Z",
              "data": [
                {
                  "one": "a",
                  "two": 1125.0
                },
                {
                  "one": "b",
                  "two": 2119.0
                },
                {
                  "one": "c",
                  "two": 0.0
                }
              ]
            }
          ]
        },
        "output": [
          "2024-12-31T00:00:00Z, a, 1125",
          "2024-12-31T00:00:00Z, b, 2119",
          "2024-12-31T00:00:00Z, c, 0"
        ]
      }
    ],
    "identifier": 79322478
  },
  {
    "context": [
      "I am using this jq form to add elements to a JSON array.",
      "However, when trying to automate this in a shell (bash) script, `jq` chokes.",
      "I have tried many ways to expand variables, e.g. without braces (`$json_content`), and have also tried without success with other incantations.",
      "For example, using `--argjson` in the terminal: ... but jq fails",
      "Try this instead:\r\n\r\n```bash\r\njq '.schemes += [inputs]' \"$json_file\" \"$@\" >\"$json_file.new\"\r\n```"
    ],
    "utterance": "Append the contents of an external file as a new element to the schemes array in settings.json using a shell command.",
    "expressions": [
      ".schemes += [inputs]"
    ],
    "data": [
      {
        "input": {
          "$help": "https://aka.ms/terminal-documentation",
          "$schema": "https://aka.ms/terminal-profiles-schema",
          "language": "en-US",
          "themes": [],
          "schemes": []
        },
        "output": {
          "$help": "https://aka.ms/terminal-documentation",
          "$schema": "https://aka.ms/terminal-profiles-schema",
          "language": "en-US",
          "themes": [],
          "schemes": [
            {
              "name": "Grape",
              "black": "#2d283f",
              "red": "#ed2261",
              "green": "#1fa91b",
              "yellow": "#8ddc20",
              "blue": "#487df4",
              "purple": "#8d35c9",
              "cyan": "#3bdeed",
              "white": "#9e9ea0",
              "brightBlack": "#59516a",
              "brightRed": "#f0729a",
              "brightGreen": "#53aa5e",
              "brightYellow": "#b2dc87",
              "brightBlue": "#a9bcec",
              "brightPurple": "#ad81c2",
              "brightCyan": "#9de3eb",
              "brightWhite": "#a288f7",
              "background": "#171423",
              "foreground": "#9f9fa1",
              "selectionBackground": "#493d70",
              "cursorColor": "#a288f7"
            }
          ]
        }
      }
    ],
    "identifier": 79711268
  },
  {
    "context": [
      "echo '{\"key\": \"value\"}' | jq '\\\"Theinputwas:\\(.key)\\\"'",
      "echo '{\"key\": \"value\"}' | jq '\\\"The input was:\\(.key)\\\"'",
      "jq: error: syntax error, unexpected end of file, expecting QQSTRING_TEXT or QQSTRING_INTERP_START or QQSTRING_END (Windows cmd shell quoting issues?)",
      "Apparently, adding a space character either after the opening or before the closing code quote seems to work (with jq 1.7.1 in PS 5.1 on Win 10):",
      "echo '{\"key\": \"value\"}' | jq ' \\\"The input was:\\(.key)\\\"'",
      "echo '{\"key\": \"value\"}' | jq '\\\"The input was:\\(.key)\\\" '",
      "\"The input was:value\""
    ],
    "utterance": "Output the object property 'key' in the string format 'The input was:<value>' while avoiding whitespace parsing errors in Windows PowerShell.",
    "expressions": [
      "\\\"The input was:\\(.key)\\\"",
      " \\\"The input was:\\(.key)\\\"",
      "\\\"The input was:\\(.key)\\\" "
    ],
    "data": [
      {
        "input": {
          "key": "value"
        },
        "output": "\"The input was:value\""
      }
    ],
    "identifier": 79455244
  },
  {
    "context": [
      "I'm trying to extract the field value for \"RecType\" from the record which has the tag where `Key==name` and `Value==uiop`.",
      "what I'm trying to do is pull the record where the Key/Value pair where `name==uiop`",
      ".Records[] |\nselect(\n    .Tags[] |\n    select(.Key == \"name\" and .Value == \"uiop\")\n) |\n.RecType",
      ".Records[] | select( .Tags | from_entries | .name == \"uiop\" ) | .RecType"
    ],
    "utterance": "Extract the RecType value from the record where there is a tag with Key equal to name and Value equal to uiop.",
    "expressions": [
      ".Records[] | select(.Tags[] | select(.Key == \"name\" and .Value == \"uiop\")) | .RecType",
      ".Records[] | select( .Tags | from_entries | .name == \"uiop\" ) | .RecType"
    ],
    "data": [
      {
        "input": {
          "Records": [
            {
              "RecType": "type-A",
              "Tags": [
                {
                  "Key": "category",
                  "Value": "foo"
                },
                {
                  "Key": "name",
                  "Value": "qwerty"
                }
              ]
            },
            {
              "RecType": "type-B",
              "Tags": [
                {
                  "Key": "category",
                  "Value": "bar"
                },
                {
                  "Key": "name",
                  "Value": "uiop"
                }
              ]
            }
          ]
        },
        "output": "type-B"
      }
    ],
    "identifier": 79437457
  },
  {
    "context": [
      "Given input JSON like this (there's a lot more to it really, but I've stripped the fields that aren't of any interest:",
      "... and desired output which has two top-level properties, each populated from different elements within the `modules.data[]` array, indexed by their `.id`:",
      "... what should my `jq` query look like to pull data from those two objects within `modules.data`?",
      "You need to work on `.modules.data` instead of `.modules.data[]`:",
      "jq '.modules.data |     { title: (.[] | select(.id == \"aod_play_area\").data[0] | \"\\(.titles.primary) - \\(.titles.secondary)\"),      tracks: (.[] | select(.id == \"aod_tracks\").data | map({        title: .titles.primary,        artist: .titles.secondary,        start: .offset.start,        end: .offset.end,        apple:   .uris[] | select(.id ==\"commercial-music-service-apple\").uri,        spotify: .uris[] | select(.id ==\"commercial-music-service-spotify\").uri    }))    }' sample.json",
      "The `INDEX` [function](https://jqlang.github.io/jq/manual/#sql-style-operators) (available since v1.6, and not to be confused with the lowercase `index` [function](https://jqlang.github.io/jq/manual/#index-rindex)) can convert an array into an object using a specific evaluation on each item to determine the respective keys. Applied to `.modules.data`, `INDEX(.id)` will produce ...",
      "With this, you can rewrite your own approach to:\n.modules.data | INDEX(.id) | {\n  title: .aod_play_area.data[0] | \"\u2026\",\n  tracks: .aod_tracks.data | map({ \u2026 })\n}"
    ],
    "utterance": "Construct an object where the title is the primary and secondary titles from the element with id 'aod_play_area', and tracks is an array with title, artist, apple, and spotify fields extracted for each entry in the element with id 'aod_tracks'.",
    "expressions": [
      ".modules.data | { title: (.[] | select(.id == \"aod_play_area\").data[0] | \"\\(.titles.primary) - \\(.titles.secondary)\"), tracks: (.[] | select(.id == \"aod_tracks\").data | map({ title: .titles.primary, artist: .titles.secondary, start: .offset.start, end: .offset.end, apple: .uris[] | select(.id ==\"commercial-music-service-apple\").uri, spotify: .uris[] | select(.id ==\"commercial-music-service-spotify\").uri })) }",
      ".modules.data | INDEX(.id) | { title: .aod_play_area.data[0] | \"\\(.titles.primary) - \\(.titles.secondary)\", tracks: .aod_tracks.data | map({ title: .titles.primary, artist: .titles.secondary, start: .offset.start, end: .offset.end, apple: .uris[] | select(.id == \"commercial-music-service-apple\").uri, spotify: .uris[] | select(.id == \"commercial-music-service-spotify\").uri }) }"
    ],
    "data": [
      {
        "input": {
          "modules": {
            "data": [
              {
                "id": "aod_play_area",
                "data": [
                  {
                    "titles": {
                      "primary": "Primary",
                      "secondary": "Secondary"
                    }
                  }
                ]
              },
              {
                "id": "aod_tracks",
                "data": [
                  {
                    "titles": {
                      "primary": "First Artist name here",
                      "secondary": "First Track title here"
                    },
                    "uris": [
                      {
                        "id": "commercial-music-service-spotify",
                        "uri": "https://open.spotify.com/track/1234567890"
                      },
                      {
                        "id": "commercial-music-service-apple",
                        "uri": "https://music.apple.com/gb/album/xyz/1234?i=9876"
                      }
                    ]
                  },
                  {
                    "titles": {
                      "primary": "Second Artist name here",
                      "secondary": "Second Track title here"
                    },
                    "uris": [
                      {
                        "id": "commercial-music-service-spotify",
                        "label": "Spotify",
                        "uri": "https://open.spotify.com/track/555555555555"
                      },
                      {
                        "id": "commercial-music-service-apple",
                        "label": "Apple Music",
                        "uri": "https://music.apple.com/gb/album/abc/5555?i=5555"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "title": "Primary - Secondary",
          "tracks": [
            {
              "title": "First Artist name here",
              "artist": "First Track title here",
              "start": null,
              "end": null,
              "apple": "https://music.apple.com/gb/album/xyz/1234?i=9876",
              "spotify": "https://open.spotify.com/track/1234567890"
            },
            {
              "title": "Second Artist name here",
              "artist": "Second Track title here",
              "start": null,
              "end": null,
              "apple": "https://music.apple.com/gb/album/abc/5555?i=5555",
              "spotify": "https://open.spotify.com/track/555555555555"
            }
          ]
        }
      }
    ],
    "identifier": 79388729
  },
  {
    "context": [
      "All columns and rows are required, including the *name* of the Referee, AR1 & AR2 (which are visible in the page source). Example of required output (top 3 rows only):\nDATE,TIME,COMPETITION,DIVISION,HOME TEAM,AWAY TEAM,VENUE,REFEREE,AR1,AR2,REFEREE NAME,AR1 NAME,AR2 NAME",
      "jq .[].klips[].components[].components $FileBase.4 > $FileBase.5",
      "jq '.[] | select(.displayName==\"FV Venue\")' $FileBase.5 > $FileBase.6",
      "if the main goal is to extract the json data you can run \n\n```\ncurl -kL https://app.klipfolio.com/published/6b16ab677623c60708ba3ef462e6ad8e/football-victoria-referee-appointments \\\n  | grep -oP 'dashboardSchemaString = \"\\K.*?(?=\";)' \\\n  | sed 's/.*/\"&\"/' \\\n  | jq -rR 'fromjson'\n```"
    ],
    "utterance": "Extract all rows with the columns DATE, TIME, COMPETITION, DIVISION, HOME TEAM, AWAY TEAM, VENUE, REFEREE, AR1, AR2, REFEREE NAME, AR1 NAME, and AR2 NAME, including the names visible in the page source.",
    "expressions": [
      ".[].klips[].components[].components",
      ".[] | select(.displayName==\"FV Venue\")"
    ],
    "identifier": 79608401
  },
  {
    "context": [
      "I need a filter to be passed to jq (v.1.7.1 currently) that allows me to get a tree reshape for a nested parent/child representation of elements, like this:",
      "In addition to this, I also have to make the \"parent\" keys disappear from each element.",
      "Try this :",
      "jq 'map(.id |= tostring | .parent |= tostring) # Convert .id/.parent to string\n  | INDEX(.[]; .id) as $r # $r means remaining to be processed.\n  | map(.parent as $a | select(any($r[];.id == $a)|not)) as $R # $R means result\n  | ($r | del(.[$R | .. | objects | .id])) # Remove processed from $r\n  | {R:$R,r:.} # Temporary object\n  | until((.r | length) == 0;\n        reduce (.R as $R | .r | map(. as $o|select(any($R | .. | objects | $o.parent == .id))))[] as $o ({R, r}; # Find next candidates\n          .r |= del(.[$o.id]) # Remove from reminaing\n        | .R |= walk(if type == \"object\" and .id == $o.parent\n                     then .children+=[$o]\n                     end\n                    ) # Add to the results\n        )\n    ).R\n  | walk(if type == \"object\" then .id |= tonumber | .parent |= tonumber end)\n' input.json"
    ],
    "utterance": "Transform an array of items with 'id', 'parent', 'type', and 'title' fields into a nested structure where children are grouped under their parent, parents are identified by type == 2, and remove 'parent' keys from each element.",
    "expressions": [
      "map(.id |= tostring | .parent |= tostring) # Convert .id/.parent to string\n  | INDEX(.[]; .id) as $r # $r means remaining to be processed.\n  | map(.parent as $a | select(any($r[];.id == $a)|not)) as $R # $R means result\n  | ($r | del(.[$R | .. | objects | .id])) # Remove processed from $r\n  | {R:$R,r:.} # Temporary object\n  | until((.r | length) == 0;\n        reduce (.R as $R | .r | map(. as $o|select(any($R | .. | objects | $o.parent == .id))))[] as $o ({R, r}; # Find next candidates\n          .r |= del(.[$o.id]) # Remove from reminaing\n        | .R |= walk(if type == \"object\" and .id == $o.parent\n                     then .children+=[$o]\n                     end\n                    ) # Add to the results\n        )\n    ).R\n  | walk(if type == \"object\" then .id |= tonumber | .parent |= tonumber end)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 7,
            "parent": 3,
            "type": 1,
            "title": "Item 1"
          },
          {
            "id": 8,
            "parent": 3,
            "type": 2,
            "title": "Folder 1"
          },
          {
            "id": 9,
            "parent": 8,
            "type": 2,
            "title": "Folder 2"
          },
          {
            "id": 10,
            "parent": 9,
            "type": 1,
            "title": "Item 3"
          },
          {
            "id": 11,
            "parent": 9,
            "type": 2,
            "title": "Folder 3"
          },
          {
            "id": 12,
            "parent": 11,
            "type": 1,
            "title": "Item 4"
          },
          {
            "id": 13,
            "parent": 11,
            "type": 1,
            "title": "Item 5"
          },
          {
            "id": 15,
            "parent": 8,
            "type": 1,
            "title": "Item 2"
          },
          {
            "id": 16,
            "parent": 3,
            "type": 1,
            "title": "Item 6"
          }
        ],
        "output": [
          {
            "title": "Item 1",
            "id": 7,
            "type": 1
          },
          {
            "title": "Folder 1",
            "id": 8,
            "type": 2,
            "children": [
              {
                "title": "Folder 2",
                "id": 9,
                "type": 2,
                "children": [
                  {
                    "title": "Item 3",
                    "id": 10,
                    "type": 1
                  },
                  {
                    "title": "Folder 3",
                    "id": 11,
                    "type": 2,
                    "children": [
                      {
                        "title": "Item 4",
                        "id": 12,
                        "type": 1
                      },
                      {
                        "title": "Item 5",
                        "id": 13,
                        "type": 1
                      }
                    ]
                  }
                ]
              },
              {
                "title": "Item 2",
                "id": 15,
                "type": 1
              }
            ]
          },
          {
            "title": "Item 6",
            "id": 16,
            "type": 1
          }
        ]
      }
    ],
    "identifier": 79315409
  },
  {
    "context": [
      "However, `empty as $var | .` produces no output. Is it expected?",
      "`empty as $v` is indeed special: `empty` causes backtracking, not the binding of $v to nothing.",
      "It can\u2019t be any other way because `$var` must have a value for the rest to be evaluated, and `empty` produces no values. (Don\u2019t confuse a lack of value and the value `null`.)",
      "* `empty as $y | ...` evaluates `...` zero times.",
      "> The expression `exp as $x | ...` means: for each value of expression `exp`, run the rest of the pipeline with the entire original input, and with `$x` set to that value. Thus `as` functions as something of a foreach loop.",
      "Since the `empty` keyword means \"no value/no input -- not even `null`\" this boils down to a loop with zero iterations."
    ],
    "utterance": "Bind the result of empty to a variable and pass the input through unchanged.",
    "expressions": [
      "empty as $var | ."
    ],
    "data": [
      {
        "input": "any input (e.g., 1)",
        "output": null
      }
    ],
    "identifier": 79576341
  },
  {
    "identifier": 79694539
  },
  {
    "context": [
      "I need the next step to strip the objects and lists of each RANDOM_STRING, leaving me with a file that shows all RANDOM_STRING names only.",
      "Expected Output:\nRANDOM_STRING1\nRANDOM_STRING2\nRANDOM_STRING3\nRANDOM_STRING4\n.....\nRANDOM_STRING100000",
      "Apparently you&#39;re shooting for:\n\njq -r '.[][] | keys_unsorted[]'\n\nor perhaps:\n\njq -c '[.[][] | keys_unsorted[]]'"
    ],
    "utterance": "List the keys at the third nesting level below the root object; exclude their values and nested structure.",
    "expressions": [
      ".[][] | keys_unsorted[]",
      "[.[][] | keys_unsorted[]]"
    ],
    "data": [
      {
        "input": {
          "JSON_KEY": {
            "SOME_TITLE": {
              "RANDOM_STRING1": {
                "label": "value",
                "units": {
                  "subunits": [
                    {
                      "item1": "1",
                      "item2": "2"
                    },
                    {
                      "item3": "3",
                      "item4": "4"
                    }
                  ]
                }
              }
            }
          }
        },
        "output": [
          "RANDOM_STRING1"
        ]
      }
    ],
    "identifier": 79379669
  },
  {
    "context": [
      "But how do I access the value of Status for both objects without knowing the index?",
      "$ jq '.provisionInfo | with_entries(.value = .value.Status)' tmp.json",
      "{\n  \"2b66706e-237c-4d05-b3c0-31b03186b9e5\": \"Up\",\n  \"3fb6886e-9877c-4d05-b39f-31b03186b9e5\": \"Up\"\n}"
    ],
    "utterance": "Extract the Status value for every sub-object under provisionInfo, preserving their keys.",
    "expressions": [
      ".provisionInfo | with_entries(.value = .value.Status)"
    ],
    "data": [
      {
        "input": {
          "provisionInfo": {
            "2b66706e-237c-4d05-b3c0-31b03186b9e5": {
              "Status": "Up",
              "key": "value"
            },
            "3fb6886e-9877c-4d05-b39f-31b03186b9e5": {
              "Status": "Up",
              "key": "value"
            }
          }
        },
        "output": {
          "2b66706e-237c-4d05-b3c0-31b03186b9e5": "Up",
          "3fb6886e-9877c-4d05-b39f-31b03186b9e5": "Up"
        }
      }
    ],
    "identifier": 79318415
  },
  {
    "context": [
      "I need it transformed to a sequential set of json \"commands\" where every table _and_ its columns is a separate line, like so:",
      "[\n{\"type\": \"TABLE\", name:\"tblFoo\"},\n{\"type\": \"COLUMN\", name:\"created\", ofTable: \"tblFoo\"},\n{\"type\": \"COLUMN\", name:\"updated\", ofTable: \"tblFoo\"},\n\u2026\n{\"type\": \"TABLE\", name:\"tblBar\"},\n{\"type\": \"COLUMN\", name:\"created\", ofTable: \"tblBar\"},\n\n]",
      "[\n  .db[].tables[] | {type: \"TABLE\", name},\n  {type: \"COLUMN\", name: .cols[].name, ofTable: .name}\n]",
      "{\n  \"type\": \"TABLE\",\n  \"name\": \"tblFoo\"\n},\n{\n  \"type\": \"COLUMN\",\n  \"name\": \"created\",\n  \"ofTable\": \"tblFoo\"\n},\n{\n  \"type\": \"COLUMN\",\n  \"name\": \"updated\",\n  \"ofTable\": \"tblFoo\"\n},\n{\n  \"type\": \"COLUMN\",\n  \"name\": \"username\",\n  \"ofTable\": \"tblFoo\"\n},\n{\n  \"type\": \"TABLE\",\n  \"name\": \"tblBar\"\n},\n{\n  \"type\": \"COLUMN\",\n  \"name\": \"created\",\n  \"ofTable\": \"tblBar\"\n}"
    ],
    "utterance": "Produce a flat array where each table and each of its columns is represented as a command object, with tables as type TABLE and columns as type COLUMN including their table name.",
    "expressions": [
      "[.db[].tables[] | {type: \"TABLE\", name}, {type: \"COLUMN\", name: .cols[].name, ofTable: .name}]"
    ],
    "data": [
      {
        "input": {
          "db": [
            {
              "tables": [
                {
                  "name": "tblFoo",
                  "cols": [
                    {
                      "name": "created",
                      "types": [
                        {
                          "data_type": "timestamp"
                        }
                      ]
                    },
                    {
                      "name": "updated",
                      "types": [
                        {
                          "data_type": "timestamp"
                        }
                      ]
                    },
                    {
                      "name": "username",
                      "types": [
                        {
                          "data_type": "timestamp"
                        }
                      ]
                    }
                  ]
                },
                {
                  "name": "tblBar",
                  "cols": [
                    {
                      "name": "created",
                      "types": [
                        {
                          "data_type": "timestamp"
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "type": "TABLE",
            "name": "tblFoo"
          },
          {
            "type": "COLUMN",
            "name": "created",
            "ofTable": "tblFoo"
          },
          {
            "type": "COLUMN",
            "name": "updated",
            "ofTable": "tblFoo"
          },
          {
            "type": "COLUMN",
            "name": "username",
            "ofTable": "tblFoo"
          },
          {
            "type": "TABLE",
            "name": "tblBar"
          },
          {
            "type": "COLUMN",
            "name": "created",
            "ofTable": "tblBar"
          }
        ]
      }
    ],
    "identifier": 79486152
  },
  {
    "context": [
      "How to identify such problematic lines which have spaces?",
      "To print out the .value strings containing blanks:",
      "jq 'def stroll:\n      if type == \"object\" \n      then if (.value | type == \"string\" and test(\" \")) then .value\n           else .[] | stroll\n           end\n      elif type == \"array\" then .[] | stroll\n           else empty\n      end;  \n    stroll' input.json"
    ],
    "utterance": "Find all string values of any .value key that contain a space character anywhere in the value.",
    "expressions": [
      "def stroll:\n      if type == \"object\" \n      then if (.value | type == \"string\" and test(\" \")) then .value\n           else .[] | stroll\n           end\n      elif type == \"array\" then .[] | stroll\n           else empty\n      end;  \nstroll"
    ],
    "identifier": 79183505
  },
  {
    "context": [
      "Im trying to write a JQ function that will take some key/value arguments and format them into a nested object of various data types.",
      "- If the arg key has a period, then use the period as a delimiter for nested object keys. Create that object and place the value there.",
      "- If the value has commas in it, then assume those are array value delimiters, and create the array.",
      "I would expect to see the output:\r\n    {\r\n      \"count\": 5,\r\n      \"name\": \"john\",\r\n      \"enabled\": false,\r\n      \"shouldbenull\": null,\r\n      \"mamals\": [\r\n        \"pig\",\r\n        \"cat\",\r\n        \"dog\"\r\n      ],\r\n      \"sea\": {\r\n        \"creatures\": [\r\n          \"shark\",\r\n          \"crab\",\r\n          654,\r\n          \"squid\"\r\n        ]\r\n      }\r\n    }",
      "This should work:\n```\ndef args2json:\n  reduce to_entries[] as $e (null;\n    setpath($e.key | split(\".\"); $e.value | cast_arg)\n  );\n```"
    ],
    "utterance": "Convert a set of key-value string pairs, using periods in keys for nesting and commas in values for arrays, coercing numbers, booleans, and nulls accordingly, into a deeply nested structure with appropriate types.",
    "expressions": [
      "def args2json:\n  reduce to_entries[] as $e (null;\n    setpath($e.key | split(\".\"); $e.value | cast_arg)\n  );"
    ],
    "data": [
      {
        "input": {
          "count": "5",
          "name": "john",
          "enabled": "false",
          "shouldbenull": "null",
          "mamals": "pig,cat,dog",
          "sea.creatures": "shark,crab,654,squid"
        },
        "output": {
          "count": 5,
          "name": "john",
          "enabled": false,
          "shouldbenull": null,
          "mamals": [
            "pig",
            "cat",
            "dog"
          ],
          "sea": {
            "creatures": [
              "shark",
              "crab",
              654,
              "squid"
            ]
          }
        }
      }
    ],
    "identifier": 79195334
  },
  {
    "context": [
      "The main requirement is to change the key names, like `city` instead of `Cities`",
      "To change the field name `Cities` into `City`, create a new object, keeping `Name` as is, while adding a new `City` field whose value comes from the old `.Cities` field:",
      ".States[] |= {Name, City: .Cities}",
      "Both approaches produce:\n{\n  \"Country\": \"India\",\n  \"States\": [\n    {\n      \"Name\": \"TN\",\n      \"City\": [\n        \"city1\",\n        \"city2\"\n      ]\n    },\n    {\n      \"Name\": \"KL\",\n      \"City\": [\n        \"city3\",\n        \"city4\"\n      ]\n    }\n  ]\n}\n"
    ],
    "utterance": "Rename the key 'Cities' to 'City' in each object of the States array while keeping the structure intact.",
    "expressions": [
      ".States[] |= {Name, City: .Cities}",
      ".States[] |= del(.Cities) + {City: .Cities}"
    ],
    "data": [
      {
        "input": {
          "Country": "India",
          "States": [
            {
              "Name": "TN",
              "Cities": [
                "city1",
                "city2"
              ]
            },
            {
              "Name": "KL",
              "Cities": [
                "city3",
                "city4"
              ]
            }
          ]
        },
        "output": {
          "Country": "India",
          "States": [
            {
              "Name": "TN",
              "City": [
                "city1",
                "city2"
              ]
            },
            {
              "Name": "KL",
              "City": [
                "city3",
                "city4"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 79542775
  },
  {
    "context": [
      "I am trying to get the count of _all_ entries in `b` for each unique `a`.",
      "The ultimate answer for this example would be 3 `b` entries for `foo` and 0 `b` entries for `bar`",
      "Here's a `reduce`-based approach that iterates over all items while adding up the corresponding array `length`s:",
      "reduce .[] as {$a,$b} ({}; .[$a] += ($b | length))"
    ],
    "utterance": "Count all entries in 'b' for each unique value of 'a', producing a mapping from 'a' to the total number of entries in 'b'.",
    "expressions": [
      "reduce .[] as {$a,$b} ({}; .[$a] += ($b | length))"
    ],
    "data": [
      {
        "input": [
          {
            "a": "foo",
            "b": [
              {
                "x": 1,
                "y": true
              }
            ]
          },
          {
            "a": "foo",
            "b": [
              {
                "x": 1,
                "y": true
              },
              {
                "x": 99,
                "y": false
              }
            ]
          },
          {
            "a": "bar",
            "b": []
          }
        ],
        "output": {
          "foo": 3,
          "bar": 0
        }
      }
    ],
    "identifier": 79564850
  },
  {
    "context": [
      "With a Json field like the one below, if eventId is a continuous value, I would like to add the value of the message field.",
      "even if eventId is continuous, if the message field starts with # Time, the message field is separated.",
      "Here's what I want it to look like:",
      "[{\"message\": \"# Time: 1, 2, 3\"}, {\"message\": \"# Time: 11\"}, {\"message\": \"# Time: 12\"}, {\"message\": \"# Time: A , B, C\"}, {\"message\": \"# Time: C\"}, {\"message\": \"# Time: D\"}]",
      "def check($e1; $e2):\n  ($e2.message[:1] != \"#\") and\n  ($e1.eventId | tonumber) + 1 == ($e2.eventId | tonumber);",
      "reduce .events[1:][] as $e (.events[:1];\n  if check(last; $e) then last.message += $e.message else . + [$e] end\n)\n| map({message})  # drop eventId, just keep message"
    ],
    "utterance": "Concatenate the message fields of consecutive events with numerically consecutive eventId values, but start a new message if the message begins with '# Time'.",
    "expressions": [
      "def check($e1; $e2):\n  ($e2.message[:1] != \"#\") and\n  ($e1.eventId | tonumber) + 1 == ($e2.eventId | tonumber);\n\nreduce .events[1:][] as $e (.events[:1];\n  if check(last; $e) then last.message += $e.message else . + [$e] end\n)\n| map({message})"
    ],
    "data": [
      {
        "input": {
          "events": [
            {
              "message": "# Time: 1",
              "eventId": "38636469249093328935961608873790523617989208925384015872"
            },
            {
              "message": ", 2, 3",
              "eventId": "38636469249093328935961608873790523617989208925384015873"
            },
            {
              "message": "# Time: 11",
              "eventId": "38636469249093328935961608873790523617989208925384015875"
            },
            {
              "message": "# Time: 12",
              "eventId": "38636469249093328935961608873790523617989208925384015876"
            },
            {
              "message": "# Time: A",
              "eventId": "1"
            },
            {
              "message": ", B, C",
              "eventId": "2"
            },
            {
              "message": "# Time: C",
              "eventId": "3"
            },
            {
              "message": "# Time: D",
              "eventId": "5"
            }
          ]
        },
        "output": [
          {
            "message": "# Time: 1, 2, 3"
          },
          {
            "message": "# Time: 11"
          },
          {
            "message": "# Time: 12"
          },
          {
            "message": "# Time: A, B, C"
          },
          {
            "message": "# Time: C"
          },
          {
            "message": "# Time: D"
          }
        ]
      }
    ],
    "identifier": 79224684
  },
  {
    "context": [
      "My goal is to get only the \"scale\" and \"energy\" values from \"forecast.solar\", and also other elements on the same level as \"forecast\", such as \"siteTitle\".",
      "How does the statement need to look like to include fields like the \"siteTitle\", even if \"forecast.solar\" is not present?",
      "For your sample containing a non-empty `.forecast`, this produces\n{\n  \"forecast\": {\n    \"scale\": 0.5792918589105848,\n    \"today\": {\n      \"energy\": 21142.72731634481,\n      \"complete\": true\n    },\n    \"tomorrow\": {\n      \"energy\": 36320.01044880075,\n      \"complete\": true\n    },\n    \"dayAfterTomorrow\": {\n      \"energy\": 12222.739005817713,\n      \"complete\": false\n    }\n  },\n  \"siteTitle\": \"KOG\"\n}\n",
      "For your other samples, one with no `.forecast`, the other one with it being an empty object, it produces\n{\n  \"siteTitle\": \"KOG\"\n}\n"
    ],
    "utterance": "Extract siteTitle and include forecast information with scale and energy details for today, tomorrow, and dayAfterTomorrow only if forecast is present and non-empty; otherwise, return only siteTitle.",
    "expressions": [
      ".result | .forecast |= (.solar | del(.timeseries) | values)"
    ],
    "data": [
      {
        "input": {
          "result": {
            "forecast": {
              "solar": {
                "scale": 0.5792918589105848,
                "today": {
                  "energy": 21142.72731634481,
                  "complete": true
                },
                "tomorrow": {
                  "energy": 36320.01044880075,
                  "complete": true
                },
                "dayAfterTomorrow": {
                  "energy": 12222.739005817713,
                  "complete": false
                },
                "timeseries": [
                  {
                    "ts": "2025-03-12T00:00:00+01:00",
                    "val": 0
                  }
                ]
              }
            },
            "siteTitle": "KOG"
          }
        },
        "output": {
          "forecast": {
            "scale": 0.5792918589105848,
            "today": {
              "energy": 21142.72731634481,
              "complete": true
            },
            "tomorrow": {
              "energy": 36320.01044880075,
              "complete": true
            },
            "dayAfterTomorrow": {
              "energy": 12222.739005817713,
              "complete": false
            }
          },
          "siteTitle": "KOG"
        }
      },
      {
        "input": {
          "result": {
            "forecast": {},
            "siteTitle": "KOG"
          }
        },
        "output": {
          "siteTitle": "KOG"
        }
      },
      {
        "input": {
          "result": {
            "siteTitle": "KOG"
          }
        },
        "output": {
          "siteTitle": "KOG"
        }
      }
    ],
    "identifier": 79503504
  },
  {
    "context": [
      "The challenge is how to merge each pair in the input, e.g. in the simpler case [\"a\",\"b\",\"c\",\"d\"] to [\"ab\",\"cd\"].",
      "You can use the undocumented _nwise function. Applied by itself using an item count of 2, you get [\"a\",\"b\"] [\"c\",\"d\"], so wrap this stream into an array, and use add to process the strings in the two items into one:",
      "jq '[ _nwise(2) | add ]' <<< '[\"a\",\"b\",\"c\",\"d\"]'",
      "If you're uncomfortable with undocumented functions, you can replicate its behavior using a while loop, that reduces the array by two items until there aren't any left, and slice each subarray further to only contain the first two items:",
      "jq '[while(length > 0; .[2:])[:2] | add]' <<< '[\"a\",\"b\",\"c\",\"d\"]'"
    ],
    "utterance": "Merge every pair of consecutive elements into a single element by concatenation, such that [\"a\",\"b\",\"c\",\"d\"] becomes [\"ab\",\"cd\"].",
    "expressions": [
      "[_nwise(2) | add]",
      "[while(length > 0; .[2:])[:2] | add]"
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c",
          "d"
        ],
        "output": [
          "ab",
          "cd"
        ]
      }
    ],
    "identifier": 79389414
  },
  {
    "context": [
      "I'm trying to filter only \"supported\" architectures:",
      "Expected output:\r\n\r\n    amd64\r\n    arm64\r\n    ppc64le",
      "You can fix it by wrapping `.key | test(\"^ofasd\\\\.io/arch\\\\.\")` in parenthesis.",
      "If you apply the iterator earlier, after `to_entries`, there is no need for `map()` any more:",
      ".properties[] \n| select(.type == \"new.data\") \n| .value.labels \n| to_entries[]\n| select((.key | test(\"^ofasd\\\\.io/arch\\\\.\")) and .value == \"supported\")\n| .key\n| sub(\"^ofasd\\\\.io/arch\\\\.\"; \"\")",
      "Here\u2019s a simplified version\n.properties[]\n| select(.type == \"new.data\")\n| .value.labels\n| to_entries[]\n| select(.value == \"supported\").key\n| scan(\"^ofasd\\\\.io/arch\\\\.\\\\K.*\")"
    ],
    "utterance": "List the architecture names with 'supported' label, stripping the 'ofasd.io/arch.' prefix.",
    "expressions": [
      ".properties[] | select(.type == \"new.data\") | .value.labels | to_entries[] | select((.key | test(\"^ofasd\\\\.io/arch\\\\.\")) and .value == \"supported\") | .key | sub(\"^ofasd\\\\.io/arch\\\\.\"; \"\")",
      ".properties[] | select(.type == \"new.data\") | .value.labels | to_entries[] | select(.value == \"supported\").key | scan(\"^ofasd\\\\.io/arch\\\\.\\\\K.*\")"
    ],
    "data": [
      {
        "input": {
          "schema": "my.schema",
          "properties": [
            {
              "type": "new.data",
              "value": {
                "labels": {
                  "ofasd.io/arch.amd64": "supported",
                  "ofasd.io/arch.arm64": "supported",
                  "ofasd.io/arch.ppc64le": "supported",
                  "ofasd.io/arch.s390x": "unsupported"
                }
              }
            }
          ]
        },
        "output": [
          "amd64",
          "arm64",
          "ppc64le"
        ]
      }
    ],
    "identifier": 79481609
  },
  {
    "context": [
      "How do I get the summary returned and the check that failed to return? I can get the failed check via something like:",
      "But I would really like to get the summary and the failed checks, or just the summary if there are no failures.",
      "Here is the command I ended up using to get the output formatted how I wanted it:",
      "`echo \"$json_string\" | jq '{\"summary\": .summary, \"checks\":[.checks[] | select(.status != \"OK\")]}'`",
      "jq '.checks |= map(select(.status != \"OK\"))' <<< \"$json_string\"",
      "{ \"summary\": \"1 failure\", \"checks\": [ { \"id\": \"check2\", \"status\": \"FAILED\" }, { \"id\": \"check3\", \"status\": \"CONFIG_WARNING\" } ] }"
    ],
    "utterance": "Return an object with the summary and a checks array containing only checks where status is not OK.",
    "expressions": [
      "{ \"summary\": .summary, \"checks\": [ .checks[] | select(.status != \"OK\") ] }",
      ".checks |= map(select(.status != \"OK\"))"
    ],
    "data": [
      {
        "input": {
          "summary": "1 failure",
          "checks": [
            {
              "id": "check1",
              "status": "OK"
            },
            {
              "id": "check2",
              "status": "FAILED"
            },
            {
              "id": "check3",
              "status": "CONFIG_WARNING"
            }
          ]
        },
        "output": {
          "summary": "1 failure",
          "checks": [
            {
              "id": "check2",
              "status": "FAILED"
            },
            {
              "id": "check3",
              "status": "CONFIG_WARNING"
            }
          ]
        }
      }
    ],
    "identifier": 79569370
  },
  {
    "context": [
      "The JSON components follow this general pattern:\r\n```json\r\n{\r\n  \"name\": \"pickles\",\r\n  \"aliases\": [\r\n    \"birds\"\r\n  ]\r\n}\r\n{\r\n  \"name\": \"cheese\",\r\n  \"aliases\": [\r\n    \"cheese1\",\r\n    \"cheese2\"\r\n  ]\r\n}\r\n```",
      "I'm looking for a CSV output to have two columns - one for name, and one for aliases, where the value in name will be in the name column and value for aliases will be in the aliases column (see below). \r\n```lang-plaintext\r\nname,aliases\r\npickles,birds\r\ncheese, cheese1\r\ncheese, cheese2\r\n```",
      "You could use --slurp to read in the stream as an array:\r\n\r\n```bash\r\n$ jq -s -r '(\"name,aliases\"), (.[] | \"\\(.name),\\(.aliases[])\")' filename.json\r\nname,aliases\r\npickles,birds\r\ncheese,cheese1\r\ncheese,cheese2\r\n```"
    ],
    "utterance": "Output each name and each of its aliases on a separate row, with columns for name and alias, as CSV.",
    "expressions": [
      "jq -s -r '(\"name,aliases\"), (.[] | \"\\(.name),\\(.aliases[])\")'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "pickles",
            "aliases": [
              "birds"
            ]
          },
          {
            "name": "cheese",
            "aliases": [
              "cheese1",
              "cheese2"
            ]
          }
        ],
        "output": "name,aliases\npickles,birds\ncheese,cheese1\ncheese,cheese2"
      }
    ],
    "identifier": 79473037
  },
  {
    "context": [
      "Here is the expected full JSON:",
      "{\r\n  \"hello\": {\r\n    \"foo\": {\r\n      \"version\": \"1.1.1\"\r\n    }\r\n  },\r\n  \"world\": {\r\n    \"bar\": {\r\n      \"version\": \"2.2.2\"\r\n    }\r\n  }\r\n  \"combined\": {\r\n    \"foo\": {\r\n      \"version\": \"1.1.1\"\r\n    },\r\n    \"bar\": {\r\n      \"version\": \"2.2.2\"\r\n    }\r\n  }\r\n}",
      "There is no need for those extra 2 steps/variables, you can achieve the expected output with 1 JQ call like so:",
      "jq '.combined = .hello + .world' <<< \"$json_string\"",
      "But if you define `world` and `hello` as seperate variabels,\nyou can pass those objects back to jq with [`--argjson`][1] and combine them in a new key:",
      "jq \\\n  --argjson hello \"$hello\" \\\n  --argjson world \"$world\" \\\n  '.combined = $hello + $world' <<< \"$json_string\""
    ],
    "utterance": "Add a new key named combined to the top-level object, where combined is the result of merging the objects at the keys hello and world.",
    "expressions": [
      ".combined = .hello + .world",
      ".combined = $hello + $world"
    ],
    "data": [
      {
        "input": {
          "hello": {
            "foo": {
              "version": "1.1.1"
            }
          },
          "world": {
            "bar": {
              "version": "2.2.2"
            }
          }
        },
        "output": {
          "hello": {
            "foo": {
              "version": "1.1.1"
            }
          },
          "world": {
            "bar": {
              "version": "2.2.2"
            }
          },
          "combined": {
            "foo": {
              "version": "1.1.1"
            },
            "bar": {
              "version": "2.2.2"
            }
          }
        }
      }
    ],
    "identifier": 79619739
  },
  {
    "context": [
      "So given an account number as input, I want to look up it's name from a file, and it needs to handle the account not being found.",
      "The account mapping file is as follows:",
      "[{\"accountnumber\": 1100, \"name\": \"Account A\"}, {\"accountnumber\": 1350, \"name\": \"Account B\"}, {\"accountnumber\": 1356, \"name\": \"Account C\"}]",
      "Expected output:",
      "[\"Account A\", \"Account B\"]",
      "Here\u2019s a simplified version of your approach:",
      "def get_account_data($account): [ $accountsdata[][] | select(.accountnumber | tostring == $account) ] as $output | if $output | length == 0 then {name: \"no mapping for \\($account).\"} else $output[0] end; def get_name: get_account_data(.).name; map(get_name)",
      "However, I\u2019d rather create a lookup object which you can query repeatedly without iterating over the accounts data again and again for each input number.",
      "For creating such object, you could employ the INDEX function, and combine it with JOIN to produce the matches, while defaulting with // to another expression if there's no match, as accessing a missing object key (i.e. performing an unsuccessful lookup) always evaluates to null:",
      "JOIN(INDEX($accountsdata[][]; .accountnumber); .[]; .; last.name // \"no mapping for \\(first).\")"
    ],
    "utterance": "For each account number in the input array, output its matching name from a mapping file, or a default message if no mapping exists.",
    "expressions": [
      "def get_account_data($account): [ $accountsdata[][] | select(.accountnumber | tostring == $account) ] as $output | if $output | length == 0 then {name: \"no mapping for \\($account).\"} else $output[0] end; def get_name: get_account_data(.).name; map(get_name)",
      "[JOIN(INDEX($accountsdata[][]; .accountnumber); .[]; .; last.name // \"no mapping for \\(first).\") ]"
    ],
    "data": [
      {
        "input": [
          "1100",
          "1350"
        ],
        "output": [
          "Account A",
          "Account B"
        ]
      },
      {
        "input": [
          "1100",
          "1234",
          "1350"
        ],
        "output": [
          "Account A",
          "no mapping for 1234.",
          "Account B"
        ]
      },
      {
        "input": [
          {
            "accountnumber": 1100,
            "name": "Account A"
          },
          {
            "accountnumber": 1350,
            "name": "Account B"
          },
          {
            "accountnumber": 1356,
            "name": "Account C"
          }
        ]
      }
    ],
    "identifier": 79483599
  },
  {
    "context": [
      "What I'm trying to do is to replace the email addresses in the JSON with the 'User id' from the CSV accordingly.",
      "I wouldn't mind a completely different approach using a single line jq but I don't know jq at all.",
      "Here's a jq-only solution, which does however assume the CSV is easy to parse:\n```\n< input.json jq --rawfile csv input.csv '\n  def toDict: reduce .[] as [$v, $k] ({}; .[$k] = $v);\n  ($csv\n   | split(\"\\n\")\n   | map(select(length>0) | split(\",\"))\n   | toDict) as $dict\n  | walk(if type == \"object\" and .watchers \n         then .watchers |= map( $dict[.] // .) end)\n'\n```"
    ],
    "utterance": "Replace all occurrences of email addresses in the watchers arrays with their corresponding User id values from a CSV mapping.",
    "expressions": [
      "jq --rawfile csv input.csv '\n  def toDict: reduce .[] as [$v, $k] ({}; .[$k] = $v);\n  ($csv\n   | split(\"\\n\")\n   | map(select(length>0) | split(\",\"))\n   | toDict) as $dict\n  | walk(if type == \"object\" and .watchers \n         then .watchers |= map( $dict[.] // .) end)\n'"
    ],
    "data": [
      {
        "input": [
          {
            "externalId": "100000",
            "watchers": [
              "some@email.address",
              "anoteher@email.address",
              "more.email@address.too"
            ]
          },
          {
            "externalId": "100002",
            "watchers": [
              "anoteher@email.address",
              "more.email@address.too"
            ]
          }
        ],
        "output": [
          {
            "externalId": "100000",
            "watchers": [
              "1234-1234-1234",
              "321-1235-44432",
              "322136231345"
            ]
          },
          {
            "externalId": "100002",
            "watchers": [
              "321-1235-44432",
              "322136231345"
            ]
          }
        ]
      }
    ],
    "identifier": 79216817
  },
  {
    "context": [
      "I need to extract all fields with the `time` equals to the current minute I can define with",
      "`--arg date \"$(date '+%Y-%m-%dT%H:%M')\"`",
      "How to use new `date` variable to select suitable records and then filter it by `log` field?",
      "jq --arg date \"$(date '+%Y-%m-%dT%H:%M')\" '\n  select(.time | startswith($date)) | .log\n' logs.json",
      "This Filters logs where `time` matches the current minute and Extracts only the `log` field"
    ],
    "utterance": "Extract the log field from records whose time field starts with a specific date string corresponding to the current minute.",
    "expressions": [
      "select(.time | startswith($date)) | .log",
      "select(.time | startswith(now | strftime(\"%Y-%m-%dT%H:%M\"))) | .log"
    ],
    "data": [
      {
        "input": [
          {
            "log": "message1",
            "stream": "stdout",
            "time": "2025-02-27T14:52:50.01405178Z"
          },
          {
            "log": "message2",
            "stream": "stdout",
            "time": "2025-02-27T14:53:01.00000000Z"
          }
        ],
        "output": [
          "message1"
        ]
      }
    ],
    "identifier": 79471640
  },
  {
    "context": [
      "How can i create a single file called ca.crt from the wget command output.",
      "$ wget ... | jq '.data.ca_chain'",
      "You'll need to [output raw (`-r`)] and combine the array into a single output (`[]`).",
      "wget ... | jq -r '.data.ca_chain[]' > ca.crt"
    ],
    "utterance": "Print each string in the ca_chain array as separate blocks in order to create a single output suitable for a CA certificate file.",
    "expressions": [
      ".data.ca_chain[]",
      "-r .data.ca_chain[]"
    ],
    "data": [
      {
        "input": {
          "data": {
            "ca_chain": [
              "-----BEGIN CERTIFICATE-----\nMIIF5jCCA86W6j2PehfjWs3\nR55ogX1Z2jk/dvIIp.......Z067gh7nrDE56fzhyA=\n-----END CERTIFICATE-----",
              "-----BEGIN CERTIFICATE-----\nMIIF4DCCA8iNzdTHItwqVl1cTglr6bcry0vckey68u+.......4gR0CRtJ\nCaLcNKCBGi/jn6pekNVvgjBamsM=\n-----END CERTIFICATE-----",
              "-----BEGIN CERTIFICATE-----\nMIIFMzCCAxnNDE5MTlaFwumZ8\nHL8n10r0b35LtMT........CxSXIjAZJRE8Fh9jOIm0\n-----END CERTIFICATE-----"
            ]
          }
        },
        "output": "-----BEGIN CERTIFICATE-----\nMIIF5jCCA86W6j2PehfjWs3\nR55ogX1Z2jk/dvIIp.......Z067gh7nrDE56fzhyA=\n-----END CERTIFICATE-----\n-----BEGIN CERTIFICATE-----\nMIIF4DCCA8iNzdTHItwqVl1cTglr6bcry0vckey68u+.......4gR0CRtJ\nCaLcNKCBGi/jn6pekNVvgjBamsM=\n-----END CERTIFICATE-----\n-----BEGIN CERTIFICATE-----\nMIIFMzCCAxnNDE5MTlaFwumZ8\nHL8n10r0b35LtMT........CxSXIjAZJRE8Fh9jOIm0\n-----END CERTIFICATE-----"
      }
    ],
    "identifier": 79166665
  },
  {
    "context": [
      "I want to add {\"key\":\"key3\",\"url\":\"url3\"} under videos that is beside \"user\":\"user-2\"",
      "Use `select` to filter for user-2 then use the `+=` operator to append to the videos array:",
      "$ jq '.[] | select(.user == \"user-2\").videos += [{\"key\":\"key3\",\"url\":\"url3\"}]'",
      "with the keys in place, your original task is reduced to just .\"user-2\".videos += [{key: \"key3\", url: \"url3\"}]"
    ],
    "utterance": "Append {\"key\":\"key3\",\"url\":\"url3\"} to the videos array of the object whose user is \"user-2\".",
    "expressions": [
      "map(if .user == \"user-2\" then .videos += [{\"key\":\"key3\", \"url\":\"url3\"}] else . end)",
      ".[] | select(.user == \"user-2\").videos += [{\"key\":\"key3\",\"url\":\"url3\"}]",
      ".[1].videos += [{\"key\":\"key3\",\"url\":\"url3\"}]",
      ".\"user-2\".videos += [{\"key\":\"key3\", \"url\":\"url3\"}]"
    ],
    "data": [
      {
        "input": [
          {
            "user": "user-1",
            "videos": [
              {
                "key": "key1",
                "url": "url1"
              }
            ]
          },
          {
            "user": "user-2",
            "videos": [
              {
                "key": "key2",
                "url": "url2"
              }
            ]
          }
        ],
        "output": [
          {
            "user": "user-1",
            "videos": [
              {
                "key": "key1",
                "url": "url1"
              }
            ]
          },
          {
            "user": "user-2",
            "videos": [
              {
                "key": "key2",
                "url": "url2"
              },
              {
                "key": "key3",
                "url": "url3"
              }
            ]
          }
        ]
      },
      {
        "input": {
          "user-1": {
            "user": "user-1",
            "videos": [
              {
                "key": "key1",
                "url": "url1"
              }
            ]
          },
          "user-2": {
            "user": "user-2",
            "videos": [
              {
                "key": "key2",
                "url": "url2"
              }
            ]
          }
        },
        "output": {
          "user-1": {
            "user": "user-1",
            "videos": [
              {
                "key": "key1",
                "url": "url1"
              }
            ]
          },
          "user-2": {
            "user": "user-2",
            "videos": [
              {
                "key": "key2",
                "url": "url2"
              },
              {
                "key": "key3",
                "url": "url3"
              }
            ]
          }
        }
      }
    ],
    "identifier": 79522387
  },
  {
    "context": [
      "I am looking to use jq to extract certain fields from \"report_general_stats_data\" section. My expected output would look something like:\n\n\"Sample\"\\t\"filtering_result_passed_filter_reads\"\\t\"filtering_result_low_quality_reads\"...\\t\"pct_adapter\"\n\"24-240_L001_R1_001\"\\t\"1106872.0\"\\t\"32142.0\"...\\t\"5.321795869058677\"\n\nand so on the rest of samples.",
      "Here's an attempt at solving the problem; the idea is to first get the unique keys from all the samples and use them to extract the data of each sample in the same order. Also, there's an additional \"trick\" which is to prepend the sample name to the sample data object:\n\n```\n.report_general_stats_data[1]\n| to_entries\n| map({\"Sample\": .key} * .value)\n| ([.[] | keys_unsorted[]] | unique) as $head\n| ($head, (.[] | . as $cols | $head | map($cols[.])))\n| @tsv\n```"
    ],
    "utterance": "Extract tab-separated table with each sample name and all its associated statistics fields from report_general_stats_data[1], with a header row listing all field names including 'Sample'.",
    "expressions": [
      ".report_general_stats_data[1]\n| to_entries\n| map({\"Sample\": .key} * .value)\n| ([.[] | keys_unsorted[]] | unique) as $head\n| ($head, (.[] | . as $cols | $head | map($cols[.])))\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "report_general_stats_data": [
            {
              "contigs": {
                "# contigs (>= 0 bp)": 232.0,
                "# contigs (>= 1000 bp)": 169.0
              }
            },
            {
              "sample1": {
                "fieldA": 1,
                "fieldB": 2,
                "fieldC": 3
              },
              "sample2": {
                "fieldA": 4,
                "fieldB": 5,
                "fieldC": 6
              }
            }
          ]
        },
        "output": "Sample\tfieldA\tfieldB\tfieldC\nsample1\t1\t2\t3\nsample2\t4\t5\t6"
      }
    ],
    "identifier": 79266175
  },
  {
    "context": [
      "How can I ask jq to go into this object and extract just the \"packages\" part?",
      "Use `fromjson` to parse json text:",
      "`jq '.Labels.\"dev.hhd.rechunk.info\" | fromjson.packages'`"
    ],
    "utterance": "Extract the value of the packages key from the dev.hhd.rechunk.info label, which is a JSON-encoded string field in the Labels object.",
    "expressions": [
      ".Labels.\"dev.hhd.rechunk.info\" | fromjson.packages"
    ],
    "data": [
      {
        "input": {
          "Labels": {
            "dev.hhd.rechunk.info": "{\"version\": 2, \"uniq\": \"gts-40.20250305\", \"packages\": {\"libgcc\": \"14.2.1-3.fc40\"}}"
          }
        },
        "output": {
          "libgcc": "14.2.1-3.fc40"
        }
      }
    ],
    "identifier": 79494219
  }
]