[
  {
    "context": [
      "Can you help me to round it off two decimal places? i.e. 134.40999999999985 to 134.41 My number can be of any length not just 3 digits.",
      "map(\n  .sum = .prebalance + .amount\n  | .sum |= (. * 100 | round / 100)\n)"
    ],
    "utterance": "Add prebalance and amount for each object and round the result to two decimal places.",
    "expressions": [
      "map(\n  .sum = .prebalance + .amount\n  | .sum |= (. * 100 | round / 100)\n)"
    ],
    "data": [
      {
        "input": [
          {
            "prebalance": -2865.59,
            "amount": 3000.0,
            "balance": 134.41
          },
          {
            "prebalance": -1865.59,
            "amount": 2000.0,
            "balance": 134.41
          }
        ],
        "output": [
          {
            "prebalance": -2865.59,
            "amount": 3000,
            "balance": 134.41,
            "sum": 134.41
          },
          {
            "prebalance": -1865.59,
            "amount": 2000,
            "balance": 134.41,
            "sum": 134.41
          }
        ]
      }
    ],
    "identifier": 73461555
  },
  {
    "context": [
      "ANSI color codes with jq",
      "parse error: Invalid escape at line 1, column 31 # returns err code 4",
      "jq: error: Invalid escape at line 1, column 4 (while parsing '\"\\0\"') at <top-level>, line 1:",
      "Octal escape sequences are not valid JSON syntax, so you need to encode the ASCII escape character as \\u001b rather than \\033.",
      "$ printf '%s\\n' '{\"a\":\"b\",\"c\":\"\\u001b[31md\\u001b[0m\"}' | jq -r .c",
      "(You can't see it, but that \"d\" is red in my terminal.)"
    ],
    "utterance": "Output the value of key 'c' containing ANSI color codes, preserving the color when printed to the terminal.",
    "expressions": [
      ".c"
    ],
    "data": [
      {
        "input": {
          "a": "b",
          "c": "\u001b[31md\u001b[0m"
        },
        "output": "\u001b[31md\u001b[0m"
      }
    ],
    "identifier": 73494478
  },
  {
    "context": [
      "I need to address that DataSetArn, but the key \"6fac5dee-3691-4ddd-ba7a-0667168bb80c\" is unknown to me at runtime.  How do I address it?",
      "I tried:",
      "jq -r '.DataSet.PhysicalTableMap.*.CustomSql.DataSourceArn'",
      "jq -r '.DataSet.PhysicalTableMap.\\*.CustomSql.DataSourceArn'",
      "jq -r '.DataSet.PhysicalTableMap.?.CustomSql.DataSourceArn'",
      "jq -r '.DataSet.PhysicalTableMap.\\?.CustomSql.DataSourceArn'",
      "jq -r '.DataSet.PhysicalTableMap.%.CustomSql.DataSourceArn'",
      "jq -r '.DataSet.PhysicalTableMap.\\%.CustomSql.DataSourceArn'",
      "All return an error similar to:",
      "jq: error: syntax error, unexpected INVALID_CHARACTER, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at <top-level>, line 1:",
      ".DataSet.PhysicalTableMap.\\?.CustomSql.DataSourceArn",
      "Something like this:",
      "jq -r '.DataSet.PhysicalTableMap[].CustomSql.DataSourceArn'",
      "The part `.DataSet.PhysicalTableMap` returns the object as *one* result, the following filter `[]` takes that object and returns *each* value as *one* result. The following filters take each of these separate results and refines more stuff."
    ],
    "utterance": "Extract the value of DataSourceArn from each entry under PhysicalTableMap via CustomSql, without knowing the key names in advance.",
    "expressions": [
      ".DataSet.PhysicalTableMap[].CustomSql.DataSourceArn"
    ],
    "data": [
      {
        "input": {
          "Status": 200,
          "DataSet": {
            "Arn": "arn:aws:quicksight:<region>:<acct>:dataset/b7c87122-e180-47a9-a8a4-19f171e13fc8",
            "DataSetId": "b7c87122-e180-47a9-a8a4-19f171e13fc8",
            "Name": "MyName",
            "CreatedTime": "2022-08-16T12:01:54.948000-05:00",
            "LastUpdatedTime": "2022-08-19T08:47:55.553000-05:00",
            "PhysicalTableMap": {
              "6fac5dee-3691-4ddd-ba7a-0667168bb80c": {
                "CustomSql": {
                  "DataSourceArn": "arn:aws:quicksight:<region>:<acct>:datasource/46f83f8b-181e-4575-8d61-84c50125f3aa"
                }
              }
            }
          }
        },
        "output": "arn:aws:quicksight:<region>:<acct>:datasource/46f83f8b-181e-4575-8d61-84c50125f3aa"
      }
    ],
    "identifier": 73488511
  },
  {
    "context": [
      "I would like to combine them matching the key:value pair of KeyId",
      "jq -s 'select(.[0].KeyID==.[1].KeyID) | add' file1.json file2.json"
    ],
    "utterance": "Combine two files into one object when they have the same KeyID value.",
    "expressions": [
      "-s 'select(.[0].KeyID==.[1].KeyID) | add'"
    ],
    "data": [
      {
        "input": [
          {
            "KeyID": 7532173,
            "KeyDetails": "Level 12"
          },
          {
            "KeyID": 7532173,
            "Level": "Access Level"
          }
        ],
        "output": {
          "KeyID": 7532173,
          "KeyDetails": "Level 12",
          "Level": "Access Level"
        }
      }
    ],
    "identifier": 73501741
  },
  {
    "context": [
      "First I want to select an array by a property name. And then I want to select an object of the array by the value of the propertyes.",
      "Example of the desired informations on output:",
      "\"href\"",
      "\"status\"",
      "\"project\"",
      "\"date-started\":",
      "\"unixtime\": 48298437239847,",
      "\"date\": \"2022-07-17\"",
      "\"date-ended\":",
      "\"unixtime\": 48298437239847,",
      "\"date\": \"2022-07-17\"",
      "\"job\":",
      "\"name\": \"cleaner\"",
      "With your input, the following invocation produces the eight values as shown below:",
      "jq '.executions[] | [.href, .status, .project, (.\"date-started\" | (.unixtime, .date)), (.\"date-ended\" | (.unixtime, .date)), .job.name]'"
    ],
    "utterance": "Extract from each object in the executions array the fields: href, status, project, date-started.unixtime, date-started.date, date-ended.unixtime, date-ended.date, and job.name, and output them as an array in that order.",
    "expressions": [
      ".executions[] | [.href, .status, .project, (.\"date-started\" | (.unixtime, .date)), (.\"date-ended\" | (.unixtime, .date)), .job.name]"
    ],
    "data": [
      {
        "input": {
          "paging": {
            "count": 0,
            "total": 0,
            "offset": 0,
            "max": 0
          },
          "executions": [
            {
              "id": 5,
              "href": "https://localhost.com.br",
              "permalink": "https://localhost.com.br",
              "status": "succeeded",
              "project": "PROJETO",
              "executionType": "scheduled",
              "date-started": {
                "unixtime": 1660793400012,
                "date": "2022-08-18T03:30:00Z"
              },
              "date-ended": {
                "unixtime": 1660793409694,
                "date": "2022-08-18T03:30:09Z"
              },
              "job": {
                "id": "cdkwednweoi-8745bjdf-kcjkjr8745",
                "averageDuration": 0,
                "name": "routine",
                "group": "",
                "project": "PROJECT",
                "description": "",
                "href": "https://localhost.com.br",
                "permalink": "https://localhost.com.br"
              },
              "description": "runner",
              "argstring": null,
              "serverUUID": "jdnsdnasldnaje382nf5ubv",
              "successfulNodes": [
                "84jsk937nf"
              ]
            }
          ]
        },
        "output": [
          "https://localhost.com.br",
          "succeeded",
          "PROJETO",
          1660793400012,
          "2022-08-18T03:30:00Z",
          1660793409694,
          "2022-08-18T03:30:09Z",
          "routine"
        ]
      }
    ],
    "identifier": 73449842
  },
  {
    "context": [
      "However when the software version is not present , jq will result in a error. Basically how do I escape the () and return empty in the csv file.",
      ".result [] | [ \"https://vuldb.com/?id.\" + .entry.id ,.software.vendor // \"empty\"\n,.software.name // \"empty\", (.software.version []| tostring // \"empty\")\n,.software.type // \"empty\"\n,.software.platform //\"empty\" ]",
      "Suppress the error and provide an alternative for empty values:",
      "(.version[] | tostring // \"empty\")? // \"no version\""
    ],
    "utterance": "For each result, list the vendor, name, each version (as a string), type, and platform; if any field including the version array or its elements are missing, substitute a default value with 'empty' or 'no version'.",
    "expressions": [
      ".result[] | [\"https://vuldb.com/?id.\" + .entry.id, .software.vendor // \"empty\", .software.name // \"empty\", (.software.version[]? // [\"no version\"] | .[]), .software.type // \"empty\", .software.platform // \"empty\"]",
      ".result | map([\"https://vuldb.com/?id.\" + .entry.id, .software.vendor // \"empty\", .software.name // \"empty\", (.software.version[]? // [\"no version\"] | .[]), .software.type // \"empty\", .software.platform // \"empty\"])"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "entry": {
                "id": "206880"
              },
              "software": {
                "vendor": "CrowdStrike",
                "name": "Falcon",
                "version": [
                  "6.31.14505.0",
                  "6.42.15610"
                ]
              }
            },
            {
              "entry": {
                "id": "123456"
              },
              "software": {
                "vendor": "OtherCompany",
                "name": "OtherProduct"
              }
            }
          ]
        },
        "output": [
          [
            "https://vuldb.com/?id.206880",
            "CrowdStrike",
            "Falcon",
            "6.31.14505.0",
            null,
            null
          ],
          [
            "https://vuldb.com/?id.206880",
            "CrowdStrike",
            "Falcon",
            "6.42.15610",
            null,
            null
          ],
          [
            "https://vuldb.com/?id.123456",
            "OtherCompany",
            "OtherProduct",
            "no version",
            null,
            null
          ]
        ]
      }
    ],
    "identifier": 73458432
  },
  {
    "context": [
      "What i have is something like:\n{\n  \"results\": [\n    {\n      \"name\": \"hostname1\",\n      \"key1\": \"somevalue1\",\n      \"key2\": \"somevalue2\",\n      \"key3\": \"somevalue3\"\n    },",
      "and i need to transform this to look like this:\n{\n  \"_meta\": {\n    \"hostvars\": {\n      \"hostname1\": {\n        \"name\": \"hostname1\",\n        \"key1\": \"somevalue1\",\n        \"key2\": \"somevalue2\",\n        \"key3\": \"somevalue3\"\n      },",
      "You need to reference it once!\n\nYou can do something like below. The key to the logic is forming an array of objects, firstly by making the key name as `.name` and the value as the whole sub-object inside.\n\nOnce you have the array, you can un-wrap into a comma-separated list of objects using `add`.\n\n{ _meta : { hostvars: ( ( .results | map( { ( .name ) : . } ) | add ) ) } } ",
      "The crucial part is: Take an array of objects and transform it into one (outer) object where the attribute names of that outer object are given by some attribute value of the inner objects. That's the job description for `INDEX(filter)`.\n\nSo:\n\n    { _meta : { hostvars: ( .results | INDEX(.name) ) } } ",
      "Yet another approach using `from_entries` could be:\n~~~sh\njq '.results | map({key: .name, value: .}) | {_meta: {hostvars: from_entries}}'\n~~~"
    ],
    "utterance": "Transform an array of objects into an object under _meta.hostvars, using the value of name as key and the entire object as value.",
    "expressions": [
      "{ _meta : { hostvars: ( ( .results | map( { ( .name ) : . } ) | add ) ) } }",
      "{ _meta : { hostvars: ( .results | INDEX(.name) ) } }",
      ".results | map({key: .name, value: .}) | {_meta: {hostvars: from_entries}}"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "name": "hostname1",
              "key1": "somevalue1",
              "key2": "somevalue2",
              "key3": "somevalue3"
            },
            {
              "name": "hostname2",
              "key1": "somevalue12",
              "key2": "somevalue22",
              "key3": "somevalue32"
            },
            {
              "name": "hostname3",
              "key1": "somevalue13",
              "key2": "somevalue23",
              "key3": "somevalue33"
            }
          ]
        },
        "output": {
          "_meta": {
            "hostvars": {
              "hostname1": {
                "name": "hostname1",
                "key1": "somevalue1",
                "key2": "somevalue2",
                "key3": "somevalue3"
              },
              "hostname2": {
                "name": "hostname2",
                "key1": "somevalue12",
                "key2": "somevalue22",
                "key3": "somevalue32"
              },
              "hostname3": {
                "name": "hostname3",
                "key1": "somevalue13",
                "key2": "somevalue23",
                "key3": "somevalue33"
              }
            }
          }
        }
      }
    ],
    "identifier": 73491467
  },
  {
    "context": [
      "Example json data:",
      "{\r\n  \"data\": [\r\n    {\r\n      \"place\": \"FM346\",\r\n      \"id\": [\r\n        \"7_day_A\",\r\n        \"7_day_B\",\r\n        \"7_day_C\",\r\n        \"7_day_D\"\r\n      ],\r\n      \"values\": [\r\n        0,\r\n        30,\r\n        23,\r\n        43\r\n      ]\r\n    },\r\n    {\r\n      \"place\": \"LH210\",\r\n      \"id\": [\r\n        \"1_day_A\",\r\n        \"1_day_B\",\r\n        \"1_day_C\",\r\n        \"1_day_D\"\r\n      ],\r\n      \"values\": [\r\n        4,\r\n        45,\r\n        100,\r\n        9\r\n      ]\r\n    }\r\n  ]\r\n}",
      "what i need to transform it into:",
      "{\r\n  \"data\": [\r\n    {\r\n      \"place\": \"FM346\",\r\n      \"7_day_A\": {\r\n        \"value\": 0\r\n      },\r\n      \"7_day_B\": {\r\n        \"value\": 30\r\n      },\r\n      \"7_day_C\": {\r\n        \"value\": 23\r\n      },\r\n      \"7_day_D\": {\r\n        \"value\": 43\r\n      }\r\n    },\r\n    {\r\n      \"place\": \"LH210\",\r\n      \"1_day_A\": {\r\n        \"value\": 4\r\n      },\r\n      \"1_day_B\": {\r\n        \"value\": 45\r\n      },\r\n      \"1_day_C\": {\r\n        \"value\": 100\r\n      },\r\n      \"1_day_D\": {\r\n        \"value\": 9\r\n      }\r\n    }\r\n  ]\r\n}",
      "You can use `transpose` here, which can play a key role in converting the arrays to key/value pairs",
      "`.data[] |= {place} + \r\n   ([ .id, .values ] | transpose | map({(.[0]): { value: .[1] } }) | add)`"
    ],
    "utterance": "For each entry, combine the elements from the 'id' array with the corresponding elements from the 'values' array to create object properties where each id is a key mapped to an object with its value.",
    "expressions": [
      ".data[] |= {place} + ([ .id, .values ] | transpose | map({(.[0]): { value: .[1] } }) | add)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "place": "FM346",
              "id": [
                "7_day_A",
                "7_day_B",
                "7_day_C",
                "7_day_D"
              ],
              "values": [
                0,
                30,
                23,
                43
              ]
            },
            {
              "place": "LH210",
              "id": [
                "1_day_A",
                "1_day_B",
                "1_day_C",
                "1_day_D"
              ],
              "values": [
                4,
                45,
                100,
                9
              ]
            }
          ]
        },
        "output": {
          "data": [
            {
              "place": "FM346",
              "7_day_A": {
                "value": 0
              },
              "7_day_B": {
                "value": 30
              },
              "7_day_C": {
                "value": 23
              },
              "7_day_D": {
                "value": 43
              }
            },
            {
              "place": "LH210",
              "1_day_A": {
                "value": 4
              },
              "1_day_B": {
                "value": 45
              },
              "1_day_C": {
                "value": 100
              },
              "1_day_D": {
                "value": 9
              }
            }
          ]
        }
      }
    ],
    "identifier": 73472165
  },
  {
    "context": [
      "However, the objects and count values are strings.\r\nInstead I want, `{ \"name\": \"john\", \"objects\": [], \"count\": 1 }`",
      "If you're sure that all the variables contain valid JSON expressions, you can use `--argjson` instead of `--arg`:",
      "Alternatively, you can use `fromjson` in the `jq` expression:"
    ],
    "utterance": "Create an object from shell variables so that string, array, and number values retain their correct types in the output, not as strings.",
    "expressions": [
      "--argjson na \"$name\" --argjson ob \"$objects\" --argjson ct \"$count\" '{name: $na, objects: $ob, count: $ct}'",
      "--arg na \"$name\" --arg ob \"$objects\" --arg ct \"$count\" '{name: $na|fromjson, objects: $ob|fromjson, count: $ct|fromjson}'"
    ],
    "data": [
      {
        "input": {
          "name": "\"john\"",
          "objects": "[]",
          "count": "1"
        },
        "output": {
          "name": "john",
          "objects": [],
          "count": 1
        }
      }
    ],
    "identifier": 73507518
  },
  {
    "context": [
      "I want to concatenate the files and extract all the values of \"bar\" across all the files into one array.",
      "In other words, I want to end up with (placed on one line for readability here): [{\u2026}, {\u2026}, {\u2026}, {\u2026}, {\u2026}]",
      "One way would be to \"slurp\" the files, like so:\n```\njq -s 'map( .foo[].bar )' input-*.json\n```",
      "If you want to save memory, you could go with:\n```\njq -n '[inputs | .foo[].bar]' input-*.json\n```"
    ],
    "utterance": "Extract all values of the key 'bar' from objects inside the 'foo' array, across multiple input files, and collect them into a single array.",
    "expressions": [
      "jq -s 'map( .foo[].bar )' input-*.json",
      "jq -n '[inputs | .foo[].bar]' input-*.json"
    ],
    "identifier": 73519720
  },
  {
    "context": [
      "How can you tell `jq` to replace variables mid JSON string?",
      "`example.json` then could become `example.jq`:\n{\n  \"title\": \"Where the \\($color) Fern Grows\"\n}",
      "Which when run, as they suggested:\n\njq -n --arg color \"Red\" -f example.jq\n\nWorks perfectly.",
      "#### example.jq:\n    {\n      \"title\": \"Where the \\($color) Fern Grows\"\n    }",
      "#### Invocation:\n    jq -n --arg color Red -f example.jq"
    ],
    "utterance": "Substitute the variable color with the value Red inside the string value of the title field.",
    "expressions": [
      "jq -n --arg color Red -f example.jq"
    ],
    "data": [
      {
        "input": {
          "title": "Where the $color Fern Grows"
        },
        "output": {
          "title": "Where the Red Fern Grows"
        }
      }
    ],
    "identifier": 73520524
  },
  {
    "context": [
      "The desired output is a JSON object with all possible keys from all input objects. The values are irrelevant, any value from any input object is OK. But all keys from input objects must be present in output object:",
      "The structure of the objects contained in `file1.json` is unknown, so the solution must be agnostic of any keys/values and the solution must not assume any structure or depth.",
      "Here is a solution that produces the expected result in the sample example, and seems to meet all the stated requirements.  It is similar to one proposed by @pmf on this page.",
      "jq -n --stream '\n  def squish: map(if type == \"number\" then 0 else . end);\n  reduce (inputs | select(length==2)) as [$p, $v] ({}; setpath($p|squish; $v))\n'"
    ],
    "utterance": "Create a single object containing all unique keys from multiple objects in lines-based files, preserving the hierarchical structure without assuming specific keys or depth, using any existing value for each key.",
    "expressions": [
      "jq -n --stream '\n  def squish: map(if type == \"number\" then 0 else . end);\n  reduce (inputs | select(length==2)) as [$p, $v] ({}; setpath($p|squish; $v))\n'"
    ],
    "data": [
      {
        "input": [
          {
            "customerId": "xx",
            "emails": [
              {
                "address": "james@zz.com",
                "customType": "",
                "type": "custom"
              },
              {
                "address": "sales@x.com",
                "primary": true
              },
              {
                "address": "info@x.com"
              }
            ]
          },
          {
            "id": "654",
            "emails": [
              {
                "address": "peter@x.com",
                "primary": true
              }
            ]
          }
        ],
        "output": {
          "customerId": "xx",
          "emails": [
            {
              "address": "peter@x.com",
              "customType": "",
              "type": "custom",
              "primary": true
            }
          ],
          "id": "654"
        }
      }
    ],
    "identifier": 73451819
  },
  {
    "context": [
      "I only need to query against the array and if the value im looking for exists in one of them I need the output to be \"yes\", and if it doesnt a \"no\". ***So a single output value is what I am looking for.***",
      "if ( [ .[] | .displayName == \"display\" ] | any ) then \"yes\" else \"no\" end",
      "A concise solution is possible with `select`: select( any(.displayName==\"display\") ) | \"yes\" // \"no\""
    ],
    "utterance": "Return \"yes\" if any object in the array has displayName equal to \"display\"; otherwise return \"no\".",
    "expressions": [
      "if ( [ .[] | .displayName == \"display\" ] | any ) then \"yes\" else \"no\" end",
      "select( any(.displayName==\"display\") ) | \"yes\" // \"no\""
    ],
    "data": [
      {
        "input": [
          {
            "displayName": "display",
            "message": "bla bla"
          },
          {
            "displayName": "test",
            "message": "bla bla"
          }
        ],
        "output": "yes"
      },
      {
        "input": [
          {
            "displayName": "alpha"
          },
          {
            "displayName": "beta"
          }
        ],
        "output": "no"
      }
    ],
    "identifier": 73527302
  },
  {
    "context": [
      "How do I do it using jq or any command line tools.",
      "If you want some (numeric) pre-processing of the key numbers, do it inside the mapping and before the string conversion, e.g.",
      "jq 'with_entries(.key |= (. + 1 | tostring))'"
    ],
    "utterance": "Convert an array of objects into an object where each key is a unique incrementing string starting from '1' and each value is the corresponding array object.",
    "expressions": [
      "with_entries(.key |= (. + 1 | tostring))"
    ],
    "data": [
      {
        "input": [
          {
            "client": "i-0816dfac36b036002",
            "instance_id": "i-0816dfac36b036002",
            "fstype": "ext4",
            "device": "nvme0n1p1"
          },
          {
            "client": "i-09ae6f92cda7fca83",
            "instance_id": "i-09ae6f92cda7fca83",
            "fstype": "ext4",
            "device": "nvme0n1p1"
          }
        ],
        "output": {
          "1": {
            "client": "i-0816dfac36b036002",
            "instance_id": "i-0816dfac36b036002",
            "fstype": "ext4",
            "device": "nvme0n1p1"
          },
          "2": {
            "client": "i-09ae6f92cda7fca83",
            "instance_id": "i-09ae6f92cda7fca83",
            "fstype": "ext4",
            "device": "nvme0n1p1"
          }
        }
      }
    ],
    "identifier": 73523980
  },
  {
    "context": [
      "Initially,  it is \n```\n{ \"objects\": [] }\n```",
      "I want to add another field called `objects_count` such that \n```\n{ \"objects\": [], \"objects_count\": 1 }\n```",
      "data=$( $data | jq --argjson oc \"$objects_count\" '. + {objects_count: $oc}' )"
    ],
    "utterance": "Add a field called objects_count with value 1 to an object that already has an objects array field.",
    "expressions": [
      ". + {objects_count: 1}"
    ],
    "data": [
      {
        "input": {
          "objects": []
        },
        "output": {
          "objects": [],
          "objects_count": 1
        }
      }
    ],
    "identifier": 73531765
  },
  {
    "context": [
      "Given the example JSON below:\n\n{\n  \"account_number\": [\n    \"123456\"\n  ],\n  \"account_name\": [\n    \"name\"\n  ],\n  \"account_id\": [\n    654321\n  ],\n  \"username\": [\n    \"demo\"\n  ]\n}",
      "I'd like to get:\n\n{\n  \"account_number\": \"123456\",\n  \"account_name\": \"name\",\n  \"account_id\": 654321,\n  \"username\": \"demo\"\n}",
      "Use `with_entries`, changing each value to the first element of itself:\n\n    jq 'with_entries(.value |= .[0])' file.json",
      "Short and sweet:\n\n     map_values(first)"
    ],
    "utterance": "Replace all top-level single-item arrays with their lone value.",
    "expressions": [
      "with_entries(.value |= .[0])",
      "map_values(first)"
    ],
    "data": [
      {
        "input": {
          "account_number": [
            "123456"
          ],
          "account_name": [
            "name"
          ],
          "account_id": [
            654321
          ],
          "username": [
            "demo"
          ]
        },
        "output": {
          "account_number": "123456",
          "account_name": "name",
          "account_id": 654321,
          "username": "demo"
        }
      }
    ],
    "identifier": 73534446
  },
  {
    "context": [
      "Now I want to modify it (I didn\u2019t write the original) to add another condition to the any function.",
      "Something like this `jq 'map(select( any(.topics[]; . == \"stackoverflow\" and .archived == \"false\" )))'`",
      "But it gives me \u201cCannot index string with string \u201carchived\u201d\u201d",
      "The archive field is on the same level as the topics array (it's repo information from the github API).",
      "The generator provided to `any` already descends to `.topics[]` from where you cannot back-reference two levels higher. Use the `select` statement to filter beforehand (also note that booleans are not strings):",
      "jq 'map(select(.archived == false and any(.topics[]; . == \"stackoverflow\")))'",
      "You should also be able to combine both calls to `jq` into one:",
      "jq -r '.[] | select(.archived == false and any(.topics[]; . == \"stackoverflow\")).name'"
    ],
    "utterance": "Select all items where archived is false and topics contains \"stackoverflow\".",
    "expressions": [
      "map(select(.archived == false and any(.topics[]; . == \"stackoverflow\")))",
      ".[] | select(.archived == false and any(.topics[]; . == \"stackoverflow\"))",
      ".[] | select(.archived == false and any(.topics[]; . == \"stackoverflow\")).name"
    ],
    "identifier": 73531965
  },
  {
    "context": [
      "I have a very large file that looks like this:",
      "[ {a: 4, b: [1,2,3]}, {a: 6, b: [7,8,9]}, ]",
      "and I would like to transform it to",
      "{a: 4, b: 1}, {a: 4, b: 2}, {a: 4, b: 3}, {a: 6, b: 7}, {a: 6, b: 8}, {a: 6, b: 9}",
      "If the \"very large file\" fits into your memory, just decompose the array `.[]`, and create your objects as needed using iterations `{a, b: .b[]}`:",
      "jq -c '.[] | {a, b: .b[]}'",
      "If not, but an array item alone would, use the `--stream` flag to read the file in parts, only consider the items level using `truncate_stream` with level `1`, re-compose the array items using `fromstream`, and create the final objects as above:",
      "jq --stream -cn 'fromstream(1 | truncate_stream(inputs)) | {a, b: .b[]}'"
    ],
    "utterance": "For each object, output a separate object for every value of b so that each result contains a and a single b.",
    "expressions": [
      ".[] | {a, b: .b[]}",
      "fromstream(1 | truncate_stream(inputs)) | {a, b: .b[]}"
    ],
    "data": [
      {
        "input": [
          {
            "a": 4,
            "b": [
              1,
              2,
              3
            ]
          },
          {
            "a": 6,
            "b": [
              7,
              8,
              9
            ]
          }
        ],
        "output": [
          {
            "a": 4,
            "b": 1
          },
          {
            "a": 4,
            "b": 2
          },
          {
            "a": 4,
            "b": 3
          },
          {
            "a": 6,
            "b": 7
          },
          {
            "a": 6,
            "b": 8
          },
          {
            "a": 6,
            "b": 9
          }
        ]
      }
    ],
    "identifier": 73527768
  },
  {
    "context": [
      "The JSON I get from my service looks something like this.",
      "\"result\": { \"terms\": [ { \"term\": \"title\", \"translation\": { \"content\": \"Welcome to {{user}}\" } }, { \"term\": \"car\", \"translation\": { \"content\": { \"one\": \"car\", \"other\": \"cars\" } } } ] }",
      "The output that I want is something like this.\n\n    {\n      \"title\": \"Welcome to {{user}}\",\n      \"car_one\": \"car\",\n      \"car_other\": \"cars\",\n    }",
      "I can't figure out how to append something to the key, e.g. turning \"car\" into \"car_one\".",
      "but the following does follow the logic of your approach and does produce the required output:",
      ".result | [.terms[] | if .translation.content|type == \"string\" then {title: .translation.content} else .term as $term | .translation | (.content|keys) as $keys | ([$keys[] as $key | {($term + \"_\" + $key): .content[$key]}] | add) end ] | add",
      ".result.terms | map( select(.translation.content | type == \"object\") | .term as $term | .translation.content | to_entries[] | .key |= \"\\($term)_\\(.)\"), (select(.translation.content | type == \"string\") | { key: .term, value: .translation.content })) | from_entries",
      ".result.terms | map( if .translation.content | type == \"object\" then .term as $term | .translation.content | to_entries[] | .key |= \"\\($term)_\\(.)\" else { key: .term, value: .translation.content } end ) | from_entries",
      ".result.terms | map(.term as $key | .translation.content | if type == \"object\" then to_entries[] | .key |= \"\\($key)_\\(.)\" else { $key, value: . } end ) | from_entries",
      ".result.terms | map(.term as $key | .translation.content | (to_entries[] | .key |= \"\\($key)_\\(.)\")? // { $key, value: . }) | from_entries",
      ".result.terms | map( .term as $key | .translation.content as $value | $value | (to_entries[] | .key |= \"\\($key)_\\(.)\")? // { $key, $value }) | from_entries"
    ],
    "utterance": "Transform an object containing an array of terms, each with a 'term' key and a 'translation.content' (either a string or an object), into a flat object mapping each term to its translation, appending suffixes to term names for plural forms as needed (e.g., 'car_one', 'car_other').",
    "expressions": [
      ".result | [.terms[] | if .translation.content|type == \"string\" then { (.term): .translation.content } else .term as $term | .translation | (.content|keys) as $keys | ([$keys[] as $key | {($term + \"_\" + $key): .content[$key]}] | add) end ] | add",
      ".result.terms | map( select(.translation.content | type == \"object\") | .term as $term | .translation.content | to_entries[] | .key |= \"\\($term)_\\(.)\"), (select(.translation.content | type == \"string\") | { key: .term, value: .translation.content })) | from_entries",
      ".result.terms | map( if .translation.content | type == \"object\" then .term as $term | .translation.content | to_entries[] | .key |= \"\\($term)_\\(.)\" else { key: .term, value: .translation.content } end ) | from_entries",
      ".result.terms | map(.term as $key | .translation.content | if type == \"object\" then to_entries[] | .key |= \"\\($key)_\\(.)\" else { ($key): . } end ) | from_entries",
      ".result.terms | map(.term as $key | .translation.content | (to_entries[] | .key |= \"\\($key)_\\(.)\")? // { ($key): . }) | from_entries",
      ".result.terms | map( .term as $key | .translation.content as $value | $value | (to_entries[] | .key |= \"\\($key)_\\(.)\")? // { ($key): $value }) | from_entries"
    ],
    "data": [
      {
        "input": {
          "result": {
            "terms": [
              {
                "term": "title",
                "translation": {
                  "content": "Welcome to {{user}}"
                }
              },
              {
                "term": "car",
                "translation": {
                  "content": {
                    "one": "car",
                    "other": "cars"
                  }
                }
              }
            ]
          }
        },
        "output": {
          "title": "Welcome to {{user}}",
          "car_one": "car",
          "car_other": "cars"
        }
      }
    ],
    "identifier": 73505346
  },
  {
    "context": [
      "I am trying to loop through the json file using jq to get the name of the agent if the result was \"succeeded\".",
      "jq ' # get the name of the agent if the result was \"succeeded\".\n  .value[]\n  | select(.result == \"succeeded\")\n  | .agent.name\n' test.json",
      "produces:\n\"John\""
    ],
    "utterance": "Get the name of the agent where result is equal to \"succeeded\".",
    "expressions": [
      ".value[] | select(.result == \"succeeded\") | .agent.name"
    ],
    "data": [
      {
        "input": {
          "count": 3,
          "value": [
            {
              "location": "CA",
              "result": "failed",
              "agent": {
                "id": 97833,
                "name": "Brad"
              },
              "priority": 0
            },
            {
              "location": "TX",
              "result": "failed",
              "agent": {
                "id": 15232,
                "name": "Tom"
              },
              "priority": 0
            },
            {
              "location": "CO",
              "result": "succeeded",
              "agent": {
                "id": 13412,
                "name": "John"
              },
              "priority": 0
            }
          ]
        },
        "output": "John"
      }
    ],
    "identifier": 73537210
  },
  {
    "context": [
      "How can I use jq to select and show only the JSON values in `data.all.members` that have their `id` in `data.all.live.online` array?",
      "jq '.data.all\n| .live.online as $online\n| {members}\n| .members |= map( select(.id | IN($online[]) // null) )\n' data.json",
      ".data.all\n| .live.online as $online\n| { members: .members | map(select([.id] | inside($online))) }",
      ".data.all\n| .live.online as $online\n| { members: .members | map(select(.id as $id | $online | any(. == $id))) }"
    ],
    "utterance": "Select members where id is present in live.online array, and output them under a members key.",
    "expressions": [
      ".data.all | .live.online as $online | {members} | .members |= map( select(.id | IN($online[]) // null) )",
      ".data.all | .live.online as $online | { members: .members | map(select([.id] | inside($online))) }",
      ".data.all | .live.online as $online | { members: .members | map(select(.id as $id | $online | any(. == $id))) }"
    ],
    "data": [
      {
        "input": {
          "data": {
            "all": {
              "members": [
                {
                  "id": 10,
                  "name": "First"
                },
                {
                  "id": 12,
                  "name": "Second"
                },
                {
                  "id": 14,
                  "name": "Third"
                }
              ],
              "live": {
                "online": [
                  10,
                  14
                ]
              }
            }
          }
        },
        "output": {
          "members": [
            {
              "id": 10,
              "name": "First"
            },
            {
              "id": 14,
              "name": "Third"
            }
          ]
        }
      }
    ],
    "identifier": 73537190
  },
  {
    "context": [
      "what i need is for it to write error for each part of the array where active doesnt exist.",
      ".data.sub1[] | .sub2.steps[].task[].active // \"error\""
    ],
    "utterance": "Output the value of active in every task or the string \"error\" where active does not exist, iterating over all steps of all sub1 elements.",
    "expressions": [
      ".data.sub1[] | .sub2.steps[].task[].active // \"error\""
    ],
    "data": [
      {
        "input": {
          "data": {
            "sub1": [
              {
                "sub2": {
                  "sub3": 32,
                  "steps": []
                }
              },
              {
                "sub2": {
                  "sub3": 21,
                  "steps": [
                    {
                      "task": [
                        {
                          "active": 223,
                          "activel": 21
                        }
                      ]
                    }
                  ]
                }
              },
              {
                "sub2": {
                  "sub3": 234,
                  "steps": [
                    {
                      "task": [
                        {
                          "active": 23,
                          "activel": 2
                        }
                      ]
                    }
                  ]
                }
              },
              {
                "sub2": {
                  "sub3": 32,
                  "steps": [
                    {
                      "task": []
                    }
                  ]
                }
              }
            ]
          }
        },
        "output": [
          "error",
          223,
          23,
          "error"
        ]
      }
    ],
    "identifier": 73541709
  },
  {
    "context": [
      "Figured this line works, but uses jq twice:",
      "cat file.json | jq -c '.[] | select(.property==\"undesired\")' | jq -c 'del(.property)'",
      "Is there a way to invoke jq just once?",
      "Just pipe the filters together within a single jq command:",
      "jq -c '.[] | select(. property==\"undesired\") | del(.property)' file.json"
    ],
    "utterance": "Filter for array items whose property equals \"undesired\" and remove the property field from those results, using a single command.",
    "expressions": [
      ".[] | select(.property==\"undesired\") | del(.property)"
    ],
    "identifier": 73548916
  },
  {
    "context": [
      "I want to change \"content\" of \"id\"==100 to \"watermelon\" then output the whole of test.json.",
      "$ jq '(.data[]|select(.id==100)).content|=\"watermelon\"' test.json",
      "jq '.data |= map(.content = if .id == 100 then \"watermelons\" else .content end)' file.json"
    ],
    "utterance": "Update the value of \"content\" to \"watermelon\" for the object where \"id\" equals 100 and return the entire file.",
    "expressions": [
      "(.data[]|select(.id==100)).content|=\"watermelon\"",
      ".data |= map(.content = if .id == 100 then \"watermelon\" else .content end)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": 0,
              "content": "apple"
            },
            {
              "id": 100,
              "content": "pears"
            }
          ]
        },
        "output": {
          "data": [
            {
              "id": 0,
              "content": "apple"
            },
            {
              "id": 100,
              "content": "watermelon"
            }
          ]
        }
      }
    ],
    "identifier": 73551461
  },
  {
    "context": [
      "I need to add an item to the ManagedPolicyArns array field where that item contains cloudformation shorthand such as !Sub.",
      "How do I get\n\n            - Fn::ImportValue: !Sub \"${MyPrefix}-my-policy-arn\"\n            - Fn::ImportValue: !Sub \"${MyPrefix}-my-new-policy-arn\"\n\ninstead of\n\n            - Fn::ImportValue: !Sub \"${MyPrefix}-my-policy-arn\"\n            - Fn::ImportValue:\n                '!Sub': ${MyPrefix}-my-new-policy-arn",
      "Use the tag operator",
      "add_policy.yq:\n\n    ( .Resources[] |= \n        select(.Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == \"ecs-tasks.amazonaws.com\" or .Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == \"lambda.amazonaws.com\")\n        .Properties.ManagedPolicyArns += {\"Fn::ImportValue\": \"${AuthAuditBucketStackName}-logging-policy-arn\" | . tag = \"!Sub\" }\n    )",
      "results in:\n\n    - Fn::ImportValue: !Sub \"${MyPrefix}-my-policy-arn\"\n    - Fn::ImportValue: !Sub ${MyPrefix}-my-new-policy-arn"
    ],
    "utterance": "Append a new entry to ManagedPolicyArns for each relevant role, where the entry uses the !Sub shorthand to reference a policy ARN with the MyPrefix parameter.",
    "expressions": [
      "( .Resources[] |= \n    select(.Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == \"ecs-tasks.amazonaws.com\" or .Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == \"lambda.amazonaws.com\")\n    .Properties.ManagedPolicyArns += {\"Fn::ImportValue\": \"${MyPrefix}-my-new-policy-arn\" | . tag = \"!Sub\" }\n)"
    ],
    "data": [
      {
        "input": {
          "AWSTemplateFormatVersion": "2010-09-09",
          "Parameters": {
            "MyPrefix": {
              "Description": "MyPrefix",
              "Type": "String"
            }
          },
          "Resources": {
            "MyRole": {
              "Type": "AWS::IAM::Role",
              "Properties": {
                "ManagedPolicyArns": [
                  {
                    "Fn::ImportValue": {
                      "!Sub": "${MyPrefix}-my-policy-arn"
                    }
                  }
                ],
                "AssumeRolePolicyDocument": {
                  "Version": "2012-10-17",
                  "Statement": [
                    {
                      "Effect": "Allow",
                      "Principal": {
                        "Service": [
                          "ecs-tasks.amazonaws.com",
                          "lambda.amazonaws.com"
                        ]
                      },
                      "Action": [
                        "sts:AssumeRole",
                        "sts:TagSession"
                      ]
                    }
                  ]
                },
                "Path": "/"
              }
            }
          }
        },
        "output": {
          "AWSTemplateFormatVersion": "2010-09-09",
          "Parameters": {
            "MyPrefix": {
              "Description": "MyPrefix",
              "Type": "String"
            }
          },
          "Resources": {
            "MyRole": {
              "Type": "AWS::IAM::Role",
              "Properties": {
                "ManagedPolicyArns": [
                  {
                    "Fn::ImportValue": {
                      "!Sub": "${MyPrefix}-my-policy-arn"
                    }
                  },
                  {
                    "Fn::ImportValue": {
                      "!Sub": "${MyPrefix}-my-new-policy-arn"
                    }
                  }
                ],
                "AssumeRolePolicyDocument": {
                  "Version": "2012-10-17",
                  "Statement": [
                    {
                      "Effect": "Allow",
                      "Principal": {
                        "Service": [
                          "ecs-tasks.amazonaws.com",
                          "lambda.amazonaws.com"
                        ]
                      },
                      "Action": [
                        "sts:AssumeRole",
                        "sts:TagSession"
                      ]
                    }
                  ]
                },
                "Path": "/"
              }
            }
          }
        }
      }
    ],
    "identifier": 73539877
  },
  {
    "context": [
      "Would it be possible for `jq` to return the patch set name (e.g. \"v7.15.x\") when given  the specific version (e.g. \"8.1.0\")?",
      ".compatibility | to_entries[] | select(.value | index(\"8.1.0\")) .key",
      "jq --arg version 8.1.0 '.compatibility | to_entries[] | select(.value | index($version)) .key'",
      "(.compatibility | with_entries({value: .key, key: .value[]})) as $lookup",
      "| $lookup[\"8.0.1\", \"7.11.2\"], $lookup[\"7.16.1\"]"
    ],
    "utterance": "Find the patch set name that contains the version 8.1.0.",
    "expressions": [
      ".compatibility | to_entries[] | select(.value | index(\"8.1.0\")) .key",
      "jq --arg version 8.1.0 '.compatibility | to_entries[] | select(.value | index($version)) .key'",
      "(.compatibility | with_entries({value: .key, key: .value[]})) as $lookup | $lookup[\"8.1.0\"]"
    ],
    "data": [
      {
        "input": {
          "compatibility": {
            "v7.11.x": [
              "7.12.1",
              "7.12.0",
              "7.11.2",
              "7.11.1",
              "7.11.0"
            ],
            "v7.13.x": [
              "7.14.2",
              "7.14.1",
              "7.14.0",
              "7.13.1",
              "7.13.0"
            ],
            "v7.15.x": [
              "8.1.0",
              "8.0.1",
              "8.0.0",
              "7.17.1",
              "7.17.0",
              "7.16.1",
              "7.16.0",
              "7.15.1",
              "7.15.0"
            ]
          }
        },
        "output": "v7.15.x"
      }
    ],
    "identifier": 73566899
  },
  {
    "context": [
      "I need to add ManagedPolicyArns to many IAM roles in many cloudformation.yaml files. Some already have this policy added so I need to select, in order to add, only those that do not.",
      "How do I keep `ManagedPolicyArns` unique and not add the new entry to it if it already exists?",
      "There\u2019s a list of null values that it is iterating and that causes the expression to just break and not evaluate. I need to instead return true for items that are null or not matching, then all will be handled and the expression evaluated fully to true or false.",
      "`add_policy.yq`: ( .Resources[] |= select((.Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == \"ecs-tasks.amazonaws.com\" or .Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == \"lambda.amazonaws.com\") and (.Properties.ManagedPolicyArns[] == null or ( .Properties.ManagedPolicyArns[].\"Fn::ImportValue\" == \"${MyPrefix}-my-policy-arn\" | not )) ) .Properties.ManagedPolicyArns += {\"Fn::ImportValue\": \"${MyPrefix}-my-policy-arn\" | . tag = \"!Sub\" } )"
    ],
    "utterance": "Add a specific policy to the ManagedPolicyArns list of each IAM role whose AssumeRolePolicyDocument matches ecs-tasks.amazonaws.com or lambda.amazonaws.com, but only if the policy is not already present.",
    "expressions": [
      "(.Resources[] |= select((.Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == \"ecs-tasks.amazonaws.com\" or .Properties.AssumeRolePolicyDocument.Statement[].Principal.Service.[] == \"lambda.amazonaws.com\") and (.Properties.ManagedPolicyArns[] == null or ( .Properties.ManagedPolicyArns[].\"Fn::ImportValue\" == \"${MyPrefix}-my-policy-arn\" | not )) ) .Properties.ManagedPolicyArns += {\"Fn::ImportValue\": \"${MyPrefix}-my-policy-arn\" | . tag = \"!Sub\" })"
    ],
    "data": [
      {
        "input": {
          "Resources": {
            "MyRole": {
              "Type": "AWS::IAM::Role",
              "Properties": {
                "ManagedPolicyArns": [
                  {
                    "Fn::ImportValue": "${MyPrefix}-my-policy-arn"
                  }
                ],
                "AssumeRolePolicyDocument": {
                  "Version": "2012-10-17",
                  "Statement": [
                    {
                      "Effect": "Allow",
                      "Principal": {
                        "Service": [
                          "ecs-tasks.amazonaws.com",
                          "lambda.amazonaws.com"
                        ]
                      },
                      "Action": [
                        "sts:AssumeRole",
                        "sts:TagSession"
                      ]
                    }
                  ]
                },
                "Path": "/"
              }
            }
          }
        }
      }
    ],
    "identifier": 73551977
  },
  {
    "context": [
      "What I want to do is copying the id from the mother object into the parent field of the child object.",
      "Assuming the first element is always the mother, this should work just fine:\n```\n.data[].assets.array |= (.[1].properties.parent = .[0].id)\n```",
      "Otherwise sort them by `labels.text` first so that they are always at certain indices.\n```\n.data[].assets.array |= (sort_by(.labels.text) | .[0].properties.parent = .[1].id)\n```",
      "```\njq '.data |= map(.assets.array | .[1].properties.parent = .[0].id)' test.json\n```"
    ],
    "utterance": "Copy the id field from the mother object to the parent property of the child object within each array of assets.",
    "expressions": [
      ".data[].assets.array |= (.[1].properties.parent = .[0].id)",
      ".data[].assets.array |= (sort_by(.labels.text) | .[0].properties.parent = .[1].id)",
      ".data |= map(.assets.array | .[1].properties.parent = .[0].id)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "assets": {
                "array": [
                  {
                    "id": "7978918",
                    "labels": {
                      "text": "mother",
                      "value": true
                    },
                    "properties": {
                      "context_ids": [],
                      "parent": null
                    }
                  },
                  {
                    "id": "caa17b2a-4582-4d13-b891-2607e4ba33c6",
                    "labels": {
                      "text": "child",
                      "value": true
                    },
                    "properties": {
                      "context_ids": [],
                      "parent": null
                    }
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "data": [
            {
              "assets": {
                "array": [
                  {
                    "id": "7978918",
                    "labels": {
                      "text": "mother",
                      "value": true
                    },
                    "properties": {
                      "context_ids": [],
                      "parent": null
                    }
                  },
                  {
                    "id": "caa17b2a-4582-4d13-b891-2607e4ba33c6",
                    "labels": {
                      "text": "child",
                      "value": true
                    },
                    "properties": {
                      "context_ids": [],
                      "parent": "7978918"
                    }
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 73581846
  },
  {
    "context": [
      "The API will sometime return an object and sometime an array, I want to catch the result using an `if` statement and return empty string when the object/array is not available.",
      "Would also like to  to use the statement globally for the whole array output so I can parse it to .csv and escape the null, since sofware name , can also contain an array or an object.",
      "The error i received from `bash` ... jq: error (at <stdin>:182): Cannot iterate over null (null)",
      "Desired outcome ... [\n  \n  \"Bluetooth Mesh SDK\",\n  \"empty\"\n]",
      "you can get the desired output by using the following JQ filter:\n\nif (.result | type) == \"array\" then . else (.result |= [.]) end \\\n    | .result[].software | [ .name, (.platform // [ \"Empty\" ] | join(\",\")) ]"
    ],
    "utterance": "Get the software name and platform values from each result, ensuring that if result or platform are missing, they are replaced with empty or 'Empty' values, with compatible handling for both array and object forms.",
    "expressions": [
      "if (.result | type) == \"array\" then . else (.result |= [.]) end | .result[].software | [ .name, (.platform // [ \"Empty\" ] | join(\",\")) ]"
    ],
    "data": [
      {
        "input": {
          "result": {
            "entry": {
              "id": "207579",
              "title": "Realtek Bluetooth Mesh SDK on Linux/Android Segmented Packet reference buffer overflow",
              "summary": "A vulnerability, which was classified as critical, was found in Realtek Bluetooth Mesh SDK on Linux/Android (the affected version unknown). This affects an unknown functionality of the component Segmented Packet Handler. There is no information about possible countermeasures known. It may be suggested to replace the affected object with an alternative product.",
              "details": {
                "affected": "A vulnerability, which was classified as critical, was found in Realtek Bluetooth Mesh SDK on Linux/Android (the affected version unknown).",
                "vulnerability": "The manipulation of the argument reference with an unknown input leads to a unknown weakness. CWE is classifying the issue as CWE-120. The program copies an input buffer to an output buffer without verifying that the size of the input buffer is less than the size of the output buffer, leading to a buffer overflow.",
                "impact": "This is going to have an impact on confidentiality, integrity, and availability.",
                "countermeasure": "There is no information about possible countermeasures known. It may be suggested to replace the affected object with an alternative product."
              },
              "timestamp": {
                "create": "1661860801",
                "change": "1661861110"
              },
              "changelog": [
                "software_argument"
              ]
            },
            "software": {
              "vendor": "Realtek",
              "name": "Bluetooth Mesh SDK",
              "platform": [
                "Linux",
                "Android"
              ],
              "component": "Segmented Packet Handler",
              "argument": "reference",
              "cpe": [
                "cpe:/a:realtek:bluetooth_mesh_sdk"
              ],
              "cpe23": [
                "cpe:2.3:a:realtek:bluetooth_mesh_sdk:*:*:*:*:*:*:*:*"
              ]
            }
          }
        },
        "output": [
          "Bluetooth Mesh SDK",
          "Linux,Android"
        ]
      },
      {
        "input": {
          "result": {
            "software": {
              "name": "Bluetooth Mesh SDK"
            }
          }
        },
        "output": [
          "Bluetooth Mesh SDK",
          "Empty"
        ]
      }
    ],
    "identifier": 73553724
  },
  {
    "context": [
      "I try to extract details when value contains certain string (here \"whatamImissing\").",
      "What I want is \r\n{\r\n  \"bar\": \"thisIsneeded\",\r\n  {\r\n    \"name\": \"foo\",\r\n    \"comments\": \"whatamImissing\"\r\n  }\r\n}",
      "Here's one way with a valid output JSON as array of objects:",
      "jq 'map(\n  .results[] as $r | select($r.comments | test(\"whatamImissing\"))\n  | {bar} + ($r | {name, comments})\n)'",
      "Another take:\n```sh\njq '\n    map({\n        bar,\n        result: (\n            .results[]\n            | select(.comments | contains(\"whatamI\"))\n            | {name, comments}\n        )\n    })\n'\n```"
    ],
    "utterance": "Extract all objects where any result's comments contains the string 'whatamImissing', and output an object containing 'bar' along with the matching result's 'name' and 'comments'.",
    "expressions": [
      "map(\n  .results[] as $r | select($r.comments | test(\"whatamImissing\"))\n  | {bar} + ($r | {name, comments})\n)",
      "map({\n  bar,\n  result: (\n    .results[]\n    | select(.comments | contains(\"whatamI\"))\n    | {name, comments}\n  )\n})"
    ],
    "data": [
      {
        "input": [
          {
            "http_method": "GET",
            "revision": "2226.1.0.17580034458892190058.1564516060",
            "results": [
              {
                "origin": 80,
                "name": "foo",
                "comments": "whatamImissing",
                "emptydata": ""
              }
            ],
            "bar": "thisIsneeded",
            "meta": "metainfo"
          }
        ],
        "output": [
          {
            "bar": "thisIsneeded",
            "name": "foo",
            "comments": "whatamImissing"
          }
        ]
      }
    ],
    "identifier": 73582719
  },
  {
    "context": [
      "I want filer out only the `name` fields and create an array named `names`",
      "Use \n\n```sh\njq '{names: [.[] | {name: .name}]}'\n```",
      "Alternatively, we use a few shortcuts produces the shorten the above.\n\n```sh\njq '{names: map({name})}'\n```"
    ],
    "utterance": "Extract all objects' name fields and wrap them in an object under the key names.",
    "expressions": [
      "{names: [.[] | {name: .name}]}",
      "{names: map({name})}"
    ],
    "data": [
      {
        "input": [
          {
            "name": "A",
            "age": 1
          },
          {
            "name": "B",
            "age": 2
          },
          {
            "name": "C",
            "age": 3
          }
        ],
        "output": {
          "names": [
            {
              "name": "A"
            },
            {
              "name": "B"
            },
            {
              "name": "C"
            }
          ]
        }
      }
    ],
    "identifier": 73591710
  },
  {
    "context": [
      "I need to be able to compare the input text value which is saved in $entry to all the values within the item_name array and return true/false depending on if the $entry value is present using jq library.",
      "The jq command that works as expected is",
      "echo $RESPONSE | jq -e '. ' | jq -r '.[\"response\"][\"docs\"] | .[].item_name ' | jq -s 'add' | jq 'any(. == \"'$entry'\") | if . == true then \"Exact match\" else \"No Exact match\" end'"
    ],
    "utterance": "Check if the value stored in the shell variable $entry exists among any item_name values, returning a specific string if found or not found.",
    "expressions": [
      ".[\"response\"][\"docs\"] | .[].item_name | flatten | any(. == \"$entry\")",
      ".[\"response\"][\"docs\"] | .[].item_name | flatten | any(. == \"$entry\") | if . == true then \"Exact match\" else \"No Exact match\" end"
    ],
    "data": [
      {
        "input": {
          "response": {
            "numFound": 2,
            "docs": [
              {
                "country": "USA",
                "item_name": [
                  "parachutes",
                  "air balloon"
                ]
              },
              {
                "country": "Brazil",
                "item_name": [
                  "gliders",
                  "aircraft carriers"
                ]
              }
            ]
          }
        },
        "output": "Exact match"
      }
    ],
    "identifier": 73586326
  },
  {
    "context": [
      "I\u2019ve an array of numbers and I need to calculate the __Sample Standard Deviation__ using `jq`.",
      "# Example of data input\n_data=\"[73,73,76,77,81,100]\"\n...\necho \"$_standard_deviation\" # Should print 10.237187",
      "This is how you do it:\n```\n(add / length) as $mean | (map(. - $mean | . * .) | add) / (length - 1) | sqrt\n```"
    ],
    "utterance": "Calculate the sample standard deviation of an array of numbers where the array is [73,73,76,77,81,100] and the output should match 10.237187.",
    "expressions": [
      "(add / length) as $mean | (map(. - $mean | . * .) | add) / (length - 1) | sqrt"
    ],
    "data": [
      {
        "input": [
          73,
          73,
          76,
          77,
          81,
          100
        ],
        "output": 10.237187
      }
    ],
    "identifier": 73599978
  },
  {
    "context": [
      "I need to transform this in a csv file but I don't know how to do.",
      "cat file.json | jq '.[]| join(\",\")'",
      "jq: error (at <stdin>:8): Cannot iterate over string (\"https://lo...)",
      "It's easier than you think:",
      "jq -r '@csv' file.json"
    ],
    "utterance": "Convert a stream of arrays, each representing a row, to CSV format.",
    "expressions": [
      "@csv"
    ],
    "data": [
      {
        "input": [
          [
            "https://localhost/rundeck/project/Enterprise/execution/show/228",
            "succeeded",
            "Enterprise",
            "2020-04-19T03:00:01Z",
            "2020-04-19T03:13:17Z",
            "job_particion"
          ],
          [
            "https://localhost/rundeck/project/Enterprise/execution/show/824",
            "succeeded",
            "Enterprise",
            "2020-09-01T04:15:00Z",
            "2020-09-01T04:15:02Z",
            "job_scheduler"
          ]
        ],
        "output": "\"https://localhost/rundeck/project/Enterprise/execution/show/228\",\"succeeded\",\"Enterprise\",\"2020-04-19T03:00:01Z\",\"2020-04-19T03:13:17Z\",\"job_particion\"\n\"https://localhost/rundeck/project/Enterprise/execution/show/824\",\"succeeded\",\"Enterprise\",\"2020-09-01T04:15:00Z\",\"2020-09-01T04:15:02Z\",\"job_scheduler\""
      }
    ],
    "identifier": 73613113
  },
  {
    "context": [
      "I want to retrieve both `app1.*` and `app2.*` object values if latency is more than 10 sec.",
      "I need to know now how I can retrieve the `app2` values along with `app1` if above condition satisfied.",
      "You could simply `or` the conditions, e.g. using your approach:",
      "| select(.source | (startswith(\"app1\") or startswith(\"app2\")) )",
      "Or you could use a regular expression, e.g.",
      "select( .source | test(\"^app[12]\") )",
      "or perhaps",
      "select( .source | test(\"^app[12][.]\") )"
    ],
    "utterance": "Retrieve objects where the source starts with 'app1.' or 'app2.' and latency is greater than 10.",
    "expressions": [
      ".[] | .end2end.data[0] | select(.latency > 10) | select(.source | (startswith(\"app1\") or startswith(\"app2\")))",
      ".[] | .end2end.data[0] | select(.latency > 10) | select(.source | test(\"^app[12]\"))",
      ".[] | .end2end.data[0] | select(.latency > 10) | select(.source | test(\"^app[12][.]\"))"
    ],
    "data": [
      {
        "input": {
          "app1.btch_src": {
            "eventrate": 0,
            "end2end": {
              "data": [
                {
                  "at": 16054343444,
                  "source": "app1.btch_src",
                  "latency": 0.05,
                  "target": "app1.btch_tgt"
                }
              ]
            }
          },
          "app1.btch1_src": {
            "eventrate": 0,
            "end2end": {
              "data": [
                {
                  "at": 16054343445,
                  "source": "app1.btch1_src",
                  "latency": 200.5,
                  "target": "app1.btch1_tgt"
                }
              ]
            }
          },
          "app2.btch_src": {
            "eventrate": 0,
            "end2end": {
              "data": [
                {
                  "at": 16054341234,
                  "source": "app2.btch_src",
                  "latency": 50.4,
                  "target": "app2.btch_tgt"
                }
              ]
            }
          },
          "app3.btch_src": {
            "eventrate": 0,
            "end2end": {
              "data": [
                {
                  "at": 16054343444,
                  "source": "app3.btch_src",
                  "latency": 10,
                  "target": "app3.btch_tgt"
                }
              ]
            }
          }
        },
        "output": [
          {
            "at": 16054343445,
            "source": "app1.btch1_src",
            "latency": 200.5,
            "target": "app1.btch1_tgt"
          },
          {
            "at": 16054341234,
            "source": "app2.btch_src",
            "latency": 50.4,
            "target": "app2.btch_tgt"
          }
        ]
      }
    ],
    "identifier": 73604109
  },
  {
    "context": [
      "I want to filter the json file using their name(eg. release-1),Then I want to return key value of the all commitId in the same object as the name.",
      "Will show each `commitId` where `name` contains ([`index()`][1]) `release-1`.",
      "Expected Output\n```\n523asdc3\n523asdc3\n523asdc3\n```",
      "```\n.releases[] | select(.name | index(\"release-1\")) | .artifacts[].commitId\n```",
      ".releases[]|select(.name|contains([\"release-1\"]))|.artifacts[].commitId",
      ".releases[]|select(.name[0] ==\"release-1\")|.artifacts[].commitId"
    ],
    "utterance": "Return each commitId for all artifacts in releases where the name includes 'release-1'.",
    "expressions": [
      ".releases[] | select(.name | index(\"release-1\")) | .artifacts[].commitId",
      ".releases[]|select(.name|contains([\"release-1\"]))|.artifacts[].commitId",
      ".releases[]|select(.name[0] ==\"release-1\")|.artifacts[].commitId"
    ],
    "data": [
      {
        "input": {
          "releases": [
            {
              "name": [
                "release-1"
              ],
              "artifacts": [
                {
                  "name": "pkg-1",
                  "commitId": "523asdc3"
                },
                {
                  "name": "pkg-2",
                  "commitId": "523asdc3"
                },
                {
                  "name": "pkg-3",
                  "commitId": "523asdc3"
                }
              ]
            },
            {
              "name": [
                "release-2"
              ],
              "artifacts": [
                {
                  "name": "pkg-3",
                  "commitId": "523asdc3"
                },
                {
                  "name": "pkg-4",
                  "commitId": "523asdc3"
                },
                {
                  "name": "pkg-5",
                  "commitId": "523asdc3"
                }
              ]
            }
          ]
        },
        "output": [
          "523asdc3",
          "523asdc3",
          "523asdc3"
        ]
      }
    ],
    "identifier": 73616458
  },
  {
    "context": [
      "Here I just want to get the last available element for the second column.",
      "Expected Answer:- `Martin`",
      "last(.values[] | select(has(1))) [1]",
      "last(.values[][1] // empty)",
      ".values | map(.[1] | select(.)) | last"
    ],
    "utterance": "Get the last value present in the second column of a 2D array, considering only rows where the column exists and is not empty.",
    "expressions": [
      "last(.values[] | select(has(1))) [1]",
      "last(.values[][1] // empty)",
      ".values | map(.[1] | select(.)) | last"
    ],
    "data": [
      {
        "input": {
          "range": "'PR-DETAILS'!A1:Z1000",
          "majorDimension": "ROWS",
          "values": [
            [
              "PR ID",
              "PR Owner"
            ],
            [
              "1929",
              "Angel"
            ],
            [
              "73",
              "Martin"
            ],
            [
              "142"
            ]
          ]
        },
        "output": "Martin"
      }
    ],
    "identifier": 73616768
  },
  {
    "context": [
      "\"Is there an option in `jq` that, instead of printing the value itself, prints the location (line and column, start and end position) of the value within a (valid) JSON file, given an *Object Identifier-Index* (`.key2.key2_2.key2_2_1` in the example)?\"",
      "\"That said, this could give you a starting point (the `--raw-output` (or `-r`) option outputs raw text instead of JSON):\\n~~~sh\\njq -Rrs ' \\n  \"\\(fromjson.key2.key2_2.key2_2_1)\" as $query    # save the query value as string\\n  | ($query | length) as $length      # save its length by counting its characters\\n  | ./\"\\n\" | to_entries[]      # split into lines and provide 0-based line numbers\\n  | {row: .key, col: .value | indices($query)[]}   # find occurrences of the query\\n  | \"(\\(.row),\\(.col)) (\\(.row),\\(.col + $length))\"            # format the output\\n'\\n~~~\\n~~~json\\n(5,24) (5,34)\\n~~~\"",
      "\"Now, this works for the sample query, how about the general case? Your example queried a number (`1.43123123`) which is an easy target as it has the same textual representation when encoded as JSON.\""
    ],
    "utterance": "Find the line and column positions (start and end) of the value at the path .key2.key2_2.key2_2_1 in the file example.json.",
    "expressions": [
      "jq -Rrs '\n  \"\\(fromjson.key2.key2_2.key2_2_1)\" as $query\n  | ($query | length) as $length\n  | ./\"\\n\" | to_entries[]\n  | {row: .key, col: .value | indices($query)[]}\n  | \"(\\(.row),\\(.col)) (\\(.row),\\(.col + $length))\"\n'"
    ],
    "data": [
      {
        "input": {
          "key1": [
            "arr value 1",
            "arr value 2",
            "arr value 3"
          ],
          "key2": {
            "key2_1": [
              "a1",
              "a2"
            ],
            "key2_2": {
              "key2_2_1": 1.43123123,
              "key2_2_2": 456.3123,
              "key2_2_3": "string1"
            }
          }
        },
        "output": "(5,24) (5,34)"
      }
    ],
    "identifier": 73616608
  },
  {
    "context": [
      "I am wanting to write a script to ... 3) then converting that Json to CSV.",
      "Currently I have to use an online Json to CSV converter to get the desired output.",
      "**Desired output csv code**",
      "I'm working hard to really grok jq, so here you go: with no explanation:",
      "jq -r '\n    .[]\n    | [.matchId, .timestamp] as [$matchId, $timestamp]\n    | (.players | [to_entries[] | .key as $id1 | .value | to_entries[] | [$id1, .key, .value.position, .value.toiseconds, .value.playername]]) as $players\n    | (.clubs | [to_entries[] | [.key, .value.toa, .value.details.name, .value.details.clubId]]) as $clubs\n    | range([$players, $clubs] | map(length) | max)\n    | [$matchId, $timestamp] + ($clubs[.] // [\"\",\"\",\"\",\"\"]) + ($players[.] // [\"\",\"\",\"\",\"\",\"\"])\n    | @csv\n' file.json",
      "The default value arrays of empty strings needs to be the same size as the amount of \"real\" data you're grabbing.",
      "Since this is a PITA to keep aligned, an update:\n\njq -r '\n    def empty_strings: reduce range(length) as $i ([]; . + [\"\"]);\n\n    .[]\n    | [.matchId, .timestamp] as [$matchId, $timestamp]\n    | (.players | [to_entries[] | .key as $id1 | .value | to_entries[] | [$id1, .key, .value.position, .value.toiseconds, .value.playername]]) as $players\n    | (.clubs | [to_entries[] | [.key, .value.toa, .value.details.name, .value.details.clubId]]) as $clubs\n    | range([$players, $clubs] | map(length) | max)\n    | [$matchId, $timestamp]\n      + ($clubs[.]   // ($clubs[0] | empty_strings))\n      + ($players[.] // ($players[0] | empty_strings))\n    | @csv\n' file.json"
    ],
    "utterance": "Convert each match object so that for every player and club, output a row with the matchId, timestamp, the club's id, toa, name, clubId, followed by the player's club id, player id, position, toiseconds, and playername, with empty strings where no club or player data is present.",
    "expressions": [
      ".[]\n| [.matchId, .timestamp] as [$matchId, $timestamp]\n| (.players | [to_entries[] | .key as $id1 | .value | to_entries[] | [$id1, .key, .value.position, .value.toiseconds, .value.playername]]) as $players\n| (.clubs | [to_entries[] | [.key, .value.toa, .value.details.name, .value.details.clubId]]) as $clubs\n| range([$players, $clubs] | map(length) | max)\n| [$matchId, $timestamp] + ($clubs[.] // [\"\",\"\",\"\",\"\"]) + ($players[.] // [\"\",\"\",\"\",\"\",\"\"])\n| @csv",
      "def empty_strings: reduce range(length) as $i ([]; . + [\"\"]);\n\n.[]\n| [.matchId, .timestamp] as [$matchId, $timestamp]\n| (.players | [to_entries[] | .key as $id1 | .value | to_entries[] | [$id1, .key, .value.position, .value.toiseconds, .value.playername]]) as $players\n| (.clubs | [to_entries[] | [.key, .value.toa, .value.details.name, .value.details.clubId]]) as $clubs\n| range([$players, $clubs] | map(length) | max)\n| [$matchId, $timestamp]\n  + ($clubs[.]   // ($clubs[0] | empty_strings))\n  + ($players[.] // ($players[0] | empty_strings))\n| @csv"
    ],
    "data": [
      {
        "input": [
          {
            "matchId": "2068447050405",
            "timestamp": 1658361314,
            "clubs": {
              "39335": {
                "toa": "486",
                "details": {
                  "name": "Team one",
                  "clubId": 39335
                }
              },
              "111655": {
                "toa": "229",
                "details": {
                  "name": "Team two",
                  "clubId": 111655
                }
              }
            },
            "players": {
              "39335": {
                "189908959": {
                  "position": "defenseMen",
                  "toiseconds": "3600",
                  "playername": "player one"
                },
                "828715674": {
                  "position": "rightWing",
                  "toiseconds": "3600",
                  "playername": "player two"
                }
              },
              "111655": {
                "515447555": {
                  "position": "defenseMen",
                  "toiseconds": "3600",
                  "playername": "player three"
                },
                "806370074": {
                  "position": "center",
                  "toiseconds": "3600",
                  "playername": "player four"
                }
              }
            }
          }
        ],
        "output": [
          "\"2068447050405\",1658361314,\"39335\",\"486\",\"Team one\",39335,\"39335\",\"189908959\",\"defenseMen\",\"3600\",\"player one\"",
          "\"2068447050405\",1658361314,\"111655\",\"229\",\"Team two\",111655,\"39335\",\"828715674\",\"rightWing\",\"3600\",\"player two\"",
          "\"2068447050405\",1658361314,\"\",\"\",\"\",\"\",\"111655\",\"515447555\",\"defenseMen\",\"3600\",\"player three\"",
          "\"2068447050405\",1658361314,\"\",\"\",\"\",\"\",\"111655\",\"806370074\",\"center\",\"3600\",\"player four\""
        ]
      }
    ],
    "identifier": 73547586
  },
  {
    "context": [
      "Suppose that the output of a jq command is a list of objects. What would be the command to get this list as the attribute of an object?",
      "This will take the json document and put it as a \"items\" attribute of a dictionary.",
      "jq '{items: .}'"
    ],
    "utterance": "Wrap the input list as the value of a new attribute called \"items\" in an object.",
    "expressions": [
      "{items: .}"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Foo"
          },
          {
            "name": "Bar"
          }
        ],
        "output": {
          "items": [
            {
              "name": "Foo"
            },
            {
              "name": "Bar"
            }
          ]
        }
      }
    ],
    "identifier": 73628028
  },
  {
    "context": [
      "I want the output where as you can see the value combine into one :\r\n\r\n    one\r\n    [\r\n      \"test\"\r\n    ]\r\n    [\r\n      \"JsonSerializer.cs\",358\r\n      \"ChatClient.cs\",1241\r\n      \"MiniJSON.cs\",382\r\n    ]\r\n    \r\n    two\r\n    [\r\n      \"secondtest\"\r\n    ]\r\n    [\r\n      \"Utilities.cs\",88\r\n      \"PhotonPing.cs\",36\r\n    ]",
      ".[] | .id, .msg, ([.FilePath, .line] | transpose | add), \"\"",
      "<stack.json jq -r '.[] | .id, .msg, ([.FilePath, .line]|transpose|add)'",
      "transpose turns [[1,2,3],[4,5,6]] into [[1,4],[2,5],[3,6]] and add collects all array elements into a single array."
    ],
    "utterance": "For each object, display the id, the msg array, and an array where each FilePath element is paired with the corresponding line element in a sub-array.",
    "expressions": [
      ".[] | .id, .msg, ([.FilePath, .line] | transpose | add), \"\"",
      ".[] | .id, .msg, ([.FilePath, .line]|transpose|add)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "one",
            "msg": [
              "test"
            ],
            "FilePath": [
              "JsonSerializer.cs",
              "ChatClient.cs",
              "MiniJSON.cs"
            ],
            "line": [
              358,
              1241,
              382
            ]
          },
          {
            "id": "two",
            "msg": [
              "secondtest"
            ],
            "FilePath": [
              "Utilities.cs",
              "PhotonPing.cs"
            ],
            "line": [
              88,
              36
            ]
          }
        ],
        "output": [
          "one",
          [
            "test"
          ],
          [
            [
              "JsonSerializer.cs",
              358
            ],
            [
              "ChatClient.cs",
              1241
            ],
            [
              "MiniJSON.cs",
              382
            ]
          ],
          "two",
          [
            "secondtest"
          ],
          [
            [
              "Utilities.cs",
              88
            ],
            [
              "PhotonPing.cs",
              36
            ]
          ]
        ]
      }
    ],
    "identifier": 73626362
  },
  {
    "context": [
      "I am unable to retrieve the observations. I am trying to retieve each of the \"observations using the following command and not able to get to the result:\r\n\r\n    cat sample3.json | jq .dataSets[0].series.0:0:0:0:0.observations.0[0]",
      "But once I try to drill down further I am getting a compile error:\r\n\r\n    $ cat sample3.json | jq .dataSets[0].series.0:0:0:0:0\r\n    jq: error: syntax error, unexpected LITERAL, expecting end of file (Unix shell quoting issues?) at <top-level>, line 1:\r\n    .dataSets[0].series.0:0:0:0:0                   \r\n    jq: 1 compile error",
      "The .foo syntax cannot be used if the key name has anything but alphanumeric characters or the underscore, or if the first character of the key name is numeric.",
      "you can always use the form: .\"foo\", which is actually an abbreviation of the basic form, .[\"foo\"]",
      "So assuming you're using a sufficiently recent version of jq, your query could begin with:\r\n\r\n    .dataSets[0].series.\"0:0:0:0:0\""
    ],
    "utterance": "Access the observations for the series with key '0:0:0:0:0' in the first dataSets element.",
    "expressions": [
      ".dataSets[0].series[\"0:0:0:0:0\"].observations",
      ".dataSets[0].series.\"0:0:0:0:0\".observations"
    ],
    "data": [
      {
        "input": {
          "header": {
            "id": "b8be2cd5-33bf-4687-9e81-eb032f6f8a71",
            "test": false,
            "prepared": "2022-09-01T13:30:57.013+02:00",
            "sender": {
              "id": "ECB"
            }
          },
          "dataSets": [
            {
              "action": "Replace",
              "validFrom": "2022-09-01T13:30:57.013+02:00",
              "series": {
                "0:0:0:0:0": {
                  "attributes": [
                    0,
                    null,
                    0,
                    null,
                    null,
                    null,
                    null,
                    null,
                    null,
                    null,
                    null,
                    null,
                    0,
                    null,
                    0,
                    null,
                    0,
                    0,
                    0,
                    0
                  ],
                  "observations": {
                    "0": [
                      1.4529,
                      0,
                      0,
                      null,
                      null
                    ],
                    "1": [
                      1.4472,
                      0,
                      0,
                      null,
                      null
                    ],
                    "2": [
                      1.4591,
                      0,
                      0,
                      null,
                      null
                    ]
                  }
                }
              }
            }
          ],
          "structure": {}
        },
        "output": {
          "0": [
            1.4529,
            0,
            0,
            null,
            null
          ],
          "1": [
            1.4472,
            0,
            0,
            null,
            null
          ],
          "2": [
            1.4591,
            0,
            0,
            null,
            null
          ]
        }
      }
    ],
    "identifier": 73596490
  },
  {
    "context": [
      "I am trying to prettify aws logs stream",
      "I want to change this to",
      "If you feed your log sample to:",
      "jq -rR 'index(\"{\") as $ix | .[0:$ix], ( .[$ix:]|fromjson)'",
      "you will get the log stamp followed by a copy of the corresponding valid JSON.",
      "Your subject line indicates you want to \"prettify\" the JSON rather than mangle it, so I'll assume you didn't intend the latter.",
      "If you really want the initial '{' to appear with the log stamp, then assuming a bash or bash-like shell, you could pipe the above into:",
      "    sed $'/^[0-9][0-9][0-9][0-9]-/ {N; s/\\n{/{/; }'"
    ],
    "utterance": "Prettify the inline JSON object at the end of each log line while preserving the original log prefix.",
    "expressions": [
      "jq -rR 'index(\"{\") as $ix | .[0:$ix], ( .[$ix:]|fromjson)'"
    ],
    "identifier": 73639504
  },
  {
    "context": [
      "aws logs describe-log-groups | jq -r --arg CLUSTER_NAME \"$EKS_CLUSTER_NAME\" '.logGroups[] | select(.logGroupName == '/aws/eks/$CLUSTER_NAME/cluster')'",
      "To include a variable's value inside a string in jq you would either add up the parts (e.g. using + as in \"..\" + $var + \"..\"), or use string interpolation \"..\\($var)..\"",
      "jq -r --arg CLUSTER_NAME \"$EKS_CLUSTER_NAME\" '\n  .logGroups[] | select(.logGroupName == \"/aws/eks/\\($CLUSTER_NAME)/cluster\")\n'"
    ],
    "utterance": "Select log group objects where logGroupName equals \"/aws/eks/$CLUSTER_NAME/cluster\", with $CLUSTER_NAME from a variable.",
    "expressions": [
      ".logGroups[] | select(.logGroupName == \"/aws/eks/\u0000($CLUSTER_NAME)/cluster\")"
    ],
    "identifier": 73641959
  },
  {
    "context": [
      "Basically i need to transform a set of arrays depending on if the index is odd or even, while the length of each array is different.",
      "transform into:",
      "{\r\n  \"children\": [\r\n    {\r\n      \"name\": \"dev\",\r\n      \"value\": 5,\r\n      \"children\": [\r\n        {\r\n          \"name\": \"RT\",\r\n          \"value\": 1\r\n        },\r\n        {\r\n          \"name\": \"CP\",\r\n          \"value\": 2\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}",
      "{\r\n  children: [\r\n    _nwise(2) | (.[0] | f) + {\r\n      children: (.[1] | map(f))\r\n    }\r\n  ]\r\n}"
    ],
    "utterance": "Group each consecutive pair of elements in the array, using the first as an object with name and value fields, and the second as an array of child name/value objects, for arrays of varying length.",
    "expressions": [
      "def f: { name: .[0], value: .[1] }; { children: [ _nwise(2) | (.[0] | f) + { children: (.[1] | map(f)) } ] }"
    ],
    "data": [
      {
        "input": [
          [
            [
              "dev",
              5
            ],
            [
              [
                "RT",
                1
              ],
              [
                "CP",
                2
              ]
            ]
          ],
          [
            [
              "jez",
              2
            ],
            [
              [
                "ME",
                1
              ],
              [
                "PW",
                1
              ]
            ],
            [
              "lem",
              3
            ],
            [
              [
                "AR",
                1
              ],
              [
                "ME",
                2
              ]
            ],
            [
              "has",
              1
            ],
            [
              [
                "MOBILE",
                1
              ]
            ]
          ]
        ],
        "output": [
          {
            "children": [
              {
                "name": "dev",
                "value": 5,
                "children": [
                  {
                    "name": "RT",
                    "value": 1
                  },
                  {
                    "name": "CP",
                    "value": 2
                  }
                ]
              }
            ]
          },
          {
            "children": [
              {
                "name": "jez",
                "value": 2,
                "children": [
                  {
                    "name": "ME",
                    "value": 1
                  },
                  {
                    "name": "PW",
                    "value": 1
                  }
                ]
              },
              {
                "name": "lem",
                "value": 3,
                "children": [
                  {
                    "name": "AR",
                    "value": 1
                  },
                  {
                    "name": "ME",
                    "value": 2
                  }
                ]
              },
              {
                "name": "has",
                "value": 1,
                "children": [
                  {
                    "name": "MOBILE",
                    "value": 1
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 73632847
  },
  {
    "context": [
      "I would like to update $runner variable value while looping using range.",
      "Store the value of the iteration itself to the $runner variable, and you can use it as envisioned. To filter out certain values, use select, no need for label and break.",
      ". as $index | range($index; 20) as $runner\n| select($runner < 10) | \"dx\\($runner)\"",
      "range(.; 20) | \"dx\\(select(. < 10))\""
    ],
    "utterance": "Generate strings prefixed with 'dx' for numbers in a range starting from the input up to 20, but only for values less than 10.",
    "expressions": [
      ". as $index | range($index; 20) as $runner | select($runner < 10) | \"dx\\($runner)\"",
      "range(.; 20) | \"dx\\(select(. < 10))\""
    ],
    "data": [
      {
        "input": 1,
        "output": [
          "dx1",
          "dx2",
          "dx3",
          "dx4",
          "dx5",
          "dx6",
          "dx7",
          "dx8",
          "dx9"
        ]
      }
    ],
    "identifier": 73645963
  },
  {
    "context": [
      "I need to loop items array such that I should continue where I left for an element of vals array.",
      "so I need to loop items array such that I should continue where I left for an element of vals array.",
      "The key to doing this cleanly is to define a helper function which allows us to keep track of where to resume the search:",
      "# input: [ $index, $array ] where $index is null or >= -1",
      "# output: the first index, $i, in the array for which",
      "#   $i > $index and $array[$i].amount == $v , or else null",
      "For computing the number of days between two dates, another helper function will be useful:",
      "# Date format: dd-mm-year",
      ".items as $items | reduce .vals[] as $val ({ix: 0, date: .vals[0].date, array: []}; ([.ix, $items] | value($val.amount)) as $ix | .ix = $ix | if $ix == null then . else .date as $date | .array += [$val | {month, value: days($items[$ix].date; $date) }] | .date = $date end )"
    ],
    "utterance": "Iterate through vals and, for each entry, sum items amounts from where the previous left off, splitting amounts between vals as needed, and compute the number of days between corresponding dates.",
    "expressions": [
      "def value($v): \n   . as [ $index, $array ]\n   | if $index == null then null\n     else first( range($index + 1; $array|length) | select($array[.].amount == $v) ) // null\n     end ;",
      "def days($finish; $start):\n  [$finish, $start]\n  | map(strptime(\"%d-%m-%Y\") | mktime)\n  | (.[0] - .[1]) / 86400 + 0.5 | trunc ;",
      ".items as $items\n| reduce .vals[] as $val ({ix: 0, date: .vals[0].date, array: []};\n    ([.ix, $items] | value($val.amount)) as $ix\n    | .ix = $ix\n    | if $ix == null\n      then .\n      else .date as $date\n      | .array += [$val | {month, value: days($items[$ix].date; $date) }]\n      | .date = $date\n      end )"
    ],
    "data": [
      {
        "input": {
          "vals": [
            {
              "month": "Jan 2022",
              "value": 0,
              "amount": -200,
              "date": "01-02-2022"
            },
            {
              "month": "Feb 2022",
              "value": 0,
              "amount": -200,
              "date": "28-02-2022"
            }
          ],
          "items": [
            {
              "date": "01-02-2022",
              "amount": -200
            },
            {
              "date": "04-02-2022",
              "amount": 100
            },
            {
              "date": "28-02-2022",
              "amount": -200
            },
            {
              "date": "10-03-2022",
              "amount": 250
            },
            {
              "date": "12-03-2022",
              "amount": 50
            }
          ]
        },
        "output": {
          "vals": [
            {
              "month": "Jan 2022",
              "value": 37
            },
            {
              "month": "Feb 2022",
              "value": 12
            }
          ]
        }
      }
    ],
    "identifier": 73637407
  },
  {
    "context": [
      "I'm new to jq and struggling to obtain a json value and use it in a bash IF statement.",
      "jq outputs \"elephant\", note the \"\"",
      "Add -r to the jq command so the quotes are removed (raw-mode)",
      "VAR=\"$(jq -r '.animal' animal.json)\";"
    ],
    "utterance": "Extract the value of the animal key without quotes for use in a shell variable.",
    "expressions": [
      "jq -r '.animal'"
    ],
    "data": [
      {
        "input": {
          "animal": "elephant",
          "colour": "red"
        },
        "output": "elephant"
      }
    ],
    "identifier": 73651039
  },
  {
    "context": [
      "I need to find the value of the `id` key of every object where the value of `state` starts with \"failed-\"",
      ".[] | .state | select(startswith(\"failed-\"))",
      "How do I find the corresponding values of `id` ?",
      ".[] | select(.state | startswith(\"failed-\")).id",
      ".[] | select(.state | test(\"^failed\")).id"
    ],
    "utterance": "Find the id of every object where the state value starts with 'failed-'.",
    "expressions": [
      ".[] | select(.state | startswith(\"failed-\")).id",
      ".[] | select(.state | test(\"^failed\")).id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "RA_kwDOGETrS84EmTf2",
            "state": "uploaded"
          },
          {
            "id": "RA_kwDOGETrS84EmTf6",
            "state": "failed-4325423"
          },
          {
            "id": "RA_kwDOGETrS84EmTf7",
            "state": "uploaded"
          }
        ],
        "output": [
          "RA_kwDOGETrS84EmTf6"
        ]
      }
    ],
    "identifier": 73650287
  },
  {
    "context": [
      "I am missing some ah-ha moment. What I am trying to do is get the some of the main array details and for each member, some of the inner details.",
      "I want to end up with this:\n\n```\n{\n  [ {\n    \"uid\" : \"fc5d20ad-03d5-4684-8836-feae73d1fe\",\n    \"name\" : \"group1\",\n    \"type\" : \"group\",\n    \"members\" : [ {\n      \"uid\" : \"7846f4d6-72e0-4cd8-8795-1f5bc2f124\",\n      \"name\" : \"member1\",\n      \"type\" : \"host\",\n      \"ipv4-address\" : \"17.19.49.10\",\n    }, {\n      \"uid\" : \"a5b12fed-e32e-4151-8310-4848f16bef\",\n      \"name\" : \"member2\",\n      \"type\" : \"host\",\n      \"ipv4-address\" : \"12.19.50.10\",\n    } ],\n   \n  }, {\n    \"uid\" : \"e8d4f757-98e8-4aae-bc31-772066d\",\n    \"name\" : \"group2\",\n    \"type\" : \"group\",\n    \"members\" : [ {\n      \"uid\" : \"84e89b9c-dbe7-441e-9859-2d0eef\",\n      \"name\" : \"member1\",\n      \"type\" : \"host\",\n      \"ipv4-address\" : \"82.19.76.10\",\n      },\n    }, {\n      \"uid\" : \"116f3792-8baa-4e56-888bcbd8194\",\n      \"name\" : \"member2\",\n      \"type\" : \"host\",\n      \"ipv4-address\" : \"84.12.48.10\",\n    } ]\n  } ]\n}\n```",
      "This repeats everything for each member, so I need an \"inner loop\" to deal with the members and I can't see it",
      "How do I keep them together, and keep the surrounding array?",
      "You were really close.\n```\n.objects[] |= {uid, name, type, members: .members | map({uid, name, type, \"ipv4-address\"})}\n```"
    ],
    "utterance": "Produce an array of objects with only uid, name, type, and for each member, only uid, name, type, and ipv4-address fields.",
    "expressions": [
      ".objects[] |= {uid, name, type, members: .members | map({uid, name, type, \"ipv4-address\"})}"
    ],
    "data": [
      {
        "input": {
          "objects": [
            {
              "uid": "fc5d20ad-03d5-4684-8836-feae73d1fe",
              "name": "group1",
              "type": "group",
              "members": [
                {
                  "uid": "7846f4d6-72e0-4cd8-8795-1f5bc2f124",
                  "name": "member1",
                  "type": "host",
                  "ipv4-address": "17.19.49.10"
                },
                {
                  "uid": "a5b12fed-e32e-4151-8310-4848f16bef",
                  "name": "member2",
                  "type": "host",
                  "ipv4-address": "12.19.50.10"
                }
              ]
            },
            {
              "uid": "e8d4f757-98e8-4aae-bc31-772066d",
              "name": "group2",
              "type": "group",
              "members": [
                {
                  "uid": "84e89b9c-dbe7-441e-9859-2d0eef",
                  "name": "member1",
                  "type": "host",
                  "ipv4-address": "82.19.76.10"
                },
                {
                  "uid": "116f3792-8baa-4e56-888bcbd8194",
                  "name": "member2",
                  "type": "host",
                  "ipv4-address": "84.12.48.10"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "uid": "fc5d20ad-03d5-4684-8836-feae73d1fe",
            "name": "group1",
            "type": "group",
            "members": [
              {
                "uid": "7846f4d6-72e0-4cd8-8795-1f5bc2f124",
                "name": "member1",
                "type": "host",
                "ipv4-address": "17.19.49.10"
              },
              {
                "uid": "a5b12fed-e32e-4151-8310-4848f16bef",
                "name": "member2",
                "type": "host",
                "ipv4-address": "12.19.50.10"
              }
            ]
          },
          {
            "uid": "e8d4f757-98e8-4aae-bc31-772066d",
            "name": "group2",
            "type": "group",
            "members": [
              {
                "uid": "84e89b9c-dbe7-441e-9859-2d0eef",
                "name": "member1",
                "type": "host",
                "ipv4-address": "82.19.76.10"
              },
              {
                "uid": "116f3792-8baa-4e56-888bcbd8194",
                "name": "member2",
                "type": "host",
                "ipv4-address": "84.12.48.10"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 73599316
  },
  {
    "context": [
      "I was using the jq to filter to output the service names with `run` value as `True`",
      "I was looking to get the output as single string separated by commas.",
      "Expected Output: \n\n`\"svc-A,svc-C\"`",
      "Keep the array using `map` instead of decomposing it with `.[]`, then join with a glue string:",
      "jq -r 'map(select(.run==\"True\") | .name) | join(\",\")' svcs.json",
      "jq -r 'map(select(.run==\"True\") | .name) | @csv' svcs.json",
      "The `.[]` expression explodes the array into a stream of its elements. You'll need to collect the transformed stream (the names) back into an array. Then you can use the `@csv` filter for the final output",
      "$ jq -r '[ .[] | select(.run==\"True\") | .name ] | @csv' svcs.json"
    ],
    "utterance": "Output the names of all objects with run equal to \"True\" as a single comma-separated string.",
    "expressions": [
      "map(select(.run==\"True\") | .name) | join(\",\")",
      "map(select(.run==\"True\") | .name) | @csv",
      "[ .[] | select(.run==\"True\") | .name ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "svc-A",
            "run": "True"
          },
          {
            "name": "svc-B",
            "run": "False"
          },
          {
            "name": "svc-C",
            "run": "True"
          }
        ],
        "output": "svc-A,svc-C"
      }
    ],
    "identifier": 73666430
  },
  {
    "context": [
      "And to output all domains formatted as hosts:",
      "jq -r '.domains[] | \"0.0.0.0 \\(.)\"' variables.json"
    ],
    "utterance": "Format each domain as '0.0.0.0 [domain]' for all domains in the file 'variables.json'.",
    "expressions": [
      ".domains[] | \"0.0.0.0 \\(.)\""
    ],
    "identifier": 73671232
  },
  {
    "context": [
      "I have a JSON array that looks like:\n\n[a,b,c]\n\nAnd I have a bash variable which is list of array indices that I would like to subset to\n\nix=\"0,2\"\n\nI would like to use `jq` to subset to those indices, yielding the following array:\n\n[\"a\", \"c\"]",
      "jq --arg ix \"$ix\" '($ix | split(\",\") | map(tonumber)) as [$a, $b] | .[$a:$b+1]'",
      "jq --argjson ixs \"[$ix]\" '[.[$ixs[]]]'",
      "$ cat test.json\n>> [\"a\", \"b\", \"c\", \"d\", \"e\" ]\n\n$ ix=\"0,2\"\n\n$ jq --arg ix \"$ix\" '($ix | split(\",\") | map(tonumber)) as [$a, $b] | .[$a:$b+1]' test.json\n\n>> [\n>>   \"a\",\n>>   \"b\",\n>>   \"c\"\n>> ]",
      "jq --arg ix \"$ix\" '($ix | split(\",\") | map(tonumber)) as [$a, $b] | .[$a,$b+1]' test.json\n\n>> \"a\"\n\n>> \"d\"",
      "Note how the output differs between `[$a:$b+1]` and `[$a,$b+1]`. \n\n`[$a:$b+1]` is array slicing which generates a sub-array \nwhereas \n`[$a,$b+1]` selects two individual elements of the original array.",
      "jq --argjson ixs \"[$ix]\" '[.[$ixs[]]]'"
    ],
    "utterance": "Select elements at indices 0 and 2 from an array using a string variable containing comma-separated indices.",
    "expressions": [
      "jq --arg ix \"$ix\" '($ix | split(\",\") | map(tonumber)) as $ixs | [.[$ixs[]]]'",
      "jq --argjson ixs \"[$ix]\" '[.[$ixs[]]]'"
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c"
        ],
        "output": [
          "a",
          "c"
        ]
      },
      {
        "input": [
          "a",
          "b",
          "c",
          "d",
          "e"
        ],
        "output": [
          "a",
          "c"
        ]
      }
    ],
    "identifier": 73666600
  },
  {
    "context": [
      "aws ecs list-tasks --cluster $1 --profile $2 | jq '.taskArns[$i]'",
      "You never set the jq var `$i` before using it. You could do so as follows:",
      "jq --arg i \"$i\" '.taskArns[ $i | tonumber ]'",
      "aws ecs list-tasks --cluster $1 --profile $2 | jq '.taskArns[0:2][]'"
    ],
    "utterance": "Select taskArns elements at positions 0 and 1 from the command output.",
    "expressions": [
      ".taskArns[ $i | tonumber ]",
      ".taskArns[0:2][]"
    ],
    "identifier": 73676257
  },
  {
    "context": [
      "So I&#39;m trying to get the top-level keys and then multiply each one by the amount under each key then post the key as many times as the amount states.",
      "How do I get jq to take json like this:",
      "and generate this output:",
      "You can use `to_entries` to access key and value, and `range` to iterate:",
      "jq -r 'to_entries[] | range(.value.amount) as $_ | .key'"
    ],
    "utterance": "Print each top-level key as many times as the value of its nested 'amount' property.",
    "expressions": [
      "to_entries[] | range(.value.amount) as $_ | .key"
    ],
    "data": [
      {
        "input": {
          "2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK": {
            "mints": [
              "Ehmx5dGtUtYSTRYDNptYSPLXs4ZSFmCPHvPd5ProtGPp",
              "DZHynoX1yrwdppnNNZmBHqap89vziSehmhJP3BQESoaN",
              "CVdM8fu474xaVxxuUzLsn7rxTA1mcrkpq8K7YYN4gRoc"
            ],
            "amount": 3
          },
          "CVjVEB2WBmDACcovpxKAEqXZZKdUGsGAn2v5EsWSjtXX": {
            "mints": [
              "CPBsjXBKrG2QfRAkaPDJ282bXr7uD9259Ymb6EC93jjb"
            ],
            "amount": 1
          },
          "Cndq2Yjt1MVkQPYiZod9eGZcTHFDhuYjJA7N6vAuVw8H": {
            "mints": [
              "66T698sRaJiyEXu6RrBw8ApNYsx1spkQQZZM9nZdA9EE",
              "65QEUZVWMg12UvrRNcoV5DwVANKWaarHPd52KemV4pRy"
            ],
            "amount": 2
          }
        },
        "output": [
          "2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK",
          "2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK",
          "2tMRnry9cMqcMo5JqPWvyFaznoU8ujcf3i9ALpzokFHK",
          "CVjVEB2WBmDACcovpxKAEqXZZKdUGsGAn2v5EsWSjtXX",
          "Cndq2Yjt1MVkQPYiZod9eGZcTHFDhuYjJA7N6vAuVw8H",
          "Cndq2Yjt1MVkQPYiZod9eGZcTHFDhuYjJA7N6vAuVw8H"
        ]
      }
    ],
    "identifier": 73670883
  },
  {
    "context": [
      "from records having a `changes` key, create new records with the `type` of their parent record",
      "records without a type should have this type [UNKN]",
      "every record must have this key/value [wanted_key: true]",
      "Here\u2019s one way:\n~~~sh\nmap(\n  select(values)\n  | (.type // \"UNKN\") as $type\n  | ., .changes[]?\n  | {id, $type, wanted_key: true}\n)\n~~~",
      "The following should work:\n\n```\nmap(select(values))\n| map(., .type as $type | (.changes[]? + {$type}))\n| map({id, type: (.type // \"UNKN\"), wanted_key: true})\n```",
      "or even with a separate normalization step for the unknown type:\n\n```\nmap(select(values))\n| map(.type //= \"UNKN\")\n| map(., .changes[]? + {type})\n| map({id, type, wanted_key: true})\n# condensed to a single line:\nmap(select(values) | .type //= \"UNKN\" | ., .changes[]? + {type} | {id, type, wanted_key: true})\n```"
    ],
    "utterance": "Produce a flat list where each object includes id, type (defaulting to \"UNKN\" if missing), and wanted_key: true; for objects with a changes array, add each element as a new object with the same type and wanted_key: true.",
    "expressions": [
      "map(\n  select(values)\n  | (.type // \"UNKN\") as $type\n  | ., .changes[]?\n  | {id, type: $type, wanted_key: true}\n)",
      "map(select(values) | .type //= \"UNKN\" | ., .changes[]? + {type} | {id, type, wanted_key: true})",
      "map(select(values))\n| map(., .type as $type | (.changes[]? + {$type}))\n| map({id, type: (.type // \"UNKN\"), wanted_key: true})"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "type": "A",
            "changes": [
              {
                "id": 12
              },
              {
                "id": 13
              }
            ],
            "wanted_key": "good",
            "unwanted_key": "aaa"
          },
          {
            "id": 2,
            "type": "A",
            "unwanted_key": "aaa"
          },
          {
            "id": 3,
            "type": "B",
            "changes": [
              {
                "id": 31
              },
              {
                "id": 32
              }
            ],
            "unwanted_key": "aaa",
            "unwanted_key2": "aaa"
          },
          {
            "id": 4,
            "type": "B",
            "unwanted_key3": "aaa"
          },
          null,
          null,
          {
            "id": 7
          }
        ],
        "output": [
          {
            "id": 1,
            "type": "A",
            "wanted_key": true
          },
          {
            "id": 12,
            "type": "A",
            "wanted_key": true
          },
          {
            "id": 13,
            "type": "A",
            "wanted_key": true
          },
          {
            "id": 2,
            "type": "A",
            "wanted_key": true
          },
          {
            "id": 3,
            "type": "B",
            "wanted_key": true
          },
          {
            "id": 31,
            "type": "B",
            "wanted_key": true
          },
          {
            "id": 32,
            "type": "B",
            "wanted_key": true
          },
          {
            "id": 4,
            "type": "B",
            "wanted_key": true
          },
          {
            "id": 7,
            "type": "UNKN",
            "wanted_key": true
          }
        ]
      }
    ],
    "identifier": 73640375
  },
  {
    "context": [
      "I'm trying to accomplish two things:\r\n\r\n - Flatten the array in this json\r\n - Reformat the json to a simple payload",
      "I\u2019m hoping to remove the \"title\" of the arrays, just keep the content, and align the contents of the array with the reset of the json:",
      "If you know that `contact` and `nextarray` are the sub-objects to merge, then:\r\n```sh\r\njq '. + .contact + .nextarray | del(.contact) | del(.nextarray)' file.json\r\n```",
      "Generically:\r\n```sh\r\njq '\r\n    to_entries \r\n    | map(if (.value|type) == \"object\" then .value else {(.key): .value} end) \r\n    | add\r\n'\r\n```"
    ],
    "utterance": "Flatten all nested objects at the top level, merging their keys into the parent and removing the nested objects.",
    "expressions": [
      ". + .contact + .nextarray | del(.contact) | del(.nextarray)",
      "to_entries | map(if (.value|type) == \"object\" then .value else {(.key): .value} end) | add"
    ],
    "data": [
      {
        "input": {
          "id": 1,
          "feed": "jqQuestion",
          "organization": "question.com",
          "category": "question",
          "contact": {
            "name": "",
            "email": "",
            "phone": ""
          },
          "website": "https://thankyou.com/",
          "schedule": "daily",
          "stamp_added": "2017-09-27 00:00:00",
          "stamp_updated": "2022-09-10 15:51:09",
          "stamp_pulled": "2022-09-10 08:51:03",
          "stamp_modified": "2019-08-07 18:29:00",
          "nextarray": {
            "value": 1,
            "value2": 2
          }
        },
        "output": {
          "id": 1,
          "feed": "jqQuestion",
          "organization": "question.com",
          "category": "question",
          "name": "",
          "email": "",
          "phone": "",
          "website": "https://thankyou.com/",
          "schedule": "daily",
          "stamp_added": "2017-09-27 00:00:00",
          "stamp_updated": "2022-09-10 15:51:09",
          "stamp_pulled": "2022-09-10 08:51:03",
          "stamp_modified": "2019-08-07 18:29:00",
          "value": 1,
          "value2": 2
        }
      }
    ],
    "identifier": 73675742
  },
  {
    "context": [
      "When i let this code run with the `fromjson` option I get an error:",
      "Should actually not use the `fromjson` filter:",
      "jq --null-input --arg yaml \"$(&lt;example-gitlab-ci.yml)\" '.content=$yaml' \\",
      "| curl \"https://gitlab.com/api/v4/ci/lint?include_merged_yaml=true\" \\",
      "--header 'Content-Type: application/json' --data @- \\",
      "| jq --raw-output '.merged_yaml'",
      "Everything in the first part of this answer still holds: jq cannot process YAML, you need yq for that. (But the GitLab docs never process the YAML document, they only print it)"
    ],
    "utterance": "Extract the merged_yaml field from the API response as a plain string output without additional processing.",
    "expressions": [
      ".merged_yaml",
      "jq --raw-output '.merged_yaml'"
    ],
    "data": [
      {
        "input": {
          "merged_yaml": "---\n\\\".api_test\\\":\n  rules:\n  - if: $CI_PIPELINE_SOURCE==\\\"merge_request_event\\\"\n    changes:\n    - src/api/*\ndeploy:\n  rules:\n  - when: manual\n    allow_failure: true\n  extends:\n  - \\\".api_test\\\"\n  script:\n  - echo \\\"hello world\\\"",
          "includes": [],
          "jobs": [
            {
              "name": "deploy",
              "stage": "test",
              "before_script": [],
              "script": [
                "echo \\\"hello world\\\""
              ],
              "after_script": [],
              "tag_list": [],
              "only": null,
              "except": null,
              "environment": null,
              "when": "on_success",
              "allow_failure": false,
              "needs": null
            }
          ],
          "status": "valid"
        },
        "output": "---\n\\\".api_test\\\":\n  rules:\n  - if: $CI_PIPELINE_SOURCE==\\\"merge_request_event\\\"\n    changes:\n    - src/api/*\ndeploy:\n  rules:\n  - when: manual\n    allow_failure: true\n  extends:\n  - \\\".api_test\\\"\n  script:\n  - echo \\\"hello world\\\""
      }
    ],
    "identifier": 73691651
  },
  {
    "context": [
      "I want it output in the following way: `key_value=foo key_value_2=bar`.",
      "How do I process the value for `Name` without losing reference to `Value`?",
      "map((.Name | split(\"/\") | last) + \"=\" + .Value) | join(\" \")",
      "map(\"\\(.Name | split(\"/\") | last)=\\(.Value)\") | join(\" \")"
    ],
    "utterance": "Produce a single space-separated string where each entry is the last segment of Name, followed by an equal sign, then the corresponding Value, e.g., key_value=foo key_value_2=bar.",
    "expressions": [
      "map((.Name | split(\"/\") | last) + \"=\" + .Value) | join(\" \")",
      "map(\"\\(.Name | split(\"/\") | last)=\\(.Value)\") | join(\" \")"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "/path/to/key_value",
            "Value": "foo"
          },
          {
            "Name": "/path/to/key_value_2",
            "Value": "bar"
          }
        ],
        "output": "key_value=foo key_value_2=bar"
      }
    ],
    "identifier": 73701211
  },
  {
    "context": [
      "And I want to append `{\"List\": []}` to the top of the list and save the JSON data to a file.",
      "The result that I want is like this:",
      "{\n  \"List\": [\n    {\n      \"slotNo\": \"2\",\n      \"tracking\": \"797aacdf9e40443aba4c818fead0195e\",\n      \"TEST\": \"ASD.mpg\",\n      \"ZXC\": \"555\",\n      \"TID\": \"T15789\",\n      \"AD\": \"123456\"\n    },\n    {\n      \"slotNo\": \"3\",\n      \"tracking\": \"897aacdf9e40443aba4c818fead0195e\",\n      \"TEST\": \"zxc.mpg\",\n      \"ZXC\": \"666\",\n      \"TID\": \"T777\",\n      \"AD\": \"789456\"\n    }\n  ]\n}",
      "You can use **`slurp`** option such as\n```\njq -s '{ List:. }'\n```",
      "Using [`inputs`](https://stedolan.github.io/jq/manual/v1.6/#IO) to consume the rest of the input data\n\n```\njq '{List: [., inputs]}'\n```"
    ],
    "utterance": "Wrap all top-level objects in a List property as an array, producing an object with 'List' as the only key.",
    "expressions": [
      "jq -s '{ List:. }'",
      "jq '{List: [., inputs]}'"
    ],
    "data": [
      {
        "input": [
          {
            "slotNo": "2",
            "tracking": "797aacdf9e40443aba4c818fead0195e",
            "TEST": "ASD.mpg",
            "ZXC": "555",
            "TID": "T15789",
            "AD": "123456"
          },
          {
            "slotNo": "3",
            "tracking": "897aacdf9e40443aba4c818fead0195e",
            "TEST": "zxc.mpg",
            "ZXC": "666",
            "TID": "T777",
            "AD": "789456"
          }
        ],
        "output": {
          "List": [
            {
              "slotNo": "2",
              "tracking": "797aacdf9e40443aba4c818fead0195e",
              "TEST": "ASD.mpg",
              "ZXC": "555",
              "TID": "T15789",
              "AD": "123456"
            },
            {
              "slotNo": "3",
              "tracking": "897aacdf9e40443aba4c818fead0195e",
              "TEST": "zxc.mpg",
              "ZXC": "666",
              "TID": "T777",
              "AD": "789456"
            }
          ]
        }
      }
    ],
    "identifier": 73699232
  },
  {
    "context": [
      "I have a json like this but much longer:",
      "I'd like to query with jq and obtain the following:\n\n    [\n      {\n        \"name\": \"home network configuration\"\n        \"definedRanges\": [\n          {\n            \"name\": \"100-200\",\n            \"beginIPv4Address\": \"192.168.090.100\",\n            \"endIPv4Address\": \"192.168.090.200\",\n          }\n        ]\n      },\n      {\n        \"name\": \"lab network configuration\",\n        \"definedRanges\": [\n          {\n            \"name\": \"100-200\",\n            \"beginIPv4Address\": \"192.168.090.100\",\n            \"endIPv4Address\": \"192.168.090.200\",\n          },\n          {\n            \"name\": \"100-200\",\n            \"beginIPv4Address\": \"192.168.090.100\",\n            \"endIPv4Address\": \"192.168.090.200\",\n          }\n        ]\n      }\n    ]",
      "or even this:\n\n    [\n      {\n        \"name\": \"home network configuration\",\n        \"definedRanges.name\": \"100-200\",\n        \"definedRanges.beginIPv4Address\": \"192.168.090.100\",\n        \"definedRanges.endIPv4Address\": \"192.168.090.200\",\n      },\n      {\n        \"name\": \"lab network configuration\",\n        \"definedRanges.name\": \"100-200\",\n        \"definedRanges.beginIPv4Address\": \"192.168.090.100\",\n        \"definedRanges.endIPv4Address\": \"192.168.090.200\",\n      },\n      {\n        \"name\": \"lab network configuration\",\n        \"definedRanges.name\": \"100-200\",\n        \"definedRanges.beginIPv4Address\": \"192.168.090.100\",\n        \"definedRanges.endIPv4Address\": \"192.168.090.200\",\n      }\n    ]",
      "So far I was able to extract the network name at the first level with:\n\n    .[] | {name}\n\nI could also extract the definedRanges with:\n\n    .[].definedRanges[] | {name,beginIPv4Address,endIPv4Address}\n\nBut I can't figure out how to merge the two with jq.",
      "Here's how you put those together:\n```\nmap({name, definedRanges: .definedRanges | map({name, beginIPv4Address, endIPv4Address})})\n```",
      "The '*or even this*' can be achieved using:\n```\nmap(.name as $name | .definedRanges[] | { name, beginIPv4Address, endIPv4Address} | with_entries(.key = \"definedRanges.\" + .key) | .name = $name)\n```",
      "Here's my shot at solutions to produce one or the other desired output:\n\n```\nmap(\n  { name }\n  + (.definedRanges[] | {\n      \"definedRanges.name\": .name,\n      \"definedRanges.beginIPv4Address\": .beginIPv4Address,\n      \"definedRanges.endIPv4Address\": .endIPv4Address\n  }))\n```",
      "Producing the first kind of output is even simpler (IMHO it reads a bit more straightforward):\n\n```\nmap({\n    name,\n    definedRanges: .definedRanges | map({ name, beginIPv4Address, endIPv4Address })\n})\n```"
    ],
    "utterance": "Transform an array of objects to include only the name and an array of their definedRanges, each with name, beginIPv4Address, and endIPv4Address.",
    "expressions": [
      "map({name, definedRanges: .definedRanges | map({name, beginIPv4Address, endIPv4Address})})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "123",
            "name": "home network configuration",
            "description": "home utilities",
            "definedRanges": [
              {
                "id": "6500b67e",
                "name": "100-200",
                "beginIPv4Address": "192.168.090.100",
                "endIPv4Address": "192.168.090.200",
                "state": "UNALLOCATED"
              }
            ]
          },
          {
            "id": "456",
            "name": "lab network configuration",
            "description": "lab experiments",
            "definedRanges": [
              {
                "id": "1209b90d",
                "name": "100-200",
                "beginIPv4Address": "192.168.090.100",
                "endIPv4Address": "192.168.090.200",
                "state": "ALLOCATED"
              },
              {
                "id": "99e08ca4",
                "name": "100-200",
                "beginIPv4Address": "192.168.090.100",
                "endIPv4Address": "192.168.090.200",
                "state": "UNALLOCATED"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "home network configuration",
            "definedRanges": [
              {
                "name": "100-200",
                "beginIPv4Address": "192.168.090.100",
                "endIPv4Address": "192.168.090.200"
              }
            ]
          },
          {
            "name": "lab network configuration",
            "definedRanges": [
              {
                "name": "100-200",
                "beginIPv4Address": "192.168.090.100",
                "endIPv4Address": "192.168.090.200"
              },
              {
                "name": "100-200",
                "beginIPv4Address": "192.168.090.100",
                "endIPv4Address": "192.168.090.200"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 73648264
  },
  {
    "context": [
      "I would like to link all the objects in an Array that have in the \"main_id\" key value a specific value other than \"none\" (with key \"details\"), to the object (which I call the parent object) containing that same value in the \"id\" key of the parent object.",
      "A simple `reduce` with an `if` expression builig up an indexed object may suffice. The final `map` converts the object back to an array.",
      "reduce .[] as $i ({};\n  if $i.main_id == \"none\" then .[$i.id] += $i\n  else .[$i.main_id].details += [$i] end\n) | map(.)"
    ],
    "utterance": "Group array elements whose main_id matches another element's id under that element, using the property details, for elements whose main_id is not none.",
    "expressions": [
      "reduce .[] as $i ({};\n  if $i.main_id == \"none\" then .[$i.id] += $i\n  else .[$i.main_id].details += [$i] end\n) | map(.)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "AAKG",
            "data": "some data...",
            "main_id": "none"
          },
          {
            "id": "PMBL",
            "data": "some data...",
            "main_id": "none"
          },
          {
            "id": "ZDFG",
            "data": "some data...",
            "main_id": "PMBL"
          },
          {
            "id": "XHGF",
            "data": "some data...",
            "main_id": "PMBL"
          },
          {
            "id": "LOKJ",
            "data": "some data...",
            "main_id": "none"
          },
          {
            "id": "JQWC",
            "data": "some data...",
            "main_id": "none"
          },
          {
            "id": "QQSZ",
            "data": "some data...",
            "main_id": "none"
          },
          {
            "id": "JQWC",
            "data": "some data...",
            "main_id": "QQSZ"
          },
          {
            "id": "LLRE",
            "data": "some data...",
            "main_id": "none"
          }
        ],
        "output": [
          {
            "id": "AAKG",
            "data": "some data...",
            "main_id": "none"
          },
          {
            "id": "PMBL",
            "data": "some data...",
            "main_id": "none",
            "details": [
              {
                "id": "ZDFG",
                "data": "some data...",
                "main_id": "PMBL"
              },
              {
                "id": "XHGF",
                "data": "some data...",
                "main_id": "PMBL"
              }
            ]
          },
          {
            "id": "LOKJ",
            "data": "some data...",
            "main_id": "none"
          },
          {
            "id": "JQWC",
            "data": "some data...",
            "main_id": "none"
          },
          {
            "id": "QQSZ",
            "data": "some data...",
            "main_id": "none",
            "details": [
              {
                "id": "JQWC",
                "data": "some data...",
                "main_id": "QQSZ"
              }
            ]
          },
          {
            "id": "LLRE",
            "data": "some data...",
            "main_id": "none"
          }
        ]
      }
    ],
    "identifier": 73680764
  },
  {
    "context": [
      "What I want to do is 'walk' on my json, and for each key named 'base', add a key which is the full 'path' of this key.",
      "And I want a result like this :\n\n    {\n      \"entity\": {\n        \"product\": {\n          \"att\": {\n            \"number_of_values\": \"Number of values\"\n          },\n          \"title\": {\n            \"base\": [\"product\", \"products\", \"pdt\", \"pdts\"],\n            \"path\": \"entity.product.title\"\n          }\n        },\n        \"rabbit\": {\n          \"att\": {\n            \"number_of_values\": \"Number of values\"\n          },\n          \"title\": {\n            \"base\": [\"rabbit\", \"rabbits\"]\n            \"path\": \"entity.rabbit.title\"\n          }\n        }\n      }\n    }",
      "You can get an array representation of the path using `path`, join it using `join` (assuming [simple, identifier-like](https://stedolan.github.io/jq/manual/#ObjectIdentifier-Index:.foo,.foo.bar) field names), and set it using `setpath`:\n~~~sh\njq '\n  reduce path((.. | objects | select(.base))) as $p (.;\n    setpath($p + [\"path\"]; $p | join(\".\"))\n  )\n'\n~~~",
      "Here is one way:\n``` none\nreduce paths(objects | has(\"base\")) as $p (.;\n  setpath($p + [\"path\"]; $p | join(\".\"))\n)\n```",
      "def add_path(p; val):\n    if p|length == 0\n    then .path = val\n    else .[p[0]] |= add_path(p[1:]; val)\n    end;\n\nreduce ([paths(..) | select(last == \"base\")] | unique | map(.[:-1]))[] as $path (.;\n    add_path($path; ($path | join(\".\")))\n)"
    ],
    "utterance": "For each object containing a key named 'base', add a new key 'path' whose value is the dot-separated path to that object.",
    "expressions": [
      "reduce path((.. | objects | select(.base))) as $p (.; setpath($p + [\"path\"]; $p | join(\".\")))",
      "reduce paths(objects | has(\"base\")) as $p (.; setpath($p + [\"path\"]; $p | join(\".\")))",
      "def add_path(p; val): if p|length == 0 then .path = val else .[p[0]] |= add_path(p[1:]; val) end; reduce ([paths(..) | select(last == \"base\")] | unique | map(.[:-1]))[] as $path (.; add_path($path; ($path | join(\".\"))))"
    ],
    "data": [
      {
        "input": {
          "entity": {
            "product": {
              "att": {
                "number_of_values": "Number of values"
              },
              "title": {
                "base": [
                  "product",
                  "products",
                  "pdt",
                  "pdts"
                ]
              }
            },
            "rabbit": {
              "att": {
                "number_of_values": "Number of values"
              },
              "title": {
                "base": [
                  "rabbit",
                  "rabbits"
                ]
              }
            }
          }
        },
        "output": {
          "entity": {
            "product": {
              "att": {
                "number_of_values": "Number of values"
              },
              "title": {
                "base": [
                  "product",
                  "products",
                  "pdt",
                  "pdts"
                ],
                "path": "entity.product.title"
              }
            },
            "rabbit": {
              "att": {
                "number_of_values": "Number of values"
              },
              "title": {
                "base": [
                  "rabbit",
                  "rabbits"
                ],
                "path": "entity.rabbit.title"
              }
            }
          }
        }
      }
    ],
    "identifier": 73716917
  },
  {
    "context": [
      "I want the value of \"title\" that should be \"pipeline-pr-test\" and value of \"pr\" that should be \"2\" from below code by using shell and jq?",
      "Below query help me to get an output:",
      "jq -r 'INDEX(.name)[\"title\", \"pr\"] | \"\\(.name) = \\(.value)\"' test.json"
    ],
    "utterance": "Extract the pairs where name is 'title' or 'pr' and show their corresponding values.",
    "expressions": [
      "jq -r 'INDEX(.name)[\"title\", \"pr\"] | \"\\(.name) = \\(.value)\"' test.json"
    ],
    "data": [
      {
        "input": [
          {
            "name": "pr",
            "value": "2"
          },
          {
            "name": "title",
            "value": "pipeline-pr-test"
          },
          {
            "name": "headhhf",
            "value": "60dd35gt6"
          },
          {
            "name": "base",
            "value": "air"
          },
          {
            "name": "basha",
            "value": "7yhfr7e85a0cc"
          }
        ]
      }
    ],
    "identifier": 73741991
  },
  {
    "context": [
      "I want to get the `product.productID, product.productName, product.details.info and product.details.desc`.",
      "input='{\"pid\"':$productID', \"pname\"':$productName', \"pd\": { \"info\"':$info', \"desc\":':$desc'}}'",
      "This will give you the product info, one per line:",
      "jq -c '.product[] | {pid: .productID, pname: .productName, pd: .details}' product.json",
      "{\"pid\":\"PR12343\",\"pname\":\"iphone13\",\"pd\":{\"info\":\"test info\",\"desc\":\"test desciption\"}}"
    ],
    "utterance": "Extract each product's productID, productName, details.info, and details.desc, and output objects with keys pid, pname, and pd (where pd is an object containing info and desc).",
    "expressions": [
      ".product[] | {pid: .productID, pname: .productName, pd: .details}",
      ".product[] | {pid: .productID, pname: .productName, pd: {info: .details.info, desc: .details.desc}}"
    ],
    "data": [
      {
        "input": {
          "product": [
            {
              "productID": "PR12343",
              "productName": "iphone13",
              "price": 1000,
              "details": {
                "info": "test info",
                "desc": "test desciption"
              }
            },
            {
              "productID": "PR8493",
              "productName": "iphone14",
              "price": 1200,
              "details": {
                "info": "test info",
                "desc": "test desciption"
              }
            }
          ],
          "inventory": [
            {
              "id": "INV8393",
              "configuration": "local",
              "name": "Macbook"
            },
            {
              "id": "INV8322",
              "configuration": "local",
              "name": "iPad"
            }
          ]
        },
        "output": [
          {
            "pid": "PR12343",
            "pname": "iphone13",
            "pd": {
              "info": "test info",
              "desc": "test desciption"
            }
          },
          {
            "pid": "PR8493",
            "pname": "iphone14",
            "pd": {
              "info": "test info",
              "desc": "test desciption"
            }
          }
        ]
      }
    ],
    "identifier": 73736577
  },
  {
    "context": [
      "I want my input as:\r\n\r\n    \"data\": {\r\n        \"AWS_ACCESS_KEY_ID\": \"topsecret\",\r\n        \"AWS_SECRET_ACCESS_KEY\": \"s3cr3t\"\r\n      }",
      "jq query like this `jq .data file.json` is only giving me output like this:\r\n\r\n    {\r\n      \"AWS_ACCESS_KEY_ID\": \"topsecret\",\r\n      \"AWS_SECRET_ACCESS_KEY\": \"s3cr3t\"\r\n     }",
      "You can preserve the key if you enclose it in curly braces, e.g.:\r\n```\r\njq '{ data }'\r\n```",
      "Note that the above is a shorthand for `{ \"data\": .data }`"
    ],
    "utterance": "Return the entire 'data' object from the input, but preserve its key in the output.",
    "expressions": [
      "{ data }",
      "{ \"data\": .data }"
    ],
    "data": [
      {
        "input": {
          "data": {
            "AWS_ACCESS_KEY_ID": "topsecret",
            "AWS_SECRET_ACCESS_KEY": "s3cr3t"
          },
          "metadata": {
            "created_time": "2022-09-16T06:49:11.45818Z",
            "deletion_time": "",
            "destroyed": false,
            "version": 23
          }
        },
        "output": {
          "data": {
            "AWS_ACCESS_KEY_ID": "topsecret",
            "AWS_SECRET_ACCESS_KEY": "s3cr3t"
          }
        }
      }
    ],
    "identifier": 73742195
  },
  {
    "context": [
      "\"cmd [sqldb]\": [\n    \"command\"\n]",
      "but with `[sqldb]`, how can I translate it to jq query format?",
      ".jps.onInstall[].\"cmd [sqldb]\" = [\"long line\", \"another line\"]",
      ".jps.onInstall[][\"cmd [sqldb]\"] = [\"long line\", \"another line\"]"
    ],
    "utterance": "Replace the value of the key cmd [sqldb] in all objects of onInstall with [\"long line\", \"another line\"].",
    "expressions": [
      ".jps.onInstall[].\"cmd [sqldb]\" = [\"long line\", \"another line\"]",
      ".jps.onInstall[][\"cmd [sqldb]\"] = [\"long line\", \"another line\"]"
    ],
    "data": [
      {
        "input": {
          "jps": {
            "onInstall": [
              {
                "cmd [sqldb]": [
                  "command"
                ]
              }
            ]
          }
        },
        "output": {
          "jps": {
            "onInstall": [
              {
                "cmd [sqldb]": [
                  "long line",
                  "another line"
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 73744529
  },
  {
    "context": [
      "Given this data I am trying to return the `servers` array with any matches from `groups` array based on `s_Group` value.",
      "I want all the attributes from `groups` pulled into the new `servers` elements where a match occurs.",
      "INDEX(.groups[] | select(.s_Group); .s_Group) as $dict\n| .servers |= map( . + $dict[.s_Group // \"\"]) \n| {servers : [.servers] }",
      "Use `JOIN` with an `INDEX` on the `.servers` items:\njq '{servers: [JOIN(\n  INDEX(.groups[]; .s_Group); .servers[]; .s_Group // empty; add\n)]}'"
    ],
    "utterance": "For each element in servers, merge in all attributes from any group where s_Group matches, keeping all original servers regardless of match.",
    "expressions": [
      "INDEX(.groups[] | select(.s_Group); .s_Group) as $dict | .servers |= map( . + $dict[.s_Group // \"\"]) | {servers : [.servers] }",
      "{servers: [JOIN( INDEX(.groups[]; .s_Group); .servers[]; .s_Group // empty; add )]}"
    ],
    "data": [
      {
        "input": {
          "servers": [
            {
              "location": "srv_apc1",
              "f_Group": "auc-1"
            },
            {
              "location": "srv_apc2",
              "f_Group": "auc-1",
              "c_Group": "c1"
            },
            {
              "location": "srv_apc3",
              "f_Group": "auc-1",
              "c_Group": "c2"
            },
            {
              "location": "srv_apc4",
              "f_Group": "auc-1",
              "c_Group": "c3"
            },
            {
              "location": "srv_wc1",
              "s_Group": "cb-1"
            },
            {
              "location": "srv_wc2",
              "s_Group": "cb-2"
            },
            {
              "location": "srv_wc3",
              "s_Group": "cb-3"
            },
            {
              "location": "srv_wc4",
              "s_Group": "cb-4"
            }
          ],
          "groups": [
            {
              "s_Group": "cb-1",
              "options": [
                "opt1",
                "opt3",
                "opt5",
                "home"
              ]
            },
            {
              "s_Group": "cb-2",
              "options": [
                "opt2",
                "opt4",
                "opt6",
                "home"
              ]
            },
            {
              "s_Group": "cb-3",
              "options": [
                "opt7",
                "opt8",
                "opt9",
                "home",
                "print"
              ]
            },
            {
              "s_Group": "cb-4",
              "options": [
                "ems99",
                "erec98",
                "expr-77",
                "home"
              ]
            },
            {
              "s_Group": "extra-99",
              "options": [
                "conf1",
                "ems34",
                "erec1",
                "home",
                "chec99",
                "franT"
              ]
            }
          ]
        },
        "output": {
          "servers": [
            [
              {
                "location": "srv_apc1",
                "f_Group": "auc-1"
              },
              {
                "location": "srv_apc2",
                "f_Group": "auc-1",
                "c_Group": "c1"
              },
              {
                "location": "srv_apc3",
                "f_Group": "auc-1",
                "c_Group": "c2"
              },
              {
                "location": "srv_apc4",
                "f_Group": "auc-1",
                "c_Group": "c3"
              },
              {
                "location": "srv_wc1",
                "s_Group": "cb-1",
                "options": [
                  "opt1",
                  "opt3",
                  "opt5",
                  "home"
                ]
              },
              {
                "location": "srv_wc2",
                "s_Group": "cb-2",
                "options": [
                  "opt2",
                  "opt4",
                  "opt6",
                  "home"
                ]
              },
              {
                "location": "srv_wc3",
                "s_Group": "cb-3",
                "options": [
                  "opt7",
                  "opt8",
                  "opt9",
                  "home",
                  "print"
                ]
              },
              {
                "location": "srv_wc4",
                "s_Group": "cb-4",
                "options": [
                  "ems99",
                  "erec98",
                  "expr-77",
                  "home"
                ]
              }
            ]
          ]
        }
      }
    ],
    "identifier": 73709666
  },
  {
    "context": [
      "assuming i'm able to provide keyspace and environment to the script, and use those as variables in my jq query, is there a way to search for the keyspace and return the value for one level up? IE, i know i can do something like:",
      "but if i'm searching for `prod_db6' how can i return the value `prod2`?",
      "Use `to_entries` to decompose an object into an array of key-value pairs, then `IN` to search in the value's array, and finally return the key:",
      "jq -r --arg env \"Prod\" --arg ksp \"prod_db6\" '\n  .[$env][] | to_entries[] | select(IN(.value[]; $ksp)).key\n' env.json",
      "prod2"
    ],
    "utterance": "Given an environment and a keyspace value, return the name of the parent database whose keyspace list contains that value.",
    "expressions": [
      ".[$env][] | to_entries[] | select(IN(.value[]; $ksp)).key"
    ],
    "data": [
      {
        "input": {
          "Prod": [
            {
              "prod1": [
                "prod_db1",
                "prod_db2",
                "prod_d31",
                "prod_db4"
              ]
            },
            {
              "prod2": [
                "prod_db5",
                "prod_db6",
                "prod_db7",
                "prod_db8"
              ]
            }
          ]
        },
        "output": "prod2"
      }
    ],
    "identifier": 73747799
  },
  {
    "context": [
      "I'm trying to dedupe and merge multiple JSON objects together, based on an id field on every JSON object.",
      "In the example below, the values of the \"employee.id\" and \"hobbygroup.id\" fields are used to determine whether to dedupe the duplicated value and remove it, or instead concatenate its separate value into another location that preserves the hierarchy.",
      "If the value of \"employee.id\" matches between the objects, then:\n1. Any child fields in the object (employee.name) gets deduped/overwritten.\n2. Any child objects (hobbygroup) get evaluated to see if its corresponding id field (hobbygroup.id) matches. \n\t* If matching, then steps 1 and 2 are reapplied recursively to this object. (ie, merge any fields, and then look at any children objects of hobbygroup)\n\t* If not matching, then these 2 hobbygroup objects get concatenated into an array of hobbygroups under the parent object (employee), as \"hobbygroups\": [{chess...}, {boxing...}]",
      "The solution needs to be generic since there's a recursive requirement; it shouldn't require knowing the names of the fields or how it's nested.",
      "It detects parent-child relationships of one level distance if the child object has the same field name with `.id` added to it, and applies the merger recursively onto the first relationship found (except for the hard-coded top level as it is an array-object, not an object-object relationship).",
      "def merge_by(f):\n  group_by(f) | map(\n    [paths[1:3] | select(\"\\(first).id\" == last)] as [$p]\n    | if $p then first + {($p[0]): (\n        map(getpath($p[:1])) | merge_by(getpath($p[1:]))\n        | if length == 1 then first else . end\n      )} else .[] end // empty\n  );\n  \n.employee |= merge_by(.\"employee.id\")"
    ],
    "utterance": "Merge objects by recursively grouping and deduplicating at each level using fields ending with '.id', so that objects with the same id are merged while different ones are concatenated into arrays, preserving hierarchy.",
    "expressions": [
      "def merge_by(f):\n  group_by(f) | map(\n    [paths[1:3] | select(\"\\(first).id\" == last)] as [$p]\n    | if $p then first + {($p[0]): (\n        map(getpath($p[:1])) | merge_by(getpath($p[1:]))\n        | if length == 1 then first else . end\n      )} else .[] end // empty\n  );\n  \n.employee |= merge_by(.\"employee.id\")"
    ],
    "data": [
      {
        "input": {
          "employee": [
            {
              "employee.id": "11",
              "employee.name": "bob",
              "hobbygroup": {
                "hobbygroup.id": "1",
                "hobbygroup.name": "chess",
                "groupmeeting": {
                  "groupmeeting.id": "a",
                  "groupmeeting.name": "kickoff meeting"
                }
              }
            },
            {
              "employee.id": "11",
              "employee.name": "bob",
              "hobbygroup": {
                "hobbygroup.id": "2",
                "hobbygroup.name": "boxing",
                "groupmeeting": {
                  "groupmeeting.id": "a",
                  "groupmeeting.name": "kickoff meeting"
                }
              }
            },
            {
              "employee.id": "11",
              "employee.name": "bob",
              "hobbygroup": {
                "hobbygroup.id": "2",
                "hobbygroup.name": "boxing",
                "groupmeeting": {
                  "groupmeeting.id": "b",
                  "groupmeeting.name": "second meeting"
                }
              }
            },
            {
              "employee.id": "11",
              "employee.name": "bob",
              "hobbygroup": {
                "hobbygroup.id": "2",
                "hobbygroup.name": "boxing"
              }
            },
            {
              "employee.id": "12",
              "employee.name": "bill",
              "hobbygroup": {
                "hobbygroup.id": "1",
                "hobbygroup.name": "chess",
                "groupmeeting": {
                  "groupmeeting.id": "a",
                  "groupmeeting.name": "kickoff meeting"
                }
              }
            }
          ]
        },
        "output": {
          "employee": [
            {
              "employee.id": "11",
              "employee.name": "bob",
              "hobbygroup": [
                {
                  "hobbygroup.id": "1",
                  "hobbygroup.name": "chess",
                  "groupmeeting": {
                    "groupmeeting.id": "a",
                    "groupmeeting.name": "kickoff meeting"
                  }
                },
                {
                  "hobbygroup.id": "2",
                  "hobbygroup.name": "boxing",
                  "groupmeeting": [
                    {
                      "groupmeeting.id": "a",
                      "groupmeeting.name": "kickoff meeting"
                    },
                    {
                      "groupmeeting.id": "b",
                      "groupmeeting.name": "second meeting"
                    }
                  ]
                }
              ]
            },
            {
              "employee.id": "12",
              "employee.name": "bill",
              "hobbygroup": {
                "hobbygroup.id": "1",
                "hobbygroup.name": "chess",
                "groupmeeting": {
                  "groupmeeting.id": "a",
                  "groupmeeting.name": "kickoff meeting"
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 73725891
  },
  {
    "context": [
      "I'm trying to use `jq` to stream objects from an `object_array` to their own files for later processing.",
      "Specifically, I'd like to capture each object like the one below, from `object_array`, and place it in its own file",
      "In jq, `select` from the stream those parts that belong to the `object_array`, then truncate by `2` (field name and array index).",
      "< enormous.json jq -cn --stream '\n  fromstream(2|truncate_stream(inputs| select(.[0][0] == \"object_array\")))\n' | while read -r json;\n    do fname=\"onif00$((++NR))\"; > \"$fname.json\" cat <<<$json;\n    done",
      "< enormous.json jq -jn --stream '\n  fromstream(2|truncate_stream(inputs| select(.[0][0] == \"object_array\")))\n  | (.name, @json) + \"\\u0000\"\n' | while read -d '' fname; read -d '' json;\n    do > \"$fname.json\" cat <<<$json;\n    done"
    ],
    "utterance": "Extract each top-level object from 'object_array' and output each to a separate file.",
    "expressions": [
      "jq -cn --stream 'fromstream(2|truncate_stream(inputs| select(.[0][0] == \"object_array\")))'"
    ],
    "data": [
      {
        "input": {
          "top_level_name": "Some Name Here",
          "top_level_type": "Some Type",
          "last_updated_on": "2022-07-09",
          "version": "1.0.0",
          "object_array": [
            {
              "arrangement": "abcd",
              "name": "another name",
              "type": "efgh",
              "type_ver": "2021",
              "code": "12345",
              "desc": "some description",
              "rate": [
                {
                  "groups": [
                    {
                      "IDs": [
                        "123654890",
                        "012365485"
                      ],
                      "id_type": {
                        "type": "xyz",
                        "value": "8527419630"
                      }
                    }
                  ],
                  "prices": [
                    {
                      "price_type": "priceType",
                      "rate": "00.00",
                      "date": "2023-01-01",
                      "svc_code": [
                        "89"
                      ],
                      "class": "some-class",
                      "modifier": [
                        "78"
                      ],
                      "additional_information": "null"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "arrangement": "abcd",
          "name": "another name",
          "type": "efgh",
          "type_ver": "2021",
          "code": "12345",
          "desc": "some description",
          "rate": [
            {
              "groups": [
                {
                  "IDs": [
                    "123654890",
                    "012365485"
                  ],
                  "id_type": {
                    "type": "xyz",
                    "value": "8527419630"
                  }
                }
              ],
              "prices": [
                {
                  "price_type": "priceType",
                  "rate": "00.00",
                  "date": "2023-01-01",
                  "svc_code": [
                    "89"
                  ],
                  "class": "some-class",
                  "modifier": [
                    "78"
                  ],
                  "additional_information": "null"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 73738001
  },
  {
    "context": [
      "I want to parse all these key names `product, inventory, rating, review` dynamically and put it in the list and iterate the key name one by one.",
      "After parsing the key name dynamically, I want to form all the key name in a comma separated and assigned to `key_list` variable like below:",
      "key_list=\"product,inventory,rating,review\"",
      "After that I want to iterate `key_list` in a loop and print them or do something with that value. The desired output would be print the key name one by one in a loop:",
      "product",
      "inventory",
      "rating",
      "review",
      "To produce a listing of the key names:\r\n\r\n    jq -r 'keys_unsorted[]'",
      "To produce a comma-separated string with the key names, you could start with:\r\n\r\n    jq 'keys_unsorted|join(\",\")'"
    ],
    "utterance": "Get all top-level key names and output them as a comma-separated list or one per line, e.g., product,inventory,rating,review.",
    "expressions": [
      "jq -r 'keys_unsorted[]'",
      "jq 'keys_unsorted|join(\",\")'"
    ],
    "data": [
      {
        "input": {
          "product": [
            {
              "productID": "123",
              "productName": "test1"
            }
          ],
          "inventory": [
            {
              "id": "12093",
              "name": "adie"
            }
          ],
          "rating": [
            {
              "value": "4",
              "status": "done"
            }
          ],
          "review": [
            {
              "desc": "good",
              "comments": "test"
            }
          ]
        },
        "output": [
          "product",
          "inventory",
          "rating",
          "review"
        ]
      },
      {
        "input": {
          "product": [
            {
              "productID": "123",
              "productName": "test1"
            }
          ],
          "inventory": [
            {
              "id": "12093",
              "name": "adie"
            }
          ],
          "rating": [
            {
              "value": "4",
              "status": "done"
            }
          ],
          "review": [
            {
              "desc": "good",
              "comments": "test"
            }
          ]
        },
        "output": "product,inventory,rating,review"
      }
    ],
    "identifier": 73758609
  },
  {
    "context": [
      "from all of the following data I want just to pull , \"ICCID\",\"MDN\",\"MSISDN\",\"MCC\",\"MNC\",\"FeatureTypes\",\"RatePlanCode\",\"RatePlanDescription\",\"DeviceState\",\"BillingCycleStartDate\",\"BillingCycleEndDate\",\"CurrentBillCycleDataUnRatedUsage\"\n\nand if any one not exist print not-exist .",
      "i'm not pushing all fields to db so i'm selecting a specific keys from that,\n(**what i'am selecting its fixed not changed**) so the select will not change and always will be :",
      "I would like to check if the value of key is missing for this case \"MSISDN\" ,if not will print for me not-exist or null",
      ".categories | map(.extendedAttributes[]) | from_entries as $attr\n  | \"ICCID\", \"MDN\", \"MSISDN\", \"MCC\", \"MNC\", \"FeatureTypes\", \"RatePlanCode\", \"RatePlanDescription\", \"DeviceState\", \"BillingCycleStartDate\", \"BillingCycleEndDate\", \"CurrentBillCycleDataUnRatedUsage\"\n  | $attr[.] // \"NOT-EXIST\"",
      "[\n  .categories | map(.extendedAttributes[]) | from_entries[\n    \"ICCID\",\n    \"MDN\",\n    \"MSISDN\",\n    \"MCC\",\n    \"MNC\",\n    \"FeatureTypes\",\n    \"RatePlanCode\",\n    \"RatePlanDescription\",\n    \"DeviceState\",\n    \"BillingCycleStartDate\",\n    \"BillingCycleEndDate\",\n    \"CurrentBillCycleDataUnRatedUsage\"\n  ]\n]\n| map(. // \"NOT-EXIST\")"
    ],
    "utterance": "Extract the values for the keys ICCID, MDN, MSISDN, MCC, MNC, FeatureTypes, RatePlanCode, RatePlanDescription, DeviceState, BillingCycleStartDate, BillingCycleEndDate, and CurrentBillCycleDataUnRatedUsage; if a key does not exist, output NOT-EXIST.",
    "expressions": [
      ".categories | map(.extendedAttributes[]) | from_entries as $attr\n  | \"ICCID\", \"MDN\", \"MSISDN\", \"MCC\", \"MNC\", \"FeatureTypes\", \"RatePlanCode\", \"RatePlanDescription\", \"DeviceState\", \"BillingCycleStartDate\", \"BillingCycleEndDate\", \"CurrentBillCycleDataUnRatedUsage\"\n  | $attr[.] // \"NOT-EXIST\"",
      "[\n  .categories | map(.extendedAttributes[]) | from_entries[\n    \"ICCID\",\n    \"MDN\",\n    \"MSISDN\",\n    \"MCC\",\n    \"MNC\",\n    \"FeatureTypes\",\n    \"RatePlanCode\",\n    \"RatePlanDescription\",\n    \"DeviceState\",\n    \"BillingCycleStartDate\",\n    \"BillingCycleEndDate\",\n    \"CurrentBillCycleDataUnRatedUsage\"\n  ]\n]\n| map(. // \"NOT-EXIST\")",
      "[\n  .categories | map(.extendedAttributes[]) | from_entries\n  | .[\"ICCID\", \"MDN\", \"MSISDN\", \"MCC\", \"MNC\", \"FeatureTypes\", \"RatePlanCode\", \"RatePlanDescription\", \"DeviceState\", \"BillingCycleStartDate\", \"BillingCycleEndDate\", \"CurrentBillCycleDataUnRatedUsage\"]\n]\n| map(. // \"NOT-EXIST\")"
    ],
    "data": [
      {
        "input": {
          "categories": [
            {
              "categoryName": "DeviceIdentifier",
              "extendedAttributes": [
                {
                  "key": "ICCID",
                  "value": "89148000"
                },
                {
                  "key": "IMSI",
                  "value": "31148094"
                },
                {
                  "key": "MDN",
                  "value": "5514048068"
                },
                {
                  "key": "MEID",
                  "value": "A0000000005006"
                },
                {
                  "key": "MIN",
                  "value": "5514041185"
                }
              ]
            },
            {
              "categoryName": "DeviceAttributes",
              "extendedAttributes": [
                {
                  "key": "MCC",
                  "value": "311"
                },
                {
                  "key": "MNC",
                  "value": "480"
                },
                {
                  "key": "FeatureCodes",
                  "value": "75802,84777,54307"
                },
                {
                  "key": "FeatureNames",
                  "value": "75802,84777,54307"
                },
                {
                  "key": "FeatureTypes",
                  "value": "4G Public Dynamic"
                },
                {
                  "key": "RatePlanCode",
                  "value": "4G5G "
                },
                {
                  "key": "RatePlanDescription",
                  "value": "4G5G"
                },
                {
                  "key": "Services",
                  "value": "null"
                }
              ]
            },
            {
              "categoryName": "Provisioning",
              "extendedAttributes": [
                {
                  "key": "LastActivationDate",
                  "value": "2022-03-01T19:38:52Z"
                },
                {
                  "key": "CreatedAt",
                  "value": "2021-12-01T21:22:55Z"
                },
                {
                  "key": "DeviceState",
                  "value": "active"
                },
                {
                  "key": "LastDeactivationDate",
                  "value": "2021-12-01T21:22:55Z"
                }
              ]
            },
            {
              "categoryName": "Connectivity",
              "extendedAttributes": [
                {
                  "key": "Connected",
                  "value": "true"
                },
                {
                  "key": "LastConnectionDate",
                  "value": "2022-09-08T03:38:55Z"
                },
                {
                  "key": "LastDisconnectDate",
                  "value": "2022-09-08T03:25:15Z"
                }
              ]
            },
            {
              "categoryName": "Billing",
              "extendedAttributes": [
                {
                  "key": "BillingCycleStartDate",
                  "value": "2022-09-02T00:00:00Z"
                },
                {
                  "key": "BillingCycleEndDate",
                  "value": "2022-10-01T00:00:00Z"
                },
                {
                  "key": "DefaultRatePlan",
                  "value": "0"
                }
              ]
            },
            {
              "categoryName": "Usage",
              "extendedAttributes": [
                {
                  "key": "CurrentRatedUsageRecordDate",
                  "value": "2022-09-04T00:00:00Z"
                },
                {
                  "key": "CurrentUnRatedUsageRecordDate",
                  "value": "2022-09-08T01:25:15Z"
                },
                {
                  "key": "CurrentBillCycleDataUnRatedUsage",
                  "value": "1698414605"
                }
              ]
            }
          ]
        },
        "output": [
          "89148000",
          "5514048068",
          "NOT-EXIST",
          "311",
          "480",
          "4G Public Dynamic",
          "4G5G ",
          "4G5G",
          "active",
          "2022-09-02T00:00:00Z",
          "2022-10-01T00:00:00Z",
          "1698414605"
        ]
      }
    ],
    "identifier": 73648521
  },
  {
    "context": [
      "I need some help extracting the value \"20456\" from here?",
      "Your input consists of two JSON documents; both have a `data` field on top level. But while the first one is itself an object which has an `.id` field, the second one is an array with one object item, which also has an `.id` field.",
      "To retrieve both, you could use the `--slurp` (or `-s`) option which wraps both top-level objects into an array, then you can address them separately by index:",
      "jq --slurp '[0].data.id, .[1].data[].id' jqTrial.txt",
      "Assuming you want the **project** id not the **user** id:",
      "jq '\n    .data\n    | if type == \"object\" then . else .[] end\n    | select(.type == \"projects\")\n    | .id\n' file.json",
      "Indeed, thanks to @pmf\n```jq\n.data | objects // arrays[] | select(.type == \"projects\").id\n```"
    ],
    "utterance": "Extract the id field where type equals \"projects\", regardless of whether data is an object or array.",
    "expressions": [
      ".data | if type == \"object\" then . else .[] end | select(.type == \"projects\") | .id",
      ".data | objects // arrays[] | select(.type == \"projects\").id"
    ],
    "data": [
      {
        "input": {
          "meta": {
            "status": "OK",
            "timestamp": "2022-09-16T14:45:55.076+0000"
          },
          "links": {},
          "data": {
            "id": 24843,
            "username": "abcd",
            "firstName": "abc",
            "lastName": "xyz",
            "email": "abc@abc.com",
            "phone": "",
            "title": "",
            "location": "",
            "licenseType": "FLOATING",
            "active": true,
            "uid": "u24843",
            "type": "users"
          }
        },
        "output": null
      },
      {
        "input": {
          "meta": {
            "status": "OK",
            "timestamp": "2022-09-16T14:45:55.282+0000",
            "pageInfo": {
              "startIndex": 0,
              "resultCount": 1,
              "totalResults": 1
            }
          },
          "links": {
            "data.createdBy": {
              "type": "users",
              "href": "https://abc@abc.com/rest/v1/users/{data.createdBy}"
            },
            "data.fields.user1": {
              "type": "users",
              "href": "https://abc@abc.com/rest/v1/users/{data.fields.user1}"
            },
            "data.modifiedBy": {
              "type": "users",
              "href": "https://abc@abc.com/rest/v1/users/{data.modifiedBy}"
            },
            "data.fields.projectManager": {
              "type": "users",
              "href": "https://abc@abc.com/rest/v1/users/{data.fields.projectManager}"
            },
            "data.parent": {
              "type": "projects",
              "href": "https://abc@abc.com/rest/v1/projects/{data.parent}"
            }
          },
          "data": [
            {
              "id": 20456,
              "projectKey": "Stratus",
              "parent": 20303,
              "isFolder": false,
              "createdDate": "2018-03-12T23:46:59.000+0000",
              "modifiedDate": "2020-04-28T22:14:35.000+0000",
              "createdBy": 18994,
              "modifiedBy": 18865,
              "fields": {
                "projectManager": 18373,
                "user1": 18628,
                "projectKey": "Stratus",
                "text1": "",
                "name": "Stratus",
                "description": "",
                "date2": "2019-03-12",
                "date1": "2018-03-12"
              },
              "type": "projects"
            }
          ]
        },
        "output": 20456
      }
    ],
    "identifier": 73746960
  },
  {
    "context": [
      "Select all top level objects from the array that have a `baseBranch` attribute and a non-empty `config` attribute and filter out the results to show me only the elements within the (`gradle` and `gradle-wrapper`) attributes within the `config` that have a non-empty `deps` array attribute. The result is a `deps` element that have a non-empty `updates` array in it.",
      "With some assumptions made for the edge cases, this should meet your requirements:\r\n~~~sh\r\nmap(select(has(\"baseBranch\") and .config != {}) | {\r\n  repository,\r\n  numberOfUpdates: 0,\r\n  gradleUpdates: .config.gradle,\r\n  gradleWrapperUpdates: .config.\"gradle-wrapper\"\r\n} | (.gradleUpdates, .gradleWrapperUpdates) |= map(\r\n  .packageFile as $fileName | .deps[] | .updates[] as $update | {\r\n    $fileName,\r\n    package: (.packageName // .depName),\r\n    currentVersion,\r\n    newVersion: $update.newValue\r\n  })\r\n  | .numberOfUpdates += ([.gradleUpdates, .gradleWrapperUpdates | length] | add)\r\n)\r\n~~~"
    ],
    "utterance": "From an array, select objects with a baseBranch and config, extract gradle/gradle-wrapper deps with non-empty updates, and output per repository: repository name, number of updates, gradleUpdates and gradleWrapperUpdates arrays, each listing file name, package, currentVersion, and newVersion.",
    "expressions": [
      "map(select(has(\"baseBranch\") and .config != {}) | {\n  repository,\n  numberOfUpdates: 0,\n  gradleUpdates: .config.gradle,\n  gradleWrapperUpdates: .config.\"gradle-wrapper\"\n} | (.gradleUpdates, .gradleWrapperUpdates) |= map(\n  .packageFile as $fileName | .deps[] | .updates[] as $update | {\n    fileName: $fileName,\n    package: (.packageName // .depName),\n    currentVersion,\n    newVersion: $update.newValue\n  })\n  | .numberOfUpdates += ([.gradleUpdates, .gradleWrapperUpdates | length] | add)\n)"
    ],
    "data": [
      {
        "input": [
          {
            "randomKey": "this is not what I am looking for",
            "otherFields": "other object that does not match the query"
          },
          {
            "repository": "myRepositoryName",
            "baseBranch": "master",
            "config": {
              "gradle": [
                {
                  "packageFile": "gradle.properties",
                  "datasource": "maven",
                  "deps": []
                },
                {
                  "packageFile": "dependencies.gradle",
                  "datasource": "maven",
                  "deps": [
                    {
                      "depName": "packageName:dependencyName",
                      "currentValue": "0.8.0",
                      "managerData": {
                        "fileReplacePosition": 611,
                        "packageFile": "dependencies.gradle"
                      },
                      "fileReplacePosition": 611,
                      "registryUrls": [
                        "https://mavenCentral/repository/release",
                        "https://mavenCentral/repository/maven-mirror",
                        "https://mavenCentral/repository/gradle-plugins"
                      ],
                      "depType": "dependencies",
                      "depIndex": 0,
                      "updates": [],
                      "warnings": [],
                      "versioning": "gradle",
                      "currentVersion": "0.8.0",
                      "fixedVersion": "0.8.0"
                    },
                    {
                      "depName": "packageName.api:feature-flags",
                      "currentValue": "0.20.0",
                      "managerData": {
                        "fileReplacePosition": 1118,
                        "packageFile": "dependencies.gradle"
                      },
                      "fileReplacePosition": 1118,
                      "registryUrls": [
                        "https://mavenCentral/repository/release",
                        "https://mavenCentral/repository/maven-mirror",
                        "https://mavenCentral/repository/gradle-plugins"
                      ],
                      "depType": "dependencies",
                      "depIndex": 8,
                      "updates": [
                        {
                          "bucket": "non-major",
                          "newVersion": "0.21.0",
                          "newValue": "0.21.0",
                          "releaseTimestamp": "2022-08-25T04:57:50.000Z",
                          "newMajor": 0,
                          "newMinor": 21,
                          "updateType": "minor",
                          "branchName": "renovate/all-minor-patch"
                        }
                      ],
                      "warnings": [],
                      "versioning": "gradle",
                      "currentVersion": "0.20.0",
                      "isSingleVersion": true,
                      "fixedVersion": "0.20.0"
                    },
                    {
                      "depName": "io.rest-assured:xml-path",
                      "currentValue": "4.5.1",
                      "managerData": {
                        "fileReplacePosition": 3307,
                        "packageFile": "dependencies.gradle"
                      },
                      "fileReplacePosition": 3307,
                      "registryUrls": [
                        "https://mavenCentral/repository/release",
                        "https://mavenCentral/repository/maven-mirror",
                        "https://mavenCentral/repository/gradle-plugins"
                      ],
                      "depType": "dependencies",
                      "depIndex": 39,
                      "updates": [
                        {
                          "bucket": "major",
                          "newVersion": "5.1.1",
                          "newValue": "5.1.1",
                          "releaseTimestamp": "2022-06-10T06:46:14.000Z",
                          "newMajor": 5,
                          "newMinor": 1,
                          "updateType": "major",
                          "branchName": "renovate/io.rest-assured-xml-path-5.x"
                        }
                      ],
                      "warnings": [],
                      "versioning": "gradle",
                      "sourceUrl": "http://svn.sonatype.org/spice/tags/oss-parent-5",
                      "homepage": "https://rest-assured.io/",
                      "currentVersion": "4.5.1",
                      "isSingleVersion": true,
                      "fixedVersion": "4.5.1"
                    },
                    {
                      "depName": "io.rest-assured:json-schema-validator",
                      "currentValue": "5.1.1",
                      "managerData": {
                        "fileReplacePosition": 3376,
                        "packageFile": "dependencies.gradle"
                      },
                      "fileReplacePosition": 3376,
                      "registryUrls": [
                        "https://mavenCentral/repository/release",
                        "https://mavenCentral/repository/maven-mirror",
                        "https://mavenCentral/repository/gradle-plugins"
                      ],
                      "depType": "dependencies",
                      "depIndex": 40,
                      "updates": [],
                      "warnings": [],
                      "versioning": "gradle",
                      "sourceUrl": "http://svn.sonatype.org/spice/tags/oss-parent-5",
                      "homepage": "http://maven.apache.org",
                      "currentVersion": "5.1.1",
                      "fixedVersion": "5.1.1"
                    }
                  ]
                },
                {
                  "packageFile": "settings.gradle",
                  "datasource": "maven",
                  "deps": []
                },
                {
                  "packageFile": "build.gradle",
                  "datasource": "maven",
                  "deps": [
                    {
                      "depType": "plugin",
                      "depName": "com.diffplug.spotless",
                      "packageName": "com.diffplug.spotless:com.diffplug.spotless.gradle.plugin",
                      "registryUrls": [
                        "https://mavenCentral/repository/release",
                        "https://mavenCentral/repository/maven-mirror",
                        "https://mavenCentral/repository/gradle-plugins",
                        "https://plugins.gradle.org/m2/"
                      ],
                      "commitMessageTopic": "plugin com.diffplug.spotless",
                      "currentValue": "6.9.0",
                      "managerData": {
                        "fileReplacePosition": 50,
                        "packageFile": "build.gradle"
                      },
                      "fileReplacePosition": 50,
                      "depIndex": 0,
                      "updates": [
                        {
                          "bucket": "non-major",
                          "newVersion": "6.10.0",
                          "newValue": "6.10.0",
                          "releaseTimestamp": "2022-08-24T14:40:44.000Z",
                          "newMajor": 6,
                          "newMinor": 10,
                          "updateType": "minor",
                          "branchName": "renovate/all-minor-patch"
                        }
                      ],
                      "warnings": [],
                      "versioning": "gradle",
                      "currentVersion": "6.9.0",
                      "isSingleVersion": true,
                      "fixedVersion": "6.9.0"
                    },
                    {
                      "depType": "plugin",
                      "depName": "docker-publish-convention",
                      "packageName": "docker-publish-convention:docker-publish-convention.gradle.plugin",
                      "registryUrls": [
                        "https://mavenCentral/repository/release",
                        "https://mavenCentral/repository/maven-mirror",
                        "https://mavenCentral/repository/gradle-plugins",
                        "https://plugins.gradle.org/m2/"
                      ],
                      "commitMessageTopic": "plugin docker-publish-convention",
                      "currentValue": "latest.release",
                      "managerData": {
                        "fileReplacePosition": 158,
                        "packageFile": "build.gradle"
                      },
                      "fileReplacePosition": 158,
                      "depIndex": 2,
                      "updates": [],
                      "warnings": [],
                      "versioning": "gradle",
                      "skipReason": "invalid-value"
                    },
                    {
                      "depType": "plugin",
                      "depName": "org.springframework.boot",
                      "packageName": "org.springframework.boot:org.springframework.boot.gradle.plugin",
                      "registryUrls": [
                        "https://mavenCentral/repository/release",
                        "https://mavenCentral/repository/maven-mirror",
                        "https://mavenCentral/repository/gradle-plugins",
                        "https://plugins.gradle.org/m2/"
                      ],
                      "commitMessageTopic": "plugin org.springframework.boot",
                      "currentValue": "2.7.2",
                      "managerData": {
                        "fileReplacePosition": 217,
                        "packageFile": "build.gradle"
                      },
                      "fileReplacePosition": 217,
                      "depIndex": 3,
                      "updates": [
                        {
                          "bucket": "non-major",
                          "newVersion": "2.7.3",
                          "newValue": "2.7.3",
                          "releaseTimestamp": "2022-08-18T06:30:12.000Z",
                          "newMajor": 2,
                          "newMinor": 7,
                          "updateType": "patch",
                          "branchName": "renovate/all-minor-patch"
                        }
                      ],
                      "warnings": [],
                      "versioning": "gradle",
                      "sourceUrl": "https://github.com/spring-projects/spring-boot",
                      "homepage": "https://spring.io/projects/spring-boot",
                      "currentVersion": "2.7.2",
                      "isSingleVersion": true,
                      "fixedVersion": "2.7.2"
                    }
                  ]
                }
              ],
              "gradle-wrapper": [
                {
                  "packageFile": "gradle/wrapper/gradle-wrapper.properties",
                  "deps": [
                    {
                      "depName": "gradle",
                      "currentValue": "7.5",
                      "replaceString": "https\\\\://mavenCentral/repository/gradle-dist/gradle-7.5-bin.zip",
                      "datasource": "gradle-version",
                      "versioning": "gradle",
                      "depIndex": 0,
                      "updates": [
                        {
                          "bucket": "non-major",
                          "newVersion": "7.5.1",
                          "newValue": "7.5.1",
                          "releaseTimestamp": "2022-08-05T21:17:56.000Z",
                          "newMajor": 7,
                          "newMinor": 5,
                          "updateType": "patch",
                          "branchName": "renovate/all-minor-patch"
                        }
                      ],
                      "warnings": [],
                      "sourceUrl": "https://github.com/gradle/gradle",
                      "homepage": "https://gradle.org",
                      "currentVersion": "7.5",
                      "isSingleVersion": true,
                      "fixedVersion": "7.5"
                    }
                  ]
                }
              ]
            }
          }
        ],
        "output": [
          {
            "repository": "myRepositoryName",
            "numberOfUpdates": 5,
            "gradleUpdates": [
              {
                "fileName": "dependencies.gradle",
                "package": "packageName.api:feature-flags",
                "currentVersion": "0.20.0",
                "newVersion": "0.21.0"
              },
              {
                "fileName": "io.rest-assured:xml-path",
                "package": "io.rest-assured:xml-path",
                "currentVersion": "4.5.1",
                "newVersion": "5.1.1"
              },
              {
                "fileName": "build.gradle",
                "package": "com.diffplug.spotless:com.diffplug.spotless.gradle.plugin",
                "currentVersion": "6.9.0",
                "newVersion": "6.10.0"
              },
              {
                "fileName": "build.gradle",
                "package": "org.springframework.boot:org.springframework.boot.gradle.plugin",
                "currentVersion": "2.7.2",
                "newVersion": "2.7.3"
              }
            ],
            "gradleWrapperUpdates": [
              {
                "fileName": "gradle/wrapper/gradle-wrapper.properties",
                "package": "gradle",
                "currentVersion": "7.5",
                "newVersion": "7.5.1"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 73541010
  },
  {
    "context": [
      "I need to transform this to a comma seperated string of following string format and store in a variable:",
      "Expected Output:\r\n\r\n```\r\napp=myApp,env=test,tier=frontend\r\n```",
      "Replace `[]` with `map()` so we keep the array, then `join` will work just fine:\r\n```\r\nto_entries | map(.key + \"=\" + .value) | join(\",\")\r\n```"
    ],
    "utterance": "Produce a single comma-separated string of key=value pairs from all key-value pairs in the input object.",
    "expressions": [
      "to_entries | map(.key + \"=\" + .value) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "app": "myApp",
          "env": "test",
          "tier": "frontend"
        },
        "output": "app=myApp,env=test,tier=frontend"
      }
    ],
    "identifier": 73774822
  },
  {
    "context": [
      "Using `-r` option to enable raw-mode option of `jq` then in main block using `select` function to check if component .templateId is `test` if yes then print its related id component value.",
      "echo \"${RESPONSE_TEMPLATES}\" | jq -r 'select(.templateId==\"test\").id'"
    ],
    "utterance": "Extract the id value where templateId equals \"test\".",
    "expressions": [
      "jq -r 'select(.templateId==\"test\").id'"
    ],
    "data": [
      {
        "input": [
          {
            "templateId": "test",
            "id": 1621030
          },
          {
            "templateId": "test1",
            "id": 5014
          },
          {
            "templateId": "test3",
            "id": 5015
          }
        ],
        "output": 1621030
      }
    ],
    "identifier": 73787711
  },
  {
    "context": [
      "I have the following JSON:\r\n```json\r\n{\r\n  \"A\": {\r\n    \"type\": \"string\",\r\n    \"value\": \"value_A\"\r\n  },\r\n  \"B\": {\r\n    \"type\": \"string\",\r\n    \"value\": \"value_B\"\r\n  }\r\n}\r\n```",
      "**Desired Output**\r\n```json\r\n{\r\n  \"A\": \"value_A\",\r\n  \"B\": \"value_B\"\r\n}\r\n```",
      "with_entries(.value |= .value)",
      "map_values(.value)",
      ".[] |= .value"
    ],
    "utterance": "Extract an object where each key is mapped to the 'value' property from its corresponding nested object.",
    "expressions": [
      "with_entries(.value |= .value)",
      "map_values(.value)",
      ".[] |= .value"
    ],
    "data": [
      {
        "input": {
          "A": {
            "type": "string",
            "value": "value_A"
          },
          "B": {
            "type": "string",
            "value": "value_B"
          }
        },
        "output": {
          "A": "value_A",
          "B": "value_B"
        }
      }
    ],
    "identifier": 73786836
  },
  {
    "context": [
      "I need to check if the above json input is present inside the following available_json:",
      "Both json are stored in variables and should report the presence for any json_input given as input based on any available_json (generic). How can this be done using jq?",
      "Using the jq filter contains",
      "jq --slurpfile input_json input_json 'contains($input_json[0])' available.json",
      "jq --argjson input_json \"$input_json\" 'contains($input_json)' available.json",
      "jq \"contains($input_json)\" available.json"
    ],
    "utterance": "Determine if a data structure is fully contained within another based on their values under the 'info' key, using arbitrary input and target structures.",
    "expressions": [
      "jq --slurpfile input_json input_json 'contains($input_json[0])' available.json",
      "jq --argjson input_json \"$input_json\" 'contains($input_json)' available.json",
      "jq 'contains({\n  \"info\": {\n    \"values\": [\n      {\n        \"data\": [\n          {\n            \"name\": \"name\",\n            \"value\": \"val\"\n          }\n        ]\n      }\n    ]\n  }\n})' available.json",
      "jq \"contains($input_json)\" available.json"
    ],
    "data": [
      {
        "input": {
          "json_input": {
            "info": {
              "values": [
                {
                  "data": [
                    {
                      "name": "name",
                      "value": "val"
                    }
                  ]
                }
              ]
            }
          },
          "available_json": {
            "info": {
              "values": [
                {
                  "data": [
                    {
                      "name": "name",
                      "value": "val"
                    },
                    {
                      "name": "name2",
                      "value": "val2"
                    },
                    {
                      "name": "name3",
                      "value": "val3"
                    }
                  ],
                  "key1": "val1",
                  "key2": "val2"
                }
              ],
              "priority": 1,
              "objects": [
                {
                  "name": "a"
                }
              ]
            }
          }
        },
        "output": true
      }
    ],
    "identifier": 73786147
  },
  {
    "context": [
      "what i want is parse the json using `jq` and search string inside `$data` with json provided",
      "Expected output is like this.\n\n\n    Search in $data with JSON config :\n    Found WEDHUS with id 1 , and MARKONAH with id 2",
      "Traverse the input document using `..`, and decompose the `objects` found into an array of key-value pairs using `to_entries`. Then, filter it by iterating `.[]` over its items, and `select`ing only those whose `.value`, if in turn being `strings`, is completely contained `inside` the `$data` string, which was provided as argument using the `--arg` option on invocation). The remaining items can then be formatted to your liking, here using string interpolation `\\(\u2026)` to produce strings, and the `-r` option on invocation to output them in raw format (as opposed to being JSON encoded).",
      "jq -r --arg data \"$data\" '\n  .. | objects | to_entries[]\n  | select(.value | strings | inside($data))\n  | \"Found \\(.value) with id \\(.key)\"\n' config.json",
      "Found JANCOK NJARAN with id CITY\nFound WEDHUS with id 1\nFound MARKONAH with id 33"
    ],
    "utterance": "Find all string values in the data that are present in the supplied variable and output their value and key.",
    "expressions": [
      ".. | objects | to_entries[] | select(.value | strings | inside($data)) | \"Found \\(.value) with id \\(.key)\""
    ],
    "data": [
      {
        "input": {
          "CITY": "JANCOK NJARAN",
          "FATHER": {
            "1": "WEDHUS",
            "2": "ANDRE"
          },
          "MOTHER": {
            "11": "SARAH",
            "22": "EVELYN",
            "33": "MARKONAH"
          }
        },
        "output": [
          "Found JANCOK NJARAN with id CITY",
          "Found WEDHUS with id 1",
          "Found MARKONAH with id 33"
        ]
      }
    ],
    "identifier": 73776972
  },
  {
    "context": [
      "Not all records in the JSON have the \"url\" key. So when I am trying to write to text it gets written as null. So, I will have to do a check if url key is present and if present, then it has to be written to 2 output text files. name will goto name.txt and url will goto url.txt",
      "How to skip the records from writing to output file when url json tag is not found",
      "Evidently you need first to `select(.url)`."
    ],
    "utterance": "Extract the name field only from records that contain the url field.",
    "expressions": [
      ".[] | select(has(\"url\")) | .name"
    ],
    "data": [
      {
        "input": [
          {
            "name": "a",
            "url": "url1"
          },
          {
            "name": "b"
          },
          {
            "name": "C"
          }
        ],
        "output": [
          "a"
        ]
      }
    ],
    "identifier": 73798871
  },
  {
    "context": [
      "Sample input:\r\n\r\n    [\r\n      {\"type\":1, \"name\": \"foo\"},\r\n      {\"type\":1, \"name\": \"bar\"},\r\n      {\"type\":2, \"name\": \"joe\"}\r\n    ]",
      "Preferred function invocation and expected results:\r\n\r\n    .[] | keep_field_only(.type):\r\n\r\n      {\"type\": 1}\r\n      {\"type\": 1}\r\n      {\"type\": 2}",
      "You can define **pick/1** as below,\r\n```\r\ndef pick(paths):\r\n  . as $in\r\n  | reduce path(paths) as $path (null;\r\n    setpath($path; $in | getpath($path))\r\n  );\r\n```",
      "and use it like so:\r\n```\r\n.[] | pick(.type)\r\n```",
      "As you say, you can use path/1 to define your `keep_field_only` and `count_by`, but it can be done in a very simple way:\r\n```\r\ndef keep_field_only(field):\r\n  (null | path(field)[0]) as $field\r\n  | {($field): field} ;\r\n```",
      "Of course this is only intended to work in examples like yours, e.g. with invocations like `keep_field_only(.type)`"
    ],
    "utterance": "For each object in an array, extract only the 'type' field, resulting in an object with just that key and its value.",
    "expressions": [
      ".[] | pick(.type)",
      "def keep_field_only(field): (null | path(field)[0]) as $field | {($field): field} ; .[] | keep_field_only(.type)"
    ],
    "data": [
      {
        "input": [
          {
            "type": 1,
            "name": "foo"
          },
          {
            "type": 1,
            "name": "bar"
          },
          {
            "type": 2,
            "name": "joe"
          }
        ],
        "output": [
          {
            "type": 1
          },
          {
            "type": 1
          },
          {
            "type": 2
          }
        ]
      }
    ],
    "identifier": 73792708
  },
  {
    "context": [
      "I have an object in a file like:",
      "{",
      "  \"methods\" :",
      "        {",
      "          0 : \"GET\",",
      "        },",
      "}",
      "I would like to convert to json with `jq` or some other shell converter. Specifically I want to turn each key into a string `0` -> `\"0\"`. Keys can be numerical or alphanumerical.",
      "Anything that gets the job done. Preferably a shell tool.",
      "With [hjson](https://github.com/laktak/hjson-py) (using Python), you could use the `-j` flag",
      "hjson -j yourfile.txt",
      "{",
      "  \"methods\": {",
      "    \"0\": \"GET\"",
      "  }",
      "}",
      "Another way could be using the YAML processor [mikefarah/yq]",
      "yq -o json yourfile.txt",
      "{",
      "  \"methods\": {",
      "    \"0\": \"GET\"",
      "  }",
      "}",
      "But yq also has a JSON converter `@json` as built-in function, if you'd want to further adjust the data on the fly:",
      "yq '@json' yourfile.txt",
      "{ \"methods\": { \"0\": \"GET\" } }"
    ],
    "utterance": "Convert an object with numeric keys into one where all keys are strings, ensuring compatibility with JSON object syntax.",
    "expressions": [
      "hjson -j yourfile.txt",
      "yq -o json yourfile.txt",
      "yq '@json' yourfile.txt"
    ],
    "data": [
      {
        "input": {
          "methods": {
            "0": "GET"
          }
        },
        "output": {
          "methods": {
            "0": "GET"
          }
        }
      }
    ],
    "identifier": 73797014
  },
  {
    "context": [
      "The output from my current jq filters looks like\n{\n  \"id1\": {\n    \"version\": 4,\n    \"lastModifier\": \"abc\"\n  }\n}\n{\n  \"id2\": {\n    \"version\": 3,\n    \"lastModifier\": \"def\"\n  }\n}\n{\n  \"id3\": {\n    \"version\": 8,\n    \"lastModifier\": \"abc\"\n  }\n}",
      "I just need to wrap this list in a object so I end up with\n{\n  \"ref\": {\n      \"id1\": {\n          \"version\": 4,\n          \"lastModifier\": \"abc\"\n      },\n      \"id2\": {\n          \"version\": 3,\n          \"lastModifier\": \"def\"\n      },\n      \"id3\": {\n          \"version\": 8,\n          \"lastModifier\": \"abc\"\n      }\n   }\n}",
      "Use the `-s` flag to read the stream into an array, the `add` it up and put it into your object:\n~~~sh\njq -s '{ref: add}'\n~~~",
      "Of course, there is also a solution using `reduce`:\n~~~sh\njq -n 'reduce inputs as $in ({}; .ref += $in)'\n~~~"
    ],
    "utterance": "Wrap multiple top-level objects, each keyed by id, into a single object under the property ref, preserving each id and its associated object.",
    "expressions": [
      "-s '{ref: add}'",
      "-n 'reduce inputs as $in ({}; .ref += $in)'"
    ],
    "data": [
      {
        "input": [
          {
            "id1": {
              "version": 4,
              "lastModifier": "abc"
            }
          },
          {
            "id2": {
              "version": 3,
              "lastModifier": "def"
            }
          },
          {
            "id3": {
              "version": 8,
              "lastModifier": "abc"
            }
          }
        ],
        "output": {
          "ref": {
            "id1": {
              "version": 4,
              "lastModifier": "abc"
            },
            "id2": {
              "version": 3,
              "lastModifier": "def"
            },
            "id3": {
              "version": 8,
              "lastModifier": "abc"
            }
          }
        }
      }
    ],
    "identifier": 73793450
  },
  {
    "context": [
      "I am trying to use `jq` to extract only the records whose ticketNumbers are \"24656\" and \"33445\".",
      "You can do something like\n\n[\"24656\", \"33445\"] as $valid | select(.record.data.ticketNumber | IN($valid[]))"
    ],
    "utterance": "Extract all objects where record.data.ticketNumber is either \"24656\" or \"33445\".",
    "expressions": [
      "[\"24656\", \"33445\"] as $valid | select(.record.data.ticketNumber | IN($valid[]))"
    ],
    "data": [
      {
        "input": [
          {
            "type": "RECORD",
            "record": {
              "stream": "...",
              "data": {
                "ticketNumber": "12345"
              }
            }
          },
          {
            "type": "RECORD",
            "record": {
              "stream": "...",
              "data": {
                "ticketNumber": "23456"
              }
            }
          },
          {
            "type": "RECORD",
            "record": {
              "stream": "...",
              "data": {
                "ticketNumber": "33445"
              }
            }
          },
          {
            "type": "RECORD",
            "record": {
              "stream": "...",
              "data": {
                "ticketNumber": "24656"
              }
            }
          },
          {
            "type": "RECORD",
            "record": {
              "stream": "...",
              "data": {
                "ticketNumber": "15523"
              }
            }
          },
          {
            "type": "RECORD",
            "record": {
              "stream": "...",
              "data": {
                "ticketNumber": "30030"
              }
            }
          }
        ],
        "output": [
          {
            "type": "RECORD",
            "record": {
              "stream": "...",
              "data": {
                "ticketNumber": "33445"
              }
            }
          },
          {
            "type": "RECORD",
            "record": {
              "stream": "...",
              "data": {
                "ticketNumber": "24656"
              }
            }
          }
        ]
      }
    ],
    "identifier": 73800715
  },
  {
    "context": [
      "I need to extract first object matching my criterium in input stream as a variable (if any), then to process the entire stream.",
      "Turns out, the stream becomes `empty` if there is no matches:",
      "How can I make the whole `inputs` available to downstream filter, whether or not there is a match?",
      "The key point here is that `first(empty)` yields the empty stream.",
      "So in your query, `first(.[] | select (.ID==3)) as $match` has the effect of `empty`, and thus your program is equivalent to `empty | .`, which is empty.",
      "you could tweak the assignment from above and directly set the variable to hold the first item or `null` by moving the array (brackets) outside of the capture:",
      "[inputs]\n| map(select (.ID == 1)) as [$match]\n| .   # yields the whole input array with $match set to {\"ID\": 1}",
      "# or",
      "[inputs]\n| map(select (.ID == 3)) as [$match]\n| .   # yields the whole input array with $match set to null"
    ],
    "utterance": "Extract the first object with ID equal to 3 and bind it to a variable (which should be null if not found), while still making all inputs available for further processing.",
    "expressions": [
      "[inputs] | map(select(.ID == 3)) as [$match] | ."
    ],
    "data": [
      {
        "input": [
          {
            "ID": 1
          },
          {
            "ID": 2
          }
        ],
        "output": [
          {
            "ID": 1
          },
          {
            "ID": 2
          }
        ]
      }
    ],
    "identifier": 73808312
  },
  {
    "context": [
      "And my goal is to fetch a specific `Name` (in my case it's the `test.devx.company.services`), however the `Name` field contains an extra \".\" at the end that I'd like to remove from the output.",
      "To additionally only remove the last character if itself is a dot, or more generally any well-defined substring in final position, either `sub`stitute it with the empty string \"\" by matching against a regex pattern, e.g. `[.]$` for a final dot, or use the dedicated `rtrimstr` function by providing the literal substring, \".\" in this case:",
      "jq '(.HostedZones[].Name | select(contains(\"test\"))) |= sub(\"[.]$\"; \"\")'",
      "jq '(.HostedZones[].Name | select(contains(\"test\"))) |= rtrimstr(\".\")'"
    ],
    "utterance": "Fetch all Name fields containing 'test' and remove a trailing dot from each if present.",
    "expressions": [
      ".HostedZones[].Name | select(contains(\"test\")) | sub(\"[.]$\"; \"\")",
      ".HostedZones[].Name | select(contains(\"test\")) | rtrimstr(\".\")"
    ],
    "data": [
      {
        "input": {
          "HostedZones": [
            {
              "ResourceRecordSetCount": 2,
              "CallerReference": "test20150527-2",
              "Config": {
                "Comment": "test2",
                "PrivateZone": true
              },
              "Id": "/hostedzone/Z119WBBTVP5WFX",
              "Name": "dev.devx.company.services."
            },
            {
              "ResourceRecordSetCount": 2,
              "CallerReference": "test20150527-1",
              "Config": {
                "Comment": "test",
                "PrivateZone": true
              },
              "Id": "/hostedzone/Z3P5QSUBK4POTI",
              "Name": "test.devx.company.services."
            }
          ],
          "IsTruncated": false,
          "MaxItems": "100"
        },
        "output": [
          "dev.devx.company.services",
          "test.devx.company.services"
        ]
      }
    ],
    "identifier": 73820269
  },
  {
    "context": [
      "I have 2 report files like the following",
      "I want to combine it using jq command with hope the end result is as follows",
      "jq -s '[ (.[0] | keys[]) as $k | reduce .[] as $item (null; .[$k] += $item[$k]) ] | add' report1.json report2.json",
      "jq '.examples += [inputs.examples[]]' report*.json",
      "jq -n '\n [inputs | to_entries] | add | {(first.key): (map(.value) | add) }\n' report{1,2}.json",
      "jq -s '{examples: map(.examples[])}' report1.json report2.json"
    ],
    "utterance": "Combine the 'examples' arrays from two files so that the result is a single object with an 'examples' key containing all entries from both files.",
    "expressions": [
      "jq -s '{examples: map(.examples[])}' report1.json report2.json",
      "jq '.examples += [inputs.examples[]]' report1.json report2.json"
    ],
    "data": [
      {
        "input": {
          "report1.json": {
            "examples": [
              {
                "description": "desc 1",
                "full_description": "full_description 1",
                "status": "status 1",
                "file_path": "file_path 1",
                "run_time": 0.01
              }
            ]
          },
          "report2.json": {
            "examples": [
              {
                "description": "desc 2",
                "full_description": "full_description 2",
                "status": "status 2",
                "file_path": "file_path 2",
                "run_time": 0.02
              }
            ]
          }
        },
        "output": {
          "examples": [
            {
              "description": "desc 1",
              "full_description": "full_description 1",
              "status": "status 1",
              "file_path": "file_path 1",
              "run_time": 0.01
            },
            {
              "description": "desc 2",
              "full_description": "full_description 2",
              "status": "status 2",
              "file_path": "file_path 2",
              "run_time": 0.02
            }
          ]
        }
      }
    ],
    "identifier": 73822884
  },
  {
    "context": [
      "How to get the unique keys from attributes key with JQ",
      "{'id':1, 'attributes':{'a': 1, 'b': 2, 'c': 3}}",
      "{'id':2, 'attributes':{'a': 4, 'b': 5, 'd': 6}}",
      "{'id':3, 'name':'ABC'}",
      "Result like this",
      "[ 'a', 'b', 'c', 'd' ]",
      "jq: error (at <stdin>:11): null (null) has no keys",
      "One way could be using `reduce` on subsequent `inputs`:\njq 'reduce inputs.attributes as $a (.attributes; . + $a) | keys'",
      "[Demo](https://jqplay.org/s/v-bat97apVr)",
      "Along the lines of your second attempt:\njq -n '[inputs.attributes // empty | keys_unsorted[]] | unique'",
      "With slurp:\njq -s 'map(.attributes|keys?)|add|unique' test.json"
    ],
    "utterance": "Extract a sorted list of all unique keys found within the 'attributes' objects across all input objects, ignoring entries where 'attributes' is missing.",
    "expressions": [
      "jq 'reduce inputs.attributes as $a (.attributes; . + $a) | keys'",
      "jq -n '[inputs.attributes // empty | keys_unsorted[]] | unique'",
      "jq -s 'map(.attributes|keys?)|add|unique' test.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "attributes": {
              "a": 1,
              "b": 2,
              "c": 3
            }
          },
          {
            "id": 2,
            "attributes": {
              "a": 4,
              "b": 5,
              "d": 6
            }
          },
          {
            "id": 3,
            "name": "ABC"
          }
        ],
        "output": [
          "a",
          "b",
          "c",
          "d"
        ]
      }
    ],
    "identifier": 73823479
  },
  {
    "context": [
      "is it possible to obtain this output ?",
      "From csv",
      "id,age,gender\n1,39,M\n2,25,M",
      "To json column array",
      "[{\"id\":[\"1\",\"2\"]},{\"age\":[\"39\",\"25\"]},{\"gender\":[\"M\",\"M\"]}]",
      "OR from json",
      "[{\"id\": \"1\", \"age\": \"39\", \"gender\": \"M\"}, {\"id\": \"2\", \"age\": \"25\", \"gender\": \"M\"}]",
      "To json column array",
      "[{\"id\":[\"1\",\"2\"]},{\"age\":[\"39\",\"25\"]},{\"gender\":[\"M\",\"M\"]}]",
      "jq 'map(to_entries) | transpose | map({(first.key): map(.value)}) | add'"
    ],
    "utterance": "Produce an array where each element is an object with a single key and as value the column of all values for that key; for example, convert a list of objects with keys id, age, gender to [{\"id\": [\"1\", \"2\"]}, {\"age\": [\"39\", \"25\"]}, {\"gender\": [\"M\", \"M\"]}].",
    "expressions": [
      "map(to_entries) | transpose | map({(first.key): map(.value)})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "age": "39",
            "gender": "M"
          },
          {
            "id": "2",
            "age": "25",
            "gender": "M"
          }
        ],
        "output": [
          {
            "id": [
              "1",
              "2"
            ]
          },
          {
            "age": [
              "39",
              "25"
            ]
          },
          {
            "gender": [
              "M",
              "M"
            ]
          }
        ]
      }
    ],
    "identifier": 73825788
  },
  {
    "context": [
      "Given the input document:\r\n\r\n```json\r\n{\"a\":1}\r\n{\"b\":2}\r\n{\"c\":3,\"d\":4}\r\n```",
      "They all seem to produce the same output.",
      "In other words, the following (simplified/reduced) invocations seem identical: \r\n\n - `jq '[.,inputs]'`\r\n - `jq -n '[inputs]'`\r\n - `jq -s '.'`.",
      "With `jq '-n [inputs] ....'` and `jq '[.,inputs] ....'`, you are loading the whole file into memory.",
      "A more memory-efficient way to achieve the result as an array is:\r\n\n```\r\njq -n '[inputs | to_entries[].value]'\r\n```"
    ],
    "utterance": "Produce an array containing the values from all top-level keys in a stream of multiple input objects.",
    "expressions": [
      "[., inputs] | map(to_entries[].value)",
      "-n '[inputs] | map(to_entries[].value)'",
      "-s 'map(to_entries[].value)'",
      "-n '[inputs | to_entries[].value]'"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1
          },
          {
            "b": 2
          },
          {
            "c": 3,
            "d": 4
          }
        ],
        "output": [
          1,
          2,
          3,
          4
        ]
      }
    ],
    "identifier": 73843868
  },
  {
    "context": [
      "set_fact:\n    data: \"{{ value.stdout | from_json }}\"",
      "shell:  echo \"{{ data }}\" | jq 'to_entries | map((.key) + \"=\" + .value)|join(\",\")'",
      "Error: parse error: Invalid numeric literal at line , column",
      "\"data\": {\n        \"key1\": \"keyval1\",\n        \"key2\": \"keyval2\"\n}",
      "shell: echo \"{{ data | to_json }}\"| jq 'to_entries | map((.key) + \"=\" + .value)|join(\",\")'",
      "shell: echo \"{{ data }}\" | sed \"s/'/\\\"/g\" | jq 'to_entries | map((.key) + \"=\" + .value)|join(\",\")'"
    ],
    "utterance": "Convert a map with string keys and values to a comma-separated list of key=value pairs.",
    "expressions": [
      "to_entries | map((.key) + \"=\" + .value)|join(\",\")"
    ],
    "data": [
      {
        "input": {
          "key1": "keyval1",
          "key2": "keyval2"
        },
        "output": "key1=keyval1,key2=keyval2"
      }
    ],
    "identifier": 73865690
  },
  {
    "context": [
      "I am trying to replace LIST_TO_REPLACE text with the below `YAML` file list data.",
      "Is there any way to replace the entire node and it could follow the indentation of **file1**?",
      "yq -y '\n  .default.app.\"service-v1\".country.list = input.app.\"list-data\"\n' file1.yaml file2.yaml",
      "yq '\n  .default.app.\"service-v1\".country.list = load(\"file2.yaml\").app.\"list-data\"\n' file1.yaml"
    ],
    "utterance": "Replace the value of 'list' under default.app.service-v1.country in the first file with the contents of 'list-data' under app in the second file.",
    "expressions": [
      ".default.app.\"service-v1\".country.list = input.app.\"list-data\"",
      ".default.app.\"service-v1\".country.list = load(\"file2.yaml\").app.\"list-data\""
    ],
    "data": [
      {
        "input": {
          "file1.yaml": {
            "default": {
              "app": {
                "service-v1": {
                  "country": {
                    "list": "LIST_TO_REPLACE"
                  }
                }
              }
            }
          },
          "file2.yaml": {
            "app": {
              "list-data": [
                {
                  "key1": "value",
                  "key2": "value",
                  "key3": [
                    "list1",
                    "list2",
                    "list3"
                  ]
                },
                {
                  "key4": "value",
                  "key5": "value",
                  "key6": [
                    "list1",
                    "list2",
                    "list3"
                  ]
                }
              ]
            }
          }
        },
        "output": {
          "default": {
            "app": {
              "service-v1": {
                "country": {
                  "list": [
                    {
                      "key1": "value",
                      "key2": "value",
                      "key3": [
                        "list1",
                        "list2",
                        "list3"
                      ]
                    },
                    {
                      "key4": "value",
                      "key5": "value",
                      "key6": [
                        "list1",
                        "list2",
                        "list3"
                      ]
                    }
                  ]
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 73847027
  },
  {
    "context": [
      "but I want the latest (highest number) release, and I want the URL of this release.",
      "How can I get the URL for the current newest release for 1.17 (should give `\"tgz+https://github.com/adoptium/temurin17-binaries/releases/download/jdk-17.0.4%2B8/OpenJDK17U-jre_x64_linux_hotspot_17.0.4_8.tar.gz\"`)",
      "Give `max_by` a try.",
      ".linux.amd64.\"jdk@adoptium-jre\"\n| to_entries\n| map(select(.key | startswith(\"1.17.\")))\n| max_by(.key)\n| .value",
      "| map(select(.key | test(\"1\\.17\\.[0-9]+\\.[0-9]+$\")))\n| sort_by(.key | split(\".\") | map(tonumber)) \n| last.value"
    ],
    "utterance": "Find the URL for the latest stable release of version 1.17 for 'adoptium-jre' on 'linux.amd64'.",
    "expressions": [
      ".linux.amd64.\"jdk@adoptium-jre\" | to_entries | map(select(.key | startswith(\"1.17.\"))) | max_by(.key) | .value",
      ".linux.amd64.\"jdk@adoptium-jre\" | to_entries | map(select(.key | test(\"1\\.17\\.[0-9]+\\.[0-9]+$\"))) | sort_by(.key | split(\".\") | map(tonumber)) | last.value"
    ],
    "identifier": 73865840
  },
  {
    "context": [
      "I&#39;m trying to detect when I get all empty json values.",
      "Here are 2 examples of empty json values.",
      "The closest I&#39;ve gotten is this, which seems to work for the first example, but not the 2nd.",
      "echo \"$json\" | jq -e 'all( .[] ; . == \"\" or . == [] or . == {}  )'",
      "This will give you `false` if all `strings` and `arrays` are `\"\"` or `[]`:\n~~~sh\njq -e 'all(.. | strings, arrays; IN(\"\", [])) | not'\n~~~"
    ],
    "utterance": "Determine if all string and array values are empty strings or empty arrays, returning true only when no non-empty string or array exists anywhere in the structure.",
    "expressions": [
      "all(.. | strings, arrays; IN(\"\", []))"
    ],
    "data": [
      {
        "input": {
          "data": [],
          "pagination": {
            "cursor": ""
          }
        },
        "output": true
      },
      {
        "input": {
          "data": [],
          "error": "",
          "message": "",
          "status": ""
        },
        "output": true
      },
      {
        "input": {
          "data": [
            1
          ],
          "pagination": {
            "cursor": ""
          }
        },
        "output": false
      }
    ],
    "identifier": 73869332
  },
  {
    "context": [
      "I want print \"[]\" in every row with jq to make a big file json proof",
      "What i want:\n\n    [[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]\n    [{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]\n    [{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]\n    [{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]]",
      "Use `--slurp` to create a single array, then use `map([ . ])` to wrap each object in his own array\n```\njq --slurp --compact-output 'map([ . ])'\n[[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}],[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}], ...\n```",
      "jq -Rnr '[inputs] | (first, .[]) |= \"[\" + . | (last, .[]) += \"]\" | .[]'\n~~~json\n[[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]\n[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]\n[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]\n[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]]"
    ],
    "utterance": "Wrap each object from a stream so every line is a single-item array, and the first and last lines have an extra opening or closing bracket respectively, to form a structure like [[{...}]\n[{...}]\n...[{...}]]",
    "expressions": [
      "jq -Rnr '[inputs] | (first, .[]) |= \"[\" + . | (last, .[]) += \"]\" | .[]'"
    ],
    "data": [
      {
        "input": [
          "{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}",
          "{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}",
          "{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}",
          "{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}"
        ],
        "output": "[[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]\n[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]\n[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]\n[{\"test\":\"index\",\"test2\":\"fdsdfs\",\"test3\":\"dfs0D0WOQAA3\"}]]"
      }
    ],
    "identifier": 73816279
  },
  {
    "context": [
      "I have:\n\n    {\n      \"dev\": {\n        \"Alpha\": {\n          \"dependencies\": [\n            \"Gamma\",\n            \"Delta\"\n          ],\n          \"other_value_1\": [\n            \"aaa\"\n          ],\n          \"other_value_n\": [\n            \"unknown number of other values\"\n          ]\n        },\n        \"Beta\": {\n          \"package_name\": \"some name\",\n          \"scm\": {\n            \"type\": \"git\",\n            \"url\": \"git url\"\n          }\n        },\n        \"Gamma\": {\n          \"dependencies\": [\n            \"Delta\"\n          ]\n        },\n        \"Delta\": {\n          \"dependencies\": []\n        }\n      }\n    }\n\nOut of which I want to get only the names of objects with dependencies (in this example: Alpha, Gamma) and the dependencies themself:",
      "Slightly more verbose way, without specifying the keys:\n```\n.dev |= with_entries(select(.value.dependencies | length > 0) | .value = { dependencies: .value.dependencies})\n```",
      "jq '.dev |= ({Alpha, Gamma} | .[] |= {dependencies})'",
      "jq '.dev[] |= ({dependencies} | select(.[] | has(0)))'",
      "{\n    dev: .dev | map_values({dependencies} | select(.[][0]))\n}"
    ],
    "utterance": "Filter the 'dev' object to retain only entries where 'dependencies' is a non-empty array, and for these, keep only the 'dependencies' key.",
    "expressions": [
      ".dev |= with_entries(select(.value.dependencies | length > 0) | .value = { dependencies: .value.dependencies})",
      ".dev |= ({Alpha, Gamma} | .[] |= {dependencies})",
      ".dev[] |= ({dependencies} | select(.[] | has(0)))",
      "{ dev: .dev | map_values({dependencies} | select(.[][0])) }"
    ],
    "data": [
      {
        "input": {
          "dev": {
            "Alpha": {
              "dependencies": [
                "Gamma",
                "Delta"
              ],
              "other_value_1": [
                "aaa"
              ],
              "other_value_n": [
                "unknown number of other values"
              ]
            },
            "Beta": {
              "package_name": "some name",
              "scm": {
                "type": "git",
                "url": "git url"
              }
            },
            "Gamma": {
              "dependencies": [
                "Delta"
              ]
            },
            "Delta": {
              "dependencies": []
            }
          }
        },
        "output": {
          "dev": {
            "Alpha": {
              "dependencies": [
                "Gamma",
                "Delta"
              ]
            },
            "Gamma": {
              "dependencies": [
                "Delta"
              ]
            }
          }
        }
      }
    ],
    "identifier": 73870153
  },
  {
    "context": [
      "I have a JSON file, like this:",
      "{ \"data\" : [ { \"values\" : [ \"ColumnHeader1\", \"ColumnHeader2\", \"ColumnHeader3\" ]}, { \"values\" : [ \"Row1Column1\", \"Row1Column2\", \"Row1Column3\" ]}, { \"values\" : [ \"Row2Column1\", \"Row2Column2\", \"Row2Column3\" ]} ] }",
      "I want to transform it, to be like this:",
      "{ data: [ { \"ColumnHeader1\" : \"Row1Value1\", \"ColumnHeader2\": \"Row1Value2\", \"ColumnHeader3\" : \"Row1Value3\" }, { \"ColumnHeader1\" : \"Row2Value1\", \"ColumnHeader2\": \"Row2Value2\", \"ColumnHeader3\" : \"Row2Value3\" } ] }",
      "Here's a solution for `jq` using `transpose` and `map`:",
      ".data |= (map(.values) | transpose\n  | map([{(.[0]): .[1:][]}]) | transpose\n  | map(add)\n)",
      "A jq-only solution:",
      "def objectify($header): \n  . as $in\n  | reduce range(0; $header|length) as $i ({}; .[$header[$i]] = $in[$i] );\n\n.data[0].values as $header\n| .data |= (.[1:] | map(.values | objectify($header)) )",
      ".data[0].values as $header\n| .data |= (.[1:] | map(.values | with_entries(.key |= $header[.])))",
      ".data |= (\n  map(.values)\n  | first as $headers | del(first)\n  | map(\n    [ $headers, .]\n    | transpose\n    | map({(first): last})\n    | add\n  )\n)",
      "{\n  data: (\n    .data | map(.values)\n    | first as $headers | del(first) \n    | map(\n      [ $headers, .]\n      | transpose\n      | map({(first): last})\n      | add\n    )\n  )\n}"
    ],
    "utterance": "Transform an object with a 'data' array where the first element is a list of headers and subsequent elements are value lists, into an array of objects mapping each header to its corresponding value in each row.",
    "expressions": [
      ".data |= (map(.values) | transpose\n  | map([{(.[0]): .[1:][]}]) | transpose\n  | map(add)\n)",
      "def objectify($header): \n  . as $in\n  | reduce range(0; $header|length) as $i ({}; .[$header[$i]] = $in[$i] );\n\n.data[0].values as $header\n| .data |= (.[1:] | map(.values | objectify($header)) )",
      ".data[0].values as $header\n| .data |= (.[1:] | map(.values | with_entries(.key |= $header[.])))",
      ".data |= (\n  map(.values)\n  | first as $headers | del(first)\n  | map(\n    [ $headers, .]\n    | transpose\n    | map({(first): last})\n    | add\n  )\n)",
      "{\n  data: (\n    .data | map(.values)\n    | first as $headers | del(first) \n    | map(\n      [ $headers, .]\n      | transpose\n      | map({(first): last})\n      | add\n    )\n  )\n}"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "values": [
                "ColumnHeader1",
                "ColumnHeader2",
                "ColumnHeader3"
              ]
            },
            {
              "values": [
                "Row1Column1",
                "Row1Column2",
                "Row1Column3"
              ]
            },
            {
              "values": [
                "Row2Column1",
                "Row2Column2",
                "Row2Column3"
              ]
            }
          ]
        },
        "output": {
          "data": [
            {
              "ColumnHeader1": "Row1Column1",
              "ColumnHeader2": "Row1Column2",
              "ColumnHeader3": "Row1Column3"
            },
            {
              "ColumnHeader1": "Row2Column1",
              "ColumnHeader2": "Row2Column2",
              "ColumnHeader3": "Row2Column3"
            }
          ]
        }
      }
    ],
    "identifier": 73818482
  },
  {
    "context": [
      "here is the original, it contains lots of information that i do not need for the purpose i am using it for.",
      "this is what i would like the output to be, with some of the values being dynamic.",
      "would appreciate any help to point me in the right direction.",
      "Here&#39;s one way you could approach it. First map out the properties you want copied over, then filter each of the properties you want to filter to add or remove from each.",
      "map(\n    # 1. select the properties\n\t{\n\t\tmatchId,\n\t\ttimestamp,\n\t\tclubs,\n\t\tplayers\n\t}\n\t|\n    # 2. filter the properties\n\t.clubs[] |= ( # update each club...\n        # 1. select the properties\n\t\twith_entries(select(.key | startswith(\"p\"))) + {shots, toa, details}\n\t\t|\n        # 2. filter the properties\n\t\t.details |= {name, clubId}\n\t)\n\t|\n\t.players[][] |= ( # update each player in the map of players\n        # 1. select the properties\n\t\twith_entries(select(.key | startswith(\"gl\")))\n\t\t+\n\t\t{opponentClubId, position, posSorted}\n\t\t+\n\t\twith_entries(select(.key | startswith(\"rating\")))\n\t\t+\n\t\twith_entries(select(.key | startswith(\"sk\")))\n\t\t+\n\t\t{toiseconds, playername}\n\t)\n)",
      "Produces the result:",
      "[\n  {\n    \"matchId\": \"2234705530498\",\n    \"timestamp\": 1661657182,\n    \"clubs\": {\n      \"79718\": {\n        \"passa\": \"79\",\n        \"passc\": \"58\",\n        \"ppg\": \"0\",\n        \"ppo\": \"0\",\n        \"shots\": \"15\",\n        \"toa\": \"252\",\n        \"details\": {\n          \"name\": \"NZHL Memphis Make A Wish\",\n          \"clubId\": 79718\n        }\n      },",
      "Here&#39;s another variation that you can provide regex patterns for the paths to select.",
      "map(select_paths($patterns))"
    ],
    "utterance": "Extract specific fields from each top-level object: matchId, timestamp, then from each club extract passa, passc, ppg, ppo, shots, toa, and under details extract name and clubId; from each player retain all fields starting with gl, rating, sk, plus opponentClubId, position, posSorted, toiseconds, and playername.",
    "expressions": [
      "map(\n  {\n    matchId,\n    timestamp,\n    clubs,\n    players\n  }\n  |\n  .clubs[] |= (\n    with_entries(select(.key | startswith(\"p\"))) + {shots, toa, details}\n    |\n    .details |= {name, clubId}\n  )\n  |\n  .players[][] |= (\n    with_entries(select(.key | startswith(\"gl\")))\n    + {opponentClubId, position, posSorted}\n    + with_entries(select(.key | startswith(\"rating\")))\n    + with_entries(select(.key | startswith(\"sk\")))\n    + {toiseconds, playername}\n  )\n)",
      "[\n\t[\"matchId\"],\n\t[\"timestamp\"],\n\t[\"clubs\", \".+\", \"p.+\"],\n\t[\"clubs\", \".+\", \"(shots|toa)\"],\n\t[\"clubs\", \".+\", \"details\", \"(name|clubId)\"],\n\t[\"players\", \".+\", \".+\", \"gl.+\"],\n\t[\"players\", \".+\", \".+\", \"(opponentClubId|position|posSorted)\"],\n\t[\"players\", \".+\", \".+\", \"rating.+\"],\n\t[\"players\", \".+\", \".+\", \"sk.+\"],\n\t[\"players\", \".+\", \".+\", \"(toiseconds|playername)\"]\n] as $patterns\n|\ndef select_paths($patterns):\n\tdef is_matching_pattern($path):\n\t\t([$path, .] | transpose) as $pairs\n\t\t|\n\t\tall($pairs[]; . as [$path, $pattern] |\n\t\t\t$path | if $pattern then test(\"^(\\($pattern))$\") else false end\n\t\t)\n\t\t;\n\tdef filter_paths: . as [$path] |\n\t\tselect(length == 1 or any($patterns[]; is_matching_pattern($path)))\n\t\t;\n\tfromstream(tostream | filter_paths)\n\t;\nmap(select_paths($patterns))"
    ],
    "data": [
      {
        "input": [
          {
            "matchId": "2234705530498",
            "timestamp": 1661657182,
            "clubs": {
              "79718": {
                "clubDivision": "4",
                "cNhlOnlineGameType": "5",
                "garaw": "3",
                "gfraw": "6",
                "losses": "0",
                "memberString": "6 / 6",
                "opponentClubId": "145078",
                "opponentScore": "3",
                "opponentTeamArtAbbr": "EASHL",
                "passa": "79",
                "passc": "58",
                "ppg": "0",
                "ppo": "0",
                "result": "1",
                "score": "6",
                "scoreString": "6 - 3",
                "shots": "15",
                "teamArtAbbr": "DROP",
                "teamSide": "1",
                "toa": "252",
                "winnerByDnf": "0",
                "winnerByGoalieDnf": "0",
                "details": {
                  "name": "NZHL Memphis Make A Wish",
                  "clubId": 79718,
                  "regionId": 1,
                  "teamId": 5108,
                  "customKit": {
                    "isCustomTeam": "1",
                    "crestAssetId": "62",
                    "useBaseAsset": "1"
                  }
                },
                "goals": "6",
                "goalsAgainst": "3"
              }
            },
            "players": {
              "145078": {
                "169580763": {
                  "class": "2",
                  "glbrksavepct": "0.00",
                  "glbrksaves": "0",
                  "glbrkshots": "0",
                  "gldsaves": "0",
                  "glga": "0",
                  "glgaa": "0.00",
                  "glpensavepct": "0.00",
                  "glpensaves": "0",
                  "glpenshots": "0",
                  "glpkclearzone": "0",
                  "glpokechecks": "0",
                  "glsavepct": "0.00",
                  "glsaves": "0",
                  "glshots": "0",
                  "glsoperiods": "0",
                  "isGuest": "1",
                  "opponentClubId": "79718",
                  "opponentScore": "6",
                  "opponentTeamId": "501",
                  "player_dnf": "0",
                  "playerLevel": "157",
                  "pNhlOnlineGameType": "5",
                  "position": "rightWing",
                  "posSorted": "3",
                  "ratingDefense": "55.00",
                  "ratingOffense": "85.00",
                  "ratingTeamplay": "70.00",
                  "score": "3",
                  "skassists": "0",
                  "skbs": "0",
                  "skdeflections": "0",
                  "skfol": "0",
                  "skfopct": "0.00",
                  "skfow": "0",
                  "skgiveaways": "4",
                  "skgoals": "2",
                  "skgwg": "0",
                  "skhits": "1",
                  "skinterceptions": "3",
                  "skpassattempts": "11",
                  "skpasses": "7",
                  "skpasspct": "63.64",
                  "skpenaltiesdrawn": "1",
                  "skpim": "0",
                  "skpkclearzone": "0",
                  "skplusmin": "-5",
                  "skpossession": "106",
                  "skppg": "1",
                  "sksaucerpasses": "0",
                  "skshg": "0",
                  "skshotattempts": "12",
                  "skshotonnetpct": "66.67",
                  "skshotpct": "25.00",
                  "skshots": "8",
                  "sktakeaways": "0",
                  "toiseconds": "3600",
                  "playername": "Ababo"
                }
              }
            }
          }
        ],
        "output": [
          {
            "matchId": "2234705530498",
            "timestamp": 1661657182,
            "clubs": {
              "79718": {
                "passa": "79",
                "passc": "58",
                "ppg": "0",
                "ppo": "0",
                "shots": "15",
                "toa": "252",
                "details": {
                  "name": "NZHL Memphis Make A Wish",
                  "clubId": 79718
                }
              }
            },
            "players": {
              "145078": {
                "169580763": {
                  "glbrksavepct": "0.00",
                  "glbrksaves": "0",
                  "glbrkshots": "0",
                  "gldsaves": "0",
                  "glga": "0",
                  "glgaa": "0.00",
                  "glpensavepct": "0.00",
                  "glpensaves": "0",
                  "glpenshots": "0",
                  "glpkclearzone": "0",
                  "glpokechecks": "0",
                  "glsavepct": "0.00",
                  "glsaves": "0",
                  "glshots": "0",
                  "glsoperiods": "0",
                  "opponentClubId": "79718",
                  "position": "rightWing",
                  "posSorted": "3",
                  "ratingDefense": "55.00",
                  "ratingOffense": "85.00",
                  "ratingTeamplay": "70.00",
                  "skassists": "0",
                  "skbs": "0",
                  "skdeflections": "0",
                  "skfol": "0",
                  "skfopct": "0.00",
                  "skfow": "0",
                  "skgiveaways": "4",
                  "skgoals": "2",
                  "skgwg": "0",
                  "skhits": "1",
                  "skinterceptions": "3",
                  "skpassattempts": "11",
                  "skpasses": "7",
                  "skpasspct": "63.64",
                  "skpenaltiesdrawn": "1",
                  "skpim": "0",
                  "skpkclearzone": "0",
                  "skplusmin": "-5",
                  "skpossession": "106",
                  "skppg": "1",
                  "sksaucerpasses": "0",
                  "skshg": "0",
                  "skshotattempts": "12",
                  "skshotonnetpct": "66.67",
                  "skshotpct": "25.00",
                  "skshots": "8",
                  "sktakeaways": "0",
                  "toiseconds": "3600",
                  "playername": "Ababo"
                }
              }
            }
          }
        ]
      }
    ],
    "identifier": 73522843
  },
  {
    "context": [
      "How do I use `jq` to transform the following json:\n\n...into a list of all pages \u2013 and with \"blocks\" contained in parenthesis.",
      "I figured it out, but if there's a better way let me know and I'll mark that as the accepted answer. \n\n```jq\ndef b($path):\n  [ $path[], \"(\\(.title?))\" ]\n  ;\ndef n($path):\n  ($path + [.text]) as $path\n  | $path, \n  if has (\"blocks\") then .blocks.block?[]? | b($path) else empty end,\n  if has (\"children\") then .children.node?[]? | n($path) else empty end\n  ;\n.sitemap.tree.node[] | n([])\n```",
      "Here's one way:\n~~~\ndef nodes:\n  .node[] | [.text] + (\n    [],\n    (.blocks.block[]? | [\"(\\(.title))\"]),\n    (.children | nodes?)\n  );\n\n[.sitemap.tree | nodes]\n~~~"
    ],
    "utterance": "Produce a list of all page paths in the sitemap tree, including each block title in parentheses as a separate path segment at the appropriate level.",
    "expressions": [
      "def b($path):\n  [ $path[], \"(\\(.title?))\" ]\n  ;\ndef n($path):\n  ($path + [.text]) as $path\n  | $path, \n  if has (\"blocks\") then .blocks.block?[]? | b($path) else empty end,\n  if has (\"children\") then .children.node?[]? | n($path) else empty end\n  ;\n.sitemap.tree.node[] | n([])",
      "def nodes:\n  .node[] | [.text] + (\n    [],\n    (.blocks.block[]? | [\"(\\(.title))\"]),\n    (.children | nodes?)\n  );\n\n[.sitemap.tree | nodes]"
    ],
    "data": [
      {
        "input": {
          "sitemap": {
            "tree": {
              "node": [
                {
                  "text": "Main",
                  "blocks": {
                    "block": [
                      {
                        "title": "Header"
                      },
                      {
                        "title": "General"
                      },
                      {
                        "title": "Message"
                      },
                      {
                        "title": "Daily"
                      },
                      {
                        "title": "Recognition"
                      },
                      {
                        "title": "Policies"
                      }
                    ]
                  },
                  "children": {
                    "node": [
                      {
                        "text": "Hub",
                        "blocks": null,
                        "children": {
                          "node": [
                            {
                              "text": "Handbook",
                              "blocks": null,
                              "children": null
                            },
                            {
                              "text": "Jobs",
                              "blocks": null,
                              "children": null
                            },
                            {
                              "text": "Perks",
                              "blocks": null,
                              "children": null
                            },
                            {
                              "text": "Benefits",
                              "blocks": null,
                              "children": null
                            }
                          ]
                        }
                      },
                      {
                        "text": "Resources",
                        "blocks": null,
                        "children": {
                          "node": [
                            {
                              "text": "Forms",
                              "blocks": null,
                              "children": null
                            },
                            {
                              "text": "Procedures",
                              "blocks": null,
                              "children": null
                            },
                            {
                              "text": "Training",
                              "blocks": null,
                              "children": null
                            },
                            {
                              "text": "Scripts",
                              "blocks": null,
                              "children": null
                            },
                            {
                              "text": "Marketing",
                              "blocks": null,
                              "children": {
                                "node": [
                                  {
                                    "text": "Logos",
                                    "blocks": null,
                                    "children": null
                                  },
                                  {
                                    "text": "Brochures",
                                    "blocks": null,
                                    "children": null
                                  },
                                  {
                                    "text": "Signage",
                                    "blocks": null,
                                    "children": null
                                  }
                                ]
                              }
                            },
                            {
                              "text": "Tips & Tricks",
                              "blocks": null,
                              "children": null
                            }
                          ]
                        }
                      },
                      {
                        "text": "About",
                        "blocks": null,
                        "children": {
                          "node": [
                            {
                              "text": "Strategy",
                              "blocks": null,
                              "children": null
                            }
                          ]
                        }
                      }
                    ]
                  }
                },
                {
                  "text": "Search",
                  "blocks": null,
                  "children": null
                },
                {
                  "text": "Logins",
                  "blocks": null,
                  "children": {
                    "node": [
                      {
                        "text": "One",
                        "blocks": null,
                        "children": null
                      },
                      {
                        "text": "Two",
                        "blocks": null,
                        "children": null
                      }
                    ]
                  }
                }
              ]
            }
          }
        },
        "output": [
          [
            "Main"
          ],
          [
            "Main",
            "(Header)"
          ],
          [
            "Main",
            "(General)"
          ],
          [
            "Main",
            "(Message)"
          ],
          [
            "Main",
            "(Daily)"
          ],
          [
            "Main",
            "(Recognition)"
          ],
          [
            "Main",
            "(Policies)"
          ],
          [
            "Main",
            "Hub"
          ],
          [
            "Main",
            "Hub",
            "Handbook"
          ],
          [
            "Main",
            "Hub",
            "Jobs"
          ],
          [
            "Main",
            "Hub",
            "Perks"
          ],
          [
            "Main",
            "Hub",
            "Benefits"
          ],
          [
            "Main",
            "Resources"
          ],
          [
            "Main",
            "Resources",
            "Forms"
          ],
          [
            "Main",
            "Resources",
            "Procedures"
          ],
          [
            "Main",
            "Resources",
            "Training"
          ],
          [
            "Main",
            "Resources",
            "Scripts"
          ],
          [
            "Main",
            "Resources",
            "Marketing"
          ],
          [
            "Main",
            "Resources",
            "Marketing",
            "Logos"
          ],
          [
            "Main",
            "Resources",
            "Marketing",
            "Brochures"
          ],
          [
            "Main",
            "Resources",
            "Marketing",
            "Signage"
          ],
          [
            "Main",
            "Resources",
            "Tips & Tricks"
          ],
          [
            "Main",
            "About"
          ],
          [
            "Main",
            "About",
            "Strategy"
          ],
          [
            "Search"
          ],
          [
            "Logins"
          ],
          [
            "Logins",
            "One"
          ],
          [
            "Logins",
            "Two"
          ]
        ]
      }
    ],
    "identifier": 73874066
  }
]