[
  {
    "context": [
      "Is it possible to transform this JSON\n```\necho -e '{\"a\": [[1,7],[2,6]],\"b\": [[1,3],[3,4]]}' | jq ...\n```\nIn to this\n```\nk, a, b\n1, 7, 3\n2, 6, -\n3, -, 4\n```\nSpecifically the first column is the join key.",
      "Do it manually, and collect and iterate through columns and rows (using `jq -r`):\n```\nkeys_unsorted as $cols | .[] |= INDEX(first) | [\"k\"] + $cols, (\n  (map(keys[]) | unique)[] as $row\n  | [$row, $cols[] as $col | .[$col][$row][1] // \"-\"]\n)\n| join(\", \")  # or | @csv\n```\n```\nk, a, b\n1, 7, 3\n2, 6, -\n3, -, 4\n```\n"
    ],
    "utterance": "Produce a table where each unique first element from the subarrays is a row labeled as 'k', and for each key ('a', 'b'), the corresponding second elements are shown in their respective columns, filling in '-' if not present.",
    "expressions": [
      "keys_unsorted as $cols | .[] |= INDEX(first) | [\"k\"] + $cols, (\n  (map(keys[]) | unique)[] as $row\n  | [$row, $cols[] as $col | .[$col][$row][1] // \"-\"]\n)\n| join(\", \")"
    ],
    "data": [
      {
        "input": {
          "a": [
            [
              1,
              7
            ],
            [
              2,
              6
            ]
          ],
          "b": [
            [
              1,
              3
            ],
            [
              3,
              4
            ]
          ]
        },
        "output": "k, a, b\n1, 7, 3\n2, 6, -\n3, -, 4"
      }
    ],
    "identifier": 75828901
  },
  {
    "context": [
      "Essentially, in the JSON that I&#39;m trying to query, the relevant values for me are inside an array whose key is a domain **twitter.com**. This is a user input hence, I&#39;m unaware of how to variably check for that input every time so it would be best if I could automatically be able to get the data inside the array.",
      "If all you want to do is extract the first item of each array property (regardless of name), the following should work:",
      "```\n.[]|first\n```",
      "Or you want all nested array elements as stream, not only the first one?\n\n```\n.[][]\n```",
      "Or are you really asking for how to pass variables to jq?\n\n```\njq --arg domain twitter.com '.[$domain][]'\n```",
      "The output \u2013 for your given sample input \u2013 regardless of which option you choose, will be:\n\n```json\n{\n  \"source_type\": \"Search\",\n  \"visits\": [\n    {\n      \"date\": \"2023-01-01\",\n      \"organic\": 277102097.489145,\n      \"paid\": 84057.14235268807\n    },\n    {\n      \"date\": \"2023-02-01\",\n      \"organic\": 251621802.6924125,\n      \"paid\": 71498.10105463082\n    }\n  ]\n}\n```"
    ],
    "utterance": "Extract the first element from each domain property, regardless of the property name, where the domain is not known in advance.",
    "expressions": [
      ".[] | first",
      ".[][]"
    ],
    "data": [
      {
        "input": {
          "twitter.com": [
            {
              "source_type": "Search",
              "visits": [
                {
                  "date": "2023-01-01",
                  "organic": 277102097.489145,
                  "paid": 84057.14235268807
                },
                {
                  "date": "2023-02-01",
                  "organic": 251621802.6924125,
                  "paid": 71498.10105463082
                }
              ]
            }
          ]
        },
        "output": {
          "source_type": "Search",
          "visits": [
            {
              "date": "2023-01-01",
              "organic": 277102097.489145,
              "paid": 84057.14235268807
            },
            {
              "date": "2023-02-01",
              "organic": 251621802.6924125,
              "paid": 71498.10105463082
            }
          ]
        }
      }
    ],
    "identifier": 75826964
  },
  {
    "context": [
      "but I want to pull `actualValue` from these two sets and store them in var1 and var2",
      "```\nnew_coverage\nnew_duplicated_lines_density\n```",
      "I want to store the response in two vars. \n```\nvar1 = \"59.42028985507246\" and var2 = \"18.823529411764707\"\n```",
      "jq -r '.projectStatus.conditions[]|select(.metricKey==\"new_coverage\").actualValue'",
      "jq -r '.projectStatus.conditions[]|select(.metricKey==\"new_duplicated_lines_density\").actualValue'"
    ],
    "utterance": "Get the actualValue for the metricKeys new_coverage and new_duplicated_lines_density.",
    "expressions": [
      ".projectStatus.conditions[] | select(.metricKey==\"new_coverage\").actualValue",
      ".projectStatus.conditions[] | select(.metricKey==\"new_duplicated_lines_density\").actualValue"
    ],
    "data": [
      {
        "input": {
          "status": "ERROR",
          "conditions": [
            {
              "status": "OK",
              "metricKey": "new_reliability_rating",
              "comparator": "GT",
              "periodIndex": 1,
              "errorThreshold": "1",
              "actualValue": "1"
            },
            {
              "status": "OK",
              "metricKey": "new_security_rating",
              "comparator": "GT",
              "periodIndex": 1,
              "errorThreshold": "1",
              "actualValue": "1"
            },
            {
              "status": "OK",
              "metricKey": "new_maintainability_rating",
              "comparator": "GT",
              "periodIndex": 1,
              "errorThreshold": "1",
              "actualValue": "1"
            },
            {
              "status": "ERROR",
              "metricKey": "new_coverage",
              "comparator": "LT",
              "periodIndex": 1,
              "errorThreshold": "80",
              "actualValue": "59.42028985507246"
            },
            {
              "status": "ERROR",
              "metricKey": "new_duplicated_lines_density",
              "comparator": "GT",
              "periodIndex": 1,
              "errorThreshold": "3",
              "actualValue": "18.823529411764707"
            }
          ],
          "periods": [],
          "ignoredConditions": false
        },
        "output": [
          "59.42028985507246",
          "18.823529411764707"
        ]
      }
    ],
    "identifier": 75818735
  },
  {
    "context": [
      "I&#39;m trying to parse some json field which contains a semantic version. I&#39;m trying the semver regex for that from the [semver site](https://semver.org/#is-there-a-suggested-regular-expression-regex-to-check-a-semver-string).",
      "How could I do this in jq:\r\n\r\n    match(^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$\r\n    )",
      "Consider passing your regex as an [`--arg`][1] to [tag:JQ], this will keeps quoting simple, and prevents your filter from becoming unreadable:",
      "$ jq --arg regex \"$regex\" 'match($regex)' <<< '\"1.0.0-beta\"'\r\n{\r\n  \"offset\": 0,\r\n  \"length\": 10,\r\n  \"string\": \"1.0.0-beta\",\r\n  \"captures\": [ ... ]\r\n}"
    ],
    "utterance": "Match a string field that contains a semantic version according to the official semver regex.",
    "expressions": [
      "match(\"^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)(?:-((?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\\+([0-9a-zA-Z-]+(?:\\.[0-9a-zA-Z-]+)*))?$\")"
    ],
    "data": [
      {
        "input": "1.0.0-beta",
        "output": {
          "offset": 0,
          "length": 10,
          "string": "1.0.0-beta",
          "captures": [
            {
              "offset": 0,
              "length": 1,
              "string": "1",
              "name": null
            },
            {
              "offset": 2,
              "length": 1,
              "string": "0",
              "name": null
            },
            {
              "offset": 4,
              "length": 1,
              "string": "0",
              "name": null
            },
            {
              "offset": 6,
              "length": 4,
              "string": "beta",
              "name": null
            },
            {
              "offset": -1,
              "string": null,
              "length": 0,
              "name": null
            }
          ]
        }
      }
    ],
    "identifier": 75825023
  },
  {
    "identifier": 75841437
  },
  {
    "context": [
      "Now I want a list of pod names that have a sidecar of `proxyv2:old-version`.",
      "But I just can't find the right query.",
      "You want to use `all(\u2026 | not)` or `any(\u2026) | not` instead:",
      "But maybe the better solution is checking your condition with `any` and `all`:"
    ],
    "utterance": "Get the names of pods whose containers include an image matching '^some-registry/istio/proxyv2:' and all such images do not end with ':old-version'.",
    "expressions": [
      ".items[] | select(.spec.containers[].image | test(\"^some-registry/istio/proxyv2:\")) | select(all(.spec.containers[].image; test(\":old-version$\") | not)) | .metadata.name",
      ".items[] | select(.spec.containers[].image | test(\"^some-registry/istio/proxyv2:\")) | select(any(.spec.containers[].image; test(\":old-version$\") ) | not) | .metadata.name",
      ".items[] | select( .spec.containers | map(.image) | any(test(\"^some-registry/istio/proxyv2:\")) and all(test(\":old-version$\")|not) ) | .metadata.name"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "app"
              },
              "spec": {
                "containers": [
                  {
                    "image": "some-registry/istio/proxyv2:new-version",
                    "name": "istio-proxy"
                  },
                  {
                    "image": "some-registry/app/app:latest",
                    "name": "app"
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "another-app"
              },
              "spec": {
                "containers": [
                  {
                    "image": "some-registry/istio/proxyv2:old-version",
                    "name": "istio-proxy"
                  },
                  {
                    "image": "some-registry/another-app/another-app:latest",
                    "name": "another-app"
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "no-sidecar-app"
              },
              "spec": {
                "containers": [
                  {
                    "image": "some-registry/no-sidecar-app/no-sidecar-app:latest",
                    "name": "no-sidecar-app"
                  }
                ]
              }
            }
          ]
        },
        "output": [
          "app"
        ]
      }
    ],
    "identifier": 75835297
  },
  {
    "context": [
      "I have this data:",
      "And I want it as such:",
      "So basically\n`map {(.[0][..]) : [:1][..]})` - I want to create a mapping between an entry in `.[0]` and it's respective entry in  the remaining `[:..]`",
      "jq '[0] as $cols \n| .[1:] \n| map(. as $row \n  | $cols   \n  | with_entries({ \"key\": .value,\"value\": $row[.key]}) \n)'",
      "Zipping manually by storing the keys into a variable, then assigning them on the fly:\n```sh\n.[0] as $keys | .[1:] | map(with_entries(.key |= $keys[.]))\n```",
      "Results:\n\n[\n  {\"USER\": \"lava1\",\"TTY\": \"pts/0\",\"FROM\": \"157.48.149.102\",\"LOGIN@\": \"05:03\",\"IDLE\": \"31.00s\",\"JCPU\": \"0.31s\",\"PCPU\": \"0.31s\",\"WHAT\": \"-bash\"},\n  {\"USER\": \"azureuse\",\"TTY\": \"pts/1\",\"FROM\": \"157.48.149.102\",\"LOGIN@\": \"07:26\",\"IDLE\": \"0.00s\",\"JCPU\": \"0.07s\",\"PCPU\": \"0.05s\",\"WHAT\": \"w\"}\n]\n"
    ],
    "utterance": "Convert an array where the first subarray contains column names and the rest are data rows, into an array of objects mapping column names to their corresponding data values for each row.",
    "expressions": [
      ".[0] as $cols | .[1:] | map(. as $row | $cols | with_entries({ \"key\": .value, \"value\": $row[.key] }))",
      ".[0] as $keys | .[1:] | map(with_entries(.key |= $keys[.]))"
    ],
    "data": [
      {
        "input": [
          [
            "USER",
            "TTY",
            "FROM",
            "LOGIN@",
            "IDLE",
            "JCPU",
            "PCPU",
            "WHAT"
          ],
          [
            "lava1",
            "pts/0",
            "157.48.149.102",
            "05:03",
            "31.00s",
            "0.31s",
            "0.31s",
            "-bash"
          ],
          [
            "azureuse",
            "pts/1",
            "157.48.149.102",
            "07:26",
            "0.00s",
            "0.07s",
            "0.05s",
            "w"
          ]
        ],
        "output": [
          {
            "USER": "lava1",
            "TTY": "pts/0",
            "FROM": "157.48.149.102",
            "LOGIN@": "05:03",
            "IDLE": "31.00s",
            "JCPU": "0.31s",
            "PCPU": "0.31s",
            "WHAT": "-bash"
          },
          {
            "USER": "azureuse",
            "TTY": "pts/1",
            "FROM": "157.48.149.102",
            "LOGIN@": "07:26",
            "IDLE": "0.00s",
            "JCPU": "0.07s",
            "PCPU": "0.05s",
            "WHAT": "w"
          }
        ]
      }
    ],
    "identifier": 75828341
  },
  {
    "context": [
      "But what I want is:\r\n[\r\n  [\r\n    \"USER\",\r\n    \"TTY\",\r\n    \"FROM\",\r\n    \"LOGIN@\",\r\n    \"IDLE\",\r\n    \"JCPU\",\r\n    \"PCPU\",\r\n    \"WHAT\"\r\n  ],\r\n  [\r\n    \"lava1\",\r\n    \"pts/0\",\r\n    \"157.48.149.102\",\r\n    \"05:03\",\r\n    \"31.00s\",\r\n    \"0.31s\",\r\n    \"0.31s\",\r\n    \"-bash\"\r\n  ],\r\n  [\r\n    \"azureuse\",\r\n    \"pts/1\",\r\n    \"157.48.149.102\",\r\n    \"07:26\",\r\n    \"0.00s\",\r\n    \"0.07s\",\r\n    \"0.05s\",\r\n    \"w\"\r\n  ]\r\n]",
      "How can I merge these array in a jq expression instead of passing it to another jq process and slurping it?",
      "jq -s .",
      "jq '[ inputs ]'",
      "jq -s '.' *.json"
    ],
    "utterance": "Combine several array documents into a single array, so each original array becomes an element in the new array, using a single command without chaining multiple invocations.",
    "expressions": [
      "jq -s .",
      "jq '[inputs]'",
      "jq -s '.' *.json"
    ],
    "data": [
      {
        "input": [
          [
            "USER",
            "TTY",
            "FROM",
            "LOGIN@",
            "IDLE",
            "JCPU",
            "PCPU",
            "WHAT"
          ],
          [
            "lava1",
            "pts/0",
            "157.48.149.102",
            "05:03",
            "31.00s",
            "0.31s",
            "0.31s",
            "-bash"
          ],
          [
            "azureuse",
            "pts/1",
            "157.48.149.102",
            "07:26",
            "0.00s",
            "0.07s",
            "0.05s",
            "w"
          ]
        ],
        "output": [
          [
            "USER",
            "TTY",
            "FROM",
            "LOGIN@",
            "IDLE",
            "JCPU",
            "PCPU",
            "WHAT"
          ],
          [
            "lava1",
            "pts/0",
            "157.48.149.102",
            "05:03",
            "31.00s",
            "0.31s",
            "0.31s",
            "-bash"
          ],
          [
            "azureuse",
            "pts/1",
            "157.48.149.102",
            "07:26",
            "0.00s",
            "0.07s",
            "0.05s",
            "w"
          ]
        ]
      }
    ],
    "identifier": 75837215
  },
  {
    "context": [
      "I would like to return the `tab_id`s of the first object whose `pane_id` field matches the value of an environment variable.",
      "I am also interested in returning the `tab_id` of only the first match",
      "So in this case, if my environment variable is 2, I need the `tab_id` value of the object whose `pane_id` is 2, that is `0`",
      "$ jq --argjson id \"$q\" 'first(.[] | select(.pane_id == $id).tab_id)' input.json",
      "0"
    ],
    "utterance": "Return the tab_id of the first object where pane_id equals a specified variable, such as 2.",
    "expressions": [
      "first(.[] | select(.pane_id == $id).tab_id)"
    ],
    "data": [
      {
        "input": [
          {
            "tab_id": 0,
            "pane_id": 0
          },
          {
            "tab_id": 0,
            "pane_id": 1
          },
          {
            "tab_id": 0,
            "pane_id": 2
          },
          {
            "tab_id": 1,
            "pane_id": 3
          },
          {
            "tab_id": 2,
            "pane_id": 4
          }
        ],
        "output": 0
      }
    ],
    "identifier": 75842391
  },
  {
    "context": [
      "Given a JSON:",
      "And a string constant: `test.internal.example.com.`.",
      "I want to select array items where the string constant ends with the `.Name` value, resulting in this output:",
      "[",
      "    {",
      "        \"Id\": \"/hostedzone/AAAA\",",
      "        \"Name\": \"example.com.\"",
      "    },",
      "    {",
      "        \"Id\": \"/hostedzone/CCCC\",",
      "        \"Name\": \"internal.example.com.\"",
      "    }",
      "]",
      "You have to switch the context between the item and your constant (`endswith` requires the full string as input, and the partial string as argument).",
      "jq --arg myconst \"test.internal.example.com.\" '\n  .HostedZones | map(select(.Name as $name | $myconst | endswith($name)))\n'"
    ],
    "utterance": "Select HostedZones array entries whose Name value is a suffix of the string 'test.internal.example.com.'.",
    "expressions": [
      ".HostedZones | map(select(.Name as $name | $myconst | endswith($name)))"
    ],
    "data": [
      {
        "input": {
          "HostedZones": [
            {
              "Id": "/hostedzone/AAAA",
              "Name": "example.com."
            },
            {
              "Id": "/hostedzone/BBBB",
              "Name": "local."
            },
            {
              "Id": "/hostedzone/CCCC",
              "Name": "internal.example.com."
            },
            {
              "Id": "/hostedzone/DDDD",
              "Name": "public.example.com."
            }
          ]
        },
        "output": [
          {
            "Id": "/hostedzone/AAAA",
            "Name": "example.com."
          },
          {
            "Id": "/hostedzone/CCCC",
            "Name": "internal.example.com."
          }
        ]
      }
    ],
    "identifier": 75842788
  },
  {
    "context": [
      "And, if I supply this JQ, I get the results I want:",
      "but I am pretty sure it's more verbose/less optimal than it can be because I do 2 splits and then have to filter out the empty arrays I get.",
      "\"How can I reduce this JQ expression and command to its bare minimum?\"",
      "Here you go, run it with the `-R` flag only:",
      "def s: [splits(\" +\")];\n[s as $k | inputs | [$k, s] | transpose | map({(.[0]): .[1]}) | add]",
      "[Online demo](https://jqplay.org/s/Sq645_nIB4D)"
    ],
    "utterance": "Transform space-delimited columnar data with a header row into an array of objects using the header fields as keys and the corresponding row values as values.",
    "expressions": [
      "def s: [splits(\" +\")];\n[s as $k | inputs | [$k, s] | transpose | map({(.[0]): .[1]}) | add]"
    ],
    "data": [
      {
        "input": "USER     TTY      FROM             LOGIN@   IDLE   JCPU   PCPU WHAT\nlava1    pts/0    157.48.149.102   05:03   31.00s  0.31s  0.31s -bash\nazureuse pts/1    157.48.149.102   07:26    0.00s  0.07s  0.05s w",
        "output": [
          {
            "USER": "lava1",
            "TTY": "pts/0",
            "FROM": "157.48.149.102",
            "LOGIN@": "05:03",
            "IDLE": "31.00s",
            "JCPU": "0.31s",
            "PCPU": "0.31s",
            "WHAT": "-bash"
          },
          {
            "USER": "azureuse",
            "TTY": "pts/1",
            "FROM": "157.48.149.102",
            "LOGIN@": "07:26",
            "IDLE": "0.00s",
            "JCPU": "0.07s",
            "PCPU": "0.05s",
            "WHAT": "w"
          }
        ]
      }
    ],
    "identifier": 75839056
  },
  {
    "context": [
      "Why not round in jq directly?",
      "```\r\n.actualValue | tonumber*100 | round/100\r\n```",
      "Referencing [this answer](https://stackoverflow.com/questions/74152553/jq-round-number-to-two-decimal-places) as mentioned by [ChrisB](https://stackoverflow.com/users/7204912/chrisb) already, rounding in `jq` is pretty simple - just a matter of using a multiple with the right number of zeroes, rounding, then dividing by the same number.",
      "```\r\n$: echo '{ \"a\": { \"b\": 123.456, \"c\": .54321 } }'|jq '.a.b*100|round/100'\r\n123.46\r\n```"
    ],
    "utterance": "Get the value of the field 'actualValue' for the object where 'metricKey' equals 'new_coverage', rounded to two decimal places.",
    "expressions": [
      "select(.metricKey==\"new_coverage\").actualValue | tonumber*100 | round/100"
    ],
    "data": [
      {
        "input": [
          {
            "status": "OK",
            "metricKey": "new_reliability_rating",
            "comparator": "GT",
            "periodIndex": 1,
            "errorThreshold": "1",
            "actualValue": "1"
          },
          {
            "status": "OK",
            "metricKey": "new_security_rating",
            "comparator": "GT",
            "periodIndex": 1,
            "errorThreshold": "1",
            "actualValue": "1"
          },
          {
            "status": "OK",
            "metricKey": "new_maintainability_rating",
            "comparator": "GT",
            "periodIndex": 1,
            "errorThreshold": "1",
            "actualValue": "1"
          },
          {
            "status": "ERROR",
            "metricKey": "new_coverage",
            "comparator": "LT",
            "periodIndex": 1,
            "errorThreshold": "80",
            "actualValue": "59.42028985507246"
          },
          {
            "status": "ERROR",
            "metricKey": "new_duplicated_lines_density",
            "comparator": "GT",
            "periodIndex": 1,
            "errorThreshold": "3",
            "actualValue": "18.823529411764707"
          }
        ],
        "output": 59.42
      }
    ],
    "identifier": 75826462
  },
  {
    "context": [
      "Second, `jq` is strongly typed; values passed in via `--arg` come in as strings (whether you put quotes around them in the shell or not), and you can't do arithmetic on strings.",
      "You could explicitly convert to a number, like so:\n\n    jq --arg PS \"$Port\" '$PS|tonumber as $P1| do math with $P1'",
      "Or you could use `--argjson` instead of `--arg`, which tells `jq` to parse the argument as JSON and therefore interpret a numeric string without any _literal_ quotation marks around it as an integer (again, shell quotes don't change anything):\n\n    jq --argjson P1 \"$Port\" 'do math with $P1'",
      "which you then pass to `jq` like this to preserve the separation:\n\n    jq \"${Args[@]}\" ...",
      "Third, you're doing this in your `jq` query expression:\n\n    { \"$S\": ...\n\nAnd that doesn't do what you think it does: an object key in quotation marks is just a literal string; \"$S\" is just a two-character key consiting of a dollar sign and an S, with no relation to the argument variable named `$S`. To use a nonliteral value as the key, you need to lose the quotes and put it in parentheses:\n\n    { ($S): ...",
      "      jq -n \\\n      --arg srv \"$srv\" \\\n      --argjson port \"$port\" \\\n      --arg PubIP \"$ip\" \\\n      --arg Node \"$name\" \\\n      '{($srv): [{$Node,$PubIP,Port1:$port,Port2:($port-1),Port3:($port+2)}]}'"
    ],
    "utterance": "Create an object keyed by a shell variable, whose value is an array containing an object with specified fields and ports derived by arithmetic on a numeric argument.",
    "expressions": [
      "{ ($S): [{Node: $Node, PubIP: $IP, Port1: $P1, Port2: ($P1-1), Port3: ($P1+2)}] }",
      "{ ($srv): [{Node: $Node, PubIP: $PubIP, Port1: $port, Port2: ($port-1), Port3: ($port+2)}] }"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "Comp1": [
            {
              "Node": "C1VM1",
              "PubIP": "1.2.3.4",
              "Port1": 1050,
              "Port2": 1049,
              "Port3": 1052
            }
          ]
        }
      }
    ],
    "identifier": 75843970
  },
  {
    "context": [
      "I am looking for the key to get values.",
      "I can't use `metadata.labels.beta.kubernetes.io/arch` as key, since the correct syntax is `metadata.labels[\"beta.kubernetes.io/arch\"]`.",
      "Is there an automated way to get the keys of a yaml file so that I can use the keys in `yq` (or `jq`)?",
      "The desired output would be something like this:\n\napiVersion = v1\nkind = Node\nmetadata.name = host-cluster-control-plane-64j47\nmetadata.labels[\"beta.kubernetes.io/arch\"] = amd64",
      "echo '\napiVersion: v1\nkind: Node\nmetadata:\n  labels:\n    beta.kubernetes.io/arch: amd64\n' | yq -o=json | jq '\n.metadata.labels = (\n  [.metadata.labels|to_entries[]\n  | {key: .key|gsub(\"[.]\";\"\\t\"), value}\n  ]\n  |from_entries)' | yq -o=p | sed -Ee 's@\\t@\\.@g'"
    ],
    "utterance": "List all key paths and values in which keys containing dots are represented with bracket and quote notation, such as metadata.labels[\"beta.kubernetes.io/arch\"] = amd64.",
    "expressions": [
      ".metadata.labels = ([.metadata.labels|to_entries[] | {key: .key|gsub(\"[.]\";\"\\t\"), value}] |from_entries)"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "kind": "Node",
          "metadata": {
            "name": "host-cluster-control-plane-64j47",
            "labels": {
              "beta.kubernetes.io/arch": "amd64"
            }
          }
        },
        "output": [
          "apiVersion = v1",
          "kind = Node",
          "metadata.name = host-cluster-control-plane-64j47",
          "metadata.labels[\"beta.kubernetes.io/arch\"] = amd64"
        ]
      }
    ],
    "identifier": 75838393
  },
  {
    "context": [
      "given a variable nested json, I would like to filter based on two select functions and return an array of values matching a key.",
      "Is it possible when the recursion between say \"dog\" and \"breed\" is unknown and different for multiple branches, but \"breed is always a child/grandchild of \"dog\" in the same json?",
      "//should return [\"one\",\"two\"]",
      "[ getpath(paths | select(.[-1] == \"breed\" and index(\"dog\"))) ]",
      "[.. | objects | .dog | .. | objects | .breed // empty]",
      "[.. | .dog? | .. | .breed? // empty]"
    ],
    "utterance": "Find all values of 'breed' that appear anywhere beneath a 'dog' key at unknown nesting levels.",
    "expressions": [
      "[ getpath(paths | select(.[-1] == \"breed\" and index(\"dog\"))) ]",
      "[.. | objects | .dog | .. | objects | .breed // empty]",
      "[.. | .dog? | .. | .breed? // empty]"
    ],
    "data": [
      {
        "input": {
          "alpha": {
            "this": {
              "dog": {
                "breed": "one",
                "colors": {
                  "eyes": "blue"
                }
              }
            }
          },
          "beta": {
            "dog": {
              "crazy": {
                "world": {
                  "breed": "two",
                  "colors": {
                    "eyes": "blue"
                  }
                }
              }
            }
          },
          "charlie": {
            "format": {
              "bird": {
                "boat": {
                  "breed": "three",
                  "colors": {
                    "eyes": "blue"
                  }
                }
              }
            }
          }
        },
        "output": [
          "one",
          "two"
        ]
      }
    ],
    "identifier": 75868249
  },
  {
    "context": [
      "I have the following CSV (truncated):\r\n\r\n```\r\n\"adfebb\",\"a-f-A-M-F-R-Z\",\"95-00123\",\"C560\",\"USAF\"\r\n\"ae0133\",\"a-f-A-M-F-R-Z\",\"97-00102\",\"C560\",\"USAF\"\r\n```\r\n\r\nI need the following JSON:\r\n```\r\n{\r\n    \"adfebb\":[\"a-f-A-M-F-R-Z\",\"95-00123\",\"C560\",\"USAF\"],\r\n    \"ae0133\":[\"a-f-A-M-F-R-Z\",\"97-00102\",\"C560\",\"USAF\"]\r\n}\r\n```",
      "jq -R '[split(\",\")[] | fromjson] |\r\n       [{key: .[0], value: .[1:]}] |\r\n       from_entries' tmp.csv | jq -s 'add'",
      "jq -nR 'reduce (inputs / \",\" | map(fromjson)) as $i ({}; .[$i[0]] = $i[1:])'"
    ],
    "utterance": "Convert a CSV file where each line has quoted values into an object mapping the first value to an array of the remaining values for each row.",
    "expressions": [
      "[split(\",\")[] | fromjson] | [{key: .[0], value: .[1:]}] | from_entries",
      "reduce (inputs / \",\" | map(fromjson)) as $i ({}; .[$i[0]] = $i[1:])"
    ],
    "data": [
      {
        "input": "\"adfebb\",\"a-f-A-M-F-R-Z\",\"95-00123\",\"C560\",\"USAF\"\n\"ae0133\",\"a-f-A-M-F-R-Z\",\"97-00102\",\"C560\",\"USAF\"",
        "output": {
          "adfebb": [
            "a-f-A-M-F-R-Z",
            "95-00123",
            "C560",
            "USAF"
          ],
          "ae0133": [
            "a-f-A-M-F-R-Z",
            "97-00102",
            "C560",
            "USAF"
          ]
        }
      }
    ],
    "identifier": 75870480
  },
  {
    "context": [
      "I am trying to extract \"ip_address\" information from json, but after several failed attempts, I still cannot understand what I am doing wrong.",
      "I was expecting to extract the \"ip_address\" from this json but failed.",
      "The value under `.\"External gateway info\"` is JSON encoded. Decode it using `fromjson`. Using the error suppression operator `?` in combination handles the cases where the key is missing.",
      "jq -r '[].\"External gateway info\" | fromjson? | .external_fixed_ips[].ip_address'",
      "10.10.10.11",
      "10.10.10.12",
      "10.10.10.13"
    ],
    "utterance": "Extract all ip_address values nested under external_fixed_ips from each object's External gateway info field, decoding it if present and skipping if null.",
    "expressions": [
      ".[].\"External gateway info\" | fromjson? | .external_fixed_ips[].ip_address"
    ],
    "data": [
      {
        "input": [
          {
            "Status": "ACTIVE",
            "External gateway info": "{\"network_id\": \"68719cf1-xxxx\", \"enable_snat\": true, \"external_fixed_ips\": [{\"subnet_id\": \"b55dc621-xxxx\", \"ip_address\": \"10.10.10.11\"}]}",
            "Name": "xxxx",
            "Tags": "",
            "Availability zones": "xxxx",
            "Project": "xxxx",
            "State": "UP",
            "Routes": "",
            "HA": true,
            "ID": "f9f7e5b1-xxxx"
          },
          {
            "Status": "ACTIVE",
            "External gateway info": "{\"network_id\": \"68719cf1-xxxx\", \"enable_snat\": true, \"external_fixed_ips\": [{\"subnet_id\": \"b55dc621-xxxx\", \"ip_address\": \"10.10.10.12\"}]}",
            "Name": "xxxx",
            "Tags": "",
            "Availability zones": "xxxx",
            "Project": "xxxx",
            "State": "UP",
            "Routes": "",
            "HA": true,
            "ID": "fbaa19aa-xxxx"
          },
          {
            "Status": "ACTIVE",
            "External gateway info": "{\"network_id\": \"68719cf1-xxxx\", \"enable_snat\": true, \"external_fixed_ips\": [{\"subnet_id\": \"b55dc621-xxxx\", \"ip_address\": \"10.10.10.13\"}]}",
            "Name": "xxxx",
            "Tags": "",
            "Availability zones": "xxxx",
            "Project": "xxxx",
            "State": "UP",
            "Routes": "",
            "HA": true,
            "ID": "fe2abdd8-xxxx"
          },
          {
            "Status": "ACTIVE",
            "External gateway info": null,
            "Name": "xxxx",
            "Tags": "",
            "Availability zones": "xxxx",
            "Project": "xxxx",
            "State": "UP",
            "Routes": "",
            "HA": true,
            "ID": "ff29444d-xxxx"
          }
        ],
        "output": [
          "10.10.10.11",
          "10.10.10.12",
          "10.10.10.13"
        ]
      }
    ],
    "identifier": 75876622
  },
  {
    "context": [
      "But if I add .\"0\" or .0 then results in:",
      "\"jq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at \\<top-level\\>, line 1:\"",
      "\"I can run this command line:\"",
      "jq '.datasets.\"0\"' data.json",
      "\"And get this output:\"",
      "{\"0\": {\"0\": 11, \"1\": 11, \"2\": 10}, \"1\": {\"0\": 73, \"1\": 77, \"2\": 87}, \"n\": {\"0\": 1027, \"1\": 1025, \"2\": 1020}}"
    ],
    "utterance": "Access the object whose key is \"0\" inside the \"datasets\" field.",
    "expressions": [
      ".datasets.\"0\""
    ],
    "data": [
      {
        "input": {
          "datasets": {
            "0": {
              "0": {
                "0": 11,
                "1": 11,
                "2": 10
              },
              "1": {
                "0": 73,
                "1": 77,
                "2": 87
              },
              "n": {
                "0": 1027,
                "1": 1025,
                "2": 1020
              }
            },
            "1": {
              "0": {
                "0": 8,
                "1": 7,
                "2": 12
              },
              "1": {
                "0": 69,
                "1": 75,
                "2": 77
              },
              "n": {
                "0": 1026,
                "1": 1026,
                "2": 1025
              }
            },
            "99": {
              "0": {
                "0": 9,
                "1": 9,
                "2": 10
              },
              "1": {
                "0": 77,
                "1": 76,
                "2": 75
              },
              "n": {
                "0": 1010,
                "1": 1011,
                "2": 1011
              }
            }
          },
          "other_label": {}
        },
        "output": {
          "0": {
            "0": 11,
            "1": 11,
            "2": 10
          },
          "1": {
            "0": 73,
            "1": 77,
            "2": 87
          },
          "n": {
            "0": 1027,
            "1": 1025,
            "2": 1020
          }
        }
      }
    ],
    "identifier": 75877645
  },
  {
    "context": [
      "How do I get the \"deployment_id\" for only the \"stack\" which are in \"c_c\" status.",
      "Note: as the name this_key_might_not_be_known_ahead_of_time suggests, I might not know the key name",
      "You can use `.[]` to stream/iterate all values of an object, regardless of their key. You can then use the `map(select(...))` pattern to select only the interesting items from the inner array:",
      ".s[] | map(select(.stack==\"c_c\").deploymentId)"
    ],
    "utterance": "Extract deploymentId values for all items where stack equals c_c, regardless of the unpredictable outer object key name.",
    "expressions": [
      ".s[] | map(select(.stack==\"c_c\").deploymentId)"
    ],
    "data": [
      {
        "input": {
          "s": {
            "this_key_might_not_be_known_ahead_of_time": [
              {
                "service": "c",
                "stack": "c_c",
                "deploymentId": "abc"
              },
              {
                "service": "c",
                "stack": "del_in_pr",
                "deploymentId": "deg"
              }
            ]
          }
        },
        "output": [
          "abc"
        ]
      }
    ],
    "identifier": 75893357
  },
  {
    "context": [
      "Somehow I need to filter out the null permission objects, either by completely removing them or by replacing them with empty arrays.",
      "You\u2019re looking for something like this:",
      "del(.[].permissions[] | nulls)"
    ],
    "utterance": "Remove all keys in the 'permissions' objects of each policy where the value is null.",
    "expressions": [
      "del(.[].permissions[] | nulls)"
    ],
    "data": [
      {
        "input": [
          {
            "applicationId": null,
            "objectId": "0123b8ac-57a6-1234-9816-ff5swa4b6d0b",
            "permissions": {
              "certificates": [
                "Get",
                "Release"
              ],
              "keys": null,
              "secrets": null,
              "storage": null
            },
            "tenantId": "abc-123"
          },
          {
            "applicationId": null,
            "objectId": "f4340076-d4ea-1234-a719-c75dfsat4d17",
            "permissions": {
              "certificates": null,
              "keys": [
                "Get",
                "Release"
              ],
              "secrets": null,
              "storage": null
            },
            "tenantId": "abc-123"
          }
        ],
        "output": [
          {
            "applicationId": null,
            "objectId": "0123b8ac-57a6-1234-9816-ff5swa4b6d0b",
            "permissions": {
              "certificates": [
                "Get",
                "Release"
              ]
            },
            "tenantId": "abc-123"
          },
          {
            "applicationId": null,
            "objectId": "f4340076-d4ea-1234-a719-c75dfsat4d17",
            "permissions": {
              "keys": [
                "Get",
                "Release"
              ]
            },
            "tenantId": "abc-123"
          }
        ]
      }
    ],
    "identifier": 75883671
  },
  {
    "context": [
      "I am attempting to display the `content` portion on my CLI using the `raw output` flag:",
      "cat sample.json | jq -r '.choices[0].message.content'",
      "parse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 3, column 69",
      "Is there something I can pass on the command line or to `jq` to resolve this issue?"
    ],
    "utterance": "Extract the value of the content field from choices[0].message, even if it contains unescaped control characters.",
    "expressions": [
      ".choices[0].message.content"
    ],
    "data": [
      {
        "input": {
          "id": "chatcmpl-6zULJUpe6ENFKuVbsW5KWySa5oBPk",
          "object": "chat.completion",
          "created": 1680112665,
          "model": "gpt-3.5-turbo-0301",
          "usage": {
            "prompt_tokens": 29,
            "completion_tokens": 403,
            "total_tokens": 432
          },
          "choices": [
            {
              "message": {
                "role": "assistant",
                "content": "Player,Team,Position,Height,Weight,College,Salary,Points per game,Rebounds per game,Assists per game\r\nLeBron James,Los Angeles Lakers,SF,6-9,250,Louisiana State University,39.2 million,25.0,7.8,10.6\r\nNikola Jokic,Denver Nuggets,C,7-0,284,N/A,29.5 million,26.5,10.9,8.4"
              },
              "finish_reason": "stop",
              "index": 0
            }
          ]
        },
        "output": "Player,Team,Position,Height,Weight,College,Salary,Points per game,Rebounds per game,Assists per game\r\nLeBron James,Los Angeles Lakers,SF,6-9,250,Louisiana State University,39.2 million,25.0,7.8,10.6\r\nNikola Jokic,Denver Nuggets,C,7-0,284,N/A,29.5 million,26.5,10.9,8.4"
      }
    ],
    "identifier": 75880833
  },
  {
    "context": [
      "I want to search a JSON object for any key with a given name and extract the value for the first occurrence in order to assign this to a bash variable for later use.",
      "first(recurse | objects | select(has(\"name\")) .name)"
    ],
    "utterance": "Extract the value of the first occurrence of a key named 'name', regardless of its depth in the object.",
    "expressions": [
      "first(recurse | objects | select(has(\"name\")) .name)"
    ],
    "data": [
      {
        "input": {
          "fruit": {
            "name": "apple",
            "color": "green",
            "sub": {
              "name": "crab-apple",
              "color": "red",
              "size": "small"
            }
          }
        },
        "output": "apple"
      }
    ],
    "identifier": 75900326
  },
  {
    "context": [
      "I would like to select only element `id=c` because it is the *first* element, with a date greater than `id=b`'s, if you sort the elements in `xs` by their `ts` field.",
      "but I don't want to hard code the date. I want to use another select to find it:",
      "map(select(.ts > select(.id == \"b\").ts)) | first",
      "Do it in two steps, store the temporary result in a variable and use it again in the next `select()`",
      "map(select(.id == \"b\").ts) as $d | map(select(.ts > $d[])) | first"
    ],
    "utterance": "Select the first element whose 'ts' value is greater than the 'ts' of the element with id equal to 'b', after sorting by 'ts'.",
    "expressions": [
      ".xs | sort_by(.ts) | (map(select(.id == \"b\").ts) as $d | map(select(.ts > $d[])) | first)"
    ],
    "data": [
      {
        "input": {
          "xs": [
            {
              "id": "a",
              "ts": "2023-01-03"
            },
            {
              "id": "b",
              "ts": "2023-01-01"
            },
            {
              "id": "c",
              "ts": "2023-01-02"
            }
          ]
        },
        "output": {
          "id": "c",
          "ts": "2023-01-02"
        }
      }
    ],
    "identifier": 75901492
  },
  {
    "context": [
      "The data in the lines of **FILE 1** is needed in the corresponding lines of **FILE 2** which contains large complex records with one line per record. In other words, data from line 1 of FILE 1 is needed in the first record of FILE 2 (line 1), data from line 2 of FILE 1 is needed in the second record of FILE 2 (line 2), data from line 9,999,999 of FILE 1 is needed in the record on line 9,999,999 of FILE 2.",
      "**Expected output**\n```\n{\"fkey1\": \"val1\", \"fkey2\": \"value1\"}\n{\"fkey1\": \"val2\", \"fkey2\": \"value2\"}\n{\"fkey1\": \"val3\", \"fkey2\": \"value3\"}\n```",
      "The first one just cross-assigns some values for a given set of (hard-coded) keys, which directly produces your output example:\n\n```sh\n< <(paste file1.json file2.json) jq -c 'input + {fkey1:.key2, fkey2:.key1}'\n```"
    ],
    "utterance": "For each pair of corresponding lines in two files, output an object with fkey1 set to key2's value from the first file and fkey2 set to key1's value from the first file.",
    "expressions": [
      "input + {fkey1:.key2, fkey2:.key1}"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value1",
            "key2": "val1"
          },
          {
            "key1": "value2",
            "key2": "val2"
          },
          {
            "key1": "value3",
            "key2": "val3"
          }
        ],
        "output": [
          {
            "fkey1": "val1",
            "fkey2": "value1"
          },
          {
            "fkey1": "val2",
            "fkey2": "value2"
          },
          {
            "fkey1": "val3",
            "fkey2": "value3"
          }
        ]
      }
    ],
    "identifier": 75893496
  },
  {
    "context": [
      "I have a json document with a huge number objects following the above pattern. I need to create following output document using **jq**.",
      "{\r\n  \"k2\": {\r\n    \"b2\": {\r\n      \"r3\": \"k2vr3\"\r\n    }\r\n  },\r\n  \"k3\": {\r\n    \"i3\": 70,\r\n    \"b2\": {\r\n      \"r3\": \"k3vr3\"\r\n    }\r\n  }\r\n}",
      "I am able to create the output using the following jq script\r\n\r\n    map_values(select(.i2 >= 20 and .b1.p2 > 150) | {i3: .i3, b2:{r3: .b2.r3}} | map_values(select(. != null)))",
      "To avoid various inefficiencies in your program, consider replacing\r\n\r\n     {i3: .i3, b2:{r3: .b2.r3}}\r\n\r\nWith:\r\n\r\n     (((select(.i3)|{i3}) // null) + { b2: {r3: .b2.r3}} )\r\n\r\nThat would obviate the need for the second call to `map_values`"
    ],
    "utterance": "Select top-level objects where i2 >= 20 and b1.p2 > 150, and for each, output only i3 if present and b2.r3.",
    "expressions": [
      "map_values(select(.i2 >= 20 and .b1.p2 > 150) | (((select(.i3)|{i3}) // null) + { b2: {r3: .b2.r3}} ))"
    ],
    "data": [
      {
        "input": {
          "k1": {
            "i1": 11,
            "i2": 10,
            "b1": {
              "p1": 101,
              "p2": 102,
              "p3": 103
            },
            "b2": {
              "r1": "k1vr1",
              "r2": "k1vr2"
            }
          },
          "k2": {
            "i1": 21,
            "i2": 20,
            "b1": {
              "p1": 201,
              "p2": 202,
              "p3": 203
            },
            "b2": {
              "r1": "k2vr1",
              "r2": "k2vr2",
              "r3": "k2vr3"
            }
          },
          "k3": {
            "i1": 51,
            "i2": 50,
            "i3": 70,
            "b1": {
              "p1": 301,
              "p2": 302,
              "p3": 303
            },
            "b2": {
              "r1": "k3vr1",
              "r2": "k3vr2",
              "r3": "k3vr3"
            }
          }
        },
        "output": {
          "k2": {
            "b2": {
              "r3": "k2vr3"
            }
          },
          "k3": {
            "i3": 70,
            "b2": {
              "r3": "k3vr3"
            }
          }
        }
      }
    ],
    "identifier": 75914820
  },
  {
    "context": [
      "Is it possible to use a single statement to balance the depth on both sides when nesting depth is unknown? ie `car > type = 3 levels`, `plane > type = 2 levels`",
      "you could change it to `..` for arbitrary deep recursion:\n```sh\ndel(.car[], .boat[], .plane[] | select(any(..; .type == \"lion\")?))\n```"
    ],
    "utterance": "Remove all sub-objects under 'car', 'boat', and 'plane' containing an object with type equal to \"lion\", regardless of nesting depth.",
    "expressions": [
      "del(.car[], .boat[], .plane[] | select(any(..; .type == \"lion\")?))"
    ],
    "data": [
      {
        "input": {
          "www": "hello",
          "car": {
            "alpha": {
              "in": {
                "model": "alpha",
                "dir": "in",
                "type": "dog"
              },
              "out": {
                "model": "alpha",
                "dir": "out",
                "type": "dog"
              }
            },
            "delta": {
              "in": {
                "model": "delta",
                "dir": "in",
                "type": "bird"
              },
              "out": {
                "model": "delta",
                "dir": "out",
                "type": "bird"
              }
            }
          },
          "boat": {
            "beta": {
              "in": {
                "model": "beta",
                "dir": "in",
                "type": "mouse"
              }
            }
          },
          "plane": {
            "beta": {
              "model": "beta",
              "dir": "in",
              "type": "lion"
            },
            "delta": {
              "model": "delta",
              "dir": "in",
              "type": "bee"
            }
          }
        },
        "output": {
          "www": "hello",
          "car": {
            "alpha": {
              "in": {
                "model": "alpha",
                "dir": "in",
                "type": "dog"
              },
              "out": {
                "model": "alpha",
                "dir": "out",
                "type": "dog"
              }
            },
            "delta": {
              "in": {
                "model": "delta",
                "dir": "in",
                "type": "bird"
              },
              "out": {
                "model": "delta",
                "dir": "out",
                "type": "bird"
              }
            }
          },
          "boat": {
            "beta": {
              "in": {
                "model": "beta",
                "dir": "in",
                "type": "mouse"
              }
            }
          },
          "plane": {
            "delta": {
              "model": "delta",
              "dir": "in",
              "type": "bee"
            }
          }
        }
      }
    ],
    "identifier": 75918014
  },
  {
    "context": [
      "I need to transform a JSON string like below to a table for output in the terminal.",
      "I want to display in the terminal:\n\n    VulnerabilityID\tPkgName\t    Severity\tInstalledVersion\tFixedVersion\n    ---------------\t-------\t    -------\t    ----------------\t------------\n    CVE-2021-33910\tlibsystemd0\tHIGH\t    237-3ubuntu10.43\t237-3ubuntu10.49\n    CVE-2021-33910\tlibudev1\tHIGH\t    237-3ubuntu10.43\t237-3ubuntu10.49",
      "jq -r '\u2026 | @tsv' json.json | column -t  # append >> output.txt if needed",
      "[(.Results[].Vulnerabilities[] | {VulnerabilityID,PkgName,Severity,InstalledVersion,FixedVersion})] | [\"VulnerabilityID\",\"PkgName\",\"       Severity\",\"InstalledVersion\",\"FixedVersion\"], [\"---------------\",\"-------\", \"       -------\", \"----------------\",\"------------\"], (.[] | [.VulnerabilityID, .PkgName, .Severity, .InstalledVersion, .FixedVersion]) | @tsv"
    ],
    "utterance": "Extract VulnerabilityID, PkgName, Severity, InstalledVersion, and FixedVersion for all Vulnerabilities and output them as a tab-separated table with headers and dividers.",
    "expressions": [
      "[[\"VulnerabilityID\",\"PkgName\",\"Severity\",\"InstalledVersion\",\"FixedVersion\"], [\"---------------\",\"-------\",\"-------\",\"----------------\",\"------------\"], (.Results[].Vulnerabilities[] | [.VulnerabilityID, .PkgName, .Severity, .InstalledVersion, .FixedVersion])] | .[] | @tsv",
      ".Results[].Vulnerabilities[] | [.VulnerabilityID, .PkgName, .Severity, .InstalledVersion, .FixedVersion] | @tsv"
    ],
    "data": [
      {
        "input": {
          "Results": [
            {
              "Vulnerabilities": [
                {
                  "VulnerabilityID": "CVE-2021-33910",
                  "PkgName": "libsystemd0",
                  "Severity": "HIGH",
                  "InstalledVersion": "237-3ubuntu10.43",
                  "FixedVersion": "237-3ubuntu10.49"
                },
                {
                  "VulnerabilityID": "CVE-2021-33910",
                  "PkgName": "libudev1",
                  "Severity": "HIGH",
                  "InstalledVersion": "237-3ubuntu10.43",
                  "FixedVersion": "237-3ubuntu10.49"
                }
              ]
            }
          ]
        },
        "output": [
          "VulnerabilityID\tPkgName\tSeverity\tInstalledVersion\tFixedVersion",
          "---------------\t-------\t-------\t----------------\t------------",
          "CVE-2021-33910\tlibsystemd0\tHIGH\t237-3ubuntu10.43\t237-3ubuntu10.49",
          "CVE-2021-33910\tlibudev1\tHIGH\t237-3ubuntu10.43\t237-3ubuntu10.49"
        ]
      }
    ],
    "identifier": 75911544
  },
  {
    "context": [
      "I would like to add a \"reason\" field equal to the key of mapping.json whose value matches the \"origine\" field of list_values.json. Like this :",
      "jq '[JOIN(\n  input | with_entries({key: .value, value: {reason: .key}});\n  .[] | .type = (.identifiant | split(\"_\")[1]);\n  .origine;\n  add\n)]' list_values.json mapping.json",
      "jq 'INDEX(input|to_entries[]; .value) as $mapping\n| map(\n  .type=(.identifiant/\"_\"|last)\n  | .reason=$mapping[.origine].key\n)' list_values.json mapping.json"
    ],
    "utterance": "Add a field 'reason' to each object, setting its value to the key from the mapping file where the mapping value matches the object's 'origine' field.",
    "expressions": [
      "[JOIN(\n  input | with_entries({key: .value, value: {reason: .key}});\n  .[] | .type = (.identifiant | split(\"_\")[1]);\n  .origine;\n  add\n)]",
      "INDEX(input|to_entries[]; .value) as $mapping\n| map(\n  .type=(.identifiant/\"_\"|last)\n  | .reason=$mapping[.origine].key\n)",
      "INDEX(input|to_entries[]; .value) as $mapping\n| .[]\n|= . + {\n  type: (.identifiant / \"_\" | last),\n  reason: $mapping[.origine].key\n}"
    ],
    "data": [
      {
        "input": [
          {
            "origine": "reason1",
            "identifiant": "1234_AAA"
          },
          {
            "origine": "reason3",
            "identifiant": "5678_BBB"
          }
        ],
        "output": [
          {
            "origine": "reason1",
            "identifiant": "1234_AAA",
            "type": "AAA",
            "reason": "REASON_1"
          },
          {
            "origine": "reason3",
            "identifiant": "5678_BBB",
            "type": "BBB",
            "reason": "REASON_3"
          }
        ]
      }
    ],
    "identifier": 75918811
  },
  {
    "context": [
      "if \n   dog.beta exists =>  $new_key_a = value of beta\n   delete key matching value of beta \nelif\n   dog.gamma exists => $new_key_a = value of [gamma].circle.triangle (sides3)\n   delete key \"sides3\"",
      "is it possible to use the output of the `if` to concatenate to use a 3rd value, such as,\nif `.gamma` is selected, then use the value of `.gamma` to get a nested value, such as `[$gamma].circle.triangle as $new_key_a`, so the del function would remove the value of  `square.circle.triangle` not the object `square`, but only if `.beta` is not found",
      "Update: considering the clarification that `.circle.triangle` should be appended only to `.gamma`, not to `.beta`, carry out the appended information to top-level (e.g. using a paths array), then realize its evaluation outside (e.g. using `getpath`):",
      "getpath(first(\n  .. | objects | select(.alpha == \"one\")\n  | if .beta then [.beta] else [.gamma, \"circle\", \"triangle\"] end\n)) as $new_key_a\n| del(.. | .[$new_key_a]?)"
    ],
    "utterance": "Delete the key whose name is the value of 'beta' if it exists under 'dog', otherwise delete the key whose name is the value found at the path ['gamma', 'circle', 'triangle'] if 'gamma' exists under 'dog' and 'beta' does not.",
    "expressions": [
      "getpath(first(\n  .. | objects | select(.alpha == \"one\")\n  | if .beta then [.beta] else [.gamma, \"circle\", \"triangle\"] end\n)) as $new_key_a\n| del(.. | .[$new_key_a]?)"
    ],
    "data": [
      {
        "input": {
          "dog": {
            "alpha": "one",
            "gamma": "square"
          },
          "square": {
            "circle": {
              "triangle": "sides3"
            }
          },
          "sides3": "delete me"
        },
        "output": {
          "dog": {
            "alpha": "one",
            "gamma": "square"
          },
          "square": {
            "circle": {
              "triangle": "sides3"
            }
          }
        }
      }
    ],
    "identifier": 75921638
  },
  {
    "context": [
      "Here&#39;s my input json:\r\n\r\n```json\r\n{\"description\": \"Fail-safe procedures include, for example, alerting operator personnel and providing specific instructions on subsequent steps to take (e.g., do nothing, re-establish system settings, shut down processes, restart the system, or contact designated organizational personnel). Related controls: CA-2, CA-7, CM-3, CM-5, CM-8, MA-2, IR-4, RA-5, SA-10, SA-1x, SI-1x\"}\r\n```",
      "The output I want is:\r\n\r\n```json\r\n{\"description\": \"Fail-safe procedures include, for example, alerting operator personnel and providing specific instructions on subsequent steps to take (e.g., do nothing, re-establish system settings, shut down processes, restart the system, or contact designated organizational personnel).\",\r\n\"relatedControls\": [\"CA-2\", \"CA-7\", \"CM-3\", \"CM-5\", \"CM-8\", \"MA-2\", \"IR-4\", \"RA-5\", \"SA-10\", \"SA-1x\", \"SI-1x\"]}\r\n```",
      "You could just split `/` at \" Related controls: \", then split again at `\", \"`:\r\n```sh\r\n.description / \" Related controls: \"\r\n| {description: .[0], relatedControls: (.[1] / \", \")}\r\n```",
      "Alternatively, here&#39;s another approach using `capture` and `scan` with your regular expressions:\r\n```sh\r\n.description\r\n| capture(\"(?<description>.*) Related controls: (?<relatedControls>.*)\")\r\n| .relatedControls |= [scan(\"[A-Z]{2}-\\\\d[0-9x]?\")]\r\n```"
    ],
    "utterance": "Extract the description before 'Related controls:' as one field, and extract all matching control codes after 'Related controls:' as an array in a new field.",
    "expressions": [
      ".description / \" Related controls: \" | {description: .[0], relatedControls: (.[1] / \", \")}",
      ".description | capture(\"(?<description>.*) Related controls: (?<relatedControls>.*)\") | .relatedControls |= [scan(\"[A-Z]{2}-\\d[0-9x]?\")]"
    ],
    "data": [
      {
        "input": {
          "description": "Fail-safe procedures include, for example, alerting operator personnel and providing specific instructions on subsequent steps to take (e.g., do nothing, re-establish system settings, shut down processes, restart the system, or contact designated organizational personnel). Related controls: CA-2, CA-7, CM-3, CM-5, CM-8, MA-2, IR-4, RA-5, SA-10, SA-1x, SI-1x"
        },
        "output": {
          "description": "Fail-safe procedures include, for example, alerting operator personnel and providing specific instructions on subsequent steps to take (e.g., do nothing, re-establish system settings, shut down processes, restart the system, or contact designated organizational personnel).",
          "relatedControls": [
            "CA-2",
            "CA-7",
            "CM-3",
            "CM-5",
            "CM-8",
            "MA-2",
            "IR-4",
            "RA-5",
            "SA-10",
            "SA-1x",
            "SI-1x"
          ]
        }
      }
    ],
    "identifier": 75934923
  },
  {
    "context": [
      "I then need to extract the string after the \"upstream=\", e.g. from",
      "*upstream=util-linux%402.36.1-8+deb11u1&*",
      "util-linux as $srcName",
      "2.36.1-8+deb11u1 as $srcVersion, after skipped '%40' (@) and before the next '&'",
      "You can use `[splits(\"[=&|%40\")]|.[0,1]` to split and extract the second and third element from your URL.",
      "[splits(\"[=&|%40\")] as [$upstream, $srcName, $srcVersion]\n| { $srcName, $srcVersion }",
      "Alternatively, use [`capture`](https://stedolan.github.io/jq/manual/#capture(val),capture(regex;flags)) to extract an object with a regular expression:",
      "capture(\"upstream=(?<srcName>.*)%40(?<srcVersion>[^&]*)&\")"
    ],
    "utterance": "Extract the source package name and version from the upstream query parameter in a URL-style string, where the value format is 'upstream=name%40version&'.",
    "expressions": [
      "[splits(\"[=&|%40\")] as [$upstream, $srcName, $srcVersion] | { $srcName, $srcVersion }",
      "capture(\"upstream=(?<srcName>.*)%40(?<srcVersion>[^&]*)&\")"
    ],
    "data": [
      {
        "input": "upstream=util-linux%402.36.1-8+deb11u1&",
        "output": {
          "srcName": "util-linux",
          "srcVersion": "2.36.1-8+deb11u1"
        }
      }
    ],
    "identifier": 75928161
  },
  {
    "context": [
      "What I want to be able to produce would look like the following:",
      "[{ \"file\": \"src/lib/A.c\", \"dupes\": 3, \"uniqueFlagCnt\": 3, \"uniqueFlags\": [ \"-Wall -DMACRO_FOR_X1 \", \"-Wall -DMACRO_FOR_Y1 \", \"-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO \" ], \"commands\": [...] }, ...]",
      "Where I\u2019m having difficulty is on accessing the `.commands.[].command.flags` to get the unique list and count them to put in that part.",
      "group_by( .file ) | map( { file: .[0].file, commands: map( .command | parse_command ) } | .uniqueFlags = ( .commands | map( .flags ) | unique ) )"
    ],
    "utterance": "For each distinct source file, list all the parsed compiler command details, along with the unique set of flag strings and their unique count.",
    "expressions": [
      "def parse_command: capture(\"(?<compiler>[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+]*)\\\\s*(?<flags>[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+=\\\\s\\\\\\\\\\\"]*?)-o\\\\s*(?<output>[a-zA-z0-9_\\\\-\\\\/]*CMakeFiles\\\\/(?<target>[a-zA-z0-9_\\\\- \\\\/]*).dir[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+]*.o)\\\\s*-c\\\\s*(?<filename>[\\\\/a-zA-Z0-9\\\\.\\\\-_\\\\+]*)\");\ngroup_by(.file) |\nmap({\n  file: .[0].file,\n  dupes: length,\n  commands: map(.command | parse_command),\n  uniqueFlags: (map(.command | parse_command | .flags) | unique),\n  uniqueFlagCnt: (map(.command | parse_command | .flags) | unique | length)\n})"
    ],
    "data": [
      {
        "input": [
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_X1 -o src/lib/X_core1/CMakeFiles/X_core.dir/src/A.c.o -c src/lib/A.c",
            "file": "src/lib/A.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Y1 -o src/lib/X_core2/CMakeFiles/Y_core.dir/src/A.c.o -c src/lib/A.c",
            "file": "src/lib/A.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/A.c.o -c src/lib/A.c",
            "file": "src/lib/A.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/B.c.o -c src/lib/B.c",
            "file": "src/lib/B.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_X1 -o src/lib/X_core/CMakeFiles/X_core.dir/src/B.c.o -c src/lib/B.c",
            "file": "src/lib/B.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/C.c.o -c src/lib/C.c",
            "file": "src/lib/C.c"
          }
        ],
        "output": [
          {
            "file": "src/lib/A.c",
            "dupes": 3,
            "uniqueFlagCnt": 3,
            "uniqueFlags": [
              "-Wall -DMACRO_FOR_X1 ",
              "-Wall -DMACRO_FOR_Y1 ",
              "-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO "
            ],
            "commands": [
              {
                "compiler": "/usr/bin/gcc",
                "flags": "-Wall -DMACRO_FOR_X1 ",
                "output": "src/lib/X_core1/CMakeFiles/X_core.dir/src/A.c.o",
                "target": "X_core",
                "filename": "src/lib/A.c"
              },
              {
                "compiler": "/usr/bin/gcc",
                "flags": "-Wall -DMACRO_FOR_Y1 ",
                "output": "src/lib/X_core2/CMakeFiles/Y_core.dir/src/A.c.o",
                "target": "Y_core",
                "filename": "src/lib/A.c"
              },
              {
                "compiler": "/usr/bin/gcc",
                "flags": "-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO ",
                "output": "src/lib/Z_core/CMakeFiles/Z_core.dir/src/A.c.o",
                "target": "Z_core",
                "filename": "src/lib/A.c"
              }
            ]
          },
          {
            "file": "src/lib/B.c",
            "dupes": 2,
            "uniqueFlagCnt": 2,
            "uniqueFlags": [
              "-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO ",
              "-Wall -DMACRO_FOR_X1 "
            ],
            "commands": [
              {
                "compiler": "/usr/bin/gcc",
                "flags": "-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO ",
                "output": "src/lib/Z_core/CMakeFiles/Z_core.dir/src/B.c.o",
                "target": "Z_core",
                "filename": "src/lib/B.c"
              },
              {
                "compiler": "/usr/bin/gcc",
                "flags": "-Wall -DMACRO_FOR_X1 ",
                "output": "src/lib/X_core/CMakeFiles/X_core.dir/src/B.c.o",
                "target": "X_core",
                "filename": "src/lib/B.c"
              }
            ]
          },
          {
            "file": "src/lib/C.c",
            "dupes": 1,
            "uniqueFlagCnt": 1,
            "uniqueFlags": [
              "-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO "
            ],
            "commands": [
              {
                "compiler": "/usr/bin/gcc",
                "flags": "-Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO ",
                "output": "src/lib/Z_core/CMakeFiles/Z_core.dir/src/C.c.o",
                "target": "Z_core",
                "filename": "src/lib/C.c"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 75825929
  },
  {
    "context": [
      "That `200` is added to the output because you call `curl -w \"%{http_code}\\n\"`, which will add the response status code to the output.",
      "If you require `200` to be part of the output, then you could instruct jq to read the full input into a single array and only operate on the first item:",
      "jq -s 'first._link' <<< \"$response\"",
      "If your input has a JSON document followed by other content, you can make your jq only read that one input:",
      "extract=$(jq -n \"input | ._links\" <<<$response)"
    ],
    "utterance": "Extract the value of the _links attribute from input that contains a JSON object followed by a status code on a new line.",
    "expressions": [
      "jq -n 'input | ._links' <<< \"$response\""
    ],
    "data": [
      {
        "input": "{\n    \"config\": {\n        \"polling\": {\n            \"sleep\": \"00:20:00\"\n        }\n    },\n    \"_links\": {\n        \"deployment\": {\n            \"href\": \"https://www.example.com\"\n        },\n        \"configData\": {\n            \"href\": \"https://www.example.com/configData\"\n        }\n    }\n}\n200\n",
        "output": "{\n  \"deployment\": {\n    \"href\": \"https://www.example.com\"\n  },\n  \"configData\": {\n    \"href\": \"https://www.example.com/configData\"\n  }\n}"
      }
    ],
    "identifier": 75940783
  },
  {
    "context": [
      "does anyone know how to return VersionNumber (16) baes on the tag value (release/6.1) using the example data from above?",
      "aws ec2 describe-launch-template-versions --launch-template-id lt-1234 | jq '.LaunchTemplateVersions[] | select(.LaunchTemplateData.TagSpecifications[].Tags[] | select(.Key == \"deployment_version\" and .Value == \"release/6.1\")) | .VersionNumber'",
      ".LaunchTemplateVersions[]\n| select(any(.LaunchTemplateData.TagSpecifications[].Tags|from_entries; .deployment_version == \"release/6.1\"))\n| .VersionNumber",
      "select(.LaunchTemplateData.TagSpecifications[0].Tags|from_entries.deployment_version == \"release/6.1\")"
    ],
    "utterance": "Return all VersionNumber values where any tag's Key is deployment_version and its Value is release/6.1.",
    "expressions": [
      ".LaunchTemplateVersions[] | select(.LaunchTemplateData.TagSpecifications[].Tags[] | select(.Key == \"deployment_version\" and .Value == \"release/6.1\")) | .VersionNumber",
      ".LaunchTemplateVersions[] | select(any(.LaunchTemplateData.TagSpecifications[].Tags|from_entries; .deployment_version == \"release/6.1\")) | .VersionNumber",
      ".LaunchTemplateVersions[] | select(.LaunchTemplateData.TagSpecifications[0].Tags|from_entries.deployment_version == \"release/6.1\") | .VersionNumber"
    ],
    "data": [
      {
        "input": {
          "LaunchTemplateVersions": [
            {
              "LaunchTemplateId": "lt-1234",
              "LaunchTemplateName": "api",
              "VersionNumber": 16,
              "LaunchTemplateData": {
                "TagSpecifications": [
                  {
                    "ResourceType": "instance",
                    "Tags": [
                      {
                        "Key": "deployment_version",
                        "Value": "release/6.1"
                      },
                      {
                        "Key": "server_type",
                        "Value": "api"
                      }
                    ]
                  }
                ]
              }
            },
            {
              "LaunchTemplateId": "lt-1234",
              "LaunchTemplateName": "api",
              "VersionNumber": 15,
              "LaunchTemplateData": {
                "TagSpecifications": [
                  {
                    "ResourceType": "instance",
                    "Tags": [
                      {
                        "Key": "deployment_version",
                        "Value": "release/5.7"
                      },
                      {
                        "Key": "server_type",
                        "Value": "api"
                      }
                    ]
                  }
                ]
              }
            }
          ]
        },
        "output": 16
      }
    ],
    "identifier": 75942661
  },
  {
    "context": [
      "I would like to transform it as the following, using linux script (on a yaml pipeline):",
      "for each component where component.purl.startwith(pkg:deb/debian/) and component.properties.syft:metadata:source is set\n   component.name = properties.where(name==\"syft:metadata:source\").value\n   if (properties.syft:metadata:sourceVersion)\n       component.version = properties.where(name==\"syft:metadata:sourceVersion\").value\n   component.purl=pkg:deb/debian/{component.name}@{component.version}?arch=source\ntake any other component not matching the where/select \"as is\"",
      ".components[]|select((.properties[].name==\"syft:metadata:source\") and (.purl | startswith(\"pkg:deb/debian\")) ) as $comps \n| .name=(.properties[] | select(.name == \"syft:metadata:source\").value)\n| .version=(.properties[] | select(.name == \"syft:metadata:sourceVersion\").value)\n| .purl=\"pkg:deb/debian/\"+(.name)+\"@\"+(.version)+\"?arch=source\"",
      "(.components[] | select(.properties|from_entries?|has(\"syft:metadata:source\")))\n|= . + (\n    .properties // []\n    | from_entries\n    | {\n        name: .\"syft:metadata:source\",\n        version: .\"syft:metadata:sourceVersion\"\n    }\n    | . + { purl: \"pkg:deb/debian/\\(.name)@\\(.version)?arch=source\" }\n)",
      "\"syft:metadata:source\" as $source\n| \"syft:metadata:sourceVersion\" as $version\n| (.components[] | select(.properties|from_entries?|has($source)))\n|= . + (\n    .properties // []\n    | from_entries\n    | {\n        name: .[$source],\n        version: .[$version],\n        purl: \"pkg:deb/debian/\\(.[$source])@\\(.[$version])?arch=source\"\n    }\n)"
    ],
    "utterance": "Rewrite each component so that, if its purl starts with 'pkg:deb/debian/' and it has a property 'syft:metadata:source', its name and version are replaced with those property values and its purl rewritten as 'pkg:deb/debian/{name}@{version}?arch=source'; leave all other components unchanged.",
    "expressions": [
      "(.components[] | select(.properties|from_entries?|has(\"syft:metadata:source\")))\n|= . + (\n    .properties // []\n    | from_entries\n    | {\n        name: .\"syft:metadata:source\",\n        version: .\"syft:metadata:sourceVersion\"\n    }\n    | . + { purl: \"pkg:deb/debian/\\(.name)@\\(.version)?arch=source\" }\n)",
      "\"syft:metadata:source\" as $source\n| \"syft:metadata:sourceVersion\" as $version\n| (.components[] | select(.properties|from_entries?|has($source)))\n|= . + (\n    .properties // []\n    | from_entries\n    | {\n        name: .[$source],\n        version: .[$version],\n        purl: \"pkg:deb/debian/\\(.[$source])@\\(.[$version])?arch=source\"\n    }\n)"
    ],
    "data": [
      {
        "input": {
          "bomFormat": "CycloneDX",
          "components": [
            {
              "name": "bsdutils",
              "version": "1:2.36.1-8+deb11u1",
              "purl": "pkg:deb/debian/bsdutils@1:2.36.1-8+deb11u1?arch=amd64&upstream=util-linux%402.36.1-8+deb11u1&distro=debian-11",
              "properties": [
                {
                  "name": "syft:metadata:source",
                  "value": "util-linux"
                },
                {
                  "name": "syft:metadata:sourceVersion",
                  "value": "2.36.1-8+deb11u1"
                }
              ]
            },
            {
              "name": "curl",
              "version": "7.74.0-1.3+deb11u7",
              "purl": "pkg:deb/debian/curl@7.74.0-1.3+deb11u7?arch=amd64&distro=debian-11"
            },
            {
              "name": "libaudit-common",
              "version": "1:3.0-2",
              "purl": "pkg:deb/debian/libaudit-common@1:3.0-2?arch=all&upstream=audit&distro=debian-11",
              "properties": [
                {
                  "name": "syft:metadata:source",
                  "value": "audit"
                }
              ]
            }
          ]
        },
        "output": {
          "bomFormat": "CycloneDX",
          "components": [
            {
              "name": "util-linux",
              "version": "2.36.1-8+deb11u1",
              "purl": "pkg:deb/debian/util-linux@2.36.1-8+deb11u1?arch=source",
              "properties": [
                {
                  "name": "syft:metadata:source",
                  "value": "util-linux"
                },
                {
                  "name": "syft:metadata:sourceVersion",
                  "value": "2.36.1-8+deb11u1"
                }
              ]
            },
            {
              "name": "curl",
              "version": "7.74.0-1.3+deb11u7",
              "purl": "pkg:deb/debian/curl@7.74.0-1.3+deb11u7?arch=amd64&distro=debian-11"
            },
            {
              "name": "audit",
              "version": "1:3.0-2",
              "purl": "pkg:deb/debian/audit@1:3.0-2?arch=source",
              "properties": [
                {
                  "name": "syft:metadata:source",
                  "value": "audit"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 75878487
  },
  {
    "context": [
      "should list the instances not with tags **key : app and value : prod** . If we could filter with case sensitive it would be even great.",
      "This will select (=keep) the items where at least one of the fields is unequal to its respective value (using `or` and `!=`):",
      "```\n.Reservations[].Instances[] | select(.Key != \"app\" or .Value != \"prod\")\n```",
      "Taking the examples from that page, I managed to create this query that shows the InstanceId of any instance that does not have `Key=app` and `Value=prod`:"
    ],
    "utterance": "List all items where either the Key is not \"app\" or the Value is not \"prod\", using case-sensitive comparison.",
    "expressions": [
      ".Reservations[].Instances[] | select(.Key != \"app\" or .Value != \"prod\")"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "Key": "app",
                  "ResourceType": "instance1",
                  "Value": "prod"
                },
                {
                  "Key": "App",
                  "ResourceType": "instance2",
                  "Value": "Prod"
                },
                {
                  "Key": "app",
                  "ResourceType": "instance3",
                  "Value": "production"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "Key": "App",
            "ResourceType": "instance2",
            "Value": "Prod"
          },
          {
            "Key": "app",
            "ResourceType": "instance3",
            "Value": "production"
          }
        ]
      }
    ],
    "identifier": 75942879
  },
  {
    "context": [
      "parse [Amazon's RDS instances ](https://pricing.us-east-1.amazonaws.com/offers/v1.0/aws/AmazonRDS/current/index.json)to mount an object of instanceType=memoryInBytes",
      "the used jq expression I've created:",
      "(. | tostream) | select(isMemory or isInstanceType) | .[1]",
      "outputs",
      "\"db.r5.24xlarge\"",
      "\"768 GiB\"",
      "The initial expresion I had, which would then use too much memory was the following:",
      ".products | to_entries | map(.value.attributes | select(.instanceType != null) | {(.instanceType): ((.memory | split(\" \") | .[0] | tonumber) * 1024 * 1024 * 1024)}) | add",
      "Here\u2019s one approach loading only the `.attributes` objects in full into memory. Using `reduce` lets you iteratively build up your final object.",
      "jq --stream -n '\n  reduce fromstream(3|truncate_stream(\n    inputs | select(.[0][2] == \"attributes\")\n  )) as {$instanceType, $memory} ({};\n    if $instanceType then .[$instanceType] = $memory else . end\n  )\n'"
    ],
    "utterance": "Extract a mapping of instanceType to memory for each RDS product instance.",
    "expressions": [
      ".products | to_entries | map(.value.attributes | select(.instanceType != null) | {(.instanceType): .memory}) | add",
      "jq --stream -n '\n  reduce fromstream(3|truncate_stream(\n    inputs | select(.[0][2] == \"attributes\")\n  )) as {$instanceType, $memory} ({};\n    if $instanceType then .[$instanceType] = $memory else . end\n  )\n'"
    ],
    "data": [
      {
        "input": {
          "formatVersion": "v1.0",
          "disclaimer": "This pricing list is for informational purposes only. All prices are subject to the additional terms included in the pricing pages on http://aws.amazon.com. All Free Tier prices are also subject to the terms included at https://aws.amazon.com/free/",
          "offerCode": "AmazonRDS",
          "version": "20230328234721",
          "publicationDate": "2023-03-28T23:47:21Z",
          "products": {
            "BHYABS232JP4AGQY": {
              "sku": "BHYABS232JP4AGQY",
              "productFamily": "Database Instance",
              "attributes": {
                "servicecode": "AmazonRDS",
                "location": "US East (Ohio)",
                "locationType": "AWS Region",
                "instanceType": "db.r5.24xlarge",
                "currentGeneration": "Yes",
                "instanceFamily": "Memory optimized",
                "vcpu": "96",
                "physicalProcessor": "Intel Xeon Platinum 8175",
                "clockSpeed": "Up to 3.1 GHz",
                "memory": "768 GiB",
                "storage": "EBS Only",
                "networkPerformance": "25 Gigabit",
                "processorArchitecture": "64-bit",
                "engineCode": "18",
                "databaseEngine": "MariaDB",
                "licenseModel": "No license required",
                "deploymentOption": "Single-AZ",
                "usagetype": "USE2-InstanceUsage:db.r5.24xl",
                "operation": "CreateDBInstance:0018",
                "dedicatedEbsThroughput": "14000 Mbps",
                "enhancedNetworkingSupported": "Yes",
                "instanceTypeFamily": "R5",
                "normalizationSizeFactor": "192",
                "regionCode": "us-east-2",
                "servicename": "Amazon Relational Database Service"
              }
            },
            "D8GBHQEK73G5ADCK": {
              "sku": "D8GBHQEK73G5ADCK",
              "productFamily": "Database Instance",
              "attributes": {
                "servicecode": "AmazonRDS",
                "location": "Asia Pacific (Tokyo)",
                "locationType": "AWS Region",
                "instanceType": "db.r4.large",
                "currentGeneration": "No",
                "instanceFamily": "Memory optimized",
                "vcpu": "2",
                "physicalProcessor": "Intel Xeon E5-2686 v4 (Broadwell)",
                "clockSpeed": "2.3 GHz",
                "memory": "15.25 GiB",
                "storage": "EBS Only",
                "networkPerformance": "Up to 10 Gigabit",
                "processorArchitecture": "64-bit",
                "engineCode": "2",
                "databaseEngine": "MySQL",
                "licenseModel": "No license required",
                "deploymentOption": "Multi-AZ",
                "usagetype": "APN1-Multi-AZUsage:db.r4.large",
                "operation": "CreateDBInstance:0002",
                "dedicatedEbsThroughput": "400 Mbps",
                "enhancedNetworkingSupported": "Yes",
                "instanceTypeFamily": "R4",
                "normalizationSizeFactor": "8",
                "processorFeatures": "Intel AVX, Intel AVX2, Intel Turbo",
                "regionCode": "ap-northeast-1",
                "servicename": "Amazon Relational Database Service"
              }
            }
          }
        },
        "output": {
          "db.r5.24xlarge": "768 GiB",
          "db.r4.large": "15.25 GiB"
        }
      }
    ],
    "identifier": 75892008
  },
  {
    "context": [
      "The problem is that $counter argument come to jq as string, but array index must be number.",
      "To pass a variable as a JSON-encoded value, use `--argjson` instead:"
    ],
    "utterance": "Select an element from the UnitTypes array using an array index from a variable, ensuring the variable is treated as a number.",
    "expressions": [
      ".value[].UnitTypes[$counter | tonumber]",
      ".value[].UnitTypes[$counter] | to_entries[] | \"\\(.key) \\(.value)\""
    ],
    "data": [
      {
        "input": {
          "@odata.context": "Sample Text Grid Context",
          "@odata.count": 1,
          "value": [
            {
              "ListingId": "DUMMY_001",
              "UnitTypes": [
                {
                  "RAN_GarageDescription": "1 Car Garage - Att,1 Space",
                  "RAN_MiscIncluded": "Air Conditioning,Dishwasher,Range/Oven,Refrigerator,Wood Burning FP",
                  "RAN_OtherRoom1Desc": "Den/Office",
                  "RAN_OtherRoom2Desc": "Rec Room",
                  "UnitTypeActualRent": 975,
                  "RAN_HalfBaths": "1",
                  "RAN_FullBaths": "1",
                  "RAN_Location": "Left/1706",
                  "RAN_OtherRoom1Fin": "10x13",
                  "RAN_OtherRoom2Fin": "10x12",
                  "RAN_VacancyType": "Rent",
                  "RAN_ElectricPaidBy": "Tenant",
                  "RAN_HeatPaidBy": "Tenant",
                  "RAN_Bedroom1": "13x12",
                  "RAN_Bedroom2": "13x12",
                  "RAN_DiningRoom": "10x10",
                  "RAN_Kitchen": "12x10",
                  "RAN_Level": "Main",
                  "RAN_LivingGreatRoom": "20x12",
                  "UnitTypeBedsTotal": 2,
                  "UnitTypeType": "Unit 1",
                  "RAN_SqFtFin": "1465",
                  "RAN_WaterPaidBy": "Tenant",
                  "UnitTypeKey": "RAN50270568Group_1"
                },
                {
                  "RAN_GarageDescription": "1 Car Garage - Detached,1 Space",
                  "RAN_MiscIncluded": "Air Conditioning,Dishwasher,Range/Oven,Wood Burning FP,Refrigerator",
                  "RAN_Bedroom1": "12x12",
                  "RAN_Bedroom2": "12x12",
                  "RAN_Bedroom3": "12x10",
                  "RAN_DiningRoom": "10x10",
                  "RAN_Kitchen": "12x10",
                  "RAN_Level": "Main",
                  "RAN_LivingGreatRoom": "20x12",
                  "RAN_Location": "Right/1704",
                  "RAN_VacancyType": "Rent",
                  "RAN_WaterPaidBy": "Tenant",
                  "RAN_LeaseExpDate": "2023-07-31",
                  "RAN_HalfBaths": "0",
                  "UnitTypeActualRent": 1145,
                  "RAN_ElectricPaidBy": "Tenant",
                  "RAN_HeatPaidBy": "Tenant",
                  "RAN_FamilyRoom": "23x10",
                  "RAN_FullBaths": "2",
                  "UnitTypeBedsTotal": 3,
                  "UnitTypeType": "Unit 2",
                  "RAN_SqFtFin": "1442",
                  "UnitTypeKey": "RAN50270568Group_2"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 75928683
  },
  {
    "context": [
      "I am trying to have JQ go through every object and find those, which do not have an element in the .labels array that is a substring of .downloadDir between 1st and 2nd '/', i.e.\n\n- for \"/merge/downloads\" it should be \"downloads\"\n- for \"/merge/tv/downloads\" it should be \"tv\"\n- for \"/merge/tv-share/downloads\" it should be \"tv-share\"\n\nFor matching objects it should return their .id.",
      "<file.json jq '.[]\n               | (.downloadDir | split(\"/\")[2]) as $key\n               | select(.labels | map(. != $key) | all).id'",
      "jq 'select(any(.labels[] == (.downloadDir / \"/\")[2]; .)).id ' input.json"
    ],
    "utterance": "Return the id of each object whose labels array does not contain the substring from downloadDir between the first and second slash.",
    "expressions": [
      ".[] | (.downloadDir | split(\"/\")[2]) as $key | select(.labels | map(. != $key) | all).id"
    ],
    "data": [
      {
        "input": [
          {
            "downloadDir": "/merge/downloads",
            "id": 2485,
            "labels": [
              "irrelevant",
              "downloads"
            ]
          },
          {
            "downloadDir": "/merge/tv/downloads",
            "id": 2486,
            "labels": [
              "irrelevant",
              "downloads"
            ]
          }
        ],
        "output": [
          2485
        ]
      }
    ],
    "identifier": 75949905
  },
  {
    "context": [
      "i am using this command,\r\n\r\n     cat kube-apiserver-audit.log | jq '.annotations.\"pod-security.kubernetes.io/audit-violations\"'\r\n\r\nhowever it gives the followign output\r\n\r\n    null\r\n    null\r\n    \"would violate PodSecurity \\\"restricted:v1.24\\\" ...\"\r\n    null\r\n    null\r\n    null\r\n    null\r\n\r\nany idea how can i remove the null values from the jq output ?",
      "You can use select to filter.\r\n\r\n    jq -r '.annotations.\"pod-security.kubernetes.io/audit-violations\" | select(. != null)'",
      "The `values` filter (see the [manual](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars)) does exactly that, filtering out `null`s while keeping the \"values\":\r\n.annotations.\"pod-security.kubernetes.io/audit-violations\" | values"
    ],
    "utterance": "Extract the .annotations.\"pod-security.kubernetes.io/audit-violations\" field from each record, excluding null values.",
    "expressions": [
      ".annotations.\"pod-security.kubernetes.io/audit-violations\" | select(. != null)",
      ".annotations.\"pod-security.kubernetes.io/audit-violations\" | values"
    ],
    "identifier": 75952221
  },
  {
    "context": [
      "I have a file with an array of JSON:",
      "and I would like to create a new file with each JSON of previous JSON array, broken down by its field \"origin\", like this:",
      "Here is one way:\n``` none\nmap({id, name: .names[]})\n```",
      "Try this:\n\n    jq '[.[] | .names[] as $n | {id: .id, name: $n}]' input.json > output.json"
    ],
    "utterance": "Transform an array of objects with 'names' arrays into a flat array of objects with each combination of id and single name.",
    "expressions": [
      "map({id, name: .names[]})",
      "[.[] | .names[] as $n | {id: .id, name: $n}]"
    ],
    "data": [
      {
        "input": [
          {
            "names": [
              "name1"
            ],
            "id": "1"
          },
          {
            "names": [
              "name1",
              "name2"
            ],
            "id": "2"
          }
        ],
        "output": [
          {
            "name": "name1",
            "id": "1"
          },
          {
            "name": "name1",
            "id": "2"
          },
          {
            "name": "name2",
            "id": "2"
          }
        ]
      }
    ],
    "identifier": 75959859
  },
  {
    "context": [
      "One task that's coming up is to show what images are deployed to what pods, using `kubectl get pods`. So far I have this:",
      "`kubectl get pods -o json | jq '.items[]|[.metadata.name,.spec.containers[].image]'`",
      "Is there any way I can include the item's index in the output? In other words, I want to see:",
      "[\n  0,\n  \"kubernetes-bootcamp-5485cc6795-4blsd\",\n  \"gcr.io/google-samples/kubernetes-bootcamp:v1\"\n]",
      "[\n  1,\n  \"kubernetes-bootcamp-5485cc6795-k824z\",\n  \"gcr.io/google-samples/kubernetes-bootcamp:v1\"\n]",
      "You could create an index variable, e.g. as follows:",
      "range(0; .items|length) as $i | .items[$i] | [$i, .metadata.name, .spec.containers[].image]",
      ".items | to_entries[] | [.key, .value.metadata.name, .value.spec.containers[].image]"
    ],
    "utterance": "List each pod with its array index, metadata name, and deployed container images from the Kubernetes pods list.",
    "expressions": [
      "range(0; .items|length) as $i | .items[$i] | [$i, .metadata.name, .spec.containers[].image]",
      ".items | to_entries[] | [.key, .value.metadata.name, .value.spec.containers[].image]"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "kubernetes-bootcamp-5485cc6795-4blsd"
              },
              "spec": {
                "containers": [
                  {
                    "image": "gcr.io/google-samples/kubernetes-bootcamp:v1"
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "kubernetes-bootcamp-5485cc6795-k824z"
              },
              "spec": {
                "containers": [
                  {
                    "image": "gcr.io/google-samples/kubernetes-bootcamp:v1"
                  }
                ]
              }
            }
          ]
        },
        "output": [
          [
            0,
            "kubernetes-bootcamp-5485cc6795-4blsd",
            "gcr.io/google-samples/kubernetes-bootcamp:v1"
          ],
          [
            1,
            "kubernetes-bootcamp-5485cc6795-k824z",
            "gcr.io/google-samples/kubernetes-bootcamp:v1"
          ]
        ]
      }
    ],
    "identifier": 75954488
  },
  {
    "context": [
      "I would like to format this way \r\n\r\n```\r\n{\r\n  \"gate01\": {\r\n    \"18\": 0.0,\r\n    \"89\": 0.0,\r\n    \"91\": 35.0,\r\n    \"20\": 33.0\r\n  },\r\n  \"gate02\": {\r\n    \"18\": 1.0,\r\n    \"89\": 24290.0,\r\n    \"91\": 110.0,\r\n    \"20\": 97.0\r\n  }\r\n}\r\n\r\n```",
      "You were close, you should expand `.statistics` only once like so:\r\n``` none\r\n.objects | map({(.key): (.statistics | map({(.id | tostring): .value}) | add)}) | add\r\n```",
      "This should achieve what you expected :\r\n\r\n```\r\njq '.objects |\r\n    map({key, value: (.statistics | \r\n                      map({value, key:.id|tostring}) |\r\n                      from_entries)\r\n      }) |\r\n    from_entries' input.json\r\n```"
    ],
    "utterance": "Reformat so that each object's key becomes a top-level key mapping to an object whose properties are the statistics ids (as strings) with their corresponding values.",
    "expressions": [
      ".objects | map({(.key): (.statistics | map({(.id | tostring): .value}) | add)}) | add",
      ".objects | map({key, value: (.statistics | map({value, key:.id|tostring}) | from_entries)}) | from_entries"
    ],
    "data": [
      {
        "input": {
          "objects": [
            {
              "statistics": [
                {
                  "dataType": 0,
                  "value": 0.0,
                  "id": 18
                },
                {
                  "dataType": 1,
                  "value": 0,
                  "id": 89
                },
                {
                  "dataType": 0,
                  "value": 35.0,
                  "id": 91
                },
                {
                  "dataType": 0,
                  "value": 33.0,
                  "id": 20
                }
              ],
              "key": "gate01"
            },
            {
              "statistics": [
                {
                  "dataType": 0,
                  "value": 1.0,
                  "id": 18
                },
                {
                  "dataType": 1,
                  "value": 24290.0,
                  "id": 89
                },
                {
                  "dataType": 0,
                  "value": 110.0,
                  "id": 91
                },
                {
                  "dataType": 0,
                  "value": 97.0,
                  "id": 20
                }
              ],
              "key": "gate02"
            }
          ]
        },
        "output": {
          "gate01": {
            "18": 0.0,
            "89": 0.0,
            "91": 35.0,
            "20": 33.0
          },
          "gate02": {
            "18": 1.0,
            "89": 24290.0,
            "91": 110.0,
            "20": 97.0
          }
        }
      }
    ],
    "identifier": 75957303
  },
  {
    "context": [
      "I have a \"horodate\" field with milliseconds :\n{\n\t\"horodate\" : \"2023-03-03T10:10:10.425Z\"\n}\n\nI would like to convert this date into a timestamp with millisecond precision",
      "Output:\n\n   1677838210425"
    ],
    "utterance": "Convert the field 'horodate' in the format '2023-03-03T10:10:10.425Z' to a Unix timestamp with millisecond precision",
    "expressions": [
      "def toMilliseconds($fmt):\n  def toM:\n    capture(\"(?<string>.*)[.](?<milliseconds>[0-9]+)Z\")\n    | .string += \"Z\"\n    | .milliseconds |= tonumber;\n  (toM // {string: ., milliseconds: 0})\n  | (.string | strptime($fmt) | mktime) * 1000 + .milliseconds ;\n\n.horodate | toMilliseconds(\"%Y-%m-%dT%H:%M:%SZ\")"
    ],
    "data": [
      {
        "input": {
          "horodate": "2023-03-03T10:10:10.425Z"
        },
        "output": 1677838210425
      }
    ],
    "identifier": 75965804
  },
  {
    "context": [
      "How can I get the users for which any of the files match the path?",
      "Given json:\r\n\r\n    [\r\n      {\r\n        \"path\": \"Module1/\",\r\n        \"users\": [\r\n          \"john\",\r\n          \"jane\"\r\n        ]\r\n      },\r\n      {\r\n        \"path\": \"Module2/\",\r\n        \"users\": [\r\n          \"mike\",\r\n          \"mary\"\r\n        ]\r\n      },\r\n      {\r\n        \"path\": \"Module3/\",\r\n        \"users\": [\r\n          \"billy\",\r\n          \"bonny\"\r\n        ]\r\n      }\r\n    ]",
      "Given array of files:\r\n\r\n    [\r\n      \"Module1/file.java\",\r\n      \"Module3/file.java\"\r\n    ]",
      "Expected output:\r\n\r\n    [\r\n      \"john\",\r\n      \"jane\",\r\n      \"billy\",\r\n      \"bonny\"\r\n    ]",
      "You can use `inside` to flip arguments for a `contains` test which performs a substring matching. Use `any` to select on first match, and `input` to read the second input (array of files):\r\n```sh\r\njq 'input as $f | map(select(any(.path | inside($f[]); .)).users[])' input.json files.json\r\n```",
      "[Demo](https://jqplay.org/s/44R5XS47ZqZ)"
    ],
    "utterance": "Find all users whose path is a substring at the beginning of any entry in the given files array.",
    "expressions": [
      "input as $f | map(select(any($f[]; startswith(.path))).users[]) | flatten"
    ],
    "data": [
      {
        "input": [
          {
            "path": "Module1/",
            "users": [
              "john",
              "jane"
            ]
          },
          {
            "path": "Module2/",
            "users": [
              "mike",
              "mary"
            ]
          },
          {
            "path": "Module3/",
            "users": [
              "billy",
              "bonny"
            ]
          }
        ],
        "output": [
          "john",
          "jane",
          "billy",
          "bonny"
        ]
      },
      {
        "input": [
          "Module1/file.java",
          "Module3/file.java"
        ]
      }
    ],
    "identifier": 75960744
  },
  {
    "context": [
      "Is it possible to create a consolidated object using jq that will look like this, objects will be consolidated and lists within the object will be concatenated. I'm looking for a general solution that will work on any type of structure and depth.",
      "{\n  \"Datacenter1\": {\n    \"prd1\": [\n      \"clone\",\n      \"rrr\"\n    ]\n  },\n  \"BackupSite\": {\n    \"prd2\": [\n      \"vol2\"\n    ]\n  }\n}"
    ],
    "utterance": "Combine multiple input objects into a single object, recursively merging all keys and concatenating arrays at any level.",
    "expressions": [
      "reduce inputs as $i (.; . *= $i )",
      "reduce inputs as $i ({}; . * $i )"
    ],
    "data": [
      {
        "input": [
          {
            "Datacenter1": {
              "prd1": [
                "clone"
              ]
            }
          },
          {
            "Datacenter1": {
              "prd1": [
                "rrr"
              ]
            }
          },
          {
            "BackupSite": {
              "prd2": [
                "vol2"
              ]
            }
          }
        ],
        "output": {
          "Datacenter1": {
            "prd1": [
              "clone",
              "rrr"
            ]
          },
          "BackupSite": {
            "prd2": [
              "vol2"
            ]
          }
        }
      }
    ],
    "identifier": 75975718
  },
  {
    "context": [
      "I need to use bash variable to specify which variable I would like to get:",
      "I can't specify \"my_var2\", I have to use only \"var2\"",
      "jq -r --arg JSONPART ${PART} '.[] .my_[$JSONPART]'",
      "The jq filter `.xyz` can be rewritten as `.[\"xyz\"]`. Thus:",
      "jq -r --arg JSONPART \"$PART\" '.[][\"my_\" + $JSONPART]'"
    ],
    "utterance": "Retrieve the value with a key formed by concatenating 'my_' and the value of a shell variable (e.g. 'var2'), using that shell variable for dynamic property access.",
    "expressions": [
      ".[][\"my_\" + $JSONPART]"
    ],
    "data": [
      {
        "input": [
          {
            "my_var1": "valueA",
            "my_var2": "valueB"
          }
        ],
        "output": "valueB"
      }
    ],
    "identifier": 76003568
  },
  {
    "context": [
      "My attempt has created a cartesian product of all possible values instead of parsing specific properties within the nested array.",
      "jq '.[] | {id, versions: (.versions[] | {id}) }'",
      "**Expecting**",
      "[{\"id\": \"afe45456-18fd-4523-a0ee-b7ed9d0a308e\", \"versions\": [{\"id\": \"07e34a2d-be28-4925-afdd-79ddcbe54db9\"}, {\"id\": \"0e4ea89c-49da-4f79-a6bc-eec0dad19133\"}]}, {\"id\": \"3644e592-c9c3-4c3b-b6d4-e6a7dbdf80fb\", \"versions\": [{\"id\": \"9d63e112-7c42-43fa-b460-3f4389b691b3\"}]}]",
      "If you want to get arrays, not a stream of items (in both, the inner and the outer case), don't destructure the source array with `.[]`, use `map` instead which retains the surrounding array:",
      "jq 'map({id, versions: (.versions | map({id})) })'"
    ],
    "utterance": "Extract the top-level id and for each, retain the nested versions array but keep only their id fields, producing an array of objects with this structure.",
    "expressions": [
      "map({id, versions: (.versions | map({id})) })"
    ],
    "data": [
      {
        "input": [
          {
            "id": "afe45456-18fd-4523-a0ee-b7ed9d0a308e",
            "versions": [
              {
                "id": "07e34a2d-be28-4925-afdd-79ddcbe54db9"
              },
              {
                "id": "0e4ea89c-49da-4f79-a6bc-eec0dad19133"
              }
            ]
          },
          {
            "id": "3644e592-c9c3-4c3b-b6d4-e6a7dbdf80fb",
            "versions": [
              {
                "id": "9d63e112-7c42-43fa-b460-3f4389b691b3"
              }
            ]
          }
        ],
        "output": [
          {
            "id": "afe45456-18fd-4523-a0ee-b7ed9d0a308e",
            "versions": [
              {
                "id": "07e34a2d-be28-4925-afdd-79ddcbe54db9"
              },
              {
                "id": "0e4ea89c-49da-4f79-a6bc-eec0dad19133"
              }
            ]
          },
          {
            "id": "3644e592-c9c3-4c3b-b6d4-e6a7dbdf80fb",
            "versions": [
              {
                "id": "9d63e112-7c42-43fa-b460-3f4389b691b3"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 75976754
  },
  {
    "context": [
      "I have a JSON object as shown below that I am trying to put in a table.\r\n\r\n```json\r\n[\r\n  {\r\n    \"name\": \"Jay\",\r\n    \"Age\": \"23\"\r\n  },\r\n  {\r\n    \"name\": \"Jamie\",\r\n    \"Age\": \"32\"\r\n  },\r\n  {\r\n    \"name\": \"\",\r\n    \"Age\":\"26\"\r\n  }\r\n]\r\n```",
      "My JSON is in a variable called `listofres`:\r\n\r\n```sh\r\necho \"$listofres\" \r\n| jq -r '.[] | [.[\"name\"], .[\"Age\"]] | @tsv' \r\n| awk 'BEGIN { printf \"%-2s %-20s %-20s\\n\", \"\",\"Name\", \"Age\"; \r\nprint \"---------------------------------------\";} \r\n{printf \"%-2s. %-20s %-20s\\n\", (NR < 10 ? \" \" : \"\")NR, $1, $2}'\r\n```",
      "The problem is that if a column value is unavailable, the value from the next column slides into it."
    ],
    "utterance": "Output a table with columns for name and Age, ensuring that missing name values do not cause Age values to appear in the name column.",
    "expressions": [
      ".[] | [.[\"name\"], .[\"Age\"]] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Jay",
            "Age": "23"
          },
          {
            "name": "Jamie",
            "Age": "32"
          },
          {
            "name": "",
            "Age": "26"
          }
        ],
        "output": "Jay\t23\nJamie\t32\n\t26"
      }
    ],
    "identifier": 75997775
  },
  {
    "context": [
      "I am using jq to parse an array. The query works fine when I use in the following format and use a fixed value inside double quotes e.g. 123456.",
      "However I am getting the value from a variable in a bash script and I want to pass the variable (e.g. $spName) into jq parameter instead of a hard coded value 123456...",
      "When I do so, I am getting error. Obviously my syntax is not correct. Can someone help me to fix the syntax?",
      "Found what I was after. This one worked.\n\n    jq -r \".[] | select(.principalName==\\\"$spName\\\") | .principalName\" sp.txt"
    ],
    "utterance": "Select objects where the principalName field matches the value stored in a shell variable and output that field.",
    "expressions": [
      "jq -r \".[] | select(.principalName==\\\"$spName\\\") | .principalName\" sp.txt"
    ],
    "identifier": 76011924
  },
  {
    "context": [
      "\"I want to get output of each rule that substitutes the `name` of the object for the numeric reference. Using my example, output for Rule 1 would be something like: ...\\n    {\\n    \\t\\\"name\\\": \\\"Light ON\\\",\\n    \\t\\\"conditions\\\": [\\\"Room 1 Motion eq true\\\",\\n    \\t\\t\\\"Room 1 Lux lt 12000\\\"\\n    \\t],\\n    \\t\\\"actions\\\": \\\"Room 1 Main on true\\\"\\n    }\"",
      "`script.jq`:\\n```jq\\ndef find($root):\\n  (.address | capture(\"^/(?<type>\\\\w+)/(?<name>\\\\w+)\", \"g\")) as $c\\n  | $root[$c.type][$c.name];\\n\\n. as $root | .rules | [to_entries[].value | {\\n  name: .name, \\n  conditions: [.conditions[] | \"\\(find($root).name) \\(.operator) \\(.value)\"],\\n  actions: [.actions[] | find($root).name + (.body | to_entries[0] | \" \\(.key) \\(.value)\")]\\n}]\\n```",
      "```json\\n$ jq -f script.jq test.json\\n[\\n  {\\n    \\\"name\\\": \\\"Light  ON\\\",\\n    \\\"conditions\\\": [\\n      \\\"Room 1 Motion eq true\\\",\\n      \\\"Room 1 Lux lt 12000\\\"\\n    ],\\n    \\\"actions\\\": [\\n      \\\"Room 1 Main on true\\\"\\n    ]\\n  }\\n]\\n```"
    ],
    "utterance": "For each rule, output its name, an array of human-readable conditions with sensor names in place of references, and an array of human-readable actions with light names in place of references, using the referenced objects' names and substituting into the appropriate output format.",
    "expressions": [
      "def find($root):\n  (.address | capture(\"^/(?<type>\\\\w+)/(?<name>\\\\w+)\", \"g\")) as $c\n  | $root[$c.type][$c.name];\n\n. as $root | .rules | [to_entries[].value | {\n  name: .name, \n  conditions: [.conditions[] | \"\\(find($root).name) \\(.operator) \\(.value)\"],\n  actions: [.actions[] | find($root).name + (.body | to_entries[0] | \" \\(.key) \\(.value)\")]\n}]"
    ],
    "data": [
      {
        "input": {
          "lights": {
            "8": {
              "name": "Room 1 Main"
            }
          },
          "groups": {
            "1": {
              "name": "Room 1",
              "lights": [
                "8",
                "9",
                "10",
                "11",
                "12"
              ]
            }
          },
          "rules": {
            "1": {
              "name": "Light  ON",
              "conditions": [
                {
                  "address": "/sensors/9/state/presence",
                  "operator": "eq",
                  "value": "true"
                },
                {
                  "address": "/sensors/10/state/lightlevel",
                  "operator": "lt",
                  "value": "12000"
                }
              ],
              "actions": [
                {
                  "address": "/lights/8/state",
                  "method": "PUT",
                  "body": {
                    "on": true
                  }
                }
              ]
            }
          },
          "sensors": {
            "9": {
              "name": "Room 1 Motion"
            },
            "10": {
              "name": "Room 1 Lux"
            }
          }
        },
        "output": [
          {
            "name": "Light  ON",
            "conditions": [
              "Room 1 Motion eq true",
              "Room 1 Lux lt 12000"
            ],
            "actions": [
              "Room 1 Main on true"
            ]
          }
        ]
      }
    ],
    "identifier": 75965031
  },
  {
    "context": [
      "All I want is to associate array elements (my attributes) and csv lines (my data) by index:\n\n\"arr[0]\":\"csv[0]\"\n\"arr[1]\":\"csv[1]\"\n...\n\"arr[n-1]\":\"csv[n-1]\"\n\nMy goal is to use something like \"'${ATTRIB_NAMES[i]}'\": $input[i] to get the same result I am getting. The advantage is I can use this script in many different CSV files just reseting ATTRIB_NAMES array.",
      "you could provide the field names as positional arguments using --args, split the linewise inputs at \";\" using /, and match keys and values using with_entries:\n< data.csv jq -Rn '{\n  students: [(inputs / \";\") | with_entries(.key |= $ARGS.positional[.])]\n}' --args name code email   # or --args \"${ATTRIB_NAMES[@]}\"",
      "For a jq 1.5 solution, you could turn the list of field names into a JSON array (either manually or by using another jq filter), and then read it into a variable using --argjson.",
      "If you also want the superordinate key (here \"students\") to be dynamic, just add it the same way using --arg."
    ],
    "utterance": "Associate attribute names provided in order with CSV fields by index, producing an array of objects that map field names to CSV values, with the option to specify a dynamic outermost key.",
    "expressions": [
      "< data.csv jq -Rn '{students: [(inputs / \";\") | with_entries(.key |= $ARGS.positional[.]) ]}' --args name code email",
      "< data.csv jq -Rn '{students: [(inputs / \";\") | with_entries(.key |= $names[.]) ]}' --argjson names '[\"name\", \"code\", \"email\"]'",
      "< data.csv jq -Rn '{students: [(inputs / \";\") | with_entries(.key |= ($names / \" \")[.]) ]}' --arg names 'name code email'",
      "< data.csv jq -Rn --arg key students '{($key): [(inputs / \";\") | with_entries(.key |= $ARGS.positional[.]) ]}' --args name code email"
    ],
    "data": [
      {
        "input": "x;y;z\na;b;c\n",
        "output": {
          "students": [
            {
              "name": "x",
              "code": "y",
              "email": "z"
            },
            {
              "name": "a",
              "code": "b",
              "email": "c"
            }
          ]
        }
      }
    ],
    "identifier": 76000829
  },
  {
    "context": [
      "I would like to replace `\"arn:123456:layer:my-layer:5\"` with `\"arn:123456:layer:my-layer:8\"` and I need to identify which element I want to replace the last portion of by specifying a regular expression on `.*my-layer.*`",
      "but of course this gives me back only the singular element I replaced:",
      "But I need it to give me the original array with just that 1 element changed.",
      "map(sub( \":my-layer.*\";  \":my-layer:8\"))",
      "(first( range(0;length) as $i | .[$i] | select(test(\"my-layer:[0-9]*$\")) | $i) // null) as $i\n| if $i then .[$i] |= sub( \":my-layer:.*\";  \":my-layer:8\") else . end"
    ],
    "utterance": "Replace the element in the array that matches the pattern 'my-layer' with its suffix changed from ':5' to ':8', preserving the original array structure.",
    "expressions": [
      "map(sub(\":my-layer.*\";  \":my-layer:8\"))",
      "(first( range(0;length) as $i | .[$i] | select(test(\"my-layer:[0-9]*$\")) | $i) // null) as $i\n| if $i then .[$i] |= sub(\":my-layer:.*\";  \":my-layer:8\") else . end"
    ],
    "data": [
      {
        "input": [
          "arn:123456:layer:my-layer:5",
          "arn:123456:layer:their-layer:1"
        ],
        "output": [
          "arn:123456:layer:my-layer:8",
          "arn:123456:layer:their-layer:1"
        ]
      }
    ],
    "identifier": 76019927
  },
  {
    "context": [
      "I am executing below jq command -\r\n\r\n```\r\njq -r '.[] | .[] | [.InstID, .Name, .ImageID, .Architecture, .OS, .InstType, (.CpuCore|tostring), (.ThreadsPerCore|tostring), .PrivIP, .Status, ((.VolID[]|[.])|join(\",\"))] | join(\"|\")'\r\n```",
      "I am expecting output as -\r\n\r\n```\r\ni-049c7aa5976d78ab3|dr-psoft-report01|ami-09a868b800080436e|x86_64|Windows|z1d.large|1|2|10.77.132.218|stopped|vol-07498f95efef04f85\r\ni-05831bbd78bcfb9ac|dr-psoft-web01|ami-09a868b800080436e|x86_64|Windows|t3.xlarge|2|2|10.77.132.170|stopped|vol-0b9390e079150ac1c,vol-0cd2df67aa096af52,vol-090c0d3290e1c4dad\r\ni-0a6ef93417cc064eb|dr-psoft-app01|ami-09a868b800080436e|x86_64|Windows|z1d.xlarge|2|2|10.77.132.139|stopped|vol-00a5285f92f18b9ee,vol-0b979d1b578a1d672\r\n```",
      "The correct jq is -\r\n```\r\njq -r '.[] | .[] | [.InstID, .Name, .ImageID, .Architecture, .OS, .InstType, (.CpuCore|tostring), (.ThreadsPerCore|tostring), .PrivIP, .Status, ([(.VolID[]|.)]|join(\":\"))] | join(\"|\")'\r\n```",
      "Instead, you want to collect all elements into an array, then join: `[.VolID[]]|join(\",\")`.\r\n\r\nBut now, if you look closely, `VolID` already is an array, so there\u2019s no sense in iterating and collecting again, just use the array directly: `.VolID|join(\",\")`.",
      "Make that:\r\n\r\n```\r\njq -r '\r\n.[][]\r\n| [.InstID, .Name, .ImageID, .Architecture, .OS, .InstType, .CpuCore, .ThreadsPerCore, .PrivIP, .Status, (VolID|join(\":\"))]\r\n| join(\"|\")\r\n'\r\n```"
    ],
    "utterance": "For each server, produce a |-delimited line containing InstID, Name, ImageID, Architecture, OS, InstType, CpuCore, ThreadsPerCore, PrivIP, Status, and all VolID values joined by commas as the last field.",
    "expressions": [
      ".[][] | [.InstID, .Name, .ImageID, .Architecture, .OS, .InstType, .CpuCore, .ThreadsPerCore, .PrivIP, .Status, (.VolID | join(\",\"))] | join(\"|\")"
    ],
    "data": [
      {
        "input": [
          [
            {
              "InstID": "i-049c7aa5976d78ab3",
              "Name": "dr-psoft-report01",
              "ImageID": "ami-09a868b800080436e",
              "Architecture": "x86_64",
              "OS": "Windows",
              "InstType": "z1d.large",
              "CpuCore": 1,
              "ThreadsPerCore": 2,
              "VolID": [
                "vol-07498f95efef04f85"
              ],
              "PrivIP": "10.77.132.218",
              "Status": "stopped"
            }
          ],
          [
            {
              "InstID": "i-05831bbd78bcfb9ac",
              "Name": "dr-psoft-web01",
              "ImageID": "ami-09a868b800080436e",
              "Architecture": "x86_64",
              "OS": "Windows",
              "InstType": "t3.xlarge",
              "CpuCore": 2,
              "ThreadsPerCore": 2,
              "VolID": [
                "vol-0b9390e079150ac1c",
                "vol-0cd2df67aa096af52",
                "vol-090c0d3290e1c4dad"
              ],
              "PrivIP": "10.77.132.170",
              "Status": "stopped"
            }
          ],
          [
            {
              "InstID": "i-0a6ef93417cc064eb",
              "Name": "dr-psoft-app01",
              "ImageID": "ami-09a868b800080436e",
              "Architecture": "x86_64",
              "OS": "Windows",
              "InstType": "z1d.xlarge",
              "CpuCore": 2,
              "ThreadsPerCore": 2,
              "VolID": [
                "vol-00a5285f92f18b9ee",
                "vol-0b979d1b578a1d672"
              ],
              "PrivIP": "10.77.132.139",
              "Status": "stopped"
            }
          ]
        ],
        "output": [
          "i-049c7aa5976d78ab3|dr-psoft-report01|ami-09a868b800080436e|x86_64|Windows|z1d.large|1|2|10.77.132.218|stopped|vol-07498f95efef04f85",
          "i-05831bbd78bcfb9ac|dr-psoft-web01|ami-09a868b800080436e|x86_64|Windows|t3.xlarge|2|2|10.77.132.170|stopped|vol-0b9390e079150ac1c,vol-0cd2df67aa096af52,vol-090c0d3290e1c4dad",
          "i-0a6ef93417cc064eb|dr-psoft-app01|ami-09a868b800080436e|x86_64|Windows|z1d.xlarge|2|2|10.77.132.139|stopped|vol-00a5285f92f18b9ee,vol-0b979d1b578a1d672"
        ]
      }
    ],
    "identifier": 75935588
  },
  {
    "context": [
      "For a equivalent json, I can use the `walk` operator to do such thing:\r\n``` bash\r\njq 'walk(if type == \"object\" and has(\"image\") and (.image|type) == \"string\" then .image = \"private.io/\" + .image else . end)' input.json\r\n```",
      "Note: With [kislyuk/yq](https://github.com/kislyuk/yq) or [itchyny/gojq](https://github.com/itchyny/gojq) you can also use your original `walk` filter on your YAML input. Both tools can process YAML files using proper jq syntax.\r\n```sh\r\nyq -y 'walk(\r\n  if type == \"object\" and has(\"image\") and (.image|type) == \"string\" \r\n  then .image |= \"private.io/\" + . else . end\r\n)'\r\n\r\n# or\r\n\r\ngojq --yaml-input --yaml-output 'walk(\r\n  if type == \"object\" and has(\"image\") and (.image|type) == \"string\" \r\n  then .image |= \"private.io/\" + . else . end\r\n)'\r\n```"
    ],
    "utterance": "Add the prefix 'private.io/' to every field named 'image' whose value is a string, recursively in all objects.",
    "expressions": [
      "walk(if type == \"object\" and has(\"image\") and (.image|type) == \"string\" then .image |= \"private.io/\" + . else . end)"
    ],
    "data": [
      {
        "input": {
          "serving": {
            "template": {
              "image": "docker.io/serving"
            }
          },
          "custom": {
            "template": {
              "image": {
                "type": "string",
                "description": "..."
              }
            }
          },
          "eventing": {
            "image": "docker.io/eventing"
          }
        },
        "output": {
          "serving": {
            "template": {
              "image": "private.io/docker.io/serving"
            }
          },
          "custom": {
            "template": {
              "image": {
                "type": "string",
                "description": "..."
              }
            }
          },
          "eventing": {
            "image": "private.io/docker.io/eventing"
          }
        }
      }
    ],
    "identifier": 76032079
  },
  {
    "context": [
      "I'm aiming to remove the duplicated \"type\": \"change\" elements with the same username, but keep the original sorting as it is important.",
      "jq -M '.steps[] | select(.value == \"root\") | unique_by(.value)' yielded error and not sure if this will keep the original sorting:",
      "jq: error (at duplicates_testing.json:178): Cannot index string with string \"value\";"
    ],
    "utterance": "Remove duplicate objects from steps where type is change and value is the same, keeping the first occurrence and preserving the original order.",
    "expressions": [
      ".steps |= (reduce .[] as $item ([]; if $item.type == \"change\" and ($item.value? // null) as $val | $val != null then . + [ $item ] | unique_by(select(.type == \"change\").value) else . + [ $item ] end))"
    ],
    "data": [
      {
        "input": {
          "title": "recording",
          "steps": [
            {
              "type": "setViewport",
              "width": 1651,
              "height": 1080,
              "deviceScaleFactor": 1,
              "isMobile": false,
              "hasTouch": false,
              "isLandscape": false
            },
            {
              "type": "navigate",
              "url": "chrome://new-tab-page/",
              "assertedEvents": [
                {
                  "type": "navigation",
                  "url": "chrome://new-tab-page/",
                  "title": "New Tab"
                }
              ]
            },
            {
              "type": "navigate",
              "url": "https://...",
              "assertedEvents": [
                {
                  "type": "navigation",
                  "url": "https://...",
                  "title": ""
                }
              ]
            },
            {
              "type": "click",
              "target": "main",
              "selectors": [
                [
                  "aria/org"
                ],
                [
                  "body > div > div.login-box-body > div:nth-child(3) > a"
                ],
                [
                  "xpath//html/body/div/div[2]/div[2]/a"
                ],
                [
                  "text/org"
                ]
              ],
              "offsetY": 5,
              "offsetX": 42.79998779296875,
              "assertedEvents": [
                {
                  "type": "navigation",
                  "url": "https:...",
                  "title": ""
                }
              ]
            },
            {
              "type": "change",
              "value": "root",
              "selectors": [
                [
                  "aria/Username or email"
                ],
                [
                  "#username"
                ],
                [
                  "xpath//*[@id=\"username\"]"
                ]
              ],
              "target": "main"
            },
            {
              "type": "doubleClick",
              "target": "main",
              "selectors": [
                [
                  "aria/Username or email"
                ],
                [
                  "#username"
                ],
                [
                  "xpath//*[@id=\"username\"]"
                ],
                [
                  "text/root"
                ]
              ],
              "offsetY": 20.79998779296875,
              "offsetX": 71.39996337890625
            },
            {
              "type": "change",
              "value": "root",
              "selectors": [
                [
                  "aria/Username or email"
                ],
                [
                  "#username"
                ],
                [
                  "xpath//*[@id=\"username\"]"
                ]
              ],
              "target": "main"
            },
            {
              "type": "keyDown",
              "target": "main",
              "key": "Tab"
            },
            {
              "type": "keyUp",
              "key": "Tab",
              "target": "main"
            },
            {
              "type": "change",
              "value": "1111",
              "selectors": [
                [
                  "aria/Password"
                ],
                [
                  "#password"
                ],
                [
                  "xpath//*[@id=\"password\"]"
                ],
                [
                  "text/1111"
                ]
              ],
              "target": "main"
            },
            {
              "type": "keyDown",
              "target": "main",
              "key": "Enter",
              "assertedEvents": [
                {
                  "type": "navigation",
                  "url": "https:...",
                  "title": ""
                }
              ]
            },
            {
              "type": "keyUp",
              "key": "Enter",
              "target": "main"
            },
            {
              "type": "click",
              "target": "main",
              "selectors": [
                [
                  "aria/\uf085 Manager"
                ],
                [
                  "body > div.wrapper > div > section.content > div.row.app-grid > div:nth-child(2) > a"
                ],
                [
                  "xpath//html/body/div[2]/div/section[2]/div[2]/div[2]/a"
                ]
              ],
              "offsetY": 129,
              "offsetX": 177.79998779296875
            }
          ]
        },
        "output": {
          "title": "recording",
          "steps": [
            {
              "type": "setViewport",
              "width": 1651,
              "height": 1080,
              "deviceScaleFactor": 1,
              "isMobile": false,
              "hasTouch": false,
              "isLandscape": false
            },
            {
              "type": "navigate",
              "url": "chrome://new-tab-page/",
              "assertedEvents": [
                {
                  "type": "navigation",
                  "url": "chrome://new-tab-page/",
                  "title": "New Tab"
                }
              ]
            },
            {
              "type": "navigate",
              "url": "https://...",
              "assertedEvents": [
                {
                  "type": "navigation",
                  "url": "https://...",
                  "title": ""
                }
              ]
            },
            {
              "type": "click",
              "target": "main",
              "selectors": [
                [
                  "aria/org"
                ],
                [
                  "body > div > div.login-box-body > div:nth-child(3) > a"
                ],
                [
                  "xpath//html/body/div/div[2]/div[2]/a"
                ],
                [
                  "text/org"
                ]
              ],
              "offsetY": 5,
              "offsetX": 42.79998779296875,
              "assertedEvents": [
                {
                  "type": "navigation",
                  "url": "https:...",
                  "title": ""
                }
              ]
            },
            {
              "type": "change",
              "value": "root",
              "selectors": [
                [
                  "aria/Username or email"
                ],
                [
                  "#username"
                ],
                [
                  "xpath//*[@id=\"username\"]"
                ]
              ],
              "target": "main"
            },
            {
              "type": "doubleClick",
              "target": "main",
              "selectors": [
                [
                  "aria/Username or email"
                ],
                [
                  "#username"
                ],
                [
                  "xpath//*[@id=\"username\"]"
                ],
                [
                  "text/root"
                ]
              ],
              "offsetY": 20.79998779296875,
              "offsetX": 71.39996337890625
            },
            {
              "type": "keyDown",
              "target": "main",
              "key": "Tab"
            },
            {
              "type": "keyUp",
              "key": "Tab",
              "target": "main"
            },
            {
              "type": "change",
              "value": "1111",
              "selectors": [
                [
                  "aria/Password"
                ],
                [
                  "#password"
                ],
                [
                  "xpath//*[@id=\"password\"]"
                ],
                [
                  "text/1111"
                ]
              ],
              "target": "main"
            },
            {
              "type": "keyDown",
              "target": "main",
              "key": "Enter",
              "assertedEvents": [
                {
                  "type": "navigation",
                  "url": "https:...",
                  "title": ""
                }
              ]
            },
            {
              "type": "keyUp",
              "key": "Enter",
              "target": "main"
            },
            {
              "type": "click",
              "target": "main",
              "selectors": [
                [
                  "aria/\uf085 Manager"
                ],
                [
                  "body > div.wrapper > div > section.content > div.row.app-grid > div:nth-child(2) > a"
                ],
                [
                  "xpath//html/body/div[2]/div/section[2]/div[2]/div[2]/a"
                ]
              ],
              "offsetY": 129,
              "offsetX": 177.79998779296875
            }
          ]
        }
      }
    ],
    "identifier": 75939289
  },
  {
    "context": [
      "Is there a shorter way to count recursively in an arbitrarily structured JSON?",
      "Likewise, you could iterate recursively using `..`, and consider only `scalars` (or `numbers`):",
      "jq 'reduce (.. | scalars) as $v (0; if $v == 3 then .+1 else . end)'",
      "Or move the condition into the iteration generator, so you can count unconditionally in the body:",
      "jq 'reduce (.. | select(numbers == 3)) as $_ (0; .+1)'"
    ],
    "utterance": "Count all occurrences of the number 3 anywhere in a nested structure.",
    "expressions": [
      "reduce (.. | scalars) as $v (0; if $v == 3 then .+1 else . end)",
      "reduce (.. | select(numbers == 3)) as $_ (0; .+1)"
    ],
    "data": [
      {
        "input": {
          "a": 3,
          "b": 4,
          "c": 3,
          "d": {
            "e": 3
          },
          "f": 6
        },
        "output": 3
      }
    ],
    "identifier": 76037803
  },
  {
    "context": [
      "I am trying to convert the below json to a markdown table(GitHub docs(.md file)), however not able to do so.",
      "Expected output:",
      "|    NAME    | ENDPOINT_ID |",
      "| --------   | -------- |",
      "| service_1  | abc-endpoint.vpce.amazonaws.com   |",
      "| service_2  | def-endpoint.vpce.amazonaws.com   |",
      "| service_3  | xyz-endpoint.vpce.amazonaws.com   |",
      "\"|NAME|ENDPOINT_ID|\\n|------|------|\\n\" + \n    (to_entries | map(\"|\\(.key)|\\(.value)|\") | join(\"\\n\"))",
      "% jq -r  '{\"NAME\": \"ENDPOINT_ID\"} + {\"---\": \"---\"} + . | to_entries[] | \"|\\(.key)|\\(.value)|\"'"
    ],
    "utterance": "Format key-value pairs as a Markdown table with header 'NAME' and 'ENDPOINT_ID', followed by a separator row and one row per service, where each key is the name and each value is the endpoint.",
    "expressions": [
      "\"|NAME|ENDPOINT_ID|\\n|------|------|\\n\" + (to_entries | map(\"|\\(.key)|\\(.value)|\") | join(\"\\n\"))",
      "'{\"NAME\": \"ENDPOINT_ID\"} + {\"---\": \"---\"} + . | to_entries[] | \"|\\(.key)|\\(.value)|\"'"
    ],
    "data": [
      {
        "input": {
          "service_1": "abc-endpoint.vpce.amazonaws.com",
          "service_2": "def-endpoint.vpce.amazonaws.com",
          "service_3": "xyz-endpoint.vpce.amazonaws.com"
        },
        "output": "|NAME|ENDPOINT_ID|\n|------|------|\n|service_1|abc-endpoint.vpce.amazonaws.com|\n|service_2|def-endpoint.vpce.amazonaws.com|\n|service_3|xyz-endpoint.vpce.amazonaws.com|"
      }
    ],
    "identifier": 76036576
  },
  {
    "context": [
      "I would like a whole word match, which would disqualify \"rem\" and only allow one of the three values in the input.",
      "you want to receive `true` if `any` (=at least one) of the items equals (`==`) a given value:",
      "$ echo '[\"lorem\", \"ipsum\", \"dolor\"]' | jq 'any(. == \"lorem\")'",
      "true",
      "$ echo '[\"lorem\", \"ipsum\", \"dolor\"]' | jq 'any(. == \"rem\")'",
      "false",
      "you want to receive `true` if a given value is contained `IN` a set of items `.[]`:",
      "$ echo '[\"lorem\", \"ipsum\", \"dolor\"]' | jq 'IN(.[]; \"lorem\")'",
      "true",
      "$ echo '[\"lorem\", \"ipsum\", \"dolor\"]' | jq 'IN(.[]; \"rem\")'",
      "false"
    ],
    "utterance": "Return true only if any string in an array exactly matches the value 'lorem'; return false if it does not.",
    "expressions": [
      "any(. == \"lorem\")",
      "IN(.[]; \"lorem\")"
    ],
    "data": [
      {
        "input": [
          "lorem",
          "ipsum",
          "dolor"
        ],
        "output": true
      },
      {
        "input": [
          "lorem",
          "ipsum",
          "dolor"
        ],
        "output": false
      }
    ],
    "identifier": 76039581
  },
  {
    "context": [
      "What I am looking for is to try to get the parent continent and parent city of each range beside each other as comma separated,",
      "`165.225.240.0/23, EMEA, Amsterdam II`",
      "Here\u0019s the solution that matches the desired output from the question:\r\n```\r\n.[\"zscaler.net\"] | to_entries[]\r\n| (.key|ltrimstr(\"continent : \")) as $cont\r\n| .value | to_entries[]\r\n| \"\\(.value[].range), \\($cont), \\(.key|ltrimstr(\"city : \"))\"\r\n```\r\nOutput:\r\n```\r\n165.225.240.0/23, EMEA, Amsterdam II\r\n147.161.132.0/23, EMEA, Amsterdam II\r\n147.161.156.0/23, EMEA, Brussels II\r\n104.129.204.0/23, Americas, Atlanta II\r\n136.226.2.0/23, Americas, Atlanta II\r\n```",
      ".[\"zscaler.net\"] | tostream\r\n| select(.[0][-1] == \"range\")\r\n| [.[-1], .[0][0:2][]|split(\":\")[-1]]\r\n| join(\",\")",
      ".[\"zscaler.net\"][] | to_entries[] | .key as $k | .value[] | [ .range, ($k | sub(\"city : \"; \"\" )) ] | join(\", \")"
    ],
    "utterance": "List each range along with its corresponding continent and city names, separated by commas, including all continents and cities.",
    "expressions": [
      ".[\"zscaler.net\"] | to_entries[]\n| (.key|ltrimstr(\"continent : \")) as $cont\n| .value | to_entries[]\n| \"\\(.value[].range), \\($cont), \\(.key|ltrimstr(\"city : \"))\"",
      ".[\"zscaler.net\"] | tostream\n| select(.[0][-1] == \"range\")\n| [.[-1], .[0][0:2][]|split(\":\")[-1]]\n| join(\", \")"
    ],
    "data": [
      {
        "input": {
          "zscaler.net": {
            "continent : EMEA": {
              "city : Amsterdam II": [
                {
                  "range": "165.225.240.0/23",
                  "vpn": "ams2-2-vpn.zscaler.net",
                  "gre": "165.225.240.12",
                  "hostname": "ams2-2.sme.zscaler.net",
                  "latitude": "52",
                  "longitude": "5"
                },
                {
                  "range": "147.161.132.0/23",
                  "vpn": "",
                  "gre": "",
                  "hostname": "",
                  "latitude": "52",
                  "longitude": "5"
                }
              ],
              "city : Brussels II": [
                {
                  "range": "147.161.156.0/23",
                  "vpn": "",
                  "gre": "",
                  "hostname": "",
                  "latitude": "50",
                  "longitude": "5"
                }
              ]
            },
            "continent : Americas": {
              "city : Atlanta II": [
                {
                  "range": "104.129.204.0/23",
                  "vpn": "atl2-vpn.zscaler.net",
                  "gre": "104.129.204.32",
                  "hostname": "atl2.sme.zscaler.net",
                  "latitude": "34",
                  "longitude": "-84"
                },
                {
                  "range": "136.226.2.0/23",
                  "vpn": "",
                  "gre": "104.129.204.32",
                  "hostname": "",
                  "latitude": "34",
                  "longitude": "-84"
                }
              ]
            }
          }
        },
        "output": [
          "165.225.240.0/23, EMEA, Amsterdam II",
          "147.161.132.0/23, EMEA, Amsterdam II",
          "147.161.156.0/23, EMEA, Brussels II",
          "104.129.204.0/23, Americas, Atlanta II",
          "136.226.2.0/23, Americas, Atlanta II"
        ]
      }
    ],
    "identifier": 75983859
  },
  {
    "context": [
      "I want to globally increment the value of \"id\" on all files without resetting the number between files.",
      "What I want is to increment id for all files, so say if one combines two separate files, the id fields will remain unique and numeric.",
      "Expected result:\n\n**file1.json:**\n```\n[\n    {\n        \"id\": 1,\n        \"name\": \"John\"\n    },\n    {\n        \"id\": 2,\n        \"name\": \"Mary\"\n    }\n]\n```\n\n**file2.json:**\n```\n[\n    {\n        \"id\": 3,\n        \"name\": \"mulberry\"\n    },\n    {\n        \"id\": 4,\n        \"name\": \"strawberry\"\n    }\n]\n```",
      "jq --argjson id $start_id '.[] |= . + {\"id\": ($id + (.id-1))}' \"$file\" > tmp.json && mv tmp.json \"$file\""
    ],
    "utterance": "Increment the \"id\" field in each object across multiple files so all ids remain unique and sequential without resetting for each file.",
    "expressions": [
      ".[] |= . + {\"id\": ($id + (.id-1))}"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": 1,
              "name": "John"
            },
            {
              "id": 2,
              "name": "Mary"
            }
          ],
          [
            {
              "id": 1,
              "name": "mulberry"
            },
            {
              "id": 2,
              "name": "strawberry"
            }
          ]
        ],
        "output": [
          [
            {
              "id": 1,
              "name": "John"
            },
            {
              "id": 2,
              "name": "Mary"
            }
          ],
          [
            {
              "id": 3,
              "name": "mulberry"
            },
            {
              "id": 4,
              "name": "strawberry"
            }
          ]
        ]
      }
    ],
    "identifier": 76040653
  },
  {
    "context": [
      "But I am having trouble changing subfields like ```name``` within the ```issuetype``` field.",
      "Running the command listed for modifying subfield, I got expected results..",
      "field=\"issuetype\"",
      "subfield=\"name\"",
      "value=\"issue type hello world\"",
      "jq --arg field \"$field\" --arg value \"$value\" --arg subfield \"$subfield\" '.fields[$field][$subfield] = $value' issue_fields.json",
      "Output:",
      "{",
      "  \"fields\": {",
      "    \"summary\": \"\",",
      "    \"issuetype\": {",
      "      \"self\": \"\",",
      "      \"id\": \"\",",
      "      \"description\": \"\",",
      "      \"iconUrl\": \"\",",
      "      \"name\": \"issue type hello world\",",
      "      \"subtask\": true,",
      "      \"avatarId\": 17116",
      "    }",
      "  }",
      "}"
    ],
    "utterance": "Update the value of 'fields.issuetype.name' to 'issue type hello world'.",
    "expressions": [
      ".fields[\"issuetype\"][\"name\"] = \"issue type hello world\"",
      "jq --arg field \"issuetype\" --arg subfield \"name\" --arg value \"issue type hello world\" '.fields[$field][$subfield] = $value' issue_fields.json"
    ],
    "data": [
      {
        "input": {
          "fields": {
            "summary": "",
            "issuetype": {
              "self": "",
              "id": "",
              "description": "",
              "iconUrl": "",
              "name": "",
              "subtask": true,
              "avatarId": 17116
            }
          }
        },
        "output": {
          "fields": {
            "summary": "",
            "issuetype": {
              "self": "",
              "id": "",
              "description": "",
              "iconUrl": "",
              "name": "issue type hello world",
              "subtask": true,
              "avatarId": 17116
            }
          }
        }
      }
    ],
    "identifier": 76035986
  },
  {
    "context": [
      "I'm trying to write a bash/shell script which checks this file using jq and if it sees that any of the \"trigger\" objects contain a threatLevel greater than or equal to a variable defined in GitLab CI/CD variables.",
      "if (jq 'any(.threatLevel | contains (>=${THRESHOLD_VALUE}))') results.json; then",
      "You should use the comparison operator \">=\" directly instead of \"contains\".",
      "Here's a revised version:",
      "if jq '[.policyEvaluationResult.alerts[] | select(.trigger.threatLevel >= env.THRESHOLD_VALUE)] | length > 0' results.json >/dev/null; then",
      "if >/dev/null jq --argjson th ${THRESHOLD_VALUE} --stream -en '\n  any(inputs | select(.[0][-1] == \"threatLevel\")[1]; . > $th)' results.json \nthen"
    ],
    "utterance": "Determine if any trigger object's threatLevel field is greater than or equal to a given threshold value defined in an environment variable.",
    "expressions": [
      "[.policyEvaluationResult.alerts[] | select(.trigger.threatLevel >= env.THRESHOLD_VALUE)] | length > 0",
      "--argjson th ${THRESHOLD_VALUE} --stream -en 'any(inputs | select(.[0][-1] == \"threatLevel\")[1]; . > $th)'"
    ],
    "data": [
      {
        "input": {
          "applicationId": "application",
          "scanId": "scanId",
          "policyEvaluationResult": {
            "alerts": [
              {
                "trigger": {
                  "policyId": "pid1",
                  "policyName": "Security-High",
                  "threatLevel": 9,
                  "policyViolationId": "pvid1"
                }
              },
              {
                "trigger": {
                  "policyId": "pid2",
                  "policyName": "Security-Low",
                  "threatLevel": 1,
                  "policyViolationId": "pvid2"
                }
              }
            ]
          }
        },
        "output": true
      }
    ],
    "identifier": 76042819
  },
  {
    "context": [
      "I want to loop the `list.json` and read the `item.json` use the `id` to mapping the current item in the loop if the `id` is matched, if matched , merge it into the list item.",
      "I hope the result is this",
      "[\n    {\n        \"id\": \"123456\",\n        \"name\": \"David\", // merged\n        \"age\": \"12\"\n    },\n    {\n        \"id\": \"654321\",\n        \"age\": \"13\"\n    }\n]",
      "jq --slurpfile item item.json \\\n    'map(if .id == $item[0].id then (. * $item[0]) else . end)' \\\nlist.json",
      "jq -s '[0] as $n | .[1] | map(select(.id == $n.id) *= $n)' item.json list.json",
      "Both options outputs:\n[\n  {\n    \"id\": \"123456\",\n    \"age\": \"12\",\n    \"name\": \"David\"\n  },\n  {\n    \"id\": \"654321\",\n    \"age\": \"13\"\n  }\n]"
    ],
    "utterance": "For each object in the list, merge in fields from the item object if the id fields match.",
    "expressions": [
      "map(if .id == $item[0].id then (. * $item[0]) else . end)",
      ".[0] as $n | .[1] | map(select(.id == $n.id) *= $n)"
    ],
    "data": [
      {
        "input": {
          "item.json": {
            "id": "123456",
            "name": "David"
          },
          "list.json": [
            {
              "id": "123456",
              "age": "12"
            },
            {
              "id": "654321",
              "age": "13"
            }
          ]
        },
        "output": [
          {
            "id": "123456",
            "name": "David",
            "age": "12"
          },
          {
            "id": "654321",
            "age": "13"
          }
        ]
      }
    ],
    "identifier": 76043585
  },
  {
    "identifier": 76056894
  },
  {
    "context": [
      "From this, I want to generate the following string -",
      "@types/lodash.camelcase@^4.3.6 @types/lodash.kebabcase@^4.1.6 @types/lodash.lowercase@^4.3.6 @types/lodash.upperfirst@^4.3.6 @types/mime@^2.0.3 @types/swagger-jsdoc@^6.0.1 async@^3.2.2 aws-arn@^1.0.1",
      "jq -r '.dependencies | to_entries | map(join(\"@\")) | join(\" \")' package.json",
      ".dependencies | to_entries | map(\"\\(.key)@\\(.value)\") | join(\" \")"
    ],
    "utterance": "Create a space-separated string of dependency names and versions in the format name@version from the dependencies field, preserving key order.",
    "expressions": [
      ".dependencies | to_entries | map(join(\"@\")) | join(\" \")",
      ".dependencies | to_entries | map(\"\\(.key)@\\(.value)\") | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "dependencies": {
            "@types/lodash.camelcase": "^4.3.6",
            "@types/lodash.kebabcase": "^4.1.6",
            "@types/lodash.lowercase": "^4.3.6",
            "@types/lodash.upperfirst": "^4.3.6",
            "@types/mime": "^2.0.3",
            "@types/swagger-jsdoc": "^6.0.1",
            "async": "^3.2.2",
            "aws-arn": "^1.0.1"
          }
        },
        "output": "@types/lodash.camelcase@^4.3.6 @types/lodash.kebabcase@^4.1.6 @types/lodash.lowercase@^4.3.6 @types/lodash.upperfirst@^4.3.6 @types/mime@^2.0.3 @types/swagger-jsdoc@^6.0.1 async@^3.2.2 aws-arn@^1.0.1"
      }
    ],
    "identifier": 76051416
  },
  {
    "context": [
      "I got keys through\n\n```keys=$(echo \"$tags\" | jq -r 'keys[]')``` where $tags is a json output",
      "for key in $keys; do\n    value=$(echo $tags | jq -r .[key])\n    echo \"$key has value $value\"\ndone",
      "Is there an easy way to pass a variable to jq to get the key value",
      "$ echo \"$tags\" |jq -r 'to_entries[] | \"\\(.key) has value \\(.value)\"'",
      "for key in $keys; do value=$(echo $tags | jq --arg k \"$key\" -r '.[$k]'); echo \"$key has value $value\";done"
    ],
    "utterance": "Loop over all key-value pairs and print each key with its corresponding value using the format: key has value value.",
    "expressions": [
      "to_entries[] | \"\\(.key) has value \\(.value)\"",
      "--arg k \"$key\" -r '.[$k]'"
    ],
    "data": [
      {
        "input": {
          "project": "en.wikipedia",
          "article": "Talking_Heads_discography",
          "granularity": "daily",
          "timestamp": "2021092800",
          "access": "all-access",
          "agent": "all-agents",
          "views": 381
        },
        "output": [
          "project has value en.wikipedia",
          "article has value Talking_Heads_discography",
          "granularity has value daily",
          "timestamp has value 2021092800",
          "access has value all-access",
          "agent has value all-agents",
          "views has value 381"
        ]
      }
    ],
    "identifier": 76055335
  },
  {
    "context": [
      "select all of the entries based upon the file in each entry starting with a path from a list of desired root paths",
      "main_target_path_array produces the following array for selecting the files from the compile_commands.json sample above:\n[\"src/libAlpha/\",\"src/libBeta/\",\"src/libGamma/\"]",
      "map(select(.file | any($mainpaths[]; startswith(.))))",
      "select( .file as $file | any($main_target_path[]; . as $match | $file | startswith($match)))"
    ],
    "utterance": "Select all objects whose \"file\" value starts with any of the strings in [\"src/libAlpha/\",\"src/libBeta/\",\"src/libGamma/\"]",
    "expressions": [
      "[\"src/libAlpha/\",\"src/libBeta/\",\"src/libGamma/\"] as $main_target_path | map(select(.file | any($main_target_path[]; startswith(.))))",
      "[\"src/libAlpha/\",\"src/libBeta/\",\"src/libGamma/\"] as $main_target_path | .[] | select(.file as $file | any($main_target_path[]; . as $match | $file | startswith($match)))",
      "[\"src/libAlpha/\",\"src/libBeta/\",\"src/libGamma/\"] as $main_target_path | .[] | select($main_target_path | any(. as $match | .file | startswith($match)))"
    ],
    "data": [
      {
        "input": [
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_X1 -o src/lib/X_core1/CMakeFiles/X_core.dir/src/A.c.o -c src/lib/A.c",
            "file": "src/libAlpha/A.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Y1 -o src/lib/X_core2/CMakeFiles/Y_core.dir/src/A.c.o -c src/lib/A.c",
            "file": "src/libBeta/A.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/A.c.o -c src/lib/A.c",
            "file": "src/libGamma/A.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/B.c.o -c src/lib/B.c",
            "file": "src/lib/B.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_X1 -o src/lib/X_core/CMakeFiles/X_core.dir/src/B.c.o -c src/lib/B.c",
            "file": "src/lib/B.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/C.c.o -c src/lib/C.c",
            "file": "src/lib/C.c"
          }
        ],
        "output": [
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_X1 -o src/lib/X_core1/CMakeFiles/X_core.dir/src/A.c.o -c src/lib/A.c",
            "file": "src/libAlpha/A.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Y1 -o src/lib/X_core2/CMakeFiles/Y_core.dir/src/A.c.o -c src/lib/A.c",
            "file": "src/libBeta/A.c"
          },
          {
            "directory": "/repository/build/build",
            "command": "/usr/bin/gcc -Wall -DMACRO_FOR_Z1 -DBOBS_SPECIAL_MACRO -o src/lib/Z_core/CMakeFiles/Z_core.dir/src/A.c.o -c src/lib/A.c",
            "file": "src/libGamma/A.c"
          }
        ]
      }
    ],
    "identifier": 76050134
  },
  {
    "context": [
      "I want to extract all the properties `name` of each element, in a **single column**, separated by a character (not comma **,**).",
      "This is the result I wish to get (with a command I couldn't find yet):",
      "id_card,name,labels\n6426edc70426309fa3bb0ccd,titre de la carte 1,\"label-red-label;label-green-label\"\n6426edc70426309fa3bb0eef,titre de la carte 2,\"label-red-label\"\n6426edc70426309fa3bb0dde,titre de la carte 3,\"label-green-label\"",
      "I didn't manage to use the `| join(\";\")` properly, but it might be a solution",
      "I found that using `[.labels.[].name] | join(\";\") ` works to put a `;` between each element.",
      "The full command:\ndocker run --rm -v \"${PWD}\":/workdir mikefarah/yq -o=csv  '[[ \"id_card\", \"name\", \"labels\"]] +  [.[] | [ .id, .name, [.labels.[].name] | join(\";\") ]]' sample.json"
    ],
    "utterance": "Output a table with each object's id, name, and the label names joined by semicolons as a single string.",
    "expressions": [
      "[[ \"id_card\", \"name\", \"labels\" ]] + [ .[] | [ .id, .name, [ .labels[].name ] | join(\";\") ] ]"
    ],
    "data": [
      {
        "input": [
          {
            "id": "6426edc70426309fa3bb0ccd",
            "labels": [
              {
                "id": "6425a8e74720c87ca4219d8f",
                "idBoard": "xxx",
                "name": "label-red-label",
                "color": "red"
              },
              {
                "id": "642aa09cd201f3dd2e12b6f6",
                "idBoard": "xxx",
                "name": "label-green-label",
                "color": "green"
              }
            ],
            "idLabels": [
              "6425a8e74720c87ca4219d8f",
              "642aa09cd201f3dd2e12b6f6"
            ],
            "name": "titre de la carte 1",
            "url": "https://trello.com/c/url-carte-1"
          },
          {
            "id": "6426edc70426309fa3bb0eef",
            "labels": [
              {
                "id": "6425a8e74720c87ca4219d8f",
                "idBoard": "xxx",
                "name": "label-red-label",
                "color": "red"
              }
            ],
            "idLabels": [
              "6425a8e74720c87ca4219d8f"
            ],
            "name": "titre de la carte 2",
            "url": "https://trello.com/c/url-carte-2"
          },
          {
            "id": "6426edc70426309fa3bb0dde",
            "labels": [
              {
                "id": "642aa09cd201f3dd2e12b6f6",
                "idBoard": "xxx",
                "name": "label-green-label",
                "color": "green"
              }
            ],
            "idLabels": [
              "642aa09cd201f3dd2e12b6f6"
            ],
            "name": "titre de la carte 3",
            "url": "https://trello.com/c/url-carte-3"
          }
        ],
        "output": [
          [
            "id_card",
            "name",
            "labels"
          ],
          [
            "6426edc70426309fa3bb0ccd",
            "titre de la carte 1",
            "label-red-label;label-green-label"
          ],
          [
            "6426edc70426309fa3bb0eef",
            "titre de la carte 2",
            "label-red-label"
          ],
          [
            "6426edc70426309fa3bb0dde",
            "titre de la carte 3",
            "label-green-label"
          ]
        ]
      }
    ],
    "identifier": 76049723
  },
  {
    "context": [
      "I want to output the filename when a value is found in a particular array within a JSON object using `jq`.",
      "I want to get the filenames when `tags[value1]` exists.",
      "The filter is called `input_filename` (see the manual). Also, with jq 1.6+ you can use the SQL-Style Operator IN to check for the existence of an item within an array.",
      "jq -r 'select(IN(.data.tags[]; \"value1\")) | input_filename' -- *.json"
    ],
    "utterance": "List the filenames of files where the array at data.tags contains the value \"value1\".",
    "expressions": [
      "select(IN(.data.tags[]; \"value1\")) | input_filename"
    ],
    "data": [
      {
        "input": {
          "data": {
            "tags": [
              "value1",
              "value2"
            ]
          }
        }
      }
    ],
    "identifier": 76096730
  },
  {
    "context": [
      "I would like it to output as CSV like:\r\n```\r\nStudent Host ID,Student ID,Student Created\r\n\"1234567890\",\"12345\",\"04/27/2017 16:29:40\"\r\n\"2345678901\",\"23456\",\"04/27/2017 16:29:50\"\r\n```",
      "I have a bunch of exports with different fields, and the actual exports can contain more than 50 fields, so I\u2019d rather it if JQ worked out the headers automagically so I can use the same command with different files.",
      "Thus far, I have...: jq -r '.results.rows[] | [.columns[].value] | map(if type==\"string\" then gsub(\"^\\\\s+|\\\\s+$\";\"\") else . end) | @csv'",
      "Putting together your snippets like so (fetching the header names from the first row):\r\n```sh\r\njq -r '\r\n  [.results.rows[0].columns[].name], (\r\n    .results.rows[] | [.columns[].value]\r\n    | map(if type==\"string\" then gsub(\"^\\\\s+|\\\\s+$\";\"\") else . end)\r\n  )\r\n  | @csv\r\n'\r\n```"
    ],
    "utterance": "Output rows as CSV with column headers inferred automatically from the 'name' field in the column definitions and values cleaned of extra whitespace.",
    "expressions": [
      ". as $data | [ $data.results.rows[0].columns[].name ], ( $data.results.rows[] | [ .columns[].value ] | map(if type==\"string\" then gsub(\"^\\s+|\\s+$\";\"\") else . end) ) | @csv",
      "[.results.rows[0].columns[].name], ( .results.rows[] | [.columns[].value] | map(if type==\"string\" then gsub(\"^\\s+|\\s+$\";\"\") else . end) ) | @csv"
    ],
    "data": [
      {
        "input": {
          "count": 804,
          "page": 1,
          "results": {
            "rows": [
              {
                "columns": [
                  {
                    "name": "Student Host ID",
                    "value": "1234567890     "
                  },
                  {
                    "name": "Student ID",
                    "value": "12345"
                  },
                  {
                    "name": "Student Created",
                    "value": "04/27/2017 16:29:40"
                  }
                ]
              },
              {
                "columns": [
                  {
                    "name": "Student Host ID",
                    "value": "2345678901     "
                  },
                  {
                    "name": "Student ID",
                    "value": "23456"
                  },
                  {
                    "name": "Student Created",
                    "value": "04/27/2017 16:29:50"
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "\"Student Host ID\",\"Student ID\",\"Student Created\"",
          "\"1234567890\",\"12345\",\"04/27/2017 16:29:40\"",
          "\"2345678901\",\"23456\",\"04/27/2017 16:29:50\""
        ]
      }
    ],
    "identifier": 76060235
  },
  {
    "context": [
      "how do i get rid of this null ouput.",
      "Because i want to use the revision id value on another steps.",
      ".actions[] | select(.lastBuiltRevision) | .lastBuiltRevision.branch[].SHA1",
      ".actions[] | try .lastBuiltRevision.branch[] | .SHA1"
    ],
    "utterance": "Extract all SHA1 values under lastBuiltRevision.branch from the actions array, omitting null outputs.",
    "expressions": [
      ".actions[] | select(.lastBuiltRevision) | .lastBuiltRevision.branch[].SHA1",
      ".actions[] | try .lastBuiltRevision.branch[] | .SHA1"
    ],
    "data": [
      {
        "input": {
          "actions": [
            {
              "_class": "hudson.model.CauseAction",
              "causes": [
                {
                  "_class": "hudson.triggers.SCMTrigger$SCMTriggerCause",
                  "shortDescription": "Started by an SCM change"
                }
              ]
            },
            {},
            {
              "_class": "jenkins.metrics.impl.TimeInQueueAction",
              "blockedDurationMillis": 0,
              "blockedTimeMillis": 0,
              "buildableDurationMillis": 0,
              "buildableTimeMillis": 0,
              "buildingDurationMillis": 499235,
              "executingTimeMillis": 499235,
              "executorUtilization": 1,
              "subTaskCount": 0,
              "waitingDurationMillis": 6006,
              "waitingTimeMillis": 6006
            },
            {},
            {},
            {
              "_class": "hudson.plugins.git.util.BuildData",
              "buildsByBranchName": {
                "refs/remotes/origin/<branch name>": {
                  "_class": "hudson.plugins.git.util.Build",
                  "buildNumber": 6,
                  "buildResult": null,
                  "marked": {
                    "SHA1": "4bvdcaeacjd652d9abb85",
                    "branch": [
                      {
                        "SHA1": "4bvdcaeacjd652d9abb85",
                        "name": "refs/remotes/origin/<branch name>"
                      }
                    ]
                  },
                  "revision": {
                    "SHA1": "4bvdcaeacjd652d9abb85",
                    "branch": [
                      {
                        "SHA1": "4bvdcaeacjd652d9abb85",
                        "name": "refs/remotes/origin/<branch name>"
                      }
                    ]
                  }
                }
              },
              "lastBuiltRevision": {
                "SHA1": "4bvdcaeacjd652d9abb85",
                "branch": [
                  {
                    "SHA1": "4bvdcaeacjd652d9abb85",
                    "name": "refs/remotes/origin/<branch name>"
                  }
                ]
              },
              "remoteUrls": [
                "<remote git url>"
              ],
              "scmName": ""
            },
            {},
            {
              "_class": "hudson.maven.reporters.MavenAggregatedArtifactRecord"
            },
            {},
            {
              "_class": "hudson.plugins.jira.JiraBuildAction"
            },
            {},
            {
              "_class": "org.jenkinsci.plugins.buildenvironment.actions.BuildEnvironmentBuildAction"
            },
            {
              "_class": "hudson.plugins.disk_usage.BuildDiskUsageAction"
            },
            {},
            {
              "_class": "org.jenkinsci.plugins.displayurlapi.actions.RunDisplayAction"
            }
          ]
        },
        "output": [
          "4bvdcaeacjd652d9abb85"
        ]
      }
    ],
    "identifier": 76060883
  },
  {
    "context": [
      "Trying to read .env file and convert it into to json file.",
      "Input:\n```\nos=amazon-linux\nregion=ap-south-1\n```",
      "Desired ouput:\n```\n{\n\"os\": \"amazon-linux\",\n\"region\": \"ap-south-1\"\n}\n```",
      "I am trying to use jq but getting 2 problems -\n1. Handle to empty lines - `jq: error (at .env:1): null (null) only strings can be parsed`\n2. Handle commented line - `#this is comment` => `\"#this is comment\": null`",
      "jq -Rn '[inputs | capture(\"(?<key>[^=]+)=(?<value>.*)\")] | from_entries'",
      "{\n  \"os\": \"amazon-linux\",\n  \"region\": \"ap-south-1\"\n}"
    ],
    "utterance": "Convert a file with '='-separated key-value pairs into an object, ignoring empty and commented lines.",
    "expressions": [
      "jq -Rn '[inputs | capture(\"(?<key>[^=]+)=(?<value>.*)\")] | from_entries'"
    ],
    "data": [
      {
        "input": "os=amazon-linux\nregion=ap-south-1\n",
        "output": {
          "os": "amazon-linux",
          "region": "ap-south-1"
        }
      }
    ],
    "identifier": 76097751
  },
  {
    "context": [
      "\"Field\\n` \\\"test\\\": (.int.example_t | formatdate iso8601 | tonumber)`\"",
      "\"Any idea any other ways to change the formatting?\"",
      "\"You can instead **formatdate** (is not a built-in **jq** function) use the UNIX timestamp:\\n\\n    jq ' { \\\"test\\\": (.int.example_t | todate // 0 | tonumber) } ' input.json\\n\\n**todate** function converts the date/time string to a UNIX timestamp.\""
    ],
    "utterance": "Convert the value of .int.example_t from an ISO8601 date/time string into its UNIX timestamp representation as a number and assign it to the field \"test\".",
    "expressions": [
      "{ \"test\": (.int.example_t | todate // 0 | tonumber) }"
    ],
    "identifier": 76098719
  },
  {
    "context": [
      "how can I use jq to trigger an action after a certain amount (=x) of records are written and still have my output every second?",
      "The action after x records is to count the amount of records, and ignore lines with \"null\" values.",
      "But what to do when I want to do this for every 5 or 100 records ?",
      "The expected output for x=5: [includes example where every 5 records, outputs the count excluding those with nulls]",
      "The following \"alert\" function does what is expected:",
      "jq -nc --argjson m \"5\" '\n    def alerts(r): r | del( .[] | select(to_entries[].value == null)) | length ; \n    foreach inputs as $in (\n         {\"recs\":[]};\n         if (.recs|length) < $m then .recs += [$in] else .recs=[$in] end;\n         .recs[-1], if (.recs|length) == $m then alerts(.recs) else empty end)\n'"
    ],
    "utterance": "After every 5 records, output each record as it arrives, and then output the count of those 5 records which do not contain any null values.",
    "expressions": [
      "jq -nc --argjson m \"5\" '\n    def alerts(r): r | del( .[] | select(to_entries[].value == null)) | length ; \n    foreach inputs as $in (\n         {\"recs\":[]};\n         if (.recs|length) < $m then .recs += [$in] else .recs=[$in] end;\n         .recs[-1], if (.recs|length) == $m then alerts(.recs) else empty end)\n'"
    ],
    "data": [
      {
        "input": [
          {
            "date": 230415072207,
            "kwL1Tl": 0,
            "kwL1": 0.022,
            "kwL2Tl": 0,
            "kwL2": 0.075,
            "kwL3Tl": 0,
            "kwL3": 0
          },
          {
            "date": 230415072311,
            "kwL1Tl": 0,
            "kwL1": 0.023,
            "kwL2Tl": 0,
            "kwL2": 0.08,
            "kwL3Tl": 0,
            "kwL3": 0
          },
          {
            "date": 230415072312,
            "kwL1Tl": null,
            "kwL1": null,
            "kwL2Tl": null,
            "kwL2": null,
            "kwL3Tl": null,
            "kwL3": null
          },
          {
            "date": 230415072415,
            "kwL1Tl": 0,
            "kwL1": 0.023,
            "kwL2Tl": 0,
            "kwL2": 0.08,
            "kwL3Tl": 0,
            "kwL3": 0
          },
          {
            "date": 230415072416,
            "kwL1Tl": 0,
            "kwL1": 0.022,
            "kwL2Tl": 0,
            "kwL2": 0.08,
            "kwL3Tl": 0,
            "kwL3": 0
          },
          {
            "date": 230415072519,
            "kwL1Tl": 0,
            "kwL1": 0.021,
            "kwL2Tl": 0,
            "kwL2": 0.08,
            "kwL3Tl": 0,
            "kwL3": 0
          }
        ],
        "output": [
          {
            "date": 230415072207,
            "kwL1Tl": 0,
            "kwL1": 0.022,
            "kwL2Tl": 0,
            "kwL2": 0.075,
            "kwL3Tl": 0,
            "kwL3": 0
          },
          {
            "date": 230415072311,
            "kwL1Tl": 0,
            "kwL1": 0.023,
            "kwL2Tl": 0,
            "kwL2": 0.08,
            "kwL3Tl": 0,
            "kwL3": 0
          },
          {
            "date": 230415072312,
            "kwL1Tl": null,
            "kwL1": null,
            "kwL2Tl": null,
            "kwL2": null,
            "kwL3Tl": null,
            "kwL3": null
          },
          {
            "date": 230415072415,
            "kwL1Tl": 0,
            "kwL1": 0.023,
            "kwL2Tl": 0,
            "kwL2": 0.08,
            "kwL3Tl": 0,
            "kwL3": 0
          },
          {
            "date": 230415072416,
            "kwL1Tl": 0,
            "kwL1": 0.022,
            "kwL2Tl": 0,
            "kwL2": 0.08,
            "kwL3Tl": 0,
            "kwL3": 0
          },
          4,
          {
            "date": 230415072519,
            "kwL1Tl": 0,
            "kwL1": 0.021,
            "kwL2Tl": 0,
            "kwL2": 0.08,
            "kwL3Tl": 0,
            "kwL3": 0
          }
        ]
      }
    ],
    "identifier": 76028685
  },
  {
    "identifier": 76125390
  },
  {
    "context": [
      "I am new to jq and try to process a nested json file and convert it to csv format. The sample nested json file is composed of three levels as below:",
      "Desired output",
      "level2, level3-label1, level3-label2, level3-lable3",
      "",
      "level2-text1, value1, value2, value3",
      "level2-text2, value4, value5, value6",
      "jq -r '[\"level1-label\"] | to_entries[] | [.key] + (.value | to_entries[] | [.key, .value]) | @csv' input.json",
      "jq -r '.\"level1-label\" | to_entries[] | [.key, .value[]] | @csv' input.json",
      "\"level2-text1\",\"value1\",\"value2\",\"value3\"",
      "\"level2-text2\",\"value4\",\"value5\",\"value6\""
    ],
    "utterance": "Convert a three-level nested object so each line contains the level 2 key followed by all level 3 values, in CSV format",
    "expressions": [
      ".\"level1-label\" | to_entries[] | [.key, .value[]] | @csv"
    ],
    "data": [
      {
        "input": {
          "level1-label": {
            "level2-text1": {
              "level3-label1": "value1",
              "level3-label2": "value2",
              "level3-label3": "value3"
            },
            "level2-text2": {
              "level3-label1": "value4",
              "level3-label2": "value5",
              "level3-label3": "value6"
            }
          }
        },
        "output": [
          "\"level2-text1\",\"value1\",\"value2\",\"value3\"",
          "\"level2-text2\",\"value4\",\"value5\",\"value6\""
        ]
      }
    ],
    "identifier": 76103251
  },
  {
    "context": [
      "jq: error (at <stdin>:1): Cannot index array with string \"0\"",
      "NEW_TASK_DEFINITION=$(echo $TASK_DEFINITION | jq -r --arg IMAGE \"$NEW_IMAGE\" --arg j \"$j\" '.taskDefinition | .containerDefinitions[$j].image = $IMAGE | del(.taskDefinitionArn) | del(.revision) | del(.status) | del(.requiresAttributes) | del(.compatibilities) | del(.registeredAt) | del (.registeredBy)')"
    ],
    "utterance": "Update the image of the container definition at index 0 using the value of the IMAGE variable, ensuring the index is given as a number, not a string.",
    "expressions": [
      ".taskDefinition.containerDefinitions[0].image = $IMAGE"
    ],
    "data": [
      {
        "input": {
          "taskDefinition": {
            "containerDefinitions": [
              {
                "name": "virtual-robot-1",
                "image": "xxxxxxx.dkr.ecr.eu-west-1.amazonaws.com/virtual-layer-robot:xxxxxx"
              }
            ]
          }
        },
        "output": {
          "taskDefinition": {
            "containerDefinitions": [
              {
                "name": "virtual-robot-1",
                "image": "xxxxxxxxxx.dkr.ecr.eu-west-1.amazonaws.com/virtual-layer-robot:xxxxxx"
              }
            ]
          }
        }
      }
    ],
    "identifier": 76111986
  },
  {
    "context": [
      "\"I want to filter it using jq or grep to get an output with only the full records where \\\"__pod_controller_name\\\" its \\\"podIwant\\\"\"",
      "With jq, you can filter using `select`. It takes some filter, and if it evaluates to `true` its input is passed on.",
      "jq 'select(.properties.__pod_controller_name == \"podIwant\")' input.json",
      "jq --arg name 'podIwant' 'select(.properties.__pod_controller_name == $name)' input.json"
    ],
    "utterance": "Return only the full records where the value of properties.__pod_controller_name is equal to podIwant.",
    "expressions": [
      "select(.properties.__pod_controller_name == \"podIwant\")",
      "select(.properties.__pod_controller_name == $name)"
    ],
    "data": [
      {
        "input": [
          {
            "endpoint": "http://10.225.25.33:8080/metrics",
            "properties": {
              "__pod_name": "pod1",
              "__pod_controller_name": "podIwant"
            }
          },
          {
            "endpoint": "http://10.225.10.21:8080/metrics",
            "properties": {
              "__pod_name": "pod2",
              "__pod_controller_name": "podIdontwant"
            }
          },
          {
            "endpoint": "http://10.225.33.52:8080/metrics",
            "properties": {
              "__pod_name": "pod3",
              "__pod_controller_name": "podIwant"
            }
          }
        ],
        "output": [
          {
            "endpoint": "http://10.225.25.33:8080/metrics",
            "properties": {
              "__pod_name": "pod1",
              "__pod_controller_name": "podIwant"
            }
          },
          {
            "endpoint": "http://10.225.33.52:8080/metrics",
            "properties": {
              "__pod_name": "pod3",
              "__pod_controller_name": "podIwant"
            }
          }
        ]
      }
    ],
    "identifier": 76122625
  },
  {
    "context": [
      "The label output from the issue:\r\n\r\n    [\r\n      {\r\n        ...\r\n        \"name\": \"dev_us-west-1\",\r\n        ...\r\n      },\r\n      {\r\n        ...\r\n        \"name\": \"prd_eu-west-1\",\r\n        ...\r\n      }\r\n    ]",
      "labels=$(jq -r '.[].name' <<< '${{ steps.get_latest_label.outputs.data }}')"
    ],
    "utterance": "Extract all label names from an array of label objects.",
    "expressions": [
      "jq -r '.[].name'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 5447687240,
            "node_id": "LA_kwDOJME-rhrtrtjnK1lSA",
            "url": "https://api.github.com/repos/MyOrg/MyRepo/labels/dev_us-west-1",
            "name": "dev_us-west-1",
            "color": "ededed",
            "default": false,
            "description": null
          },
          {
            "id": 5898781642,
            "node_id": "LA_kwDOJME-derhehehK1lSg",
            "url": "https://api.github.com/repos/MyOrg/MyRepo/labels/prd_eu-west-1",
            "name": "prd_eu-west-1",
            "color": "ededed",
            "default": false,
            "description": null
          }
        ],
        "output": [
          "dev_us-west-1",
          "prd_eu-west-1"
        ]
      }
    ],
    "identifier": 76139526
  },
  {
    "context": [
      "Suppose I have a JSON file like this:\r\n```\r\n{\r\n  \"a\": 1,\r\n  \"b\": [1, 2],\r\n  \"c\": [{\r\n    \"x\": 1\r\n  }, {\r\n    \"x\": 2\r\n  }]\r\n}\r\n```\r\nThis is my JSON model.",
      "Then I have a text file like this:\r\n```\r\nA is {.a} and B is an array {.b}.\r\nThere is also c[].x = {.c[].x}\r\n```\r\nThis is my template. Curly braces can be replaced with anything else, if it makes the rendering easier.",
      "When that template is rendered against the aforementioned JSON model we should get this:\r\n```\r\nA is 1 and B is an array [1,2].\r\nThere is also c[].x = [1,2]\r\n```\r\nDoes jq allow us to perform such a rendering?",
      "Here\u0019s a jq-only solution to the stated problem. \r\n\r\nWith your text input and $json set to the given JSON:\r\n```\r\njq -nrR --argjson json \"$json\" 'inputs\r\n  | gsub(\"\\\\{.(?\\u003cv\\u003e[^[}]+)\\\\}\", $json[.v]|tostring) \r\n  | gsub(\"\\\\{.(?\\u003cv\\u003e[^[}]+)\\\\[][.](?\\u003cx\\u003e[^}]+)\\\\}\", [$json[.v][][.x]]|tostring ) \r\n'\r\n```\r\nproduces:\r\n```\r\nA is 1 and B is an array [1,2].\r\nThere is also c[].x = [1,2]\r\n```\r\n"
    ],
    "utterance": "Render a template file, replacing placeholders like {.a}, {.b}, and {.c[].x} with corresponding values from an input object where a = 1, b = [1,2], c = [{x:1}, {x:2}], so output lines like 'A is 1 and B is an array [1,2]. There is also c[].x = [1,2]'.",
    "expressions": [
      "jq -nrR --argjson json \"$json\" 'inputs\n  | gsub(\"\\\\{.(?<v>[^\\[\\]}]+)\\\\}\"; $json[.v]|tostring) \n  | gsub(\"\\\\{.(?<v>[^\\[\\]}]+)\\[\\]\\.(?<x>[^}]+)\\\\}\"; [$json[.v][][.x]|tostring])\n'"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": [
            1,
            2
          ],
          "c": [
            {
              "x": 1
            },
            {
              "x": 2
            }
          ]
        },
        "output": "A is 1 and B is an array [1,2].\nThere is also c[].x = [1,2]"
      }
    ],
    "identifier": 76124153
  },
  {
    "context": [
      "If I have an array such as this one:\n[\n  [\n    \"AppA\",\n    \"ServiceA\",\n    \"SecretKey\",\n    \"topSecretKeyA\"\n  ],\n  [\n    \"AppB\",\n    \"ServiceB\",\n    \"SecretKey\",\n    \"topSecretKeyB\"\n  ],\n  [\n    \"AppC\",\n    \"ServiceC\",\n    \"SecretKey\",\n    \"topSecretKeyC\"\n  ]\n]",
      "How can I convert this to an object that looks like the following?\n{\n  \"AppA\": {\n    \"ServiceA\": {\n      \"SecretKey\": \"topSecretKeyA\"\n    }\n  },\n  \"AppB\": {\n    \"ServiceB\": {\n      \"SecretKey\": \"topSecretKeyB\"\n    }\n  },\n  \"AppC\": {\n    \"ServiceC\": {\n      \"SecretKey\": \"topSecretKeyC\"\n    }\n  }\n}",
      "Use `setpath` ([manual](https://stedolan.github.io/jq/manual/#setpath%28PATHS%3BVALUE%29)) to set a given path to a value:\nreduce .[] as $k (null; setpath($k[:-1]; $k[-1]))",
      "with `map` and `from_entries`\nmap({key: .[0], value: {(.[1]): {(.[2]): .[3]}}}) | from_entries"
    ],
    "utterance": "Convert an array of arrays, each with four strings, into an object where the first three items form nested keys and the fourth is the value.",
    "expressions": [
      "reduce .[] as $k (null; setpath($k[:-1]; $k[-1]))",
      "map({key: .[0], value: {(.[1]): {(.[2]): .[3]}}}) | from_entries"
    ],
    "data": [
      {
        "input": [
          [
            "AppA",
            "ServiceA",
            "SecretKey",
            "topSecretKeyA"
          ],
          [
            "AppB",
            "ServiceB",
            "SecretKey",
            "topSecretKeyB"
          ],
          [
            "AppC",
            "ServiceC",
            "SecretKey",
            "topSecretKeyC"
          ]
        ],
        "output": {
          "AppA": {
            "ServiceA": {
              "SecretKey": "topSecretKeyA"
            }
          },
          "AppB": {
            "ServiceB": {
              "SecretKey": "topSecretKeyB"
            }
          },
          "AppC": {
            "ServiceC": {
              "SecretKey": "topSecretKeyC"
            }
          }
        }
      }
    ],
    "identifier": 76132500
  },
  {
    "context": [
      "I am attempting to update certain properties of a JSON file based on a few conditions:",
      "- The name of the attribute must contain the string \"Description\".",
      "- The attribute's `ismydata` property must be `true`.",
      "- The attribute's `deprecatedVersion` must have an empty string for its value.",
      "How do I condense this into a single output?",
      "the simplest approach would probably be to use the form: `.attributes |= ...`",
      ".attributes |=\n  with_entries(\n    if (.key|contains(\"Description\")) \n        and .value.ismydata == true\n        and .value.deprecatedVersion == \"\"\n    then .value |= \n      ((.deprecatedVersion = \"Y\")\n       | .description |= \"Deprecated- this has been replaced by... \\(.)\")\n    else .\n    end)",
      "Your solution can be salvaged by using `reduce` over $matchKey:",
      "reduce (\n     .attributes\n     | ( with_entries( select(.key|contains(\"Description\"))) \n         | keys[] as $k | .[$k] \n         | select(.ismydata==true) and select(.deprecatedVersion==\"\") | $k)) as $matchKey (.;\n       .attributes[$matchKey].deprecatedVersion = \"Y\"\n     | .attributes[$matchKey].description |= \"Deprecated- this has been replaced by... \\(.)\" )"
    ],
    "utterance": "Update all attributes where the key contains 'Description', ismydata is true, and deprecatedVersion is empty by setting deprecatedVersion to 'Y' and prepending 'Deprecated- this has been replaced by... ' to their description.",
    "expressions": [
      ".attributes |=\n  with_entries(\n    if (.key|contains(\"Description\")) \n        and .value.ismydata == true\n        and .value.deprecatedVersion == \"\"\n    then .value |= \n      ((.deprecatedVersion = \"Y\")\n       | .description |= \"Deprecated- this has been replaced by... \\(.)\")\n    else .\n    end)",
      "reduce (\n  .attributes\n  | ( with_entries( select(.key|contains(\"Description\"))) \n      | keys[] as $k | .[$k] \n      | select(.ismydata==true) and select(.deprecatedVersion==\"\") | $k)) as $matchKey (.;\n    .attributes[$matchKey].deprecatedVersion = \"Y\"\n  | .attributes[$matchKey].description |= \"Deprecated- this has been replaced by... \\(.)\" )"
    ],
    "data": [
      {
        "input": {
          "name": "account",
          "description": "Some description",
          "attributes": {
            "accountNameCode": {
              "description": "Name of the account type.",
              "type": "string",
              "ismydata": true,
              "deprecatedVersion": ""
            },
            "accountNameDescription": {
              "description": "Description of the account type.",
              "type": "string",
              "ismydata": true,
              "deprecatedVersion": ""
            },
            "anotherDescription": {
              "description": "Some other thing.",
              "type": "string",
              "ismydata": true,
              "deprecatedVersion": ""
            }
          }
        },
        "output": {
          "name": "account",
          "description": "Some description",
          "attributes": {
            "accountNameCode": {
              "description": "Name of the account type.",
              "type": "string",
              "ismydata": true,
              "deprecatedVersion": ""
            },
            "accountNameDescription": {
              "description": "Deprecated- this has been replaced by... Description of the account type.",
              "type": "string",
              "ismydata": true,
              "deprecatedVersion": "Y"
            },
            "anotherDescription": {
              "description": "Deprecated- this has been replaced by... Some other thing.",
              "type": "string",
              "ismydata": true,
              "deprecatedVersion": "Y"
            }
          }
        }
      }
    ],
    "identifier": 76104354
  },
  {
    "context": [
      "When retrieving an object from an array with `jq` in a JSON file like this",
      "How can `ascii_downcase` be used here to match the string in lower case?",
      ".[] | select(.field1 | ascii_downcase == \"object1_value1\") | .field1, .field3",
      ".[] | select(.field1 | ascii_downcase? == \"object1_value1\") | .field1, .field3",
      ".[] | select(has(\"field1\")) | select(.field1 | ascii_downcase == \"object1_value1\") | .field1, .field3",
      "Output:\nObject1_Value1\nObject1_Value3"
    ],
    "utterance": "Retrieve the values of field1 and field3 for objects where field1, case-insensitively, is equal to 'object1_value1'.",
    "expressions": [
      ".[] | select(.field1 | ascii_downcase == \"object1_value1\") | .field1, .field3",
      ".[] | select(.field1 | ascii_downcase? == \"object1_value1\") | .field1, .field3",
      ".[] | select(has(\"field1\")) | select(.field1 | ascii_downcase == \"object1_value1\") | .field1, .field3"
    ],
    "data": [
      {
        "input": [
          {
            "field1": "Object1_Value1",
            "field2": "Object1_Value2",
            "field3": "Object1_Value3"
          },
          {
            "field1": "Object2_Value1",
            "field2": "Object2_Value2",
            "field3": "Object2_Value3"
          }
        ],
        "output": [
          "Object1_Value1",
          "Object1_Value3"
        ]
      }
    ],
    "identifier": 76152862
  },
  {
    "context": [
      "The input will bring multiple lines but in the original format below, the values will be different for each line, which is expected and I will have a json files with multiple lines as well.  The mycustomvalue will be added to the bash output.",
      "Desired output:",
      "{\r\n    \"g\": [{\r\n            \"m\": \"myv1\",\r\n            \"v\": \"myv6\",\r\n            \"t\":  myv3,\r\n            \"d\": {\r\n                \"a\": \"myv2\",\r\n\t\t\t\"r\": \"myv5\"\r\n\t\t\t\"s\": \"mycustomvalue\",\r\n                \"o\": \"myv4\",\r\n                \"n\": \"myv7\"\r\n            }\r\n        }, {\r\n            \"m\": \"myv1\",\r\n            \"v\": \"myv6\",\r\n            \"t\":  myv3,\r\n            \"d\": {\r\n                \"a\": \"myv2\",\r\n\t\t\t\"r\": \"myv5\"\t\t\t\t\r\n                \"s\": \"mycustomvalue\",\r\n                \"o\": \"myv4\",\r\n                \"n\": \"myv7\"\r\n            }\r\n        }\r\n    ]\r\n}",
      "To get the expected output from your question, you have to change your jq filters slightly:",
      "$ jq -n '{\r\n  g: [\r\n    range(2)\r\n    | { \r\n      m: $one,\r\n      v: $two,\r\n      d: { a: $four, r: $five, s: $six, o: $seven, n: $eight }\r\n      }\r\n  ]\r\n}' \\",
      "--arg one 'myv1' \\",
      "--arg two 'myv6' \\",
      "--arg three 'myv3' \\",
      "--arg four 'myv2' \\",
      "--arg five 'myv5' \\",
      "--arg six 'mycustomvar' \\",
      "--arg seven 'myv4' \\",
      "--arg eight 'myv7'"
    ],
    "utterance": "Create an object with a key 'g' containing an array of objects, each having the specified values mapped to their respective keys, including an added key with a custom value at a sub-level.",
    "expressions": [
      "{\n  g: [\n    range(2)\n    | {\n      m: $one,\n      v: $two,\n      d: { a: $four, r: $five, s: $six, o: $seven, n: $eight }\n    }\n  ]\n}"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "g": [
            {
              "m": "myv1",
              "v": "myv6",
              "d": {
                "a": "myv2",
                "r": "myv5",
                "s": "mycustomvar",
                "o": "myv4",
                "n": "myv7"
              }
            },
            {
              "m": "myv1",
              "v": "myv6",
              "d": {
                "a": "myv2",
                "r": "myv5",
                "s": "mycustomvar",
                "o": "myv4",
                "n": "myv7"
              }
            }
          ]
        }
      }
    ],
    "identifier": 76149631
  },
  {
    "context": [
      "Code with a proper `YAML` parser, [`yq`](https://github.com/kislyuk/yq):",
      "yq -y '\n  (\n    .spec.containers[] | \n     select(.image==\"nginx:latest\" and .imagePullPolicy==\"IfNotPresent\")\n    .imagePullPolicy\n   ) = {}\n' file",
      "Credits to emanuele6 from jq@libera.irc",
      "#### [Online Demo](https://jqplay.org/s/VVRa93_OSwZ)",
      "#### Output\n    kind: Pod\n    metadata:\n      name: abc12\n    spec:\n      containers:\n        - image: ubuntu:latest\n          name: Ubuntu\n          imagePullPolicy: IfNotPresent\n        - image: nginx:latest\n          name: Nginx\n          imagePullPolicy: {}"
    ],
    "utterance": "Set imagePullPolicy to an empty object for any container whose image is nginx:latest and imagePullPolicy is IfNotPresent.",
    "expressions": [
      "(.spec.containers[] | select(.image==\"nginx:latest\" and .imagePullPolicy==\"IfNotPresent\") .imagePullPolicy) = {}"
    ],
    "data": [
      {
        "input": {
          "kind": "Pod",
          "metadata": {
            "name": "abc12"
          },
          "spec": {
            "containers": [
              {
                "image": "ubuntu:latest",
                "name": "Ubuntu",
                "imagePullPolicy": "IfNotPresent"
              },
              {
                "image": "nginx:latest",
                "name": "Nginx",
                "imagePullPolicy": "IfNotPresent"
              }
            ]
          }
        },
        "output": {
          "kind": "Pod",
          "metadata": {
            "name": "abc12"
          },
          "spec": {
            "containers": [
              {
                "image": "ubuntu:latest",
                "name": "Ubuntu",
                "imagePullPolicy": "IfNotPresent"
              },
              {
                "image": "nginx:latest",
                "name": "Nginx",
                "imagePullPolicy": {}
              }
            ]
          }
        }
      }
    ],
    "identifier": 76156973
  },
  {
    "context": [
      "I have two files config.json and types.json.",
      "And I want to append the types.json to config.json on the root level, and name it as a new element, i.e. \"typelist\"",
      "The target is to have an out.json file like the following:",
      "{ ... \"typelist\": [ /*This should be added*/ ... ] }",
      "You're looking for something like this:\n``` sh\njq '.typelist = input' config.json types.json\n```"
    ],
    "utterance": "Add the contents of types.json as a root-level element named typelist in config.json.",
    "expressions": [
      ".typelist = input"
    ],
    "data": [
      {
        "input": {
          "config.json": {
            "origconfig1": {
              "id1Config1": null,
              "id2Config1": true,
              "id3Config1": false,
              "id24Config1": false
            },
            "origconfig2": {
              "id1Config2": "",
              "id2Config2": "3a4b68",
              "id3Config2": "f2af35",
              "id4Config2": true,
              "id5Config2": "d.m.Y",
              "id6Config2": true
            }
          },
          "types.json": [
            {
              "code": "CODE_TYPE1",
              "languageCode": "EN",
              "type": "TYPE1"
            },
            {
              "code": "CODE_TYPE2",
              "languageCode": "EN",
              "type": "TYPE2"
            },
            {
              "code": "CODE_TYPE3",
              "languageCode": "EN",
              "type": "TYPE3"
            }
          ]
        },
        "output": {
          "origconfig1": {
            "id1Config1": null,
            "id2Config1": true,
            "id3Config1": false,
            "id24Config1": false
          },
          "origconfig2": {
            "id1Config2": "",
            "id2Config2": "3a4b68",
            "id3Config2": "f2af35",
            "id4Config2": true,
            "id5Config2": "d.m.Y",
            "id6Config2": true
          },
          "typelist": [
            {
              "code": "CODE_TYPE1",
              "languageCode": "EN",
              "type": "TYPE1"
            },
            {
              "code": "CODE_TYPE2",
              "languageCode": "EN",
              "type": "TYPE2"
            },
            {
              "code": "CODE_TYPE3",
              "languageCode": "EN",
              "type": "TYPE3"
            }
          ]
        }
      }
    ],
    "identifier": 76163928
  },
  {
    "context": [
      "I need to find all users that are NOT in the @xyz.com domain.",
      "jq '.[] | select(.email | test(\"@xyz.com\")) | {id, username}'",
      "`not` should negate the boolean value used by `select`, so it has to be a part of its argument (i.e. go inside of it):",
      "jq '.[] | select(.email | test(\"@xyz.com\") | not) | {id, username}'"
    ],
    "utterance": "Find all users whose email does not contain @xyz.com and return their id and username.",
    "expressions": [
      ".[] | select(.email | test(\"@xyz.com\") | not) | {id, username}"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "username": "alice",
            "email": "alice@abc.com"
          },
          {
            "id": 2,
            "username": "bob",
            "email": "bob@xyz.com"
          },
          {
            "id": 3,
            "username": "charlie",
            "email": "charlie@def.org"
          }
        ],
        "output": [
          {
            "id": 1,
            "username": "alice"
          },
          {
            "id": 3,
            "username": "charlie"
          }
        ]
      }
    ],
    "identifier": 76167856
  },
  {
    "context": [
      "i only need to filter out the FIRST element in \"Objects\" array. any other elements must stay intact.",
      ".Objects |= .[1:]",
      "{ Objects: .Objects[1:] }",
      "del(.Objects[0])",
      "The last solution is probably closest to what you want to do, expressed in code, i.e. \"delete the first array element\"."
    ],
    "utterance": "Remove the first element from the Objects array while preserving the rest of the structure.",
    "expressions": [
      ".Objects |= .[1:]",
      "{ Objects: .Objects[1:] }",
      "del(.Objects[0])"
    ],
    "data": [
      {
        "input": {
          "Objects": [
            {
              "Key": "file.txt",
              "VersionId": "111111"
            },
            {
              "Key": "file.txt",
              "VersionId": "22222"
            },
            {
              "Key": "file.txt",
              "VersionId": "33333"
            }
          ]
        },
        "output": {
          "Objects": [
            {
              "Key": "file.txt",
              "VersionId": "22222"
            },
            {
              "Key": "file.txt",
              "VersionId": "33333"
            }
          ]
        }
      }
    ],
    "identifier": 76174600
  },
  {
    "context": [
      "one of the variables ($input[5]/\"programNumber\") needs to be imported as an integer and the script I am using is pulling everything with a set of quotes",
      "programNumber: $input[5]",
      "Here&#39;s a condensed version using `tonumber` just once:",
      "programNumber: .[5] | tonumber"
    ],
    "utterance": "Convert the value in the sixth CSV column to an integer before inserting it as programNumber in the output.",
    "expressions": [
      "programNumber: .[5] | tonumber"
    ],
    "identifier": 76167976
  },
  {
    "context": [
      "I have this json and I&#39;d like to go under the &quot;rgw.main&quot; but for some reason I&#39;m not sure how to define.",
      "I&#39;m trying to take out the rgw.main num_objects, however I can&#39;t get into only the rgw.main.",
      "* Your key is `&quot;rgw.main&quot;`, not `&quot;rgw&quot;.&quot;main&quot;`. In other words, your object structure is `{ &quot;rgw.main&quot;: 42 }` and not `{ &quot;rgw&quot;: { &quot;main&quot;: 42 } }`. You must use `.&quot;rgw.main&quot;` or `.[&quot;rgw.main&quot;]` if your key contains characters which are special to jq",
      ".usage.&quot;rgw.main&quot;.num_objects",
      ".usage[&quot;rgw.main&quot;].num_objects",
      "Output:\r\n29670"
    ],
    "utterance": "Extract the value of num_objects under the rgw.main key within usage.",
    "expressions": [
      ".usage.\"rgw.main\".num_objects",
      ".usage[\"rgw.main\"].num_objects"
    ],
    "data": [
      {
        "input": {
          "bucket": "mybucket",
          "num_shards": 11,
          "tenant": "",
          "zonegroup": "xxx-11111",
          "placement_rule": "default-placement",
          "explicit_placement": {
            "data_pool": "",
            "data_extra_pool": "",
            "index_pool": ""
          },
          "id": "234324324",
          "marker": "234324324.2",
          "index_type": "Normal",
          "owner": "store",
          "ver": "0#1196975824,1#1195439377,2#1195232380,3#1194062417,4#1195521322,5#1195488056,6#1193225866,7#1195484409,8#1195542434,9#1195529602,10#1195327401",
          "master_ver": "0#0,1#0,2#0,3#0,4#0,5#0,6#0,7#0,8#0,9#0,10#0",
          "mtime": "2022-02-18T11:16:22.620065Z",
          "creation_time": "2021-03-12T10:02:54.033355Z",
          "max_marker": "0#01196975823.2645569872.5,1#01195439376.3395178223.5,2#01195232379.3168551901.5,3#01194062416.2633030768.5,4#01195521321.2647348717.5,5#01195488055.3126383883.5,6#01193225865.2630243615.5,7#01195484408.2645677558.5,8#01195542433.2655116258.5,9#01195529601.2621773307.5,10#01195327400.2629607598.5",
          "usage": {
            "rgw.none": {
              "size": 0,
              "size_actual": 0,
              "size_utilized": 0,
              "size_kb": 0,
              "size_kb_actual": 0,
              "size_kb_utilized": 0,
              "num_objects": 230
            },
            "rgw.main": {
              "size": 120124562767,
              "size_actual": 120220463104,
              "size_utilized": 120124562767,
              "size_kb": 117309144,
              "size_kb_actual": 117402796,
              "size_kb_utilized": 117309144,
              "num_objects": 29670
            },
            "rgw.multimeta": {
              "size": 0,
              "size_actual": 0,
              "size_utilized": 7776,
              "size_kb": 0,
              "size_kb_actual": 0,
              "size_kb_utilized": 8,
              "num_objects": 288
            }
          },
          "bucket_quota": {
            "enabled": false,
            "check_on_raw": false,
            "max_size": -1,
            "max_size_kb": 0,
            "max_objects": -1
          }
        },
        "output": 29670
      }
    ],
    "identifier": 76164954
  },
  {
    "context": [
      "How can I add user, on Bash (maybe with `jq` command), (for instance: BATU) and array users",
      "\"users\":[\"XXXX\",\"XXXXX\",...,\"XXXXXX\",\"usrpfm\"]",
      "turn to",
      "\"users\":[\"XXXX\",\"XXXXX\",...,\"XXXXXX\",\"usrpfm\",\"BATU\"]",
      "jq  '.policyItems[0].users  |=  . + [\"BATUU\"]' file.json",
      "Use \"|= . +\" to add an additional array index (BATUU) to policyItems[0].users"
    ],
    "utterance": "Append BATU to the users array in the first element of the policyItems array.",
    "expressions": [
      ".policyItems[0].users |= . + [\"BATU\"]"
    ],
    "data": [
      {
        "input": {
          "policyItems": [
            {
              "users": [
                "XXXX",
                "XXXXX",
                "XXXX",
                "XXXXXX",
                "XXXXX",
                "XXXXXX",
                "XXXXXX",
                "usrpfm"
              ],
              "accesses": [
                {
                  "type": "consume",
                  "isAllowed": true
                },
                {
                  "type": "describe",
                  "isAllowed": true
                }
              ],
              "groups": [
                ""
              ],
              "roles": [],
              "conditions": [],
              "delegateAdmin": false
            },
            {
              "users": [
                "rangerlookup"
              ],
              "accesses": [
                {
                  "type": "consume",
                  "isAllowed": true
                },
                {
                  "type": "describe",
                  "isAllowed": true
                },
                {
                  "type": "delete",
                  "isAllowed": true
                }
              ],
              "groups": [
                ""
              ],
              "roles": [],
              "conditions": [],
              "delegateAdmin": false
            }
          ]
        },
        "output": {
          "policyItems": [
            {
              "users": [
                "XXXX",
                "XXXXX",
                "XXXX",
                "XXXXXX",
                "XXXXX",
                "XXXXXX",
                "XXXXXX",
                "usrpfm",
                "BATU"
              ],
              "accesses": [
                {
                  "type": "consume",
                  "isAllowed": true
                },
                {
                  "type": "describe",
                  "isAllowed": true
                }
              ],
              "groups": [
                ""
              ],
              "roles": [],
              "conditions": [],
              "delegateAdmin": false
            },
            {
              "users": [
                "rangerlookup"
              ],
              "accesses": [
                {
                  "type": "consume",
                  "isAllowed": true
                },
                {
                  "type": "describe",
                  "isAllowed": true
                },
                {
                  "type": "delete",
                  "isAllowed": true
                }
              ],
              "groups": [
                ""
              ],
              "roles": [],
              "conditions": [],
              "delegateAdmin": false
            }
          ]
        }
      }
    ],
    "identifier": 76180304
  },
  {
    "context": [
      "I want to recursively remove all the keys that point at empty arrays or objects, so that the result looks like:",
      "Here's a solution using `walk` and `IN`:",
      "walk( if type == \"object\" \n      then with_entries(select(.value | IN([],{}) | not ) ) \n      else . end)"
    ],
    "utterance": "Recursively remove all keys whose values are empty arrays or empty objects.",
    "expressions": [
      "walk( if type == \"object\" then with_entries(select(.value | IN([],{}) | not)) else . end)"
    ],
    "data": [
      {
        "input": {
          "a": {
            "a": "foo",
            "b": "bar"
          },
          "b": {
            "a": [],
            "b": []
          },
          "c": {},
          "d": [
            "foo",
            "bar"
          ]
        },
        "output": {
          "a": {
            "a": "foo",
            "b": "bar"
          },
          "d": [
            "foo",
            "bar"
          ]
        }
      }
    ],
    "identifier": 76184199
  },
  {
    "context": [
      "What code would select all objects with `key` matching a value between 99 and 201?",
      "select(.key | tonumber | 99<. and .<201 )",
      "select(.key | tonumber | IN(range(100;200)))",
      "printf '%s\\n' \"$json\" |jq 'select((.key|tonumber >=100) and (.key|tonumber <=200))'"
    ],
    "utterance": "Select all objects where the key is a number between 99 and 201.",
    "expressions": [
      "select(.key | tonumber | 99 < . and . < 201)",
      "select(.key | tonumber | IN(range(100;200)))",
      "select((.key|tonumber >=100) and (.key|tonumber <=200))"
    ],
    "data": [
      {
        "input": [
          {
            "key": "100"
          },
          {
            "key": "200"
          },
          {
            "key": "300"
          }
        ],
        "output": [
          {
            "key": "100"
          },
          {
            "key": "200"
          }
        ]
      }
    ],
    "identifier": 76188487
  },
  {
    "context": [
      "I pipe this object to the filter `.results[] | select(.name == \"foobar\").description`, but I'm not super confident I've written the `select()` filter completely correctly. How can I assert that the `select()` filter is functioning as intended, and returning exactly 1 result?",
      "[select(.name == \"foobar\").description]  | if length == 1 then .[] else \"\\(length) results produced\" | error end",
      "def assert_n($n; f; g): if reduce f as $_ (0; .+1) == $n then f else g end;",
      "assert_n(1; .results[] | select(.name == \"foobar\").description; error(\"not one\"))",
      ".results | map(select(.name == \"foobar\") | .description) | if length == 1 then first else error(\"expected exactly one result\") end",
      "def assert_one(s):\n  reduce s as $x (null;\n    if . == null then {emit: $x, n:1}\n    else \"assertion error: more than one\"|error\n    end )\n  | select(.n == 1).emit \n  // (\"assertion error: none\"|error);",
      "[{ name: \"foobar\", description: \"yes\"},\n { name: \"foobar\", description: \"maybe\"} ]\n| assert_one(.[] | select(.name == \"foobar\" and has(\"description\")).description)"
    ],
    "utterance": "Assert that selecting objects with name equal to \"foobar\" and retrieving their description returns exactly one result; raise an error otherwise.",
    "expressions": [
      "[.results[] | select(.name == \"foobar\").description] | if length == 1 then .[] else \"\\(length) results produced\" | error end",
      "def assert_n($n; f; g): if reduce f as $_ (0; .+1) == $n then f else g end; assert_n(1; .results[] | select(.name == \"foobar\").description; error(\"not one\"))",
      ".results | map(select(.name == \"foobar\") | .description) | if length == 1 then first else error(\"expected exactly one result\") end",
      "def assert_one(s):\n  reduce s as $x (null;\n    if . == null then {emit: $x, n:1}\n    else \"assertion error: more than one\"|error\n    end )\n  | select(.n == 1).emit \n  // (\"assertion error: none\"|error); .results[] | assert_one(select(.name == \"foobar\").description)"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "name": "foobar",
              "description": "it's the foobar 1000 baby!"
            },
            {
              "name": "another_thing",
              "description": "acme 1000 whizbang machine"
            }
          ]
        },
        "output": "it's the foobar 1000 baby!"
      },
      {
        "input": {
          "results": [
            {
              "name": "foobar",
              "description": "desc1"
            },
            {
              "name": "foobar",
              "description": "desc2"
            }
          ]
        },
        "output": "error"
      },
      {
        "input": {
          "results": [
            {
              "name": "another_thing",
              "description": "acme 1000 whizbang machine"
            }
          ]
        },
        "output": "error"
      }
    ],
    "identifier": 76178228
  },
  {
    "context": [
      "How do I keep the lines in `block_list` on one line?",
      "Here's an approach that will work with your example and many like it, but please understand its limitations:",
      "jq 'walk(if type == \"array\" and length < 10 then \"<Q>\" + tostring + \"<Q>\" else . end)' | sed '/\"<Q>[[].*[]]<Q>\"/ {s/\"<Q>\\[\\[/[/; s/[]]<Q>\"/]/;}'",
      "Here's a variant that avoids problems with arrays-within-arrays:",
      "jq 'walk(if type == \"array\" and length < 10 and all(type != \"string\" or (startswith(\"<Q>\") | not))\n         then \"<Q>\" + tostring + \"<Q>\" else . end)' |\n    sed '/\"<Q>[[].*[]]<Q>\"/ {s/\"<Q>\\[\\[/[/g; s/[]]<Q>\"/]/g;}'"
    ],
    "utterance": "Produce output where the block_list array appears on a single line instead of being spread across multiple lines.",
    "expressions": [
      "jq 'walk(if type == \"array\" and length < 10 then \"<Q>\" + tostring + \"<Q>\" else . end)' | sed '/\"<Q>[[].*[]]<Q>\"/ {s/\"<Q>\\[\\[/[/; s/[]]<Q>\"/]/;}'",
      "jq 'walk(if type == \"array\" and length < 10 and all(type != \"string\" or (startswith(\"<Q>\") | not)) then \"<Q>\" + tostring + \"<Q>\" else . end)' | sed '/\"<Q>[[].*[]]<Q>\"/ {s/\"<Q>\\[\\[/[/g; s/[]]<Q>\"/]/g;}'"
    ],
    "data": [
      {
        "input": {
          "errno": 0,
          "return_type": 1,
          "block_list": [
            0,
            1,
            2,
            3,
            4
          ],
          "uploadid": "xxx",
          "request_id": 10
        },
        "output": {
          "errno": 0,
          "return_type": 1,
          "block_list": [
            0,
            1,
            2,
            3,
            4
          ],
          "uploadid": "xxx",
          "request_id": 10
        }
      }
    ],
    "identifier": 76185364
  },
  {
    "context": [
      "I need to convert file to csv format with specific values only.",
      "sometimes value of a field is array of subdocuments, in the other case it's value is just subcdoc or field just does not exists.",
      "My goal is to extract value of .meta.dev.devId (if field does not exists, then use empty column in csv.",
      "jq -r '.[] | [.docId, .item, .meta.date, .meta.name, .meta.dev[]?.devId] | @csv' file.json > file.csv",
      "Cannot index string with string \"devId\"",
      "You can use an if-then-else-end on the type to map() over devId when dev is an array, or just use .devId if it's not:",
      ".[] | [ .meta?.dev? | if type == \"array\" then map(.devId)[] else .devId? end ] | @csv",
      "Alternatively [sic], you could use the Destructuring Alternative Operator ?// to provide for the different structures expected ([{$devId}] or {$devId}):",
      ".[] | [ .docId, .item, .meta.date, .meta.name, (.meta.dev as [{$devId}] ?// {$devId} | $devId) // \"missing\" ] | @csv"
    ],
    "utterance": "Extract docId, item, meta.date, meta.name, and meta.dev.devId from each document, outputting an empty or placeholder value when meta.dev or devId is missing or when dev is not consistently an array or object.",
    "expressions": [
      ".[] | [ .docId, .item, .meta.date, .meta.name, ( .meta?.dev? | if type == \"array\" then map(.devId)[] else .devId? end ) ] | @csv",
      ".[] | [ .docId, .item, .meta.date, .meta.name, ( .meta.dev as [{$devId}] ?// {$devId} | $devId ) // \"missing\" ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "docId": "some_hex",
            "bin": {
              "field": "value",
              "length": "123456"
            },
            "item": "item",
            "meta": {
              "date": "dateFnc(123456789)",
              "name": "name",
              "dev": {
                "devId": "987654321",
                "devName": "name"
              },
              "type": "type1"
            }
          },
          {
            "docId": "some_hex",
            "bin": {
              "field": "value",
              "length": "123456"
            },
            "item": "item",
            "meta": {
              "date": "dateFnc(123456789)",
              "name": "name",
              "dev": [
                {
                  "devId": "987654321",
                  "devName": "name"
                }
              ],
              "type": "type1"
            }
          },
          {
            "docId": "some_hex",
            "bin": {
              "field": "value",
              "length": "123456"
            },
            "item": "item",
            "meta": {
              "date": "dateFnc(123456789)",
              "name": "name",
              "type": "type1"
            }
          }
        ],
        "output": [
          "\"some_hex\",\"item\",\"dateFnc(123456789)\",\"name\",\"987654321\"",
          "\"some_hex\",\"item\",\"dateFnc(123456789)\",\"name\",\"987654321\"",
          "\"some_hex\",\"item\",\"dateFnc(123456789)\",\"name\",\"missing\""
        ]
      }
    ],
    "identifier": 76155634
  },
  {
    "context": [
      "Sample JSON 1:\n\n    {\"name\":\"John\",\"last\":\"Smith\",\"position\": \"clerk\"}\n\nSample JSON 2:\n\n    {\"personData\": {\"name\":\"John\",\"last\":\"Smith\"}}",
      "I was using this at the beginning as all my test jsons had the first form:\n\n    jq '{nombre: .name, apellido: .last, puesto: .position}'",
      "When they started coming up empty I tries using the // operator but it doesn't seem to work if I'm providing the keys:\n\nDoesn't work:\n\n    jq '{nombre: .name//.personData.name, apellido: .last, puesto: .position}'",
      "Works (but I don't get any keys):\n\n    jq '{nombre: .name//.personData.name, apellido: .last, puesto: .position//null}'",
      "Expected output would be for the first sample:\n\n    {\"nombre\" : \"John\", \"apellido\": \"Smith\", \"puesto\": \"clerk\" }\n\nAnd for the second sample: \n\n    {\"nombre\" : \"John\", \"apellido\": \"Smith\", \"puesto\": null}",
      "One of many possibilities:\n\n    (.personData // .) |  {nombre: .name, apellido: .last, puesto: .position}",
      "One way, using recursion `..`:\n\n\n    .. | select(has(\"name\") and has(\"last\"))? |\n        { nombre: .name, appelido: .last, puesto: .position }"
    ],
    "utterance": "Extract fields 'name', 'last', and 'position', mapping them to 'nombre', 'apellido', and 'puesto', using either top-level keys or keys under 'personData', returning 'puesto' as null if not available.",
    "expressions": [
      "(.personData // .) | {nombre: .name, apellido: .last, puesto: .position}",
      ".. | select(has(\"name\") and has(\"last\"))? | { nombre: .name, appelido: .last, puesto: .position }"
    ],
    "data": [
      {
        "input": {
          "name": "John",
          "last": "Smith",
          "position": "clerk"
        },
        "output": {
          "nombre": "John",
          "apellido": "Smith",
          "puesto": "clerk"
        }
      },
      {
        "input": {
          "personData": {
            "name": "John",
            "last": "Smith"
          }
        },
        "output": {
          "nombre": "John",
          "apellido": "Smith",
          "puesto": null
        }
      }
    ],
    "identifier": 76191802
  },
  {
    "context": [
      "cat file | jq '[.tx[].vout[]] | max_by(.value)'",
      "cat file | jq '[.tx[]] | max_by(.vout[].value)'",
      "The #1 output is always right, but its output doesn't include parent keys.",
      "I've figured it out to work around with this solution:\nmax=$(cat file | jq '[.tx[].vout[]] | max_by(.value) | .value')\ncat file | jq '.tx[] | select(.vout[].value=='$max')",
      "Your solution can easily be simplified so that only one call to jq is necessary.  Further refinement leads to:\n.tx \n| ([.[].vout[].value]|max) as $max\n| .[] | select(.vout[].value==$max)",
      ".tx \n| ([.[].vout[].value]|max) as $max\n|   .[] | select(any(.vout[]; .value == $max))",
      ".tx \n| ([.[].vout[].value]|max) as $max\n| first(.[] | select(any(.vout[]; .value == $max)))",
      ".tx | max_by( [.vout[].value] | max)"
    ],
    "utterance": "Find the transaction object that contains the highest vout value among all transactions, including all its fields.",
    "expressions": [
      ".tx | max_by([.vout[].value] | max)"
    ],
    "data": [
      {
        "input": {
          "hash": "00000000000000000001241066f08f95165581bcfc9bf322cb8fe2bfb6b2f06c",
          "confirmations": 1,
          "height": 786329,
          "version": 591831040,
          "versionHex": "2346a000",
          "merkleroot": "93fae4566cf6de6321e0cd1ed4ab9ac600189d26d7d61ef6c41487752344bf49",
          "time": 1682050350,
          "mediantime": 1682049479,
          "nonce": 3398206502,
          "bits": "1705c739",
          "difficulty": 48712405953118.43,
          "chainwork": "00000000000000000000000000000000000000004630bda1645c6b5192c287b4",
          "nTx": 1800,
          "previousblockhash": "0000000000000000000266435d01b562713c63d22844afbc2ddabfeaabab0ed0",
          "strippedsize": 751963,
          "size": 1737058,
          "weight": 3992947,
          "tx": [
            {
              "txid": "273baace700870d378d68b9d386520f0b3b3796521748c36b6f494865725728a",
              "vout": [
                {
                  "value": 6.36518171,
                  "n": 0
                },
                {
                  "value": 0.0,
                  "n": 1
                }
              ]
            },
            {
              "txid": "82cad0c8bf23f1e0ada86df5e4cbcd508245ab45618f2424ac4f354445ae1e81",
              "vout": [
                {
                  "value": 0.024,
                  "n": 0
                },
                {
                  "value": 0.00160719,
                  "n": 1
                },
                {
                  "value": 0.01845731,
                  "n": 2
                }
              ]
            },
            {
              "txid": "802ef44673ff9c90bae2a9790aba0a71176cef71f5c7dfde723401beecef6d5a",
              "vout": [
                {
                  "value": 0.006,
                  "n": 0
                },
                {
                  "value": 8.89321842,
                  "n": 1
                }
              ]
            },
            {
              "txid": "d007aa4ef0fdd0add723551e4e43a7214692491c0dd44d8bb93bffd44c9799da",
              "vout": [
                {
                  "value": 0.084,
                  "n": 0
                },
                {
                  "value": 14.3234994,
                  "n": 1
                }
              ]
            },
            {
              "txid": "7cb5c8d5e9aecac1b96bd17d9cbbfa32a2a692f6fae997f648953a8aa92bc74f",
              "vout": [
                {
                  "value": 0.0037595,
                  "n": 0
                },
                {
                  "value": 0.00949735,
                  "n": 1
                },
                {
                  "value": 5.93817769,
                  "n": 2
                }
              ]
            },
            {
              "txid": "b080e7e39d6db4414a25c8c37b642a00e5e5c29592b3ef475754448ccccfb75e",
              "vout": [
                {
                  "value": 0.0188,
                  "n": 0
                },
                {
                  "value": 0.00392486,
                  "n": 1
                },
                {
                  "value": 0.0372562,
                  "n": 2
                },
                {
                  "value": 0.0049577,
                  "n": 3
                },
                {
                  "value": 4.25211103,
                  "n": 4
                }
              ]
            },
            {
              "txid": "e741044ca9a20a860c8f64f43aab9834d61e76370cd81d2963ee48bd3f731e01",
              "vout": [
                {
                  "value": 0.0098211,
                  "n": 0
                },
                {
                  "value": 0.0007907,
                  "n": 1
                },
                {
                  "value": 0.0084311,
                  "n": 2
                },
                {
                  "value": 0.0071109,
                  "n": 3
                },
                {
                  "value": 0.58401219,
                  "n": 4
                }
              ]
            },
            {
              "txid": "af6c40234770c8e3fac9bfc14b5dc4ef59223407e8a24320233d3b89c36500c0",
              "vout": [
                {
                  "value": 5.736,
                  "n": 0
                },
                {
                  "value": 45.68360097,
                  "n": 1
                }
              ]
            }
          ]
        },
        "output": {
          "txid": "af6c40234770c8e3fac9bfc14b5dc4ef59223407e8a24320233d3b89c36500c0",
          "vout": [
            {
              "value": 5.736,
              "n": 0
            },
            {
              "value": 45.68360097,
              "n": 1
            }
          ]
        }
      }
    ],
    "identifier": 76069291
  },
  {
    "context": [
      "I need to capture the string\n\n```\n\"browser_download_url\": \"https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpdl-10.01.1.tar.xz\"\n```\n\nspecifically the value part\n\n```\nhttps://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpdl-10.01.1.tar.xz\n```",
      "The desired string is the last produced by:\n```\n..\n| objects\n| select(has(\"browser_download_url\"))\n| .browser_download_url\n```\nso in the absence of more detailed requirements, I'll go with wrapping this in last():\n\n    last( .... )",
      "Here's another way to do it using `tostream`.\n```\n[ tostream\n| select(.[0][-1] == \"browser_download_url\" and .[1])\n| .[-1] ]\n| last\n```"
    ],
    "utterance": "Extract the value of the last occurrence of the key browser_download_url from the array, specifically the one for ghostpdl-10.01.1.tar.xz.",
    "expressions": [
      "last( .. | objects | select(has(\"browser_download_url\")) | .browser_download_url )",
      "[ tostream | select(.[0][-1] == \"browser_download_url\" and .[1]) | .[-1] ] | last"
    ],
    "data": [
      {
        "input": [
          {
            "url": "https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/96992569",
            "assets_url": "https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/96992569/assets",
            "upload_url": "https://uploads.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/96992569/assets{?name,label}",
            "html_url": "https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/tag/gs10011",
            "id": 96992569,
            "author": {
              "login": "chris-liddell",
              "id": 11627080,
              "node_id": "MDQ6VXNlcjExNjI3MDgw",
              "avatar_url": "https://avatars.githubusercontent.com/u/11627080?v=4",
              "gravatar_id": "",
              "url": "https://api.github.com/users/chris-liddell",
              "html_url": "https://github.com/chris-liddell",
              "followers_url": "https://api.github.com/users/chris-liddell/followers",
              "following_url": "https://api.github.com/users/chris-liddell/following{/other_user}",
              "gists_url": "https://api.github.com/users/chris-liddell/gists{/gist_id}",
              "starred_url": "https://api.github.com/users/chris-liddell/starred{/owner}{/repo}",
              "subscriptions_url": "https://api.github.com/users/chris-liddell/subscriptions",
              "organizations_url": "https://api.github.com/users/chris-liddell/orgs",
              "repos_url": "https://api.github.com/users/chris-liddell/repos",
              "events_url": "https://api.github.com/users/chris-liddell/events{/privacy}",
              "received_events_url": "https://api.github.com/users/chris-liddell/received_events",
              "type": "User",
              "site_admin": false
            },
            "node_id": "RE_kwDOAwH6wM4Fx_05",
            "tag_name": "gs10011",
            "target_commitish": "master",
            "name": "Ghostscript/GhostPDL 10.01.1",
            "draft": false,
            "prerelease": false,
            "created_at": "2023-03-27T08:44:15Z",
            "published_at": "2023-03-27T10:02:24Z",
            "assets": [
              {
                "url": "https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/assets/101122360",
                "id": 101122360,
                "node_id": "RA_kwDOAwH6wM4GBwE4",
                "name": "ghostpcl-10.01.1-win32.zip",
                "label": null,
                "uploader": {
                  "login": "chris-liddell",
                  "id": 11627080,
                  "node_id": "MDQ6VXNlcjExNjI3MDgw",
                  "avatar_url": "https://avatars.githubusercontent.com/u/11627080?v=4",
                  "gravatar_id": "",
                  "url": "https://api.github.com/users/chris-liddell",
                  "html_url": "https://github.com/chris-liddell",
                  "followers_url": "https://api.github.com/users/chris-liddell/followers",
                  "following_url": "https://api.github.com/users/chris-liddell/following{/other_user}",
                  "gists_url": "https://api.github.com/users/chris-liddell/gists{/gist_id}",
                  "starred_url": "https://api.github.com/users/chris-liddell/starred{/owner}{/repo}",
                  "subscriptions_url": "https://api.github.com/users/chris-liddell/subscriptions",
                  "organizations_url": "https://api.github.com/users/chris-liddell/orgs",
                  "repos_url": "https://api.github.com/users/chris-liddell/repos",
                  "events_url": "https://api.github.com/users/chris-liddell/events{/privacy}",
                  "received_events_url": "https://api.github.com/users/chris-liddell/received_events",
                  "type": "User",
                  "site_admin": false
                },
                "content_type": "application/zip",
                "state": "uploaded",
                "size": 10126052,
                "download_count": 1081,
                "created_at": "2023-03-27T08:51:12Z",
                "updated_at": "2023-03-27T08:51:15Z",
                "browser_download_url": "https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpcl-10.01.1-win32.zip"
              },
              {
                "url": "https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/assets/101122363",
                "id": 101122363,
                "node_id": "RA_kwDOAwH6wM4GBwE7",
                "name": "ghostpcl-10.01.1-win64.zip",
                "label": null,
                "uploader": {
                  "login": "chris-liddell",
                  "id": 11627080,
                  "node_id": "MDQ6VXNlcjExNjI3MDgw",
                  "avatar_url": "https://avatars.githubusercontent.com/u/11627080?v=4",
                  "gravatar_id": "",
                  "url": "https://api.github.com/users/chris-liddell",
                  "html_url": "https://github.com/chris-liddell",
                  "followers_url": "https://api.github.com/users/chris-liddell/followers",
                  "following_url": "https://api.github.com/users/chris-liddell/following{/other_user}",
                  "gists_url": "https://api.github.com/users/chris-liddell/gists{/gist_id}",
                  "starred_url": "https://api.github.com/users/chris-liddell/starred{/owner}{/repo}",
                  "subscriptions_url": "https://api.github.com/users/chris-liddell/subscriptions",
                  "organizations_url": "https://api.github.com/users/chris-liddell/orgs",
                  "repos_url": "https://api.github.com/users/chris-liddell/repos",
                  "events_url": "https://api.github.com/users/chris-liddell/events{/privacy}",
                  "received_events_url": "https://api.github.com/users/chris-liddell/received_events",
                  "type": "User",
                  "site_admin": false
                },
                "content_type": "application/zip",
                "state": "uploaded",
                "size": 10654174,
                "download_count": 2190,
                "created_at": "2023-03-27T08:51:15Z",
                "updated_at": "2023-03-27T08:51:18Z",
                "browser_download_url": "https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpcl-10.01.1-win64.zip"
              },
              {
                "url": "https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/assets/101122291",
                "id": 101122291,
                "node_id": "RA_kwDOAwH6wM4GBwDz",
                "name": "ghostpdl-10.01.1.tar.gz",
                "label": null,
                "uploader": {
                  "login": "chris-liddell",
                  "id": 11627080,
                  "node_id": "MDQ6VXNlcjExNjI3MDgw",
                  "avatar_url": "https://avatars.githubusercontent.com/u/11627080?v=4",
                  "gravatar_id": "",
                  "url": "https://api.github.com/users/chris-liddell",
                  "html_url": "https://github.com/chris-liddell",
                  "followers_url": "https://api.github.com/users/chris-liddell/followers",
                  "following_url": "https://api.github.com/users/chris-liddell/following{/other_user}",
                  "gists_url": "https://api.github.com/users/chris-liddell/gists{/gist_id}",
                  "starred_url": "https://api.github.com/users/chris-liddell/starred{/owner}{/repo}",
                  "subscriptions_url": "https://api.github.com/users/chris-liddell/subscriptions",
                  "organizations_url": "https://api.github.com/users/chris-liddell/orgs",
                  "repos_url": "https://api.github.com/users/chris-liddell/repos",
                  "events_url": "https://api.github.com/users/chris-liddell/events{/privacy}",
                  "received_events_url": "https://api.github.com/users/chris-liddell/received_events",
                  "type": "User",
                  "site_admin": false
                },
                "content_type": "application/gzip",
                "state": "uploaded",
                "size": 96849416,
                "download_count": 2624,
                "created_at": "2023-03-27T08:50:15Z",
                "updated_at": "2023-03-27T08:50:32Z",
                "browser_download_url": "https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpdl-10.01.1.tar.gz"
              },
              {
                "url": "https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/releases/assets/101122309",
                "id": 101122309,
                "node_id": "RA_kwDOAwH6wM4GBwEF",
                "name": "ghostpdl-10.01.1.tar.xz",
                "label": null,
                "uploader": {
                  "login": "chris-liddell",
                  "id": 11627080,
                  "node_id": "MDQ6VXNlcjExNjI3MDgw",
                  "avatar_url": "https://avatars.githubusercontent.com/u/11627080?v=4",
                  "gravatar_id": "",
                  "url": "https://api.github.com/users/chris-liddell",
                  "html_url": "https://github.com/chris-liddell",
                  "followers_url": "https://api.github.com/users/chris-liddell/followers",
                  "following_url": "https://api.github.com/users/chris-liddell/following{/other_user}",
                  "gists_url": "https://api.github.com/users/chris-liddell/gists{/gist_id}",
                  "starred_url": "https://api.github.com/users/chris-liddell/starred{/owner}{/repo}",
                  "subscriptions_url": "https://api.github.com/users/chris-liddell/subscriptions",
                  "organizations_url": "https://api.github.com/users/chris-liddell/orgs",
                  "repos_url": "https://api.github.com/users/chris-liddell/repos",
                  "events_url": "https://api.github.com/users/chris-liddell/events{/privacy}",
                  "received_events_url": "https://api.github.com/users/chris-liddell/received_events",
                  "type": "User",
                  "site_admin": false
                },
                "content_type": "application/x-xz",
                "state": "uploaded",
                "size": 73020984,
                "download_count": 7698,
                "created_at": "2023-03-27T08:50:32Z",
                "updated_at": "2023-03-27T08:50:49Z",
                "browser_download_url": "https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpdl-10.01.1.tar.xz"
              }
            ],
            "tarball_url": "https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/tarball/gs928rc3",
            "zipball_url": "https://api.github.com/repos/ArtifexSoftware/ghostpdl-downloads/zipball/gs928rc3",
            "body": ""
          }
        ],
        "output": "https://github.com/ArtifexSoftware/ghostpdl-downloads/releases/download/gs10011/ghostpdl-10.01.1.tar.xz"
      }
    ],
    "identifier": 76020187
  }
]