[
  {
    "context": [
      "My expected output is sample-bucket and i want to select it using the \"num_objects\"",
      "This filter first selects the object where the \"num_objects\" property is equal to 189398, and then extracts the value of the \"bucket\" property from that object,so this should give you the expected output of \"sample-bucket\"!",
      "cat testjql.txt | jq -r 'select(.num_objects == 189398).bucket'"
    ],
    "utterance": "Select the value of the property 'bucket' where 'num_objects' equals 189398.",
    "expressions": [
      "select(.num_objects == 189398).bucket"
    ],
    "data": [
      {
        "input": {
          "bucket": "sample-bucket",
          "tenant": "",
          "num_objects": 189398,
          "num_shards": 0,
          "objects_per_shard": 189398,
          "fill_status": "OVER 100.000000%"
        },
        "output": "sample-bucket"
      }
    ],
    "identifier": 77141019
  },
  {
    "context": [
      "If i pipe this into ```jq``` using ```python3 jqtest.py | jq .``` it only prints the JSON when the script has completely finished.",
      "How can i invoke ```jq``` for every new JSON object received during execution, not just at the end?",
      "You need to unbuffer python&#39;s stdout, e.g.:",
      "python3 -u jqtest.py | jq '.'."
    ],
    "utterance": "Process each line of streaming output as individual objects as they arrive, instead of waiting for script completion.",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": "{\"Iteration\": 1, \"Field0\": 0, \"Field1\": 1, \"Field2\": 2}\n{\"Iteration\": 2, \"Field0\": 0, \"Field1\": 1, \"Field2\": 2}\n{\"Iteration\": 3, \"Field0\": 0, \"Field1\": 1, \"Field2\": 2}\n",
        "output": "{\"Iteration\": 1, \"Field0\": 0, \"Field1\": 1, \"Field2\": 2}\n{\"Iteration\": 2, \"Field0\": 0, \"Field1\": 1, \"Field2\": 2}\n{\"Iteration\": 3, \"Field0\": 0, \"Field1\": 1, \"Field2\": 2}\n"
      }
    ],
    "identifier": 77162311
  },
  {
    "context": [
      "Given the following JSON structure",
      "How can I use jq to structure the data as",
      "Take the `.data` array, and `map` each item to an object. Use `.teams[]` to iterate without capturing the items in a separate array, so the output is multiplicated:",
      "jq '.data | map({id, team: .teams[]})'",
      "This is another way:\n\n```shell\njq '[ .data[] | { id, team: .teams[] } ]'\n```"
    ],
    "utterance": "For each item, create a new object for every team with the original id and the team value as a separate property.",
    "expressions": [
      ".data | map({id, team: .teams[]})",
      "[ .data[] | { id, team: .teams[] } ]"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "000000000014444A",
              "teams": [
                "000000000011AE74"
              ]
            },
            {
              "id": "000000000014434B",
              "teams": [
                "000000000011AE74",
                "00000000001583CE",
                "000000000010B4D7"
              ]
            }
          ]
        },
        "output": [
          {
            "id": "000000000014444A",
            "team": "000000000011AE74"
          },
          {
            "id": "000000000014434B",
            "team": "000000000011AE74"
          },
          {
            "id": "000000000014434B",
            "team": "00000000001583CE"
          },
          {
            "id": "000000000014434B",
            "team": "000000000010B4D7"
          }
        ]
      }
    ],
    "identifier": 77160241
  },
  {
    "context": [
      "USERNAMES=$(jq -r 'to_entries[]| select(.value.policy_name)?| [.key, .value.username, .value.policy_name, .value.atg_type ]| join(\" \")' ${DS_SRC_FILE})",
      "while read  ds current_username policy atg; do",
      "But when trying it from a linux box, with other bash and jq versions :",
      "It fails, because there is no carriage return after the 1st end of line :"
    ],
    "utterance": "Extract all entries with a 'policy_name' and output each as a single line with the key, username, policy_name, and atg_type fields joined by spaces.",
    "expressions": [
      "to_entries[] | select(.value.policy_name)? | [.key, .value.username, .value.policy_name, .value.atg_type] | @tsv",
      "to_entries[] | select(.value.policy_name)? | [.key, .value.username, .value.policy_name, .value.atg_type] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "DS1": {
            "username": "user_1",
            "policy_name": "policy_1",
            "atg_type": "CORE"
          },
          "DS3": {
            "username": "user_2",
            "policy_name": "policy_2",
            "atg_type": "SWA"
          },
          "DS4": {
            "username": "user_3",
            "policy_name": "policy_3",
            "atg_type": "SWB"
          }
        },
        "output": [
          "DS1 user_1 policy_1 CORE",
          "DS3 user_2 policy_2 SWA",
          "DS4 user_3 policy_3 SWB"
        ]
      }
    ],
    "identifier": 77151239
  },
  {
    "context": [
      "I don't know how to get the 2nd record key (4.2.5) in bash with jq.",
      "You can use `keys_unsorted` to get a list of keys in representation order, then take the second one (at index 1):",
      "jq -r '.versions | keys_unsorted[1]'"
    ],
    "utterance": "Get the second key in the versions object, which is 4.2.5.",
    "expressions": [
      ".versions | keys_unsorted[1]"
    ],
    "data": [
      {
        "input": {
          "versions": {
            "dev": "spip/dev/spip-master.zip",
            "4.2.5": "spip/archives/spip-v4.2.5.zip",
            "4.1.12": "spip/archives/spip-v4.1.12.zip",
            "4.0.11": "spip/archives/spip-v4.0.11.zip",
            "3.2.19": "spip/archives/spip-v3.2.19.zip"
          }
        },
        "output": "4.2.5"
      }
    ],
    "identifier": 77168700
  },
  {
    "context": [
      "when filtering out all items that are objects and arrays, null values are affected as well.",
      "Desired (and expected) output:",
      "{\n  \"[\\\"object\\\",\\\"key1\\\"]\": 1,\n  \"[\\\"object\\\",\\\"key2\\\"]\": null,\n  \"[\\\"object\\\",\\\"key3\\\"]\": 3,\n  \"[\\\"array\\\",0]\": \"a\",\n  \"[\\\"array\\\",1]\": null,\n  \"[\\\"array\\\",2]\": \"c\"\n}",
      "your node filter also applies another `select/1` around the result, causing *falsy* values (`null` and `false`) being filtered out. Remove your `select/1` from the node filter, and it'll work:",
      "[ paths(type | IN(\"object\", \"array\") | not) as $path\n  | { \"\\($path)\": getpath($path) }\n] | add",
      "[ path(.. | select(type | IN(\"object\", \"array\") | not)) as $path\n  | { \"\\($path)\": getpath($path) }\n] | add",
      "[ path(.. | scalars) as $path\n  | { \"\\($path)\": getpath($path) }\n] | add"
    ],
    "utterance": "Extract all values that are not objects or arrays, including those that are null, and map them by their path.",
    "expressions": [
      "[ paths(type | IN(\"object\", \"array\") | not) as $path | { \"\\($path)\": getpath($path) } ] | add",
      "[ path(.. | select(type | IN(\"object\", \"array\") | not)) as $path | { \"\\($path)\": getpath($path) } ] | add",
      "[ path(.. | scalars) as $path | { \"\\($path)\": getpath($path) } ] | add"
    ],
    "data": [
      {
        "input": {
          "object": {
            "key1": 1,
            "key2": null,
            "key3": 3
          },
          "array": [
            "a",
            null,
            "c"
          ]
        },
        "output": {
          "[\"object\",\"key1\"]": 1,
          "[\"object\",\"key2\"]": null,
          "[\"object\",\"key3\"]": 3,
          "[\"array\",0]": "a",
          "[\"array\",1]": null,
          "[\"array\",2]": "c"
        }
      }
    ],
    "identifier": 77164858
  },
  {
    "context": [
      "But what I am looking for is\n`adb shell am start -a android.intent.action.VIEW -d file:////Downloads/test.mp3 -t audio/mp3`",
      "it's possible for `jq` to form the `command` string in one go using a filter like this.  Perhaps you can adapt it for your application.\n```jq\n.commands.play_music\n| .command as $cmd\n| .variables\n  | .device_directory.variable as $dir\n  | .music_file.variable as $file\n  | .audio_type.variable as $type\n| $cmd\n| sub(\"\\\\${device_directory}\"; $dir)\n| sub(\"\\\\${music_file}\"; $file)\n| sub(\"\\\\${audio_type}\"; $type)\n```",
      "The same output is produced by this filter and is perhaps more adaptable to your application.\n```jq\n.commands.play_music\n| (.variables|map({k: .name, v: .variable})) as $vars\n| reduce $vars[] as $var (.command; .|sub(\"\\\\${\\\\($var.k)}\"; $var.v))\n```",
      "... and more incomprehensibly as:\n```jq\n.commands.play_music\n| reduce .variables[] as $var (.command; .|sub(\"\\\\${\\\\($var.name)}\"; $var.variable))\n```"
    ],
    "utterance": "Substitute all variable placeholders in the 'play_music' command with their corresponding values to produce the complete command string.",
    "expressions": [
      ".commands.play_music\n| .command as $cmd\n| .variables\n  | .device_directory.variable as $dir\n  | .music_file.variable as $file\n  | .audio_type.variable as $type\n| $cmd\n| sub(\"\\\\${device_directory}\"; $dir)\n| sub(\"\\\\${music_file}\"; $file)\n| sub(\"\\\\${audio_type}\"; $type)",
      ".commands.play_music\n| (.variables|map({k: .name, v: .variable})) as $vars\n| reduce $vars[] as $var (.command; .|sub(\"\\\\${\\\\($var.k)}\"; $var.v))",
      ".commands.play_music\n| reduce .variables[] as $var (.command; .|sub(\"\\\\${\\\\($var.name)}\"; $var.variable))"
    ],
    "data": [
      {
        "input": {
          "commands": {
            "play_music": {
              "name": "play_music",
              "command": "adb shell am start -a android.intent.action.VIEW -d file:///${device_directory}${music_file} -t audio/${audio_type}",
              "variables": {
                "device_directory": {
                  "name": "device_directory",
                  "variable": "/Downloads/"
                },
                "music_file": {
                  "name": "music_file",
                  "variable": "test.mp3"
                },
                "audio_type": {
                  "name": "audio_type",
                  "variable": "mp3"
                }
              }
            }
          }
        },
        "output": "adb shell am start -a android.intent.action.VIEW -d file:////Downloads/test.mp3 -t audio/mp3"
      }
    ],
    "identifier": 77138622
  },
  {
    "identifier": 77182646
  },
  {
    "context": [
      "I have two simple jsons like:",
      "info.json\n[\n  {\n    \"filename\": \"drilldown.json\",\n    \"line\": 14,\n    \"column\": \"43-49\"\n  },\n  {\n    \"filename\": \"drilldown.json\",\n    \"line\": 10,\n    \"column\": \"38-44\"\n  }\n]",
      "keywords.json\n[\n  {\n    \"keyword\": \" `master1` \"\n  },\n  {\n    \"keyword\": \" `Master2` \"\n  }\n]",
      "Would like to have the result as:",
      "results.json\n[\n  {\n    \"filename\": \"drilldown.json\",\n    \"line\": 14,\n    \"column\": \"43-49\",\n    \"keyword\": \" `master1` \"\n  },\n  {\n    \"filename\": \"drilldown.json\",\n    \"line\": 10,\n    \"column\": \"38-44\",\n    \"keyword\": \" `Master2` \"\n  }\n]",
      "You can merge (`add`) the items based on their index in their respective arrays using `--slurp` (or `-s`) and `transpose`:",
      "jq -s 'transpose | map(add)' info.json keywords.json",
      "Output:\n[\n  {\n    \"filename\": \"drilldown.json\",\n    \"line\": 14,\n    \"column\": \"43-49\",\n    \"keyword\": \" `master1` \"\n  },\n  {\n    \"filename\": \"drilldown.json\",\n    \"line\": 10,\n    \"column\": \"38-44\",\n    \"keyword\": \" `Master2` \"\n  }\n]"
    ],
    "utterance": "Combine two arrays of objects into a single array so that each object from the first array is merged with the object at the same index from the second array.",
    "expressions": [
      "jq -s 'transpose | map(add)' info.json keywords.json",
      "jq 'reduce (inputs | to_entries)[] as {$key, $value} (.; .[$key] += $value)' info.json keywords.json",
      "jq --stream -n 'reduce (inputs | select(has(1))) as $i (.; setpath($i[0]; $i[1]))' info.json keywords.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "filename": "drilldown.json",
              "line": 14,
              "column": "43-49"
            },
            {
              "filename": "drilldown.json",
              "line": 10,
              "column": "38-44"
            }
          ],
          [
            {
              "keyword": " `master1` "
            },
            {
              "keyword": " `Master2` "
            }
          ]
        ],
        "output": [
          {
            "filename": "drilldown.json",
            "line": 14,
            "column": "43-49",
            "keyword": " `master1` "
          },
          {
            "filename": "drilldown.json",
            "line": 10,
            "column": "38-44",
            "keyword": " `Master2` "
          }
        ]
      }
    ],
    "identifier": 77153469
  },
  {
    "context": [
      "I need JQ statement for getting VM names (such as vm01, vm03) which have \"relevant\" key set to \"true\"",
      ".vms[] | to_entries[] | select(any(.value[]; .relevant == \"true\")).key",
      "We want to select the vms where any of its values have a `relevant` key set to `\"true\"`."
    ],
    "utterance": "Get the names of VMs whose associated array contains an object with 'relevant' equal to 'true'.",
    "expressions": [
      ".vms[] | to_entries[] | select(any(.value[]; .relevant == \"true\")).key"
    ],
    "data": [
      {
        "input": {
          "vms": [
            {
              "vm01": [
                {
                  "relevant": "true"
                }
              ],
              "vm02": [
                {
                  "relevant": "false"
                }
              ],
              "vm03": [
                {
                  "relevant": "true"
                }
              ]
            }
          ]
        },
        "output": [
          "vm01",
          "vm03"
        ]
      }
    ],
    "identifier": 77178511
  },
  {
    "context": [
      "I would like to publish modified schema without all required properties.",
      "The schema itself is repeatable, the \"required\" key can also be found in a 9th or 10th nested level. That's why I need a solution which enables to do it recursively.",
      "If you want to delete all `\"required\"` properties at any level, the following expression should work:",
      "del(..|.required?)",
      "**Recursively remove one key**",
      "jq 'walk(if type == \"object\" then del(.required) else . end)'",
      "# same as",
      "jq 'del(..|.required?)'"
    ],
    "utterance": "Remove all keys named 'required' at any level from the data, recursively.",
    "expressions": [
      "del(..|.required?)",
      "walk(if type == \"object\" then del(.required) else . end)"
    ],
    "data": [
      {
        "input": {
          "$schema": "http://json-schema.org/draft-07/schema#",
          "type": "object",
          "properties": {
            "blackbox": {
              "type": "object",
              "properties": {
                "enabled": {
                  "type": "boolean"
                }
              },
              "required": [
                "enabled"
              ]
            }
          },
          "required": [
            "blackbox"
          ]
        },
        "output": {
          "$schema": "http://json-schema.org/draft-07/schema#",
          "type": "object",
          "properties": {
            "blackbox": {
              "type": "object",
              "properties": {
                "enabled": {
                  "type": "boolean"
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 77171901
  },
  {
    "context": [
      "I want the output to be filtered only with select key and values. The filtered output I need is ",
      "jq '[.[] | {iid: .iid, project_id: .project_id, ref: .ref, status: .status, source: .source, created_at: .created_at, updated_at: .updated_at, web_url: .web_url}]'",
      "map(pick( .iid, .project_id, .ref, .status, .source, .created_at, .updated_at, .web_url ))",
      "map(del(.id, .sha))",
      "map(with_entries(select(.key | IN( \"iid\", \"project_id\", \"ref\", \"status\", \"source\", \"created_at\", \"updated_at\", \"web_url\" ))))",
      "map(with_entries(select(.key | IN(\"id\", \"sha\") | not)))",
      "map({ iid, project_id, ref, status, source, created_at, updated_at, web_url })"
    ],
    "utterance": "Filter each object to only include iid, project_id, ref, status, source, created_at, updated_at, and web_url fields.",
    "expressions": [
      "[.[] | {iid: .iid, project_id: .project_id, ref: .ref, status: .status, source: .source, created_at: .created_at, updated_at: .updated_at, web_url: .web_url}]",
      "map({iid, project_id, ref, status, source, created_at, updated_at, web_url})",
      "map(pick(.iid, .project_id, .ref, .status, .source, .created_at, .updated_at, .web_url))",
      "map(del(.id, .sha))",
      "map(with_entries(select(.key | IN(\"iid\", \"project_id\", \"ref\", \"status\", \"source\", \"created_at\", \"updated_at\", \"web_url\"))))",
      "map(with_entries(select(.key | IN(\"id\", \"sha\") | not)))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 4449282,
            "iid": 6316,
            "project_id": 1234,
            "sha": "abcdefg",
            "ref": "test_branch",
            "status": "running",
            "source": "web",
            "created_at": "2023-09-25T05:55:20.788Z",
            "updated_at": "2023-09-25T05:55:23.481Z",
            "web_url": "https://example.gitlab.com"
          }
        ],
        "output": [
          {
            "iid": 6316,
            "project_id": 1234,
            "ref": "test_branch",
            "status": "running",
            "source": "web",
            "created_at": "2023-09-25T05:55:20.788Z",
            "updated_at": "2023-09-25T05:55:23.481Z",
            "web_url": "https://example.gitlab.com"
          }
        ]
      }
    ],
    "identifier": 77170372
  },
  {
    "context": [
      "I have an array of string in json format. I'd like to check whether it includes a specific string value.",
      "I have tried to use `contains`:\n\necho '[\"aa\", \"bb\", \"cc\"]' |jq '. | contains([\"aa\"])'\n> true\n\nit works but it also return true for a partial match: \n\necho '[\"aa\", \"bb\", \"cc\"]' |jq '. | contains([\"a\"])'\n> true",
      "how can I find the exact match?",
      "You could use a regex with a word boundary:\n\n$ echo '[\"aa\", \"bb\", \"cc\"]' | jq -r '.[] | test([\"\\\\baa\\\\b\"]) | tostring | select(. == \"true\")'\ntrue"
    ],
    "utterance": "Check if an array contains a specific string value as an exact match.",
    "expressions": [
      "any(.[]; . == \"aa\")",
      "[.[] == \"aa\"] | any",
      "index(\"aa\") != null"
    ],
    "data": [
      {
        "input": [
          "aa",
          "bb",
          "cc"
        ],
        "output": true
      },
      {
        "input": [
          "ab",
          "bb",
          "cc"
        ],
        "output": false
      }
    ],
    "identifier": 77187096
  },
  {
    "context": [
      "Construct the JSON entry",
      "# Add the new entry to Machines.json",
      "jq \". += {\\\"$received_data\\\": $new_entry}\" /Machines.json > tmp.json && mv tmp.json /Machines.json"
    ],
    "utterance": "Add a new key-value entry to an object where the key is a variable and the value is a constructed object, without corrupting the original data.",
    "expressions": [
      ". += {\"$received_data\": $new_entry}"
    ],
    "data": [
      {
        "input": {
          "1.2.3.4": {
            "visible": true,
            "color": "rgb(125, 255, 0)",
            "address": "1.2.3.4"
          }
        },
        "output": {
          "1.2.3.4": {
            "visible": true,
            "color": "rgb(125, 255, 0)",
            "address": "1.2.3.4"
          },
          "5.6.7.8": {
            "visible": true,
            "color": "rgb(0, 253, 255)",
            "user": "REDACTED",
            "address": "5.6.7.8"
          }
        }
      }
    ],
    "identifier": 77210078
  },
  {
    "context": [
      "I have two string arrays and I'd like to find all strings from the second array that exist in the first array. For example:\n\narr1=[\"a\", \"b\", \"c\"]\narr2=[\"b\", \"d\", \"1\"]\n\nI'd like to return [\"b\"].",
      "[\"a\", \"b\", \"c\"] - ([\"a\", \"b\", \"c\"] - [\"b\", \"d\", \"1\"])\n\nWill output \n[\n  \"b\"\n]",
      "jq -n --argjson arr1 '[\"a\",\"b\",\"c\"]' --argjson arr2 '[\"b\",\"d\",\"1\"]' '\n    $arr1 + $arr2 \n    | reduce .[] as $x ({}; .[$x] += 1) \n    | to_entries \n    | map(select(.value == 2) | .key)\n'"
    ],
    "utterance": "Find all values from the second array that are also present in the first array, given arr1=[\"a\",\"b\",\"c\"] and arr2=[\"b\",\"d\",\"1\"].",
    "expressions": [
      "[\"a\", \"b\", \"c\"] - ([\"a\", \"b\", \"c\"] - [\"b\", \"d\", \"1\"])",
      "--argjson arr1 '[\"a\",\"b\",\"c\"]' --argjson arr2 '[\"b\",\"d\",\"1\"]' '$arr1 + $arr2 | reduce .[] as $x ({}; .[$x] += 1) | to_entries | map(select(.value == 2) | .key)'"
    ],
    "data": [
      {
        "input": {
          "arr1": [
            "a",
            "b",
            "c"
          ],
          "arr2": [
            "b",
            "d",
            "1"
          ]
        },
        "output": [
          "b"
        ]
      }
    ],
    "identifier": 77187628
  },
  {
    "context": [
      "I'm trying to just pick out the ones that have \"StatusIndicator\" set to \"Fail\" and print out the .PhysicalLocation.PartLocation.ServiceLabel.",
      "I tried:\n\n```\njq -r '.Drives[] | select(.StatusIndicator==\"Fail\") | .PhysicalLocation.PartLocation.ServiceLabel' json-file\n```\nbut I get nothing.  Anyone have an idea what I am doing wrong?"
    ],
    "utterance": "Select all drives where StatusIndicator is equal to \"Fail\" and output their PhysicalLocation.PartLocation.ServiceLabel.",
    "expressions": [
      ".Drives[] | select(.StatusIndicator == \"Fail\") | .PhysicalLocation.PartLocation.ServiceLabel"
    ],
    "data": [
      {
        "input": {
          "Server": "my-pc.org",
          "ArrayController": "DE0080000",
          "Health": "OK",
          "NumDrives": "2",
          "Drives": [
            {
              "@odata.id": "/redfish/v1/Systems/1/Storage/DE0080000/Drives/0",
              "@odata.type": "#Drive.v1_14_0.Drive",
              "Id": "0",
              "Name": "15TB 22.5G SAS SSD",
              "Status": {
                "State": "UnavailableOffline",
                "Health": "Critical"
              },
              "LocationIndicatorActive": false,
              "Model": "VO001920RZWUV",
              "Revision": "HPD0",
              "Protocol": "SAS",
              "MediaType": "SSD",
              "CapacityBytes": 1920383410176,
              "BlockSizeBytes": 512,
              "SerialNumber": "12BA08LTL08",
              "FailurePredicted": false,
              "PredictedMediaLifeLeftPercent": 100,
              "StatusIndicator": "Fail",
              "Identifiers": [
                {
                  "DurableName": "58CE38EE21D51FE",
                  "DurableNameFormat": "NAA"
                }
              ],
              "PhysicalLocation": {
                "PartLocation": {
                  "LocationType": "Bay",
                  "ServiceLabel": "Slot=1:Port=2E:Box=1:Bay=1",
                  "LocationOrdinalValue": 1
                }
              },
              "HotspareType": "None",
              "EncryptionAbility": "None",
              "WriteCacheEnabled": false,
              "CapableSpeedGbs": 22.5,
              "NegotiatedSpeedGbs": 12,
              "Operations": [],
              "Multipath": true,
              "Links": {
                "Volumes@odata.count": 1,
                "Volumes": [
                  {
                    "@odata.id": "/redfish/v1/Systems/1/Storage/DE0080000/Volumes/1"
                  }
                ]
              },
              "@odata.etag": "\"63838C5C\""
            },
            {
              "@odata.id": "/redfish/v1/Systems/1/Storage/DE0080000/Drives/1",
              "@odata.type": "#Drive.v1_14_0.Drive",
              "Id": "1",
              "Name": "15TB 22.5G SAS SSD",
              "Status": {
                "State": "Enabled",
                "Health": "OK"
              },
              "LocationIndicatorActive": false,
              "Model": "VO001920RZWUV",
              "Revision": "HPD0",
              "Protocol": "SAS",
              "MediaType": "SSD",
              "CapacityBytes": 1920383410176,
              "BlockSizeBytes": 512,
              "SerialNumber": "12BA08LTL08",
              "FailurePredicted": false,
              "PredictedMediaLifeLeftPercent": 100,
              "StatusIndicator": "OK",
              "Identifiers": [
                {
                  "DurableName": "58CE38EE21D51FE",
                  "DurableNameFormat": "NAA"
                }
              ],
              "PhysicalLocation": {
                "PartLocation": {
                  "LocationType": "Bay",
                  "ServiceLabel": "Slot=1:Port=2E:Box=1:Bay=2",
                  "LocationOrdinalValue": 2
                }
              },
              "HotspareType": "None",
              "EncryptionAbility": "None",
              "WriteCacheEnabled": false,
              "CapableSpeedGbs": 22.5,
              "NegotiatedSpeedGbs": 12,
              "Operations": [],
              "Multipath": true,
              "Links": {
                "Volumes@odata.count": 1,
                "Volumes": [
                  {
                    "@odata.id": "/redfish/v1/Systems/1/Storage/DE0080000/Volumes/1"
                  }
                ]
              },
              "@odata.etag": "\"6383FE34\""
            }
          ]
        },
        "output": "Slot=1:Port=2E:Box=1:Bay=1"
      }
    ],
    "identifier": 77180739
  },
  {
    "context": [
      "I want to find those entries in file2 that their id exist in file1, in the example above the expected output should be like:",
      "jq --slurp '.[0] as $filt | reduce .[1][] as $ref ([]; if IN($ref.id; $filt[]) then . + [$ref] else . end)' file1.json file2.json",
      "jq --null-input 'input as $filt | reduce inputs[] as $ref ([]; if IN($ref.id; $filt[]) then . + [$ref] else . end)' file1.json file2.json",
      "jq 'input as $ids | map(select(IN(.id; $ids[])))' file2.json file1.json"
    ],
    "utterance": "Select all objects from the second file whose id matches any value in the first file's array.",
    "expressions": [
      "jq --slurp '.[0] as $filt | reduce .[1][] as $ref ([]; if IN($ref.id; $filt[]) then . + [$ref] else . end)' file1.json file2.json",
      "jq --null-input 'input as $filt | reduce inputs[] as $ref ([]; if IN($ref.id; $filt[]) then . + [$ref] else . end)' file1.json file2.json",
      "jq 'input as $ids | map(select(IN(.id; $ids[])))' file2.json file1.json"
    ],
    "data": [
      {
        "input": {
          "file1.json": [
            "id1",
            "id2"
          ],
          "file2.json": [
            {
              "id": "id1",
              "name": "name1"
            },
            {
              "id": "id1",
              "name": "name2"
            },
            {
              "id": "id3",
              "name": "name3"
            },
            {
              "id": "id5",
              "name": "name5"
            },
            {
              "id": "id2",
              "name": "name6"
            }
          ]
        },
        "output": [
          {
            "id": "id1",
            "name": "name1"
          },
          {
            "id": "id1",
            "name": "name2"
          },
          {
            "id": "id2",
            "name": "name6"
          }
        ]
      }
    ],
    "identifier": 77222636
  },
  {
    "context": [
      "I want to add `key3` to output only when `amc.ott.req.ip` equals to `t`, can please someone help on how to add json key based on condition?",
      "Here's one way to do it.",
      "($reqs | map({(.wc): ({\"type\": .wc, \"value\":$resources[.os]} + (if .ip == \"t\" then {\"key3\": $resources.sp.hH} else null end))}))"
    ],
    "utterance": "Add the key 'key3' with value from 'sp.hH' to the output object under the property whose 'ip' field equals 't'; otherwise, do not include 'key3'.",
    "expressions": [
      ".[1].res[0] as $resources\n| .[0].amc.ott[].req as $reqs\n| ($reqs | map({(.wc): ({\"type\": .wc, \"value\":$resources[.os]} + (if .ip == \"t\" then {\"key3\": $resources.sp.hH} else null end))}))\n+ [ {\"Column\" : {\"type\":\"S\",\"value\":.[0].sn}},\n    {\"Mod\": $reqs[] | select(.wc == \"rm\") | {\"type\": .wc,\"value\": $resources[.os]}}\n  ]\n| add"
    ],
    "data": [
      {
        "input": [
          {
            "sn": "rv",
            "amc": {
              "ott": [
                {
                  "req": [
                    {
                      "wc": "tc",
                      "os": "des",
                      "dt": "rt",
                      "ip": "f"
                    },
                    {
                      "wc": "nm",
                      "os": "id",
                      "dt": "s",
                      "ip": "t"
                    },
                    {
                      "wc": "rm",
                      "os": "mo",
                      "dt": "ts",
                      "ip": "f"
                    }
                  ]
                }
              ]
            }
          },
          {
            "res": [
              {
                "sp": {
                  "dm": "dmValue",
                  "hH": "hHValue"
                },
                "des": "desval",
                "id": "1234",
                "mo": "movalur"
              }
            ]
          }
        ],
        "output": {
          "tc": {
            "type": "tc",
            "value": "desval"
          },
          "nm": {
            "type": "nm",
            "value": "1234",
            "key3": "hHValue"
          },
          "rm": {
            "type": "rm",
            "value": "movalur"
          },
          "Column": {
            "type": "S",
            "value": "rv"
          },
          "Mod": {
            "type": "rm",
            "value": "movalur"
          }
        }
      }
    ],
    "identifier": 77157402
  },
  {
    "context": [
      "The values of the `$ref` properties in the schema are incomplete.  The validator tool is unable to resolve the references.",
      "The references above should be `TypeDefinitions.json#/extensions` and `Membership.json`, respectively.",
      "I tried to come up with jq code to use a regex to edit these references at any depth, but I haven't quite figured it out.",
      "Couldn't you just update (`|=`) every `.\"$ref\"` key that points to a string by prepending either the first `#` or the end of the string with `.json`?",
      "```sh\n(.. | objects.\"$ref\" | strings) |= sub(\"(?<a>#|$)\", \".json\\(.a)\")\n```",
      "For versions 1.5+ (since regexp support was added), this can be mitigated by explicitly treating that case: Add `// \"\"` to manually provide the empty string as an alternative if `.a` evaluates to a *falsy* value (like `null`).",
      "```sh\n(.. | objects.\"$ref\" | strings) |= sub(\"(?<a>#|$)\", \".json\\(.a // \"\")\")\n```"
    ],
    "utterance": "Append '.json' before the first '#' or at the end of every string value of any '$ref' property, at any depth.",
    "expressions": [
      "(.. | objects.\"$ref\" | strings) |= sub(\"(?<a>#|$)\", \".json\\(.a)\")",
      "(.. | objects.\"$ref\" | strings) |= sub(\"(?<a>#|$)\", \".json\\(.a // \"\")\")"
    ],
    "data": [
      {
        "input": {
          "schema": "http://json-schema.org/draft-04/schema#",
          "id": "FubarAgent",
          "metaFormat": "http://example.org/fubar/",
          "type": "object",
          "properties": {
            "extensions": {
              "$ref": "TypeDefinitions#/extensions"
            },
            "name": {
              "type": "string",
              "maxLength": 2048,
              "title": "name"
            },
            "membership": {
              "oneOf": [
                {
                  "$ref": "Membership"
                },
                {
                  "type": "string",
                  "maxLength": 2048
                }
              ]
            }
          },
          "title": "FubarAgent"
        },
        "output": {
          "schema": "http://json-schema.org/draft-04/schema#",
          "id": "FubarAgent",
          "metaFormat": "http://example.org/fubar/",
          "type": "object",
          "properties": {
            "extensions": {
              "$ref": "TypeDefinitions.json#/extensions"
            },
            "name": {
              "type": "string",
              "maxLength": 2048,
              "title": "name"
            },
            "membership": {
              "oneOf": [
                {
                  "$ref": "Membership.json"
                },
                {
                  "type": "string",
                  "maxLength": 2048
                }
              ]
            }
          },
          "title": "FubarAgent"
        }
      }
    ],
    "identifier": 77190745
  },
  {
    "context": [
      "\"timestamp\": \"1696358217197\"",
      "This is a timestamp prefixed with a month (This number is supposed to be October).",
      "I can't find a way to convert from this format to Year-Month-Day (ie: 2023-10-02).",
      "extract the string using `.timestamp`, convert to number using `tonumber`, divide by 1000 to convert milliseconds to seconds, and finally convert to your preferred date format using `strftime` (`%F` is equivalent to `%Y-%m-%d`):",
      "jq -r '.timestamp | tonumber / 1000 | strftime(\"%F\")'",
      "2023-10-03"
    ],
    "utterance": "Convert the millisecond epoch value from the 'timestamp' field to a date in the format YYYY-MM-DD.",
    "expressions": [
      ".timestamp | tonumber / 1000 | strftime(\"%F\")"
    ],
    "data": [
      {
        "input": {
          "timestamp": "1696358217197"
        },
        "output": "2023-10-03"
      }
    ],
    "identifier": 77224785
  },
  {
    "context": [
      "So, I have a .netrc file that looks like this:\r\n\r\n```\r\nmachine foo\r\nlogin usera\r\npassword somepass\r\nmachine somehost\r\nlogin userb\r\npassword otherpass\r\n```\r\n\r\nAnd I am trying to get it into an array of object, grouped in sets of 3, which I can then sort and select out uniq ones (yes, there are probably other, non jq ways...)\r\n\r\nAnd I keep getting lost.",
      "expected\r\n```json\r\n[\r\n  {\r\n    \"machine\": \"foo\",\r\n    \"login\": \"usera\",\r\n    \"password\": \"somepass\"\r\n  },\r\n  {\r\n    \"machine\": \"somehost\",\r\n    \"login\": \"userb\",\r\n    \"password\": \"otherpass\"\r\n  }\r\n]\r\n```",
      "jq --null-input --raw-input 'reduce (inputs | scan(\"(\\w+) (.*)\")) as [$k,$v] (\r\n   [] ; .[(input_line_number / 3 | ceil - 1)][$k] = $v\r\n   )' ~/.netrc",
      "jq -Rn '[[inputs | [splits(\"\\\\s+\")] | {(.[0]):.[1]}] | _nwise(3) | add]'",
      "jq --null-input --raw-input '[inputs| [scan(\"\\\\w+\"), (input_line_number/3|ceil)]] | group_by(.[2]) | map(map({(.[0]): .[1]})|add)'"
    ],
    "utterance": "Group entries from a .netrc-like file into objects by matching every three lines as key-value pairs.",
    "expressions": [
      "jq --null-input --raw-input 'reduce (inputs | scan(\"(\\w+) (.*)\")) as [$k,$v] ( [] ; .[(input_line_number / 3 | ceil - 1)][$k] = $v )'",
      "jq -Rn '[[inputs | [splits(\"\\\\s+\")] | {(.[0]):.[1]}] | _nwise(3) | add]'",
      "jq --null-input --raw-input '[inputs| [scan(\"\\\\w+\"), (input_line_number/3|ceil)]] | group_by(.[2]) | map(map({(.[0]): .[1]})|add)'"
    ],
    "data": [
      {
        "input": "machine foo\nlogin usera\npassword somepass\nmachine somehost\nlogin userb\npassword otherpass\n",
        "output": [
          {
            "machine": "foo",
            "login": "usera",
            "password": "somepass"
          },
          {
            "machine": "somehost",
            "login": "userb",
            "password": "otherpass"
          }
        ]
      }
    ],
    "identifier": 77199004
  },
  {
    "context": [
      "I want `jq` to return the name of the array that contains certain value: ",
      "if I look for `service-a` jq should return `blue_services`",
      "if I look for `service-h` jq should return `black_services`",
      "You could use `to_entries` to get an array of key-value pairs. Search the values using IN, and output the key. Use `--arg` to import a string from the command-line.",
      "jq -r --arg q \"service-a\" 'to_entries[] | select(IN($q; .value[]?)).key'",
      "Here's another way to do it by _streaming_ the input.  `select` passes only arrays having `$q` (your variable input) as an element, and then `.[0][-2]` extracts the key name for the array.",
      "jq --stream -r --arg q \"service-a\" 'select((.[0][-1] | numbers) and (.[1] == $q)) | .[0][-2]'"
    ],
    "utterance": "Return the key of the array containing a specific value, such as 'service-a' or 'service-h'.",
    "expressions": [
      "to_entries[] | select(IN($q; .value[]?)).key",
      "--stream -r --arg q \"service-a\" 'select((.[0][-1] | numbers) and (.[1] == $q)) | .[0][-2]'"
    ],
    "data": [
      {
        "input": {
          "somekey": "somevalue",
          "blue_services": [
            "service-a",
            "service-b",
            "service-c"
          ],
          "otherkey": "othervalue",
          "red_services": [
            "service-d",
            "service-e",
            "service-f"
          ],
          "black_services": [
            "service-g",
            "service-h",
            "service-i"
          ]
        },
        "output": "blue_services"
      }
    ],
    "identifier": 77235385
  },
  {
    "context": [
      "The first object in the list where `Action.Charge` is nonzero has been updated with the new value.",
      ".[].Action.Charge |= if . > 0 then 34 end",
      "(.[].Action.Charge | select(. > 0)) = 34"
    ],
    "utterance": "Set the Action.Charge property to 34 for each object in a list if its current Action.Charge is greater than 0.",
    "expressions": [
      ".[].Action.Charge |= if . > 0 then 34 end",
      "(.[].Action.Charge | select(. > 0)) = 34"
    ],
    "data": [
      {
        "input": [
          {
            "Action": {
              "Charge": 21,
              "Discharge": 100
            },
            "T": "2023-10-05T01:00:00Z"
          },
          {
            "Action": {
              "Charge": 0,
              "Discharge": 22
            },
            "T": "2023-10-05T04:00:00Z"
          }
        ],
        "output": [
          {
            "Action": {
              "Charge": 34,
              "Discharge": 100
            },
            "T": "2023-10-05T01:00:00Z"
          },
          {
            "Action": {
              "Charge": 0,
              "Discharge": 22
            },
            "T": "2023-10-05T04:00:00Z"
          }
        ]
      }
    ],
    "identifier": 77242778
  },
  {
    "context": [
      "The aim is to list: each members name, date of most senior grade (per type), type of grade, level of grade.",
      "Paul Simmons, [music, 3, 2023-01-28], [sports, 2, 2021-02-02].",
      "You could use `group_by` to combine same grade types, and `max_by` to get the one with the highest grade level:",
      ".member[] | [\"\\(.firstName) \\(.lastName)\", (.certificates\n  | group_by(.grade.type)[] | max_by(.grade.level)\n  | \"[\\(.grade.type), \\(.grade.level), \\(.awardDate)]\"\n)] | join(\", \") + \".\""
    ],
    "utterance": "List each member's name followed by, for each certificate type, the type, highest level, and award date of the certificate with the highest level.",
    "expressions": [
      ".member[] | [\"\\(.firstName) \\(.lastName)\", (.certificates | group_by(.grade.type)[] | max_by(.grade.level) | \"[\\(.grade.type), \\(.grade.level), \\(.awardDate)]\") ] | join(\", \") + \".\""
    ],
    "data": [
      {
        "input": {
          "member": [
            {
              "firstName": "Paul",
              "lastName": "Simons",
              "certificates": [
                {
                  "status": "Pass",
                  "grade": {
                    "type": "music",
                    "level": 3
                  },
                  "awardDate": "2023-01-28"
                },
                {
                  "status": "Pass",
                  "grade": {
                    "type": "sports",
                    "level": 2
                  },
                  "awardDate": "2021-02-02"
                },
                {
                  "status": "Pass",
                  "grade": {
                    "type": "music",
                    "level": 2
                  },
                  "awardDate": "2021-02-02"
                }
              ]
            }
          ]
        },
        "output": "Paul Simons, [music, 3, 2023-01-28], [sports, 2, 2021-02-02]."
      }
    ],
    "identifier": 77235620
  },
  {
    "context": [
      "I have a simple script where I am attempting to extract the directory path of a package from a json file using a bash script.",
      "A single call can solve your problem:",
      "jq -r '\n[.tasks[].directory] as $paths\n| .packages[]\n| . as $app\n| $paths[]\n| (\n  \"path \\(.)\",\n  \"built app \\($app)\",\n  (select(contains($app)) | \"it is a match\")\n)\n' affected.json"
    ],
    "utterance": "List each directory path along with each package name, indicating if the directory contains the package name as a substring.",
    "expressions": [
      "[.tasks[].directory] as $paths | .packages[] | . as $app | $paths[] | (\"path \\(.)\", \"built app \\($app)\", (select(contains($app)) | \"it is a match\"))"
    ],
    "data": [
      {
        "input": {
          "packages": [
            "package-1"
          ],
          "tasks": [
            {
              "directory": "packages/subfolder/package-1"
            },
            {
              "directory": "packages/subfolder/package-2"
            }
          ]
        },
        "output": [
          "path packages/subfolder/package-1",
          "built app package-1",
          "it is a match",
          "path packages/subfolder/package-2",
          "built app package-1"
        ]
      }
    ],
    "identifier": 77243900
  },
  {
    "context": [
      "What I want is something like this.\nMake a single call to the system that gives above json and store these \"key\" and \"value\" values in variables.",
      "You can use this in combination with `read` and its `-d` flag with an empty string as argument which \"will terminate a line when it reads a NUL character\".",
      "`jq --raw-output0 '.key, .value' file.json`",
      "With older versions of jq (1.5+), use the `-j` flag to omit the newlines, and print the NUL character manually using `\"\\u0000\"`:",
      "`jq -j '.key, .value | ., \"\\u0000\"' file.json`"
    ],
    "utterance": "Extract the values of the properties named 'key' and 'value' from an object in a single call, separating them for assignment to variables.",
    "expressions": [
      ".key, .value",
      ".key, .value | ., \"\\u0000\""
    ],
    "data": [
      {
        "input": {
          "key": "hello",
          "value": "world"
        },
        "output": [
          "hello",
          "world"
        ]
      }
    ],
    "identifier": 77247944
  },
  {
    "context": [
      "I want to iterate and lets say print each JSON block in this whole output I want to traverse each {} block and do something with it.",
      "jq 1.7 provides the `--raw-output0` flag which you can combine with `read -d ''`:\n```sh\nwhile read -r -d '' json\ndo printf \"Using %s to do something.\\n\\n\" \"$json\"\ndone < <(jq --raw-output0 . file.json)\n```",
      "With older versions of jq (1.5+), you can instead use the `-j` flag, and manually produce the NUL characters by changing the filter to `., \"\\u0000\"`."
    ],
    "utterance": "Iterate over each object and output it as a separate block, so a shell script can process each one individually.",
    "expressions": [
      ".",
      "., \"\\u0000\""
    ],
    "data": [
      {
        "input": [
          {
            "key": "hello",
            "value": "world"
          },
          {
            "key": "foo",
            "value": "bar"
          },
          {
            "key": "Disney",
            "value": "World"
          },
          {
            "key": "South",
            "value": "Africa"
          }
        ],
        "output": [
          {
            "key": "hello",
            "value": "world"
          },
          {
            "key": "foo",
            "value": "bar"
          },
          {
            "key": "Disney",
            "value": "World"
          },
          {
            "key": "South",
            "value": "Africa"
          }
        ]
      }
    ],
    "identifier": 77255519
  },
  {
    "context": [
      "I have the following json:\n\n```\necho '{\"a\": [1, 3, 5, 7, 9 ], \"b\": [2, 4, 6, 8, 10 ]}' | jq                    \n{\n  \"a\": [\n    1,\n    3,\n    5,\n    7,\n    9\n  ],\n  \"b\": [\n    2,\n    4,\n    6,\n    8,\n    10\n  ]\n}\n```",
      "I would like to get the following csv:\n\n```\n1,2\n3,4\n5,6\n7,8\n9,10\n```",
      "You can use `transpose`. It \"rotates\" a table by taking a an array of arrays. Iterate over the rotated rows, and use `@csv` to generate the CSV:",
      "jq -r '[.a, .b] | transpose[] | @csv'"
    ],
    "utterance": "Output each pair of elements from arrays 'a' and 'b' as comma-separated values, with one pair per line, matching their indices.",
    "expressions": [
      "[.a, .b] | transpose[] | @csv"
    ],
    "data": [
      {
        "input": {
          "a": [
            1,
            3,
            5,
            7,
            9
          ],
          "b": [
            2,
            4,
            6,
            8,
            10
          ]
        },
        "output": "1,2\n3,4\n5,6\n7,8\n9,10"
      }
    ],
    "identifier": 77262936
  },
  {
    "context": [
      "echo {&quot;ok&quot;:true,&quot;elapsed&quot;:&quot;317ns&quot;} | jq -r &#39;.ok&#39;",
      "jq: parse error: Invalid numeric literal at line 1, column 3",
      "echo '{\"ok\":true,\"elapsed\":\"317ns\"}' | jq -r '.ok'",
      "true"
    ],
    "utterance": "Extract the value of the 'ok' key where the input contains keys 'ok': true and 'elapsed': '317ns'.",
    "expressions": [
      ".ok"
    ],
    "data": [
      {
        "input": {
          "ok": true,
          "elapsed": "317ns"
        },
        "output": true
      }
    ],
    "identifier": 77281024
  },
  {
    "context": [
      "And I need to create a new json object with all the keys in the different array entries, but with the accumulated values. Something like this:",
      "Assuming the array has only flat objects, you could use `to_entries` to iterate over their key-value pairs, and add them up in a `reduce` folding:",
      "reduce (.[] | to_entries[]) as {$key, $value} ({};\n  .[$key] += $value\n)",
      "Another approach using `group_by` ([demo][1]):",
      "  map(to_entries[]) \n| group_by(.key)\n| map({ key : first.key, value : ([ .[].value ] | add) } )\n| from_entries"
    ],
    "utterance": "Sum all values for each unique key across an array of flat objects, producing an object mapping each key to its total.",
    "expressions": [
      "reduce (.[] | to_entries[]) as {$key, $value} ({}; .[$key] += $value)",
      "map(to_entries[]) | group_by(.key) | map({ key : first.key, value : ([ .[].value ] | add) } ) | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "a": 10,
            "b": 20
          },
          {
            "a": 11,
            "c": 30
          },
          {
            "b": 21,
            "c": 31
          }
        ],
        "output": {
          "a": 21,
          "b": 41,
          "c": 61
        }
      }
    ],
    "identifier": 77271148
  },
  {
    "context": [
      "How can extract the chapters from those videos that really have chapters? (because I think it gets stuck when no chapters are found).",
      "If `.chapters` is not present, it evaluates to `null`, and `.chapters[]` will fail with the error `Cannot iterate over null (null)`.",
      "Use `.chapters | map(.title?) | join(\", \")` instead.",
      "jq -c '{\n  Date: .upload_date | (.[0:4] + \"-\" + .[4:6] + \"-\" + .[6:8]),\n  ID: .id,\n  Title: .fulltitle,\n  Chaps: ((.chapters | map(.title) | join(\", \"))? // null)\n}'"
    ],
    "utterance": "Produce an object with formatted date, id, title, and a comma-separated string of chapter titles only if chapters exist; otherwise, set chapters field to null.",
    "expressions": [
      "{ Date: .upload_date | (.[0:4] + \"-\" + .[4:6] + \"-\" + .[6:8]), ID: .id, Title: .fulltitle, Chaps: ((.chapters | map(.title) | join(\", \"))? // null) }"
    ],
    "data": [
      {
        "input": {
          "id": "pvkTC2xIbeY",
          "upload_date": "20200617",
          "fulltitle": "How to Add Chapters to YouTube Videos | Chapters Explained",
          "chapters": [
            {
              "start_time": 0,
              "title": "Intro",
              "end_time": 10
            },
            {
              "start_time": 10,
              "title": "YouTube Chapters",
              "end_time": 45
            },
            {
              "start_time": 45,
              "title": "What are YouTube chapters?",
              "end_time": 85
            }
          ]
        },
        "output": {
          "Date": "2020-06-17",
          "ID": "pvkTC2xIbeY",
          "Title": "How to Add Chapters to YouTube Videos | Chapters Explained",
          "Chaps": "Intro, YouTube Chapters, What are YouTube chapters?"
        }
      },
      {
        "input": {
          "id": "abcd123",
          "upload_date": "20211105",
          "fulltitle": "A video with no chapters"
        },
        "output": {
          "Date": "2021-11-05",
          "ID": "abcd123",
          "Title": "A video with no chapters",
          "Chaps": null
        }
      }
    ],
    "identifier": 77244169
  },
  {
    "context": [
      "I would like extract latitude,longitude,elevation,accuracy and process them differently : round the first 2 with 5 decimals, and the last 2 to nearest integer, and leave one intact",
      "q1. But can one easily combine such filters into a single one ?",
      "You can apply the functions directly while contructing the array:\n[\n  (.latitude, .longitude | .*100000 | round/100000),\n  (.altitude, .accuracy | round),\n  .provider\n]",
      "Or apply functions using ranges:\n[.latitude, .longitude, .altitude, .accuracy, .provider]\n| .[0:2] |= map(.*100000 | round/100000)\n| .[2:4] |= map(round)"
    ],
    "utterance": "Produce an array where latitude and longitude are rounded to 5 decimals, altitude and accuracy are rounded to the nearest integer, and provider is left unchanged.",
    "expressions": [
      "[\n  (.latitude, .longitude | .*100000 | round/100000),\n  (.altitude, .accuracy | round),\n  .provider\n]",
      "[.latitude, .longitude, .altitude, .accuracy, .provider]\n| .[0:2] |= map(.*100000 | round/100000)\n| .[2:4] |= map(round)"
    ],
    "data": [
      {
        "input": {
          "latitude": 66.32418638,
          "longitude": -121.77029769,
          "altitude": 465.46502685546875,
          "accuracy": 17.6742248535156,
          "vertical_accuracy": 36.48805236816406,
          "bearing": 0.0,
          "speed": 0.0,
          "elapsedMs": 55,
          "provider": "gps"
        },
        "output": [
          66.32419,
          -121.7703,
          465,
          18,
          "gps"
        ]
      }
    ],
    "identifier": 77269823
  },
  {
    "context": [
      "I have a tag on my EC2 instances - backup_policy",
      "It should be set to \"EC2_Prod_Daily_Weekly_Monthly\" for prod accounts",
      "but sometimes prod may have the nonprod backup tag!",
      "I need CLI or JQ where tag NOT EQUAL to value.",
      "I need the instanceId and incorrect tag value (plus accountid which is also in my tags)",
      "Here is example of json trying to parse:",
      "[{\"InstanceId\": \"i-03226b321aaff1122\",\"Tags\": [{\"Key\": \"account_id\",\"Value\": \"1231231231\"},{\"Key\": \"backup_policy\",\"Value\": \"EC2_Prod_Daily_Weekly_Monthly-oldvalue\"}],}]"
    ],
    "utterance": "Return the instance ID, backup_policy tag value, and account_id tag value for each instance where the backup_policy tag value is not equal to EC2_Prod_Daily_Weekly_Monthly.",
    "expressions": [
      "map(select(.Tags[]? | select(.Key == \"backup_policy\" and .Value != \"EC2_Prod_Daily_Weekly_Monthly\"))) | map({InstanceId, backup_policy: (.Tags[] | select(.Key == \"backup_policy\").Value), account_id: (.Tags[] | select(.Key == \"account_id\").Value)})"
    ],
    "data": [
      {
        "input": [
          {
            "InstanceId": "i-03226b321aaff1122",
            "Tags": [
              {
                "Key": "account_id",
                "Value": "1231231231"
              },
              {
                "Key": "backup_policy",
                "Value": "EC2_Prod_Daily_Weekly_Monthly-oldvalue"
              }
            ]
          },
          {
            "InstanceId": "i-0999999999999999",
            "Tags": [
              {
                "Key": "account_id",
                "Value": "5555555555"
              },
              {
                "Key": "backup_policy",
                "Value": "EC2_Prod_Daily_Weekly_Monthly"
              }
            ]
          }
        ],
        "output": [
          {
            "InstanceId": "i-03226b321aaff1122",
            "backup_policy": "EC2_Prod_Daily_Weekly_Monthly-oldvalue",
            "account_id": "1231231231"
          }
        ]
      }
    ],
    "identifier": 77271347
  },
  {
    "context": [
      "But what I need is length of the corresponding elements respective to each of the json file along with the name as below:",
      "[\n  {\n    \"name\": \"foo.json\",\n    \"size\": 5\n  },\n  {\n    \"name\": \"bar.json\",\n    \"size\": 10\n  },\n  {\n    \"name\": \"baz.json\",\n    \"size\": 15\n  }\n]",
      "jq -s 'map(length) ' ./*.json",
      "You can use `input_filename` to get the file name:",
      "jq -n '[inputs | { name: input_filename, size: length }]' *.json",
      "jq -n 'reduce inputs as $in ([]; . + [{\n  name: input_filename,\n  size: $in | length\n}])' *.json"
    ],
    "utterance": "Create an array of objects containing each file name and the element count from all files named '*.json' in the directory.",
    "expressions": [
      "jq -n '[inputs | { name: input_filename, size: length }]' *.json",
      "jq -n 'reduce inputs as $in ([]; . + [{ name: input_filename, size: $in | length }])' *.json"
    ],
    "identifier": 77289827
  },
  {
    "identifier": 77311449
  },
  {
    "context": [
      "I want to extract the IDs on the first JSON file, `data.json` with this jq:",
      "I want to get those values and use them to match the IDs of the other JSON...",
      "jq can already handle multiple input files by itself:",
      "map(select(.attributes.closeReason == \"Fraud\") | .relationships.customer.data.id) as $ids\n| input\n| .data[]\n| select(.id | IN($ids[]))",
      "Alternatively, if you really want to invoke two instances of jq:",
      "jq \\\n--argjson ids \"$(jq 'map(select(.attributes.closeReason == \"Fraud\") | .relationships.customer.data.id)' accounts.json)\" \\\n'.data[] | select(.id | IN($ids[]))' \\\ndata.json"
    ],
    "utterance": "Filter customer objects in one file whose id matches customer ids from deposit accounts with closeReason equal to 'Fraud' in another file.",
    "expressions": [
      "jq 'map(select(.attributes.closeReason == \"Fraud\") | .relationships.customer.data.id) as $ids | input | .data[] | select(.id | IN($ids[]))' accounts.json data.json",
      "jq --argjson ids \"$(jq 'map(select(.attributes.closeReason == \"Fraud\") | .relationships.customer.data.id)' accounts.json)\" '.data[] | select(.id | IN($ids[]))' data.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "type": "depositAccount",
              "id": "991231",
              "attributes": {
                "name": "William Heckerd",
                "status": "Closed",
                "closeReason": "Fraud",
                "fraudReason": "ACHActivity",
                "updatedAt": "2023-02-24T19:41:30.224Z"
              },
              "relationships": {
                "customer": {
                  "data": {
                    "type": "customer",
                    "id": "123456"
                  }
                }
              }
            }
          ],
          {
            "data": [
              {
                "type": "individualCustomer",
                "id": "567898765",
                "attributes": {
                  "createdAt": "2023-09-10T08:32:07.921Z",
                  "fullName": {
                    "first": "Foo",
                    "last": "Example"
                  },
                  "email": "theemail@gmail.com",
                  "status": "Archived",
                  "archiveReason": "FraudClientIdentified"
                }
              }
            ]
          }
        ],
        "output": []
      }
    ],
    "identifier": 77288554
  },
  {
    "context": [
      "I want to make a script that will generate a list of certificates that will expire in a month and write it in json format to a file.",
      "So that it would be like this:\n```\n{\n  \"data\": [\n    {\n      \"expiration_date\": \"test1_expiration_date_value\",\n      \"serial_number\": \"test1_expiration_date_value\"\n    },\n    {\n      \"expiration_date\": \"test2_expiration_date_value\",\n      \"serial_number\": \"test2_expiration_date_value\"\n    },\n    {\n      \"expiration_date\": \"testN_expiration_date_value\",\n      \"serial_number\": \"testN_expiration_date_value\"\n    }\n  ]\n}\n```",
      "Assuming `curl \u2026 https://some_uri | jq '.data.keys'` outputs a JSON array of strings like `[\"test1\", \"test2\", \"testN\"]`, and `curl \u2026 https://some_uri/test1 | jq '.data.data'` outputs a JSON object like `{\"expiration_date\": \"\u2026\", \"serial_number\": \"\u2026\"}`, then the following might solve your task.",
      "A final call to jq then collects all of them in an array using the `-s` flag, and wraps it into an object with field name `data`.",
      "done | jq -s '{data: .}'"
    ],
    "utterance": "Aggregate a set of certificate objects each containing expiration_date and serial_number into a top-level object with a data array.",
    "expressions": [
      "jq -s '{data: .}'"
    ],
    "data": [
      {
        "input": [
          {
            "expiration_date": "2023-10-11 11:27:10",
            "serial_number": "18:df:b4:..."
          },
          {
            "expiration_date": "2023-11-01 09:12:00",
            "serial_number": "ab:cd:..."
          }
        ],
        "output": {
          "data": [
            {
              "expiration_date": "2023-10-11 11:27:10",
              "serial_number": "18:df:b4:..."
            },
            {
              "expiration_date": "2023-11-01 09:12:00",
              "serial_number": "ab:cd:..."
            }
          ]
        }
      }
    ],
    "identifier": 77281480
  },
  {
    "context": [
      "I want to pull the contents from the main 'Data' array from each file and make it look something like this:\n{\n  \"Everything\":[\n    {\"data\":\"data1\"},\n    {\"data\":\"data2\"},\n    {\"data\":\"data3\"},\n    {\"data\":\"data4\"}\n  ]\n}",
      "jq -n '{Everything: [inputs.Data[]]}' *.json",
      "jq -s '{ Everything:[ .[].Data[] ] }' *.json"
    ],
    "utterance": "Combine the 'Data' arrays from multiple files into a single object with key 'Everything' containing all elements from these arrays.",
    "expressions": [
      "{Everything: [inputs.Data[]]}",
      "{ Everything:[ .[].Data[] ] }"
    ],
    "data": [
      {
        "input": [
          {
            "Brand": "brand1",
            "Fulfilled": 5600,
            "Total": 5626,
            "Data": [
              {
                "data": "data1"
              },
              {
                "data": "data2"
              }
            ]
          },
          {
            "Brand": "brand2",
            "Fulfilled": 3000,
            "Total": 3100,
            "Data": [
              {
                "data": "data3"
              },
              {
                "data": "data4"
              }
            ]
          }
        ],
        "output": {
          "Everything": [
            {
              "data": "data1"
            },
            {
              "data": "data2"
            },
            {
              "data": "data3"
            },
            {
              "data": "data4"
            }
          ]
        }
      }
    ],
    "identifier": 77296368
  },
  {
    "context": [
      "I need to retrive all the labels of every project I have access and put it together in a CSV document.",
      "the problem is how I get the column names across all the projects and then how should I put the values to fit.",
      "I have tried with `--format=\"json\" | jq -r '.[].labels'` and formating the output, but I get to the same problem on how to fix all the keys across all the projects.",
      "Assuming this is the output you want for the following input:",
      "\"windy-bearing-129522\",\"env\",\"test\"",
      "jq --raw-output '.[] | { projectId, label : (.labels | to_entries) [] } |\n                       [.projectId, .label.key, .label.value ] | @csv   '"
    ],
    "utterance": "Produce a CSV where each row contains a project's ID, a label key, and its corresponding value, listing all labels for each project even if label keys differ across projects.",
    "expressions": [
      ".[] | { projectId, label : (.labels | to_entries) [] } | [.projectId, .label.key, .label.value ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "labels": {
              "env": "test",
              "version": "alpha"
            },
            "projectId": "windy-bearing-129522"
          },
          {
            "labels": {
              "env": "test",
              "version": "beta"
            },
            "projectId": "canvas-syntax-130823"
          }
        ],
        "output": [
          "\"windy-bearing-129522\",\"env\",\"test\"",
          "\"windy-bearing-129522\",\"version\",\"alpha\"",
          "\"canvas-syntax-130823\",\"env\",\"test\"",
          "\"canvas-syntax-130823\",\"version\",\"beta\""
        ]
      }
    ],
    "identifier": 77290075
  },
  {
    "context": [
      "How can i select / filter all connection with field.usesEncryption is true using jq from JSON data below",
      "jq '.connections.connection[].field[] | select(.usesEncryption)' EnvironmentExtensions.json",
      ".connections.connection[].field |= map(select(.usesEncryption))",
      ".connections.connection |= map(.field |= map(select(.usesEncryption)))"
    ],
    "utterance": "Filter all fields within each connection where usesEncryption is true, preserving the overall structure of connections.",
    "expressions": [
      ".connections.connection[].field[] | select(.usesEncryption)",
      ".connections.connection[].field |= map(select(.usesEncryption))",
      ".connections.connection |= map(.field |= map(select(.usesEncryption)))"
    ],
    "data": [
      {
        "input": {
          "connections": {
            "connection": [
              {
                "field": [
                  {
                    "id": "url",
                    "encryptedValueSet": false,
                    "usesEncryption": false,
                    "componentOverride": false,
                    "useDefault": false
                  },
                  {
                    "id": "user",
                    "encryptedValueSet": false,
                    "usesEncryption": false,
                    "componentOverride": false,
                    "useDefault": false
                  },
                  {
                    "id": "password",
                    "encryptedValueSet": true,
                    "usesEncryption": true,
                    "componentOverride": false,
                    "useDefault": false
                  }
                ],
                "id": "3ea89002-51f5-4369-9539-63c3bd406a64"
              }
            ]
          }
        },
        "output": [
          {
            "id": "password",
            "encryptedValueSet": true,
            "usesEncryption": true,
            "componentOverride": false,
            "useDefault": false
          }
        ]
      }
    ],
    "identifier": 77299184
  },
  {
    "context": [
      "Given the string \"fe80::4dd:baff:fecb:ef91\" I want to get the value \"ens5\"",
      "to_entries[] | select(.value[] | contains(\"fe80::4dd:baff:fecb:ef91\")).key",
      "paths(strings | select(. == \"fe80::4dd:baff:fecb:ef91\"))[-2]"
    ],
    "utterance": "Find the key whose array value contains the string 'fe80::4dd:baff:fecb:ef91'.",
    "expressions": [
      "to_entries[] | select(.value[] | contains(\"fe80::4dd:baff:fecb:ef91\")).key",
      "paths(strings | select(. == \"fe80::4dd:baff:fecb:ef91\"))[-2]"
    ],
    "data": [
      {
        "input": {
          "lo": [
            "127.0.0.1",
            "::1"
          ],
          "ens5": [
            "10.77.23.18",
            "fe80::4dd:baff:fecb:ef91"
          ],
          "ens6": [
            "10.77.18.149",
            "fe80::445:b3ff:fe48:bd98"
          ]
        },
        "output": "ens5"
      }
    ],
    "identifier": 77316284
  },
  {
    "context": [
      "Irrespective of the order of hosts list HOST-A & HOST-B in the actual JSON files, I want to order the hosts in the JSON and print or output data into a variable or use `sponge` to replace in the same JSON files, based on the conditions, 1 & 2 above.",
      "if the condition is A, the RedisHost should be\n\n    \"RedisHost\": \"HOST-A;HOST-B\"",
      "if the condition is B, the RedisHost should be \n\n    \"RedisHost\": \"HOST-B;HOST-A\"",
      "jq --arg myvar \"$order_host\" '(..|objects|select(.RedisHost).RedisHost)|=$myvar' File1.json)"
    ],
    "utterance": "Replace all RedisHost fields in the data so their value is either 'HOST-A;HOST-B' if condition A, or 'HOST-B;HOST-A' if condition B, regardless of original order.",
    "expressions": [
      "jq --arg this $this '(if $this == \"A\" then \"B\" else \"A\" end) as $that| (.. | select(type == \"object\" and has(\"RedisHost\")).RedisHost?) = \"HOST-\u007f($this);HOST-\u007f($that)\"' File1.json",
      "jq --arg myvar \"$order_host\" '(..|objects|select(.RedisHost).RedisHost)|=$myvar' File1.json",
      "jq --arg condition \"$condition\" '\n  def maybeReorderHost:\n    ( if $condition == \"A\" then \"HOST-A\" else \"HOST-B\" end) as $priorityPattern |\n    if type != \"object\" then . else (\n      if .RedisHost? == null then . else (\n        .RedisHost |= (split(\";\") as $hostArr |\n        [[$hostArr[] | select(index($priorityPattern) != null)],\n         [$hostArr[] | select(index($priorityPattern) == null)]]\n        | add | join(\";\") )\n    ) end\n  ) end;\n\n  walk(maybeReorderHost)\n' <FileA.json"
    ],
    "data": [
      {
        "input": {
          "ServiceSettings": {
            "ServiceName": "my-service",
            "RedisSettings": {
              "RedisHost": "HOST-A;HOST-B"
            }
          }
        },
        "output": {
          "ServiceSettings": {
            "ServiceName": "my-service",
            "RedisSettings": {
              "RedisHost": "HOST-B;HOST-A"
            }
          }
        }
      },
      {
        "input": {
          "RedisHost": "HOST-A;HOST-B"
        },
        "output": {
          "RedisHost": "HOST-B;HOST-A"
        }
      }
    ],
    "identifier": 77294135
  },
  {
    "context": [
      "i have below JSON which i am trying to filter using \"isEnabled\" value. I am able to filter  but loosing original array as result only shows filtered data. is there any way to return result in same array?",
      "cat myjson.json | jq '.policies[] | select(.isEnabled == false)'",
      "cat myjson.json | jq '.policies = [.policies[] | select(.isEnabled == false)]'"
    ],
    "utterance": "Return the full input object with the 'policies' array filtered to only those elements where isEnabled is false.",
    "expressions": [
      ".policies = [.policies[] | select(.isEnabled == false)]"
    ],
    "data": [
      {
        "input": {
          "startIndex": 0,
          "pageSize": 200,
          "totalCount": 174,
          "resultSize": 174,
          "sortType": "asc",
          "sortBy": "policyId",
          "queryTimeMS": 1697604282484,
          "policies": [
            {
              "id": 1,
              "guid": "d3a007c9-a877-44b8-a526-57f484916cd6",
              "isEnabled": true,
              "version": 210,
              "service": "Prod-Hue",
              "name": "all - url"
            },
            {
              "id": 2,
              "guid": "abc-123",
              "isEnabled": false,
              "version": 59,
              "service": "Prod-Hue",
              "name": "test"
            }
          ]
        },
        "output": {
          "startIndex": 0,
          "pageSize": 200,
          "totalCount": 174,
          "resultSize": 174,
          "sortType": "asc",
          "sortBy": "policyId",
          "queryTimeMS": 1697604282484,
          "policies": [
            {
              "id": 2,
              "guid": "abc-123",
              "isEnabled": false,
              "version": 59,
              "service": "Prod-Hue",
              "name": "test"
            }
          ]
        }
      }
    ],
    "identifier": 77313769
  },
  {
    "context": [
      "having input json like so ... i would like to get array of arrays with object values, so: [ [ \"o1k1\", \"o1k2\", \"o1k_xxx\" ], [ \"o2k1\", \"o2k2\", \"o2k_yyy\" ] ]",
      "tried `.[] | to_entries[].value`, but it eats up the individual arrays - and produces just: \"o1k1\", \"o1k2\", \"o1k_xxx\", \"o2k1\", \"o2k2\", \"o2k_yyy\"",
      "Double-nest `map(\u2026)` or `[.[]]` (or even `.[] |= \u2026` on the array, not the object). All of these do what you want:",
      "jq 'map(map(.))'     # nesting map(\u2026) and map(\u2026)",
      "jq 'map([.[]])'      # nesting map(\u2026) and [.[]]",
      "jq '[.[] | [.[]]]'   # nesting [.[]] and [.[]]",
      "jq '[.[] | map(.)]'  # nesting [.[]] and map(\u2026)",
      "jq '.[] |= map(.)'   # nesting .[] |= \u2026 and map(\u2026)",
      "jq '.[] |= [.[]]'    # nesting .[] |= \u2026 and [.[]]"
    ],
    "utterance": "Return an array where each element is an array of the values from each object in the original input array.",
    "expressions": [
      "map(map(.))",
      "map([.[]])",
      "[.[] | [.[]]]",
      "[.[] | map(.)]",
      ".[] |= map(.)",
      ".[] |= [.[]]"
    ],
    "data": [
      {
        "input": [
          {
            "k1": "o1k1",
            "k2": "o1k2",
            "k_opt1": "o1k_xxx"
          },
          {
            "k1": "o2k1",
            "k2": "o2k2",
            "k_opt2": "o2k_yyy"
          }
        ],
        "output": [
          [
            "o1k1",
            "o1k2",
            "o1k_xxx"
          ],
          [
            "o2k1",
            "o2k2",
            "o2k_yyy"
          ]
        ]
      }
    ],
    "identifier": 77315351
  },
  {
    "context": [
      "I want to merge two JSON files, where the objects in the base file (A) are augmented by matching objects in file (B), but not overwritten where A and B have different values for the same key.",
      "I want a result where:\n\n* alpha should have the metadata\n* beta should be banana, not blueberry.\n* gamma should be in the final list\n* omega should NOT be in the final list\n* Order of objects in the list should be maintained.",
      "jq 'reduce input[] as $i (INDEX(.name);\n  if has($i.name) then .[$i.name] |= $i + . end\n) | [.[]]' fileA.json fileB.json",
      "INDEX(.[0][] ; .name) as $elements  |\nINDEX(.[1][] ; .name) as $lookup    |\n$elements | keys []   as $key       |\n$elements[$key]       as $value     |\n$lookup[$key]         as $match     | ( $match // {} ) * $value",
      "( .[0][] ) as $element \n| ( .[1] | map(select(.name == $element.name)) [] // {} ) as $match \n| $match * $element"
    ],
    "utterance": "Merge two arrays of objects where each object from the first array is augmented with matching object fields from the second array based on 'name', retaining all objects from the first array and their original values if keys differ, and including additional keys from the second array only if 'name' matches.",
    "expressions": [
      "jq 'reduce input[] as $i (INDEX(.name);\n  if has($i.name) then .[$i.name] |= $i + . end\n) | [.[]]' fileA.json fileB.json",
      "jq 'INDEX(.[0][] ; .name) as $elements  |\nINDEX(.[1][] ; .name) as $lookup    |\n$elements | keys []   as $key       |\n$elements[$key]       as $value     |\n$lookup[$key]         as $match     | ( $match // {} ) * $value' a.json b.json",
      "jq '( .[0][] ) as $element \n| ( .[1] | map(select(.name == $element.name)) [] // {} ) as $match \n| $match * $element' a.json b.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "alpha",
              "value": "apple"
            },
            {
              "name": "beta",
              "value": "banana"
            },
            {
              "name": "gamma",
              "value": "guava"
            }
          ],
          [
            {
              "name": "alpha",
              "value": "apple",
              "metadata": {
                "types": [
                  "granny"
                ]
              }
            },
            {
              "name": "beta",
              "value": "blueberry"
            },
            {
              "name": "omega",
              "value": "orange"
            }
          ]
        ],
        "output": [
          {
            "name": "alpha",
            "value": "apple",
            "metadata": {
              "types": [
                "granny"
              ]
            }
          },
          {
            "name": "beta",
            "value": "banana"
          },
          {
            "name": "gamma",
            "value": "guava"
          }
        ]
      }
    ],
    "identifier": 77299198
  },
  {
    "context": [
      "But I would like to count only the keys like this.",
      "To produce a stream of key-depths, you could write:",
      "jq 'paths(scalars) | map(strings) | length' input.json"
    ],
    "utterance": "Count how many key names precede each scalar value, ignoring arrays.",
    "expressions": [
      "paths(scalars) | map(strings) | length"
    ],
    "data": [
      {
        "input": {
          "one": {
            "two": {
              "three": [
                {
                  "four": [
                    {
                      "five": [
                        {
                          "six": [
                            {
                              "sevenA": {
                                "eightA": [
                                  {
                                    "nineA": "Blub"
                                  },
                                  {
                                    "nineB": "def"
                                  },
                                  {
                                    "nineC": "foo"
                                  },
                                  {
                                    "nineD": 22
                                  }
                                ]
                              }
                            },
                            {
                              "sevenB": {
                                "eightB": [
                                  {
                                    "nineE": "Bla"
                                  },
                                  {
                                    "nineF": "int"
                                  },
                                  {
                                    "nineG": "s"
                                  },
                                  {
                                    "nineH": 60
                                  }
                                ]
                              }
                            }
                          ]
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 77325832
  },
  {
    "context": [
      "How to convert UTC datetime to local daylight saving time (AEDT) using JQ (jq-1.6)",
      "echo '\"2023-10-19T04:59:59Z\"' | jq 'fromdate | localtime | todate'",
      "> \"2023-10-19T16:59:59Z\""
    ],
    "utterance": "Convert '2023-10-19T04:59:59Z' to the corresponding time in AEDT, correctly accounting for daylight saving time.",
    "expressions": [
      "fromdateiso8601 | strftime(\"%Y-%m-%d %H:%M:%S %Z\")"
    ],
    "data": [
      {
        "input": "2023-10-19T04:59:59Z",
        "output": "2023-10-19 15:59:59 AEDT"
      }
    ],
    "identifier": 77326940
  },
  {
    "context": [
      "The criteria here was \"the data contains an url beginning with http://my-cluster-dns\".",
      "I would like to have something like that in output (csv) :",
      "my-namespace,cluster-agent-config,DATA_2,http://my-cluster-dns.my-service:8080",
      "her-namespace,cluster-agent-misc,DATA_1,http://my-cluster-dns.my-service:9000",
      "Here\u2019s one way that uses `to_entries` to access key and value, and stores it in a variable for later:",
      ".items[] | ( .data | to_entries[] | select(.value | strings | startswith(\"http://my-cluster-dns\")) ) as $data | [.metadata.namespace, .metadata.name, $data.key, $data.value] | join(\",\") # or @csv"
    ],
    "utterance": "Extract all data entries where the value starts with 'http://my-cluster-dns', outputting namespace, config map name, key, and value in CSV format.",
    "expressions": [
      ".items[] | ( .data | to_entries[] | select(.value | strings | startswith(\"http://my-cluster-dns\")) ) as $data | [.metadata.namespace, .metadata.name, $data.key, $data.value] | @csv"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "items": [
            {
              "apiVersion": "v1",
              "data": {
                "DATA_1": false,
                "DATA_2": "http://my-cluster-dns.my-service:8080",
                "DATA_3": 200
              },
              "kind": "ConfigMap",
              "metadata": {
                "name": "cluster-agent-config",
                "namespace": "my-namespace"
              }
            },
            {
              "apiVersion": "v1",
              "data": {
                "agent-log.yaml": "log-level: INFO\nmax-filesize-mb: 50\nmax-backups: 5\nwrite-to-stdout: true"
              },
              "kind": "ConfigMap",
              "metadata": {
                "name": "cluster-agent-log",
                "namespace": "your-namespace"
              }
            },
            {
              "apiVersion": "v1",
              "data": {
                "agent-monitoring.yml": "metric-collection-interval-seconds: 30\ncluster-metric-collection-interval-seconds: 60\nmetadata-collection-interval-seconds: 60\ncontainer-registration-batch-size: 5\npod-registration-batch-size: 6\nmetric-upload-retry-count: 2\nmetric-upload-retry-interval-milliseconds: 5\nmax-pods-to-register-count: 750\nmax-pod-logs-tail-lines-count: 500\ninstrumentation-max-polling-attempts: 10\npod-filter: {}\nns-to-monitor-regex: \".*\""
              },
              "kind": "ConfigMap",
              "metadata": {
                "name": "cluster-agent-mon",
                "namespace": "his-namespace"
              }
            },
            {
              "apiVersion": "v1",
              "data": {
                "DATA_1": "http://my-cluster-dns.my-service:9000",
                "DATA_2": "something"
              },
              "kind": "ConfigMap",
              "metadata": {
                "name": "cluster-agent-misc",
                "namespace": "her-namespace"
              }
            }
          ],
          "kind": "List",
          "metadata": {
            "resourceVersion": ""
          }
        },
        "output": [
          "\"my-namespace\",\"cluster-agent-config\",\"DATA_2\",\"http://my-cluster-dns.my-service:8080\"",
          "\"her-namespace\",\"cluster-agent-misc\",\"DATA_1\",\"http://my-cluster-dns.my-service:9000\""
        ]
      }
    ],
    "identifier": 77317448
  },
  {
    "context": [
      "How could I get the model lets say for `MS-23-AMV` with JQ?",
      "and now use the `jq` to get the model for `ms-23-amw`:",
      "jq '.cars.\"ms-23-amw\".model' cars.json",
      "output",
      "\"a8\""
    ],
    "utterance": "Select the value of the property 'model' for the car with key 'ms-23-amw', nested under the 'cars' object.",
    "expressions": [
      ".cars.\"ms-23-amw\".model"
    ],
    "data": [
      {
        "input": {
          "cars": {
            "ms-23-amw": {
              "brand": "audi",
              "model": "a8",
              "displayname": "audi a8",
              "engine": "4.5l"
            },
            "sj-08-rew": {
              "brand": "bmw",
              "model": "335i",
              "displayname": "bmw 3 series",
              "engine": "3.5l"
            }
          }
        },
        "output": "a8"
      }
    ],
    "identifier": 77344181
  },
  {
    "context": [
      "I have JSON objects that can contain different fields.",
      "In this example, the object can have the field optionalA or optionalB.",
      "I want to filter on both if they are present.",
      "Or use the alternative operator `//` also instead of the boolean operator `or`, so in case of `empty` the next expression can be evaluated:",
      "select(\n  (.object.optionalA // empty | contains(\"d\")) \n  //\n  (.object.optionalB // empty | contains(\"Z\"))\n)",
      "Another way could be using `has` to query the presence of a field:",
      "select(\n  (.object | has(\"optionalA\") and (.optionalA | contains(\"d\")))\n  or\n  (.object | has(\"optionalB\") and (.optionalB | contains(\"Z\")))\n)",
      "Yet another to use the error suppression operator `?` to handle the case of absent fields:",
      "select(\n  .object | (.optionalA | contains(\"d\")?) // (.optionalB | contains(\"Z\")?)\n)"
    ],
    "utterance": "Filter objects where .object.optionalA contains \"d\" or .object.optionalB contains \"Z\".",
    "expressions": [
      "select((.object.optionalA // \"\" | contains(\"d\")) or (.object.optionalB // \"\" | contains(\"Z\")))",
      "select((.object.optionalA // empty | contains(\"d\")) // (.object.optionalB // empty | contains(\"Z\")))",
      "select((.object | has(\"optionalA\") and (.optionalA | contains(\"d\"))) or (.object | has(\"optionalB\") and (.optionalB | contains(\"Z\"))))",
      "select(.object | (.optionalA | contains(\"d\")?) // (.optionalB | contains(\"Z\")?))"
    ],
    "data": [
      {
        "input": {
          "object": {
            "a": "b",
            "optionalA": "d"
          }
        },
        "output": {
          "object": {
            "a": "b",
            "optionalA": "d"
          }
        }
      },
      {
        "input": {
          "object": {
            "a": "b",
            "optionalB": "Z"
          }
        },
        "output": {
          "object": {
            "a": "b",
            "optionalB": "Z"
          }
        }
      }
    ],
    "identifier": 77330695
  },
  {
    "context": [
      "I have a json object which is not an array.",
      "I'd like to loop through the object to find any `result` is not equal to `success`.",
      "I think that you can use:\n\n    to_entries[] | select(.value.result != \"success\") | .key",
      "This will yield the keys of the entries whose result is not \"success\".",
      "With the following JSON:\n\n    {\n      \"affected-apps\": {\n        \"result\": \"success\",\n        \"outputs\": {\n          \"affected_apps_array\": [\n            \"logger\",\n            \"aws-sdk-wrapper\",\n            \"transaction\",\n            \"deposit\",\n            \"identity\",\n            \"user\",\n            \"core\"\n          ]\n        }\n      },\n      \"build-affected-apps\": {\n        \"result\": \"success\",\n        \"outputs\": {}\n      },\n      \"load-affected-apps\": {\n        \"result\": \"failure\",\n        \"outputs\": {}\n      }\n    }\n\nit will yield:\n\n    \"load-affected-apps\""
    ],
    "utterance": "Find all keys whose nested result field is not equal to success.",
    "expressions": [
      "to_entries[] | select(.value.result != \"success\") | .key"
    ],
    "data": [
      {
        "input": {
          "affected-apps": {
            "result": "success",
            "outputs": {
              "affected_apps_array": [
                "logger",
                "aws-sdk-wrapper",
                "transaction",
                "deposit",
                "identity",
                "user",
                "core"
              ]
            }
          },
          "build-affected-apps": {
            "result": "success",
            "outputs": {}
          },
          "load-affected-apps": {
            "result": "failure",
            "outputs": {}
          }
        },
        "output": "load-affected-apps"
      }
    ],
    "identifier": 77342021
  },
  {
    "context": [
      "My goal is parsing json-logs from file from some date.",
      "cat eve.json | jq -c --arg s '2023-10-20T21:08:58.992978+0300' 'select(.timestamp | . >= $s)'",
      "builder.command(\n    \"jq\", // or the absolute path\n    \"-c\",\n    \"--arg\",\n    \"s\",\n    \"2023-10-20T21:08:58.992978+0300\",\n    \"select(.timestamp | . >= $s)\");"
    ],
    "utterance": "Filter all log entries where the timestamp is greater than or equal to 2023-10-20T21:08:58.992978+0300.",
    "expressions": [
      "jq -c --arg s '2023-10-20T21:08:58.992978+0300' 'select(.timestamp | . >= $s)'"
    ],
    "identifier": 77334870
  },
  {
    "context": [
      "From the above file, I need to extract only one JSON stanza that I intend to evaluate/test. Expected output,",
      "{  \r\n  \"key\": \"SEA-739\",\r\n  \"status\": \"Open\",\r\n  \"assignee\": null\r\n}"
    ],
    "utterance": "Extract the object where the key field equals SEA-739.",
    "expressions": [
      "select(.key == \"SEA-739\")"
    ],
    "data": [
      {
        "input": [
          {
            "key": "SEA-739",
            "status": "Open",
            "assignee": null
          },
          {
            "key": "SEA-738",
            "status": "Resolved",
            "assignee": "user2@mycompany.com"
          }
        ],
        "output": {
          "key": "SEA-739",
          "status": "Open",
          "assignee": null
        }
      }
    ],
    "identifier": 77347936
  },
  {
    "context": [
      "I need to convert this to a CSV to look like: \"run_number\",\"cinfo.name\",\"cinfo.state\",\"cinfo.city\"",
      "jq -r '.document.results.summary.run.[] | . as {$run_number} | .cinfo[] | [$run_number, .name, .state, .city] | @csv' input.json",
      "jq -r '.[] | .[0] as $run_number | .[1][] | [$run_number, .name, .state, .city] | @csv' input.json",
      "The complete filter would be:\n  .document.results.summary.run.[] \n| [.run_number, .cinfo] \n| [ .[0] ] + (.[1] [] | [ .[] ])\n| @csv"
    ],
    "utterance": "Convert each run entry to a CSV row containing run_number, name, state, and city for every person in cinfo.",
    "expressions": [
      ".document.results.summary.run[] | . as {$run_number} | .cinfo[] | [$run_number, .name, .state, .city] | @csv",
      ".[] | .[0] as $run_number | .[1][] | [$run_number, .name, .state, .city] | @csv",
      ".document.results.summary.run[] | [.run_number, .cinfo] | [.[0]] + (.[1][] | [.[]]) | @csv"
    ],
    "data": [
      {
        "input": {
          "document": {
            "results": {
              "summary": {
                "run": [
                  {
                    "run_number": "42",
                    "cinfo": [
                      {
                        "name": "Joe shmo",
                        "state": "AZ",
                        "city": "Phoenix"
                      },
                      {
                        "name": "Jane shmo",
                        "state": "CA",
                        "city": "Blythe"
                      }
                    ]
                  },
                  {
                    "run_number": "84",
                    "cinfo": [
                      {
                        "name": "Jake shmo",
                        "state": "NY",
                        "city": "Albany"
                      },
                      {
                        "name": "Jay shmo",
                        "state": "TN",
                        "city": "Franklin"
                      }
                    ]
                  }
                ]
              }
            }
          }
        },
        "output": "\"42\",\"Joe shmo\",\"AZ\",\"Phoenix\"\n\"42\",\"Jane shmo\",\"CA\",\"Blythe\"\n\"84\",\"Jake shmo\",\"NY\",\"Albany\"\n\"84\",\"Jay shmo\",\"TN\",\"Franklin\""
      }
    ],
    "identifier": 77347258
  },
  {
    "context": [
      "and i am trying to get the entire `ResourceTagMappingList` for when `Costcenter` is untagged.",
      "and i ran the jq query for this :",
      "aws resourcegroupstaggingapi get-resources --tags-per-page 100 | jq '.ResourceTagMappingList[] | select(contains({Tags: [{Key: \u201cCostCenter\u201d} ]}) | not)'",
      "`jq` and JSON only support the ASCII double quotes, not the \"smart ones\".",
      "... | jq '.ResourceTagMappingList[] | select(contains({Tags: [{Key: \"CostCenter\"} ]}) | not)'"
    ],
    "utterance": "Return all objects in ResourceTagMappingList where the CostCenter tag is missing.",
    "expressions": [
      ".ResourceTagMappingList[] | select(contains({Tags: [{Key: \"CostCenter\"} ]}) | not)"
    ],
    "data": [
      {
        "input": {
          "ResourceTagMappingList": [
            {
              "ResourceARN": "<arn1>",
              "Tags": [
                {
                  "Key": "CostCenter",
                  "Value": ""
                },
                {
                  "Key": "Region",
                  "Value": "us-west-2"
                },
                {
                  "Key": "Team",
                  "Value": "SRE"
                }
              ]
            },
            {
              "ResourceARN": "<arn2>",
              "Tags": [
                {
                  "Key": "Region",
                  "Value": "us-west-2"
                },
                {
                  "Key": "Team",
                  "Value": "Architects"
                }
              ]
            }
          ]
        },
        "output": {
          "ResourceARN": "<arn2>",
          "Tags": [
            {
              "Key": "Region",
              "Value": "us-west-2"
            },
            {
              "Key": "Team",
              "Value": "Architects"
            }
          ]
        }
      }
    ],
    "identifier": 77347441
  },
  {
    "context": [
      "Each key-value pair should be transformed to an object containing the keys `name, type, value`. While `name` should be the original _key_. `type` should be the _type_ of the original value perceived by jq's `type` operator. Since Key-value pairs are transformed to complex objects, pairs on the same hierarchy become part of the same array.",
      "def f: {\n  type: type,\n  value: (objects |= (to_entries | map({name: .key} + (.value | f))))\n};\nf.value",
      "Your requirement almost fits what `to_entries` is doing. But you need to carry down the type in a top-down recursion...",
      "If, however, you want the recursion to be propagated down into array items as well, also update arrays (before objects, to not run into the bottom-up issue), e.g. using `arrays |= map(f.value) | objects |= \u2026` ([Demo](https://jqplay.org/s/6UAQudofLqt)), which would produce `[1, [{\"name\": \"x\", \"type\": \"number\", \"value\": 2}], 3]` for the altered example."
    ],
    "utterance": "Recursively transform each key-value pair in an object into an object with keys name (original property name), type (value's type), and value (original value or recursively transformed array/object), nesting this transformation for any property whose value is an object.",
    "expressions": [
      "def f: {\n  type: type,\n  value: (objects |= (to_entries | map({name: .key} + (.value | f))))\n};\nf.value"
    ],
    "data": [
      {
        "input": {
          "id": 123456,
          "name": "Test",
          "more": [
            1,
            2,
            3
          ],
          "instance": {
            "id": 987654,
            "name": "Different"
          }
        },
        "output": [
          {
            "name": "id",
            "type": "number",
            "value": 123456
          },
          {
            "name": "name",
            "type": "string",
            "value": "Test"
          },
          {
            "name": "more",
            "type": "array",
            "value": [
              1,
              2,
              3
            ]
          },
          {
            "name": "instance",
            "type": "object",
            "value": [
              {
                "name": "id",
                "type": "number",
                "value": 987654
              },
              {
                "name": "name",
                "type": "string",
                "value": "Different"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 77322217
  },
  {
    "context": [
      "I would like it to be displayed as `Wednesday, September 27, 2023`",
      "jq provides access to your local operating system's `strftime` and `strptime` functions.",
      ".[0].released_at |                # extract field",
      "split(\".\")[0] |                  # strip seconds (not portably parsable)",
      "strptime(\"%Y-%m-%dT%H:%M:%S\") |  # parse with strptime",
      "strftime(\"%A, %B, %Y\")           # format with strftime"
    ],
    "utterance": "Display the released_at timestamp as 'Wednesday, September 27, 2023'.",
    "expressions": [
      ".[0].released_at | split(\".\")[0] | strptime(\"%Y-%m-%dT%H:%M:%S\") | strftime(\"%A, %B %d, %Y\")"
    ],
    "data": [
      {
        "input": [
          {
            "released_at": "2023-09-27T17:36:07.182Z"
          }
        ],
        "output": "Wednesday, September 27, 2023"
      }
    ],
    "identifier": 77362948
  },
  {
    "context": [
      "I\u2019d like to get the count of elements in an json array using jq (without the elements with \"name\": \"current\" in the snapshots array).",
      "This is the result I\u2019m looking for (excluding the entries with \"name: \"current\" in the snapshots array):\n\ntest1: 1\ntest2: 2",
      "jq --raw-output \n  '\"\\(.name): \\( .snapshots | map(select(.name != \"current\")) | length )\"'",
      "def count(f): reduce (.[] | f) as $i (0; if $i then . + 1 end);\n\"\\(.name): \\(.snapshots | count(.name != \"current\"))\"",
      "\"\\(.name): \\(count(.snapshots[] | select(.name != \"current\")))\""
    ],
    "utterance": "For each object, output its name and the count of snapshots whose name is not \"current\".",
    "expressions": [
      "\"\\(.name): \\(.snapshots | map(select(.name != \\\"current\\\")) | length)\"",
      "def count(f): reduce (.[] | f) as $i (0; if $i then . + 1 end);\n\"\\(.name): \\(.snapshots | count(.name != \\\"current\\\"))\"",
      "def count(s): reduce s as $_ (0; .+1);\n\"\\(.name): \\(count(.snapshots[] | select(.name != \\\"current\\\")))\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "test1",
            "snapshots": [
              {
                "description": "You are here!",
                "name": "current",
                "digest": "ccc",
                "running": 1
              },
              {
                "description": "You are here!",
                "name": "snap1",
                "digest": "ddd",
                "running": 1
              }
            ]
          },
          {
            "name": "test2",
            "snapshots": [
              {
                "digest": "bbb",
                "description": "You are here!",
                "name": "current",
                "running": 1
              },
              {
                "description": "You are here!",
                "name": "snap1",
                "digest": "aaa",
                "running": 1
              },
              {
                "description": "You are here!",
                "name": "snap2",
                "digest": "abc",
                "running": 1
              }
            ]
          }
        ],
        "output": [
          "test1: 1",
          "test2: 2"
        ]
      }
    ],
    "identifier": 77358545
  },
  {
    "context": [
      "Each item in .items array should be sorted by date based on the \"lastModified\" value, so that in the output they would be listed from oldest to newest.",
      "This worked out:\r\n\r\n    jq -s '[0].items |= sort_by(.assets[0].lastModified) | .[0].items'"
    ],
    "utterance": "Sort the items array by the lastModified value of the first asset in each item, from oldest to newest.",
    "expressions": [
      ".[0].items |= sort_by(.assets[0].lastModified) | .[0].items",
      ".[].items |= sort_by(.assets[0].lastModified) | .[].items"
    ],
    "data": [
      {
        "input": [
          {
            "items": [
              {
                "id": "Y29tbW9KJHDGGViZjdihjdfgJDHF72Q2NNlNTE4MQ",
                "repository": "files",
                "format": "raw",
                "group": "/artifactory",
                "name": "artifactory/jfrog-artifactory-cpp-ce-7.68.14.rpm",
                "version": null,
                "assets": [
                  {
                    "downloadUrl": "https://nexusrepo.com/repository/files/artifactory/jfrog-artifactory-cpp-ce-7.68.14.rpm",
                    "path": "artifactory/jfrog-artifactory-cpp-ce-7.68.14.rpm",
                    "id": "MKUKYTGkNTEFYGidfUDFWQ4Mw",
                    "repository": "files",
                    "format": "raw",
                    "checksum": {
                      "sha1": "f7ff96bc6c0cc6ca6163a61635b",
                      "sha256": "97c152220522a2b91032f3a884313a88431a4371a4ef22e2e517cb3b",
                      "sha512": "52d225b9d3a35ef800b556e20067452c7b225b9d3a35ef80066173850c24bd4",
                      "md5": "63044d747d7e5b0c59436"
                    },
                    "contentType": "application/x-rpm",
                    "lastModified": "2023-10-18T12:59:48.331+00:00",
                    "lastDownloaded": "2023-10-26T09:34:14.859+00:00",
                    "uploader": "user",
                    "uploaderIp": "10.30.55.12",
                    "fileSize": 1273649726,
                    "blobCreated": null
                  }
                ]
              }
            ],
            "continuationToken": null
          }
        ]
      }
    ],
    "identifier": 77366770
  },
  {
    "context": [
      "Does `jq` have a way to translate delimited non-JSON data into a JSON array?",
      "Example\n\nInput\n\nABC,123,XYZ,A\"B,{1}\n\nOutput\n\n[\"ABC\", \"123\", \"XYZ\", \"A\\\"B\", \"{1}\"]",
      "You could use the [`/`](https://jqlang.github.io/jq/manual/v1.7/#multiplication-division-modulo) operator, which splits the first string using the second as a separator, like so:\n\n```lang-sh\njq -cR './\",\"' <<< 'ABC,123,XYZ,A\"B,{1}'\n```\n\n```lang-json\n[\"ABC\",\"123\",\"XYZ\",\"A\\\"B\",\"{1}\"]\n```",
      "Or equivalently, using the [`split`](https://jqlang.github.io/jq/manual/v1.7/#split-1) function:\n\n```lang-sh\njq -cR 'split(\",\")' <<< 'ABC,123,XYZ,A\"B,{1}'\n```"
    ],
    "utterance": "Convert a comma-delimited string like 'ABC,123,XYZ,A\"B,{1}' into an array of strings split on commas, preserving embedded special characters and quotes.",
    "expressions": [
      "./\",\"",
      "split(\",\")"
    ],
    "data": [
      {
        "input": "ABC,123,XYZ,A\"B,{1}",
        "output": [
          "ABC",
          "123",
          "XYZ",
          "A\"B",
          "{1}"
        ]
      }
    ],
    "identifier": 77370739
  },
  {
    "context": [
      "I build up the jq using this chain of thought step by step:",
      ".project[] | select( .name |contains(\"ma\")) |.name\n>> \"dungeon master\"\n#success",
      "To avoid code duplication, you could even pull the extraction of .name out of, i.e. before the condition, making it already the context for select and the final output:",
      "jq -r '.project[].name | select(contains(\"ma\"))'",
      "dungeon master",
      "{ \"project\": [ {\u2026},{\u2026},{\u2026},{\u2026} ] } | .project[] | select( .name | contains( \"ma\" ) )",
      "select is called four times, one for each of the projects ({\u2026}). Each time, it will either return the project, or nothing. So you'll end up with zero to four projects. This is what you want."
    ],
    "utterance": "Return the names of all projects whose name contains the substring 'ma'.",
    "expressions": [
      ".project[] | select(.name | contains(\"ma\")) | .name",
      ".project[].name | select(contains(\"ma\"))"
    ],
    "data": [
      {
        "input": {
          "project": [
            {
              "name": "dungeon master",
              "date": "2022-05-11T16:07:29.000Z",
              "status": "active"
            },
            {
              "name": "great gatsby",
              "date": "2023-04-20T19:49:26.000Z",
              "status": "active"
            },
            {
              "name": "hundred years",
              "date": "2022-11-29T23:37:29.000Z",
              "status": "active"
            },
            {
              "name": "passage to india",
              "date": "2022-11-22T04:16:50.000Z",
              "status": "active"
            }
          ]
        },
        "output": [
          "dungeon master"
        ]
      }
    ],
    "identifier": 77351746
  },
  {
    "context": [
      "I am trying to create a list of this json with each property in a single line with its \"path\" separated with dots. Something like this:\n\n.user.name = \"Matias\"\n.user.age = 12\n.role.it.developer = true\n.role.it.designer = false",
      "You could use the `--stream` option to produce a stream of path-value arrays. Filter for those where a value is present, `join` the path (the `first` item), and add the value (the `last` item). I used `@json` for the encoding (quotes around strings) as you didn&#39;t specify otherwise.\n```sh\njq -r --stream 'select(has(1)) | \".\\(first | join(\".\")) = \\(last | @json)\"'\n```",
      "You can get all the leaf nodes, and emit the path and value for each node ([demo][1]):\n\n```\npaths(scalars | true) as $p | \"\\(\".\" + ($p | join(\".\"))) = \\(getpath($p) | @json)\"\n```"
    ],
    "utterance": "Output each leaf property in the input, with its dot-separated path and value, using the format: .path.to.leaf = value, quoting strings appropriately.",
    "expressions": [
      "jq -r --stream 'select(has(1)) | \".\\(first | join(\".\")) = \\(last | @json)\"'",
      "paths(scalars | true) as $p | \".\\($p | join(\".\")) = \\(getpath($p) | @json)\""
    ],
    "data": [
      {
        "input": {
          "user": {
            "name": "Matias",
            "age": 12
          },
          "role": {
            "it": {
              "developer": true,
              "designer": false
            }
          }
        },
        "output": [
          ".user.name = \"Matias\"",
          ".user.age = 12",
          ".role.it.developer = true",
          ".role.it.designer = false"
        ]
      }
    ],
    "identifier": 77366859
  },
  {
    "context": [
      "I am trying to convert to this format ...",
      "Using jq, just define for each field what it should iterate over and collect:",
      "{\n  order: .orders | map({\n    items: .order | map(\n      .items[] | {name, type} | .type |= (map(\n        .value |= .[].value\n      ) | from_entries)\n    ),\n    id\n  })\n}",
      "Another approach ([demo][1]) without using nested mutations (`|=`):",
      "def transform:\n    { name, type : [ .type[] | { (.name) : .value[].value } ] | add };\n\n{ order : [ .orders[] | { items: [ .order[].items[] | transform ], id } ] }"
    ],
    "utterance": "Transform a nested data structure with 'orders', each having an array of 'order' objects containing 'items', so that each item's 'type' array becomes an object mapping 'name' to the value in the contained 'value' array, outputting top-level 'order' array of objects with 'items' (with name and type fields) and 'id'.",
    "expressions": [
      "{\n  order: .orders | map({\n    items: .order | map(\n      .items[] | {name, type} | .type |= (map(\n        .value |= .[].value\n      ) | from_entries)\n    ),\n    id\n  })\n}",
      "def transform:\n    { name, type : [ .type[] | { (.name) : .value[].value } ] | add };\n\n{ order : [ .orders[] | { items: [ .order[].items[] | transform ], id } ] }"
    ],
    "data": [
      {
        "input": {
          "orders": [
            {
              "order": [
                {
                  "items": [
                    {
                      "name": "Item 1",
                      "id": [],
                      "type": [
                        {
                          "name": "Color",
                          "value": [
                            {
                              "value": "blue"
                            }
                          ]
                        },
                        {
                          "name": "model",
                          "value": [
                            {
                              "value": "Stereo"
                            }
                          ]
                        }
                      ]
                    }
                  ]
                },
                {
                  "items": [
                    {
                      "name": "Item 2",
                      "id": [],
                      "type": [
                        {
                          "name": "Color",
                          "value": [
                            {
                              "value": "Yellow"
                            }
                          ]
                        },
                        {
                          "name": "model",
                          "value": [
                            {
                              "value": "NewModel"
                            }
                          ]
                        }
                      ]
                    }
                  ]
                }
              ],
              "id": "715874"
            },
            {
              "order": [
                {
                  "items": [
                    {
                      "name": "Item 6",
                      "id": [],
                      "type": [
                        {
                          "name": "Range",
                          "value": [
                            {
                              "value": "10"
                            }
                          ]
                        },
                        {
                          "name": "Type",
                          "value": [
                            {
                              "value": "AllRegion"
                            }
                          ]
                        }
                      ]
                    }
                  ]
                },
                {
                  "items": [
                    {
                      "name": "Item 4",
                      "id": [],
                      "type": [
                        {
                          "name": "Color",
                          "value": [
                            {
                              "value": "Yellow"
                            }
                          ]
                        },
                        {
                          "name": "model",
                          "value": [
                            {
                              "value": "OldModel"
                            }
                          ]
                        }
                      ]
                    }
                  ]
                }
              ],
              "id": "715875"
            }
          ]
        },
        "output": {
          "order": [
            {
              "items": [
                {
                  "name": "Item 1",
                  "type": {
                    "Color": "blue",
                    "model": "Stereo"
                  }
                },
                {
                  "name": "Item 2",
                  "type": {
                    "Color": "Yellow",
                    "model": "NewModel"
                  }
                }
              ],
              "id": "715874"
            },
            {
              "items": [
                {
                  "name": "Item 6",
                  "type": {
                    "Range": "10",
                    "Type": "AllRegion"
                  }
                },
                {
                  "name": "Item 4",
                  "type": {
                    "Color": "Yellow",
                    "model": "OldModel"
                  }
                }
              ],
              "id": "715875"
            }
          ]
        }
      }
    ],
    "identifier": 77319296
  },
  {
    "context": [
      "I am attempting to create a jq script that can identify, if the array \"all_answers\" in q1 has duplicate entries and delete the entire object. In the end I want to only keep entries in the top level array .[] that have at least one divergent entry in .ratings.q1.all_answers.",
      "In my example I want to delete .[0] because all three values of q1 are the same (\"all_answers\" : [ \"a\", \"a\", \"a\" ]). There should be at least one different \"answer\" like [ \"a\", \"b\", \"b\" ] for it to stay",
      "If you want that there is at least one pair of items with different values, then check if the length of the `unique` array is greater than `1`:",
      ".[] |= select(.ratings.q1.all_answers | unique | length > 1)"
    ],
    "utterance": "Remove objects from the top-level array where all the values in ratings.q1.all_answers are identical, keeping only those with at least one differing value.",
    "expressions": [
      ".[] |= select(.ratings.q1.all_answers | unique | length > 1)"
    ],
    "data": [
      {
        "input": [
          {
            "ratings": {
              "q1": {
                "all_answers": [
                  "a",
                  "a",
                  "a"
                ],
                "top_answer": "a"
              },
              "q2": {
                "all_answers": [
                  "no",
                  "yes",
                  "yes"
                ],
                "top_answer": "yes"
              }
            }
          },
          {
            "ratings": {
              "q1": {
                "all_answers": [
                  "a",
                  "b",
                  "b"
                ],
                "top_answer": "a"
              },
              "q2": {
                "all_answers": [
                  "no",
                  "yes",
                  "yes"
                ],
                "top_answer": "yes"
              }
            }
          },
          {
            "ratings": {
              "q1": {
                "all_answers": [
                  "a",
                  "b",
                  "c"
                ],
                "top_answer": "a"
              },
              "q2": {
                "all_answers": [
                  "no",
                  "yes",
                  "yes"
                ],
                "top_answer": "yes"
              }
            }
          }
        ],
        "output": [
          {
            "ratings": {
              "q1": {
                "all_answers": [
                  "a",
                  "b",
                  "b"
                ],
                "top_answer": "a"
              },
              "q2": {
                "all_answers": [
                  "no",
                  "yes",
                  "yes"
                ],
                "top_answer": "yes"
              }
            }
          },
          {
            "ratings": {
              "q1": {
                "all_answers": [
                  "a",
                  "b",
                  "c"
                ],
                "top_answer": "a"
              },
              "q2": {
                "all_answers": [
                  "no",
                  "yes",
                  "yes"
                ],
                "top_answer": "yes"
              }
            }
          }
        ]
      }
    ],
    "identifier": 77369574
  },
  {
    "context": [
      "I am trying to replace the value \"data-omitted\" inside **services** \"check-api\" with \"xxxxxx\" inside plugin \"oauth2\" in the following json file:",
      "Use the `select` filters on the left-hand side of the assignment:\n```sh\n( .services[]\n  | select(.name == \"check-api\").plugins[]\n  | select(.name == \"oauth2\").config.provision_key\n) = \"xxxxxx\"\n```",
      ".services\n|= map(if .name==\"check-api\"\n       then .plugins |= map(if .name==\"oauth2\"\n                            then .config.provision_key=\"xxxxxx\"\n                            end)\n       end)",
      ".services |= map_values( \n    select(.name == \"check-api\" ).plugins[] \n    |= (select(.name == \"oauth2\" ).config.provision_key |= \"xxxxxx\")\n)",
      ".services[] |= ( select(.name == \"check-api\" ).plugins[]\n            |= ( select(.name == \"oauth2\" ).config.provision_key |= \"xxxxxx\" ))"
    ],
    "utterance": "Replace the value of provision_key with \"xxxxxx\" in the config of the oauth2 plugin for the service named check-api.",
    "expressions": [
      "( .services[] | select(.name == \"check-api\").plugins[] | select(.name == \"oauth2\").config.provision_key ) = \"xxxxxx\"",
      ".services |= map(if .name==\"check-api\" then .plugins |= map(if .name==\"oauth2\" then .config.provision_key=\"xxxxxx\" end) end)",
      ".services |= map_values(select(.name == \"check-api\").plugins[] |= (select(.name == \"oauth2\").config.provision_key |= \"xxxxxx\"))",
      ".services[] |= ( select(.name == \"check-api\" ).plugins[] |= ( select(.name == \"oauth2\" ).config.provision_key |= \"xxxxxx\" ))"
    ],
    "data": [
      {
        "input": {
          "consumers": [
            {
              "username": "api-user2"
            },
            {
              "username": "oauth2-devops-app"
            }
          ],
          "services": [
            {
              "name": "check-api",
              "plugins": [
                {
                  "config": {
                    "allow": [
                      "acl-devops"
                    ],
                    "deny": null,
                    "hide_groups_header": false
                  },
                  "name": "acl"
                },
                {
                  "config": {
                    "credentials": false,
                    "preflight_continue": false
                  },
                  "enabled": true,
                  "name": "cors"
                },
                {
                  "config": {
                    "provision_key": "data-omitted",
                    "token_expiration": 300
                  },
                  "enabled": true,
                  "name": "oauth2"
                }
              ],
              "port": 5000,
              "write_timeout": 60000
            },
            {
              "name": "check-api2",
              "plugins": [
                {
                  "config": {
                    "deny": null,
                    "hide_groups_header": false
                  },
                  "enabled": true,
                  "name": "acl"
                },
                {
                  "config": {
                    "credentials": false,
                    "preflight_continue": false
                  },
                  "enabled": true,
                  "name": "oauth2"
                }
              ],
              "port": 5000,
              "write_timeout": 60000
            }
          ]
        },
        "output": {
          "consumers": [
            {
              "username": "api-user2"
            },
            {
              "username": "oauth2-devops-app"
            }
          ],
          "services": [
            {
              "name": "check-api",
              "plugins": [
                {
                  "config": {
                    "allow": [
                      "acl-devops"
                    ],
                    "deny": null,
                    "hide_groups_header": false
                  },
                  "name": "acl"
                },
                {
                  "config": {
                    "credentials": false,
                    "preflight_continue": false
                  },
                  "enabled": true,
                  "name": "cors"
                },
                {
                  "config": {
                    "provision_key": "xxxxxx",
                    "token_expiration": 300
                  },
                  "enabled": true,
                  "name": "oauth2"
                }
              ],
              "port": 5000,
              "write_timeout": 60000
            },
            {
              "name": "check-api2",
              "plugins": [
                {
                  "config": {
                    "deny": null,
                    "hide_groups_header": false
                  },
                  "enabled": true,
                  "name": "acl"
                },
                {
                  "config": {
                    "credentials": false,
                    "preflight_continue": false
                  },
                  "enabled": true,
                  "name": "oauth2"
                }
              ],
              "port": 5000,
              "write_timeout": 60000
            }
          ]
        }
      }
    ],
    "identifier": 77319427
  },
  {
    "context": [
      "What I want is\r\n`{ \"sensor.current_consumption\": \"1.4\", \"sensor.current_power\": \"194.6\", \"sensor.current_mains_voltage\": \"239.9\" }`",
      "Don&#39;t iterate the elements of the array with `.[]` but [`map`](https://jqlang.github.io/jq/manual/#map-map_values) them to a new array, then `add` them to a single object:\r\n\r\n```\r\nmap(select(.entity_id|startswith(\"sensor.current.\")) | { (.entity_id) : .state})\r\n| add\r\n```",
      "Alternatively, [`reduce`](https://jqlang.github.io/jq/manual/#reduce) to your final object:\r\n\r\n```\r\nreduce (.[] | select(.entity_id|startswith(\"sensor.current.\")))\r\nas $x ({}; .[$x.entity_id] = $x.state)\r\n```",
      "The third option is using [`from_entries`](https://jqlang.github.io/jq/manual/#to_entries-from_entries-with_entries) to construct an object from an array of key-value-pairs:\r\n\r\n```\r\nmap(select(.entity_id|startswith(\"sensor.current.\")) | { key: .entity_id, value: .state})\r\n| from_entries\r\n```",
      "This works for me in eating large Json blocks \r\n\r\n```\r\njq 'map(select(.entity_id|startswith(\"sensor.current\")) | { (.entity_id) : .state})| add' foo.json\r\n```"
    ],
    "utterance": "Combine all array objects whose entity_id starts with 'sensor.current.' into a single object mapping each entity_id to its state.",
    "expressions": [
      "map(select(.entity_id|startswith(\"sensor.current.\")) | { (.entity_id) : .state }) | add",
      "reduce (.[] | select(.entity_id|startswith(\"sensor.current.\"))) as $x ({}; .[$x.entity_id] = $x.state)",
      "map(select(.entity_id|startswith(\"sensor.current.\")) | { key: .entity_id, value: .state}) | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "entity_id": "sensor.current_consumption",
            "state": "1.4"
          },
          {
            "entity_id": "sensor.current_power",
            "state": "194.6"
          },
          {
            "entity_id": "sensor.current_mains_voltage",
            "state": "239.9"
          },
          {
            "entity_id": "sensor.other_sensor",
            "state": "5"
          }
        ],
        "output": {
          "sensor.current_consumption": "1.4",
          "sensor.current_power": "194.6",
          "sensor.current_mains_voltage": "239.9"
        }
      }
    ],
    "identifier": 77395822
  },
  {
    "context": [
      "The following method works well in PowerShell to get the value `7.3.9-win-x64.msi` from the JSON above:",
      "    PS C:\\> gc pw.txt | jq -r '.[] | .[] | .[] | .[].management | .[0].microsoft | .shell.associated.scripting.component.windows.powershell'"
    ],
    "utterance": "Select the string value '7.3.9-win-x64.msi' located at the nested key path: .PowerShell[\"is a task\"].automation[0].management[0].microsoft.shell.associated.scripting.component.windows.powershell",
    "expressions": [
      ".[] | .[] | .[] | .[].management | .[0].microsoft | .shell.associated.scripting.component.windows.powershell"
    ],
    "data": [
      {
        "input": {
          "PowerShell": {
            "is a task": {
              "automation": [
                {
                  "and": "configuration",
                  "management": [
                    {
                      "program": "from",
                      "microsoft": {
                        "consisting of": "a command-line",
                        "shell": {
                          "and": "the",
                          "associated": {
                            "scripting": {
                              "language.": "initially a windows",
                              "component": {
                                "only": "known as",
                                "windows": {
                                  "powershell": "7.3.9-win-x64.msi",
                                  "it was made": "open-source"
                                }
                              }
                            }
                          }
                        }
                      }
                    }
                  ]
                },
                {
                  "the former": "is built on the .NET Framework",
                  "the latter on": ".NET (previously .NET Core)."
                }
              ]
            }
          }
        },
        "output": "7.3.9-win-x64.msi"
      }
    ],
    "identifier": 77405440
  },
  {
    "context": [
      "In JQ is it possible to execute the command from same object?",
      "If you see i have name and cmd as two keys. If you run the text from cmd's value in [JQPlay][1]. You will see below object `\"John Smith\"`",
      "Is it possible to do it using single JQ query ?",
      "jq does not provide an \"eval\" function, so if you really wanted to evaluate jq expressions, you'd have to write your own",
      "you could piggy-back off jq's support for array-paths, and write a simple evaluator",
      "if you were willing to write your JSON template as:",
      "{\n  \"name\": [[\"firstname\"], \" Smith\"],\n  \"firstname\": \"John\"\n}",
      "then this little bit of infrastructure:\ndef ispath:\n  type == \"array\" and all(.[]; type | IN(\"string\",\"number\") );\n  \n# eval . in the context of $context\ndef eval($context):\n  . as $x\n  | if type == \"string\" then .\n    elif ispath then $context | getpath($x)\n    elif type == \"array\"\n    then map( eval($context) ) | add\n    elif type == \"object\"\n    then map_values(eval($context))\n    else tostring\n    end;",
      "{\n  \"name\": [[\"firstname\"], \" Smith\"],\n  \"firstname\": \"John\"\n}\n| eval(.)"
    ],
    "utterance": "Produce an object where the value of one key is constructed by evaluating a reference to another key and concatenating a string literal.",
    "expressions": [
      "def ispath: type == \"array\" and all(.[]; type | IN(\"string\",\"number\") );\ndef eval($context):\n  . as $x\n  | if type == \"string\" then .\n    elif ispath then $context | getpath($x)\n    elif type == \"array\"\n    then map( eval($context) ) | add\n    elif type == \"object\"\n    then map_values(eval($context))\n    else tostring\n    end;\n\neval(.)"
    ],
    "data": [
      {
        "input": {
          "name": [
            [
              "firstname"
            ],
            " Smith"
          ],
          "firstname": "John"
        },
        "output": {
          "name": "John Smith",
          "firstname": "John"
        }
      }
    ],
    "identifier": 77399537
  },
  {
    "context": [
      "I used the following long command to get a JSON value `7.3.9-win-x64.msi`...",
      "$ cat json.txt  | jq -r '.[] | .[] | .[] | .[].management | .[0].microsoft | .shell.associated.scripting.component.windows.powershell'",
      "So is there a more shortest command to do it?.",
      "If you\u2019re willing to take the risk, you could go with s.t. like:\n.. | objects | .powershell // empty",
      "Or if you know s.t. distinctive about the string of interest, e.g. that it ends with \".msi\":\n.. | strings | select(endswith(\".msi\"))",
      ".[][][][].management[0].microsoft.shell.associated.scripting.component.windows.powershell"
    ],
    "utterance": "Extract the value that ends with \".msi\" anywhere in the data structure.",
    "expressions": [
      ".. | strings | select(endswith(\".msi\"))"
    ],
    "data": [
      {
        "input": {
          "PowerShell": {
            "is a task": {
              "automation": [
                {
                  "and": "configuration",
                  "management": [
                    {
                      "program": "from",
                      "microsoft": {
                        "consisting of": "a command-line",
                        "shell": {
                          "and": "the",
                          "associated": {
                            "scripting": {
                              "language.": "initially a windows",
                              "component": {
                                "only": "known as",
                                "windows": {
                                  "powershell": "7.3.9-win-x64.msi",
                                  "it was made": "open-source"
                                }
                              }
                            }
                          }
                        }
                      }
                    }
                  ]
                },
                {
                  "the former": "is built on the .NET Framework",
                  "the latter on": ".NET (previously .NET Core)."
                }
              ]
            }
          }
        },
        "output": "7.3.9-win-x64.msi"
      }
    ],
    "identifier": 77406373
  },
  {
    "context": [
      "I have a json as :\r\n\r\n    {\"message\":[\"Another open merge request already exists for this source branch: !5193\"]}",
      "I want to you use jq in a shell script and check whether this string is there or not .",
      "The string i want to search is `Another open merge request already exists for this source branch`",
      "`cat temp.json | jq --arg MESSAGE \"$MESSAGE\" 'any(.message[];startswith($MESSAGE))'`",
      "this will return true or false depends on whether the string is found or not"
    ],
    "utterance": "Check if any string in the message array starts with 'Another open merge request already exists for this source branch'.",
    "expressions": [
      "jq --arg MESSAGE \"$MESSAGE\" 'any(.message[];startswith($MESSAGE))'"
    ],
    "data": [
      {
        "input": {
          "message": [
            "Another open merge request already exists for this source branch: !5193"
          ]
        },
        "output": true
      }
    ],
    "identifier": 77408894
  },
  {
    "context": [
      "I would like to flatten it to the following tab separated structure, perhaps using jq",
      "| id | time       | cities | type |",
      "| -- | ---------- | ------ | ---- |",
      "| 1  | 1659800397 | london |    1 |",
      "| 1  | 1659800397 | paris  |    1 |",
      "| 1  | 1659800411 | rome   |    2 |",
      ". as {$id} | .activities[] | .cities[] as $city\n| [$id, .time, $city, .type] | @tsv",
      "[.id] + (.activities[] | [.time] + (.cities[] | [.]) + [.type]) | @tsv",
      "jq -r '.id as $id | .activities[] | \"\\($id);\\(.time);\\(.type);\\(.cities[])\"' input.json"
    ],
    "utterance": "Produce tab-separated rows, each containing the top-level id, activity time, each city in the activity, and activity type, with a row for each city.",
    "expressions": [
      ". as {$id} | .activities[] | .cities[] as $city | [$id, .time, $city, .type] | @tsv",
      "[.id] + (.activities[] | [.time] + (.cities[] | [.]) + [.type]) | @tsv",
      ".id as $id | .activities[] | .cities[] as $city | \"\u001b[$id]\t\u001b[.time]\t$city\t\u001b[.type]\"",
      ".id as $id | .activities[] | \"\u001b[$id];\u001b[.time];\u001b[.type];\u001b[.cities[]]\""
    ],
    "data": [
      {
        "input": {
          "id": 1,
          "activities": [
            {
              "time": 1659800397,
              "cities": [
                "london",
                "paris"
              ],
              "type": 1
            },
            {
              "time": 1659800411,
              "cities": [
                "rome"
              ],
              "type": 2
            }
          ]
        },
        "output": [
          "1\t1659800397\tlondon\t1",
          "1\t1659800397\tparis\t1",
          "1\t1659800411\trome\t2"
        ]
      }
    ],
    "identifier": 77401140
  },
  {
    "context": [
      "now with this command line: `cat list | jq -R '.'. The result is:\n\n    \"me\"\n    \"you\"\n    \"them\"\n\nok now I want to convert to array, so as in the questions I should only put some brackets in the identity filter. If I do this (`cat list | jq -R '[.]')` I get:\n\n    [\n      \"me\"\n    ]\n    [\n      \"you\"\n    ]\n    [\n      \"them\"\n    ]",
      "how do I get \n\n    [\n        \"me\",\n        \"you\",\n        \"them\"\n    ]\n\n? I don't want to use `inputs` function. I want to be able to use in the simple `cat whatever | jq 'whatever'` format.",
      "I found a way to do it, but I don't consider this an answer because I really think there should be a better way, please enlighten me on how I could do this better.\n\n    cat list | jq -sR 'split(\"\\n\") | map(select(length > 0))'",
      "Next best without using `split` would be:\n\n    jq -R . list | jq -s .",
      "cat list | jq -R '.' | jq -s '.'\n\nboth work given the original input.",
      "The answer you arrived at is valid, but this is an explanation of why it works and why the other attempts did not:\n\n### Why does `cat list | jq -R '[.]'` not work?\n\nBecause `jq` isn't running the filter once, but once for **each line** of input. In other words, the `.` is only ever one of the 3 inputs by itself; so `[.]` turns that single element into an array, and then having run 3 times, you have 3 arrays.",
      "Why does `cat list | jq -R | jq -s '.'` work?\n\nRunning the `jq -R` quotes the strings, and so we are basically doing: "
    ],
    "utterance": "Combine lines from a text file into a single array of strings, with each line as a separate string element.",
    "expressions": [
      "jq -R . list | jq -s .",
      "cat list | jq -R '.' | jq -s '.'"
    ],
    "data": [
      {
        "input": "me\nyou\nthem\n",
        "output": [
          "me",
          "you",
          "them"
        ]
      }
    ],
    "identifier": 77414104
  },
  {
    "context": [
      "I\u2019d like to to flatten a (nested) array of objects to an array of strings.",
      "given the input\n\n``` lang-json\n{\n  \"message-id\": 1,\n  \"result\": {\n    \"info\": {\n      \"id\": 1,\n      \"name\": \"foobar\",\n      \"route\": [\n        {\n          \"nodeid\": 1,\n          \"nodename\": \"name-1\"\n        },\n        {\n          \"nodeid\": 2,\n          \"nodename\": \"name-2\"\n        }\n      ]\n    }\n  }\n}\n```",
      "I\u2019d like to turn it in to \n``` lang-json\n{\n  \"name\": \"foobar\",\n  \"route\": [\n    \"name-1\",\n    \"name-2\"\n  ]\n}\n```",
      ".result.info | { name: .name, route: .route }",
      "\"Here's one way you could do it that's pretty close to your attempt.\n```lang-jq\n.result.info\n| {name} + {route: .route|map(.nodename)}\n```\"",
      "\"Here's another variation that is the same as your attempt, plus one step to modify `route`:\n\n```none\n.result.info\n| .route |= map(.nodename)\n| {name, route}\n```"
    ],
    "utterance": "Extract the object at .result.info, keeping the name as-is and converting the route array into an array containing only the nodename values.",
    "expressions": [
      ".result.info | {name} + {route: .route | map(.nodename)}",
      ".result.info | .route |= map(.nodename) | {name, route}"
    ],
    "data": [
      {
        "input": {
          "message-id": 1,
          "result": {
            "info": {
              "id": 1,
              "name": "foobar",
              "route": [
                {
                  "nodeid": 1,
                  "nodename": "name-1"
                },
                {
                  "nodeid": 2,
                  "nodename": "name-2"
                }
              ]
            }
          }
        },
        "output": {
          "name": "foobar",
          "route": [
            "name-1",
            "name-2"
          ]
        }
      }
    ],
    "identifier": 77423031
  },
  {
    "context": [
      "But, this is missing the 2nd level - package name.",
      "Expected output",
      "host1, packages.device-mapper-event-libs, x86_64, 7, 2023-08-05T09:18:20Z, 6.0.5.el7_9.5,1.02.170",
      "keys_unsorted[] as $host | .[$host]\n| keys_unsorted[] as $pkg | .[$pkg]\n| [\n    $host, $pkg,\n    .arch, .epoch, (.installdate | tonumber | todate), .release, .version\n  ]\n| join(\", \") # or @csv",
      "to_entries[] | \"\\(.key), \\(.value|keys[]), \\(.value[].arch), \\(.value[].epoch), \\(.value[].installdate | tonumber | todate), \\(.value[].release), \\(.value[].version)\""
    ],
    "utterance": "Convert nested host and package information to CSV rows, including host, package name, arch, epoch, installdate (as date), release, and version.",
    "expressions": [
      ".rows[]\n| keys_unsorted[] as $host | .[$host]\n| keys_unsorted[] as $pkg | .[$pkg]\n| [\n    $host, $pkg,\n    .arch, .epoch, (.installdate | tonumber | todate), .release, .version\n  ]\n| join(\", \")",
      "to_entries[] | \"\\(.key), \\(.value|keys[]), \\(.value[].arch), \\(.value[].epoch), \\(.value[].installdate | tonumber | todate), \\(.value[].release), \\(.value[].version)\""
    ],
    "data": [
      {
        "input": {
          "host1": {
            "packages.device-mapper-event-libs": {
              "epoch": "7",
              "version": "1.02.170",
              "release": "6.0.5.el7_9.5",
              "installdate": "1691227100",
              "arch": "x86_64"
            }
          }
        },
        "output": "host1, packages.device-mapper-event-libs, x86_64, 7, 2023-08-05T09:18:20Z, 6.0.5.el7_9.5, 1.02.170"
      },
      {
        "input": {
          "host2": {
            "packages.device-mapper-event-libs": {
              "epoch": "7",
              "version": "1.02.170",
              "release": "6.0.5.el7_9.5",
              "installdate": "1691232631",
              "arch": "x86_64"
            }
          }
        },
        "output": "host2, packages.device-mapper-event-libs, x86_64, 7, 2023-08-05T10:50:31Z, 6.0.5.el7_9.5, 1.02.170"
      }
    ],
    "identifier": 77417285
  },
  {
    "context": [
      "And I can see that sometimes some annotation is just a value and at other times its json.  I want to be able to expand out the json annotations to make it more readable",
      "I want to expand out kubectl.kubernetes.io/last-applied-configuration and other annotations that are json"
    ],
    "utterance": "Display annotation values as parsed objects if they are valid JSON; otherwise, show the annotation value as-is.",
    "expressions": [
      ".items[].metadata.annotations | to_entries[] | \"\\(.key)=\\(try (.value | fromjson | .) catch .)\""
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "annotations": {
                  "test.bob.k8s.elastic.co/token": "622fb4bd-e5f9-46e5-a73b-80b9d0fad43a",
                  "kubectl.kubernetes.io/last-applied-configuration": "{\"apiVersion\":\"agent.k8s.elastic.co/v1alpha1\",\"kind\":\"Agent\",\"metadata\":{\"annotations\":{},\"name\":\"test-agent\",\"namespace\":\"default\"},\"spec\":{\"daemonSet\":{\"podTemplate\":{\"spec\":{\"automountServiceAccountToken\":true,\"containers\":[{\"command\":[\"bash\",\"-c\",\"#!/usr/bin/env bash\\nset -e\\nif [[ -f /mnt/test-internal/test-association/default/bob/certs/ca.crt ]]; then\\n  cp /mnt/test-internal/test-association/default/bob/certs/ca.crt /usr/local/share/ca-certificates\\n  update-ca-certificates\\nfi\\n/usr/bin/tini -- /usr/local/bin/docker-entrypoint -e\\n\"],\"name\":\"agent\"}],\"securityContext\":{\"runAsUser\":0},\"serviceAccountName\":\"test-agent\"}}},\"testServerRef\":{\"name\":\"test-server\"},\"testRef\":{\"name\":\"bob\"},\"mode\":\"test\",\"version\":\"1.10.2\"}}"
                }
              }
            }
          ]
        },
        "output": [
          "test.bob.k8s.elastic.co/token=622fb4bd-e5f9-46e5-a73b-80b9d0fad43a",
          "kubectl.kubernetes.io/last-applied-configuration={\"apiVersion\":\"agent.k8s.elastic.co/v1alpha1\",\"kind\":\"Agent\",\"metadata\":{\"annotations\":{},\"name\":\"test-agent\",\"namespace\":\"default\"},\"spec\":{\"daemonSet\":{\"podTemplate\":{\"spec\":{\"automountServiceAccountToken\":true,\"containers\":[{\"command\":[\"bash\",\"-c\",\"#!/usr/bin/env bash\\nset -e\\nif [[ -f /mnt/test-internal/test-association/default/bob/certs/ca.crt ]]; then\\n  cp /mnt/test-internal/test-association/default/bob/certs/ca.crt /usr/local/share/ca-certificates\\n  update-ca-certificates\\nfi\\n/usr/bin/tini -- /usr/local/bin/docker-entrypoint -e\\n\"],\"name\":\"agent\"}],\"securityContext\":{\"runAsUser\":0},\"serviceAccountName\":\"test-agent\"}}},\"testServerRef\":{\"name\":\"test-server\"},\"testRef\":{\"name\":\"bob\"},\"mode\":\"test\",\"version\":\"1.10.2\"}}"
        ]
      }
    ],
    "identifier": 77424571
  },
  {
    "context": [
      "json example:\n\n```\n{\"_id\":{\"$oid\":\"5200a366e36f237975000783\"},\"derived_form\":{\"$numberInt\":\"1\"},\"intransitive\":true,\"lemma\":\"badbad\",\"phonetic\":\"b\u0250db\u0250t\",\"pos\":\"VERB\",\"root\":{\"radicals\":\"b-d-b-d\"},\"sources\":[\"Spagnol2011\",\"Falzon2013\"],\"glosses\":[{\"gloss\":\"to fornicate\",\"examples\":[]},{\"gloss\":\"to cough a lot\",\"examples\":[]}],\"norm_freq\":{\"$numberDouble\":\"0.0\"}}\n```",
      "How do I convert to .csv:\n\n```5200a366e36f237975000783, badbad, b\u0250db\u0250t, VERB, true, b-d-b-d, \"to fornicate, to cough a lot\"```",
      "To obtain the desired csv output:\n\n```bash\n$ jq -r '\"\\(._id[]), \\(.lemma), \\(.phonetic), \\(.pos), \\(.intransitive), \\(.root.radicals), \\\"\\([.glosses[].gloss] | join(\",\"))\\\"\"' file\n5200a366e36f237975000783, badbad, b\u0250db\u0250t, VERB, true, b-d-b-d, \"to fornicate,to cough a lot\""
    ],
    "utterance": "Output a CSV line containing the $oid, lemma, phonetic, pos, intransitive, root.radicals, and all glosses joined by comma in quotes.",
    "expressions": [
      "\"\\(._id[]), \\(.lemma), \\(.phonetic), \\(.pos), \\(.intransitive), \\(.root.radicals), \\\"\\([.glosses[].gloss] | join(\",\"))\\\"\""
    ],
    "data": [
      {
        "input": {
          "_id": {
            "$oid": "5200a366e36f237975000783"
          },
          "derived_form": {
            "$numberInt": "1"
          },
          "intransitive": true,
          "lemma": "badbad",
          "phonetic": "b\u0250db\u0250t",
          "pos": "VERB",
          "root": {
            "radicals": "b-d-b-d"
          },
          "sources": [
            "Spagnol2011",
            "Falzon2013"
          ],
          "glosses": [
            {
              "gloss": "to fornicate",
              "examples": []
            },
            {
              "gloss": "to cough a lot",
              "examples": []
            }
          ],
          "norm_freq": {
            "$numberDouble": "0.0"
          }
        },
        "output": "5200a366e36f237975000783, badbad, b\u0250db\u0250t, VERB, true, b-d-b-d, \"to fornicate,to cough a lot\""
      }
    ],
    "identifier": 77436995
  },
  {
    "identifier": 77438599
  },
  {
    "context": [
      "In case of multiple versions, pick latest - based in **installdate**",
      "Each version has a *installdate*. The details in the main part are not necessarily related to the *latest* version.",
      "I am interested in getting the details of each package's *latest* version.",
      "For packages that don't have multiple versions, the one details are picked as is - there are no versions.",
      "[$host, .key,\n   (.value\n    | if has(\"versions\") then .versions|sort_by(.installdate)|last end \n    | .arch, .epoch, .installdate, .version, .release\n   )\n  ]\n| @csv",
      "You can use `max_by` for that.",
      "For that, you can use the error suppression operator `?` in combination wit the alternative operator `//`.",
      ".versions | max_by(.installdate))? // ."
    ],
    "utterance": "Output, for each host and package, the details of the latest version (by highest installdate) if multiple, or the current details if only one; format as CSV including host, package, arch, epoch, installdate, version, and release.",
    "expressions": [
      "to_entries[]\n| .key as $host\n| .value\n| to_entries[]\n| [$host, .key,\n   (.value\n    | if has(\"versions\") then .versions|sort_by(.installdate)|last end \n    | .arch, .epoch, .installdate, .version, .release\n   )\n  ]\n| @csv",
      "keys_unsorted[] as $host | .[$host]\n| keys_unsorted[] as $pkg | .[$pkg]\n| (.versions | max_by(.installdate))? // .\n| [\n    $host, $pkg,\n    .arch, .epoch, .installdate, .version, .release\n  ]\n| @csv"
    ],
    "data": [
      {
        "input": {
          "host1": {
            "packages.kernel": {
              "epoch": "0",
              "version": "3.10.0",
              "release": "1160.102.1.0.1.el7",
              "installdate": "1698822019",
              "arch": "x86_64",
              "versions": [
                {
                  "epoch": "0",
                  "version": "3.10.0",
                  "release": "1160.66.1.el7",
                  "installdate": "1654792248",
                  "arch": "x86_64"
                },
                {
                  "epoch": "0",
                  "version": "3.10.0",
                  "release": "1160.49.1.el7",
                  "installdate": "1640181036",
                  "arch": "x86_64"
                },
                {
                  "epoch": "0",
                  "version": "3.10.0",
                  "release": "1160.102.1.0.1.el7",
                  "installdate": "1698822019",
                  "arch": "x86_64"
                }
              ]
            },
            "packages.yum": {
              "epoch": "0",
              "version": "3.4.3",
              "release": "168.0.5.el7",
              "installdate": "1698822027",
              "arch": "noarch"
            }
          }
        },
        "output": [
          "\"host1\",\"packages.kernel\",\"x86_64\",\"0\",\"1698822019\",\"3.10.0\",\"1160.102.1.0.1.el7\"",
          "\"host1\",\"packages.yum\",\"noarch\",\"0\",\"1698822027\",\"3.4.3\",\"168.0.5.el7\""
        ]
      },
      {
        "input": {
          "host2": {
            "packages.kernel": {
              "epoch": "0",
              "version": "3.10.0",
              "release": "1160.49.1.el7",
              "installdate": "1640181036",
              "arch": "x86_64",
              "versions": [
                {
                  "epoch": "0",
                  "version": "3.10.0",
                  "release": "1160.102.1.0.1.el7",
                  "installdate": "1698820106",
                  "arch": "x86_64"
                },
                {
                  "epoch": "0",
                  "version": "3.10.0",
                  "release": "1160.66.1.el7",
                  "installdate": "1654792238",
                  "arch": "x86_64"
                },
                {
                  "epoch": "0",
                  "version": "3.10.0",
                  "release": "1160.49.1.el7",
                  "installdate": "1640181036",
                  "arch": "x86_64"
                }
              ]
            },
            "packages.yum": {
              "epoch": "0",
              "version": "3.4.3",
              "release": "168.0.5.el7",
              "installdate": "1698820115",
              "arch": "noarch"
            }
          }
        },
        "output": [
          "\"host2\",\"packages.kernel\",\"x86_64\",\"0\",\"1698820106\",\"3.10.0\",\"1160.102.1.0.1.el7\"",
          "\"host2\",\"packages.yum\",\"noarch\",\"0\",\"1698820115\",\"3.4.3\",\"168.0.5.el7\""
        ]
      }
    ],
    "identifier": 77420750
  },
  {
    "context": [
      "I need to replace the value of a field of this file with a random string.",
      "the field value to replace is the one of \"field_2\"",
      "RUN jq '.things[0].field_2= \"$(openssl rand -base64 12)\"' /app/config.json > /app/new_config.json",
      "jq --arg rand \"$(openssl rand -base64 12)\" '.things[0].field_2 = $rand'",
      "Your original code did not work because single quotes prevent command substitution."
    ],
    "utterance": "Replace the value of 'field_2' inside the first element of 'things' array with a random string value.",
    "expressions": [
      "jq --arg rand \"$(openssl rand -base64 12)\" '.things[0].field_2 = $rand' /app/config.json > /app/new_config.json"
    ],
    "data": [
      {
        "input": {
          "things": [
            {
              "field_1": "val_1",
              "field_2": "val_2"
            }
          ]
        },
        "output": {
          "things": [
            {
              "field_1": "val_1",
              "field_2": "SOME_RANDOM_STRING"
            }
          ]
        }
      }
    ],
    "identifier": 77445297
  },
  {
    "context": [
      "I am trying to create a csv with the following column names : ARN, Stage, CostCenter, Service, Domain, Team and the values should be what is found in the key value pairs of the Tags array and whatever key value pairs do not exist then just leave the column as blank.",
      "Basically the final CSV should look like \n\n    ARN STAGE CostCenter Service Domain Team\n    arn st.   \"\"          \"\"      \"\"     \"\"\n    arn st    \"\"          \"\"      \"\"     \"\" \n    arn ec    Development MP.     \"\"     VNP\n",
      "Since you state you wish to produce CSV, let me start with a filter that does just that:\n```\n[\"ARN\", \"STAGE\", \"CostCenter\", \"Service\", \"Domain\", \"Team\"] as $columns\n| $columns, \n  (.[]\n   | .ResourceARN as $ARN\n   |  .Tags | from_entries\n   | [$ARN, .[ $columns[1:][]]] )\n| @csv\n```",
      "Your illustrative output seems to correspond more closely to TSV, and you indicate you want missing fields to be represented by `\"\"`, so we could tweak the above accordingly:\n```\n[\"ARN\", \"STAGE\", \"CostCenter\", \"Service\", \"Domain\", \"Team\"] as $columns\n| \"\\\"\\\"\" as $q\n| $columns, \n  (.[]\n   | .ResourceARN as $ARN\n   |  .Tags | from_entries\n   | [$ARN, (.[ $columns[1:][]] | (. // $q ) ) ] )\n| @tsv\n```",
      "With your sample input, this produces:\n```\nARN\tSTAGE\tCostCenter\tService\tDomain\tTeam\narn\tst\t\"\" \t\"\" \t\"\" \t\"\"\narn\tst\t\"\" \t\"\" \t\"\" \t\"\"\narn\tec\tDevelopment\tMP\t\"\"\tVNP\n```"
    ],
    "utterance": "Create a table with columns ARN, STAGE, CostCenter, Service, Domain, Team from an array of objects, taking values from ResourceARN and Tags (using Tags[].Key/Value mappings), and represent missing tag values as an empty quoted string.",
    "expressions": [
      "[\"ARN\", \"STAGE\", \"CostCenter\", \"Service\", \"Domain\", \"Team\"] as $columns\n| $columns, \n  (.[]\n   | .ResourceARN as $ARN\n   |  .Tags | from_entries\n   | [$ARN, .[ $columns[1:][]]] )\n| @csv",
      "[\"ARN\", \"STAGE\", \"CostCenter\", \"Service\", \"Domain\", \"Team\"] as $columns\n| \"\\\"\\\"\" as $q\n| $columns, \n  (.[]\n   | .ResourceARN as $ARN\n   |  .Tags | from_entries\n   | [$ARN, (.[ $columns[1:][]] | (. // $q ) ) ] )\n| @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "ResourceARN": "arn",
            "Tags": [
              {
                "Key": "STAGE",
                "Value": "st"
              }
            ]
          },
          {
            "ResourceARN": "arn",
            "Tags": [
              {
                "Key": "STAGE",
                "Value": "st"
              }
            ]
          },
          {
            "ResourceARN": "arn",
            "Tags": [
              {
                "Key": "aws:cloudformation:stack-name",
                "Value": "aud"
              },
              {
                "Key": "CostCenter",
                "Value": "Development"
              },
              {
                "Key": "aws:cloudformation:stack-id",
                "Value": "arn"
              },
              {
                "Key": "STAGE",
                "Value": "ec"
              },
              {
                "Key": "Environment",
                "Value": "development"
              },
              {
                "Key": "Region",
                "Value": "us-west-2"
              },
              {
                "Key": "Service",
                "Value": "MP"
              },
              {
                "Key": "aws:cloudformation:logical-id",
                "Value": "ApiGatewayRestApi"
              },
              {
                "Key": "Team",
                "Value": "VNP"
              }
            ]
          }
        ],
        "output": "ARN\tSTAGE\tCostCenter\tService\tDomain\tTeam\narn\tst\t\"\"\t\"\"\t\"\"\t\"\"\narn\tst\t\"\"\t\"\"\t\"\"\t\"\"\narn\tec\tDevelopment\tMP\t\"\"\tVNP"
      }
    ],
    "identifier": 77390622
  },
  {
    "context": [
      "Given the following JSON which has details of packages - with the host name available separately, convert it into CSV.",
      "Expected output",
      "host1, PuTTY release 0.77 (64-bit), 0.77.0.0, Simon Tatham, 20220916",
      ".rows[] | . as {$name} | .automatic.packages",
      "| keys_unsorted[] as $pkg | .[$pkg]",
      "| [$name, $pkg, .version, .publisher, .installdate]",
      "| join(\", \")  # or @csv"
    ],
    "utterance": "Produce a CSV with lines containing host name, package name, version, publisher, and installdate for each package on each host.",
    "expressions": [
      ".rows[] | . as {$name} | .automatic.packages | keys_unsorted[] as $pkg | .[$pkg] | [$name, $pkg, .version, .publisher, .installdate] | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "rows": [
            {
              "name": "host1",
              "automatic": {
                "packages": {
                  "PuTTY release 0.77 (64-bit)": {
                    "version": "0.77.0.0",
                    "publisher": "Simon Tatham",
                    "installdate": "20220916"
                  },
                  "Microsoft Visual C++ 2013 x86 Additional Runtime - 12.0.21005": {
                    "version": "12.0.21005",
                    "publisher": "Microsoft Corporation",
                    "installdate": "20210816"
                  }
                }
              }
            },
            {
              "name": "host2",
              "automatic": {
                "packages": {
                  "Notepad++ (64-bit x64)": {
                    "version": "8.4.2",
                    "publisher": "Notepad++",
                    "installdate": "20230517"
                  },
                  "Oracle Windows VirtIO Drivers": {
                    "version": "1.1.3",
                    "publisher": "Oracle Corporation",
                    "installdate": "20200316"
                  },
                  "ManageEngine UEMS - Agent": {
                    "version": "11.2.2315.5.W",
                    "publisher": "ZohoCorp",
                    "installdate": "20230601"
                  }
                }
              }
            }
          ]
        },
        "output": [
          "host1, PuTTY release 0.77 (64-bit), 0.77.0.0, Simon Tatham, 20220916",
          "host1, Microsoft Visual C++ 2013 x86 Additional Runtime - 12.0.21005, 12.0.21005, Microsoft Corporation, 20210816",
          "host2, Notepad++ (64-bit x64), 8.4.2, Notepad++, 20230517",
          "host2, Oracle Windows VirtIO Drivers, 1.1.3, Oracle Corporation, 20200316",
          "host2, ManageEngine UEMS - Agent, 11.2.2315.5.W, ZohoCorp, 20230601"
        ]
      }
    ],
    "identifier": 77438555
  },
  {
    "context": [
      "But I want to get just \"status\":\"success\" part to make a test, if status=success then I execute the next jenkins pipeline stage.",
      "this is my curl command:\n\n```\n...\n\techo \"$pipelineStatus' | jq -r '.status'\", returnStatus: true)//.trim()\n\n\tif (status == 'success') {\n\t\techo \"Pipeline succeeded\"\n\t} else {\n\t\techo \"Pipeline did not succeed\"\n\t}\n```\n",
      "As you have your response from api in JSON format, the easiest way is to parse the response, and get value of `status` key.",
      "{...\"status\":\"success\",...}"
    ],
    "utterance": "Extract the value of the top-level field named status from the response to check if it is success.",
    "expressions": [
      ".status",
      "jq -r '.status'"
    ],
    "data": [
      {
        "input": {
          "id": 1664,
          "iid": 19,
          "project_id": 229,
          "sha": "9e70fd49d14e86ccd6091addf394ded51d22ab50",
          "ref": "main",
          "status": "success",
          "source": "trigger",
          "created_at": "2023-11-06T15:41:36.238Z",
          "updated_at": "2023-11-06T15:41:38.854Z",
          "web_url": "https://mygitlab.domain/test-ci/-/pipelines/1664",
          "before_sha": "0000000000000000000000000000000000000000",
          "tag": false,
          "yaml_errors": null,
          "user": {
            "id": 98,
            "username": "907802",
            "name": "myname",
            "state": "active",
            "locked": false,
            "avatar_url": "https://mygitlab.domain/uploads/-/system/user/avatar/98/avatar.png",
            "web_url": "https://mygitlab.domain/907802"
          },
          "started_at": "2023-11-06T15:41:37.695Z",
          "finished_at": "2023-11-06T15:41:38.841Z",
          "committed_at": null,
          "duration": 1,
          "queued_duration": 1,
          "coverage": null,
          "detailed_status": {
            "icon": "status_success",
            "text": "Passed",
            "label": "passed",
            "group": "success",
            "tooltip": "passed",
            "has_details": false,
            "details_path": "/907802/test-ci/-/pipelines/1664",
            "illustration": null,
            "favicon": "/assets/ci_favicons/favicon_status_success-8451333011eee8ce9f2ab25dc487fe24a8758c694827a582f17f42b0a90446a2.png"
          },
          "name": null
        },
        "output": "success"
      }
    ],
    "identifier": 77437463
  },
  {
    "context": [
      "I would like to find in a JSON file a specific value (without worrying about the key) at any level of my JSON file (I don't know in advance the exact tree) and display the parent keys.",
      "But I would like also to get the parent key \"logId\" at the first level.",
      "You could use `paths` to find the paths with matching values, extract from it the first two items (`[\"auditLogs\",0]` in this case), use `getpath` to retrieve that object, and extract `.logId` from there:",
      "jq -r 'getpath(paths(. == \"CREDENTIALS_VAULT-1212121212121\")[:2]).logId'",
      "You can also consider collecting the results in an array by wrapping `[\u2026]` around the filter.",
      "You can use [`IN`](https://jqlang.github.io/jq/manual/#sql-style-operators) (or `any(stream; condition)`):",
      ".auditLogs[] | select(IN(.. | .credentialId?; \"CREDENTIALS_VAULT-1212121212121\")) | .logId",
      "Here's a straightforward approach that meets both these requirements (and I'd hazard is faster than using `paths` and `getpath`):",
      ".. | objects | select(.logId) | .logId as $id | .. | objects | select(.[] == \"CREDENTIALS_VAULT-1212121212121\") | $id",
      "Thank you very much for your answers. I finally chose to use the first solution using the getpath() function. With this solution, we don\u2019t care about the name of the key. Indeed in my case the pattern to search (\"CREDENTIALS_VAULT-1212121212121\") is not necessary the value of the key \"credentialId\". This can be another key"
    ],
    "utterance": "Find all objects containing the value \"CREDENTIALS_VAULT-1212121212121\" at any depth and return their parent object's logId field.",
    "expressions": [
      "getpath(paths(. == \"CREDENTIALS_VAULT-1212121212121\")[:2]).logId",
      "getpath(paths(. == \"CREDENTIALS_VAULT-1212121212121\")[:2]) | {logId}",
      ".auditLogs[] | select(IN(.. | .credentialId?; \"CREDENTIALS_VAULT-1212121212121\")) | .logId",
      ".auditLogs[] | select(IN(.. | .credentialId?; \"CREDENTIALS_VAULT-1212121212121\")) | { logId }",
      ".. | objects | select(.logId) | .logId as $id | .. | objects | select(.[] == \"CREDENTIALS_VAULT-1212121212121\") | $id"
    ],
    "data": [
      {
        "input": {
          "totalCount": 2,
          "pageSize": 1000,
          "auditLogs": [
            {
              "logId": "169807591200060002",
              "eventType": "CREATE",
              "category": "CONFIG",
              "entityId": "HTTP_CHECK-12121212121212",
              "timestamp": 1698075912003,
              "success": true,
              "patch": [
                {
                  "op": "replace",
                  "path": "/",
                  "value": {
                    "steps": [
                      {
                        "id": {
                          "type": "HTTP_CHECK_STEP"
                        },
                        "requestType": "OAUTH2",
                        "destinationUrl": "https://www.mywebsite.com",
                        "httpMethod": "POST",
                        "acceptAnyCertificate": true,
                        "followRedirects": true,
                        "displayName": "My Website",
                        "userAgent": "",
                        "httpCheckHeaders": [
                          {
                            "name": "Content-Type",
                            "value": "application/x-www-form-urlencoded"
                          }
                        ],
                        "stepPerformanceThreshold": 0,
                        "requestBody": null,
                        "constraints": [
                          {
                            "constraintType": "HttpStatusesList",
                            "passIfFound": false,
                            "pattern": ">=400"
                          }
                        ],
                        "preScript": "",
                        "postScript": "",
                        "attributes": {
                          "oAuth2RequestId": "1",
                          "oAuth2BodyInputType": "RAW",
                          "oAuth2addAuthDataTo": "REQUEST_BODY"
                        },
                        "postExecutionScriptVariables": [
                          "{bearerToken-1}"
                        ],
                        "preExecutionScriptVariables": [],
                        "certificateId": "",
                        "basicAuthId": "",
                        "certStoreId": 0,
                        "basicAuthStoreId": 0,
                        "authenticationConfig": {
                          "type": "BASIC_AUTHENTICATION",
                          "realmName": null,
                          "kdcIp": null,
                          "credentialId": "CREDENTIALS_VAULT-1212121212121"
                        },
                        "executionProperties": {},
                        "shouldNotPersistSensitiveData": true
                      }
                    ],
                    "publicLocationIds": [
                      124
                    ],
                    "userModificationTimestamp": 1698075911987,
                    "customProperties": [],
                    "version": 6
                  },
                  "oldValue": null
                }
              ]
            },
            {
              "logId": "169807591200060001",
              "eventType": "CREATE",
              "category": "CONFIG",
              "entityId": "HTTP_CHECK-12121212121212",
              "environmentId": "b416bf43-a9d2-4123-aa70-e36ff39c0ad9",
              "timestamp": 1698075911986,
              "success": true,
              "patch": [
                {
                  "op": "replace",
                  "path": "/",
                  "value": {
                    "frequency (Frequency)": 0,
                    "locations": [
                      {
                        "location (Location)": "SYNTHETIC_LOCATION-000000000000007C"
                      }
                    ]
                  },
                  "oldValue": null
                }
              ]
            }
          ]
        },
        "output": [
          "169807591200060002"
        ]
      }
    ],
    "identifier": 77372497
  },
  {
    "context": [
      "I\u2019d like to convert environment variables containing the word KEY or PASSWORD to a secret for each docker service, and move the environment to env_file like following:",
      "But I failed to create the secrets for each service:\n    secrets:\n      - CHASSEAUXLIVRES_KEY\n      - TEL_PASSWORD\n      - SPRING_DATASOURCE_PASSWORD",
      "I could use bash commands but I do want to do such a thing with manipulating json using jq"
    ],
    "utterance": "Extract all environment variable names containing 'KEY' or 'PASSWORD' from each service under 'services' and output a list of these as the 'secrets' array for each corresponding service.",
    "expressions": [
      ".services |= with_entries(.value |= (. + {secrets: (.environment | to_entries | map(select(.key | test(\"KEY|PASSWORD\"))) | map(.key))}))"
    ],
    "data": [
      {
        "input": {
          "services": {
            "theses-api-diffusion": {
              "container_name": "theses-api-diffusion",
              "environment": {
                "CHASSEAUXLIVRES_KEY": "?key=3a072b56267e9c3ba4b6f3ff66f7",
                "CHASSEAUXLIVRES_URL": "http://www.chasse-aux-livres.fr/api/v1/price/",
                "JAVA_OPTS": "-Doracle.jdbc.timezoneAsRegion=false -Duser.timezone=CEST",
                "SERVER_PORT": "8992",
                "SPRING_DATASOURCE_PASSWORD": "PORTAIL",
                "SPRING_DATASOURCE_URL": "jdbc:oracle:thin:@//orpins-p-scan.v110.abes.fr:1521/THESES",
                "SPRING_DATASOURCE_USERNAME": "PORTAIL",
                "TEL_HOSTSWORD": "api.archives-ouvertes.fr",
                "TEL_PASSWORD": "dedt@sa",
                "TEL_USERID": "star_abes",
                "THESES_PATH_LOCAL": "/starstock/"
              }
            },
            "theses-api-recherche": {
              "container_name": "theses-api-recherche",
              "environment": {
                "FOO": "bar"
              }
            }
          }
        },
        "output": {
          "services": {
            "theses-api-diffusion": {
              "container_name": "theses-api-diffusion",
              "environment": {
                "CHASSEAUXLIVRES_KEY": "?key=3a072b56267e9c3ba4b6f3ff66f7",
                "CHASSEAUXLIVRES_URL": "http://www.chasse-aux-livres.fr/api/v1/price/",
                "JAVA_OPTS": "-Doracle.jdbc.timezoneAsRegion=false -Duser.timezone=CEST",
                "SERVER_PORT": "8992",
                "SPRING_DATASOURCE_PASSWORD": "PORTAIL",
                "SPRING_DATASOURCE_URL": "jdbc:oracle:thin:@//orpins-p-scan.v110.abes.fr:1521/THESES",
                "SPRING_DATASOURCE_USERNAME": "PORTAIL",
                "TEL_HOSTSWORD": "api.archives-ouvertes.fr",
                "TEL_PASSWORD": "dedt@sa",
                "TEL_USERID": "star_abes",
                "THESES_PATH_LOCAL": "/starstock/"
              },
              "secrets": [
                "CHASSEAUXLIVRES_KEY",
                "SPRING_DATASOURCE_PASSWORD",
                "TEL_PASSWORD"
              ]
            },
            "theses-api-recherche": {
              "container_name": "theses-api-recherche",
              "environment": {
                "FOO": "bar"
              },
              "secrets": []
            }
          }
        }
      }
    ],
    "identifier": 77440643
  },
  {
    "context": [
      "I want to merge the second array items to the first one using the `jq` command.",
      "I want to receive \n```json\n{\"fruits\":[{\"name\":\"banana\"},{\"name\":\"apple\"},{\"name\":\"tomato\"},{\"name\":\"onion\"}]}\n```",
      "You could iterate over all second-level items using `.[][]`, and collect them into an array using the array constructor `[\u2026]`:\n```sh\njq -c '{fruits: [.[][]]}'\n```",
      "Several alternatives:\n\n```\n.fruits += .vegetables | del(.vegetables)\n```\n\n```\n{ fruits: (.fruits + .vegetables) }\n```\n\n```\n{ fruits: map(.[]) }\n```"
    ],
    "utterance": "Combine the items from 'vegetables' into 'fruits', resulting in a single key 'fruits' containing all items from both arrays.",
    "expressions": [
      "{fruits: [.[][]]}",
      ".fruits += .vegetables | del(.vegetables)",
      "{ fruits: (.fruits + .vegetables) }",
      "{ fruits: map(.[]) }"
    ],
    "data": [
      {
        "input": {
          "fruits": [
            {
              "name": "banana"
            },
            {
              "name": "apple"
            }
          ],
          "vegetables": [
            {
              "name": "tomato"
            },
            {
              "name": "onion"
            }
          ]
        },
        "output": {
          "fruits": [
            {
              "name": "banana"
            },
            {
              "name": "apple"
            },
            {
              "name": "tomato"
            },
            {
              "name": "onion"
            }
          ]
        }
      }
    ],
    "identifier": 77473122
  },
  {
    "context": [
      "How do I prepend my own header to each value to get the following output\n\n\"Description\": \"Test A\", \"Start\": \"2023-11-13T06:00:00Z\", \"End\": \"2023-11-20T08:00:00Z\"\n\"Description\": \"Test B\", \"Start\": \"2023-11-13T06:00:00Z\", \"End\": \"2023-11-20T06:00:00Z\"\n\"Description\": \"Test C\", \"Start\": \"2023-11-13T06:00:00Z\", \"End\": \"2023-11-20T06:00:00Z\"",
      "Instead of constructing an array of values, construct an object and name your fields as you see fit.",
      "Then, use the `-c` flag to output each object on izs own line:\n\n```sh\n\u2026 | jq -c '.[] | select(IN(.priority; \"low\", \"high\", \"moderate\"))\n| {Description: .description, Start: .planned_start, End: .planned_end}'\n```",
      "Since you want the keys and values quoted strings, you could use `tojson` to have them quoted. With the array of strings you want to output, you  could then join that array.\n\n```\n$ command | jq -r '\nselect(.priority == (\"low\", \"high\", \"moderate\"))\n  | { Description: .description, Start: .planned_start, End: .planned_end }\n  | to_entries\n  | map(\"\\(.key|tojson): \\(.value|tojson)\")\n  | join(\", \")\n'\n```"
    ],
    "utterance": "Output each object with priority low, high, or moderate as a single line of quoted key-value pairs labeled Description, Start, and End.",
    "expressions": [
      ".[] | select(IN(.priority; \"low\", \"high\", \"moderate\")) | {Description: .description, Start: .planned_start, End: .planned_end}",
      "select(.priority == (\"low\", \"high\", \"moderate\"))\n  | { Description: .description, Start: .planned_start, End: .planned_end }\n  | to_entries\n  | map(\"\\(.key|tojson): \\(.value|tojson)\")\n  | join(\", \")"
    ],
    "data": [
      {
        "input": [
          {
            "description": "Test A",
            "planned_start": "2023-11-13T06:00:00Z",
            "planned_end": "2023-11-20T08:00:00Z",
            "priority": "low"
          },
          {
            "description": "Test B",
            "planned_start": "2023-11-13T06:00:00Z",
            "planned_end": "2023-11-20T06:00:00Z",
            "priority": "medium"
          },
          {
            "description": "Test C",
            "planned_start": "2023-11-13T06:00:00Z",
            "planned_end": "2023-11-20T06:00:00Z",
            "priority": "high"
          }
        ],
        "output": [
          "\"Description\": \"Test A\", \"Start\": \"2023-11-13T06:00:00Z\", \"End\": \"2023-11-20T08:00:00Z\"",
          "\"Description\": \"Test C\", \"Start\": \"2023-11-13T06:00:00Z\", \"End\": \"2023-11-20T06:00:00Z\""
        ]
      }
    ],
    "identifier": 77466018
  },
  {
    "context": [
      "I would like to get the environments.dev.\"vm-IP\" that is active.",
      "Here are my unsuccessful scripts for \"dev\".",
      "error: Cannot index string with string \"status\""
    ],
    "utterance": "Get the vm-IP value for the dev environment entry where status is \"active\".",
    "expressions": [
      ".environments.dev[] | select(.status == \"active\") | .\"vm-IP\""
    ],
    "data": [
      {
        "input": {
          "environments": {
            "dev": [
              {
                "id": "1",
                "vm-IP": "ww.www.ww.ww",
                "sql-name": "vmname1.eastus.cloudapp.azure.com",
                "status": "inactive"
              },
              {
                "id": "2",
                "vm-IP": "xx.xxx.xx.xx",
                "sql-name": "vmname2.eastus.cloudapp.azure.com",
                "status": "active"
              }
            ],
            "stg": {
              "id": "3",
              "vm-IP": "yy.yyy.yy.yy",
              "sql-name": "vmname3.eastus.cloudapp.azure.com"
            },
            "prod": {
              "id": "4",
              "vm-IP": "zz.zzz.zz.zz",
              "sql-name": "vmname4.eastus.cloudapp.azure.com"
            }
          }
        },
        "output": "xx.xxx.xx.xx"
      }
    ],
    "identifier": 77477468
  },
  {
    "context": [
      "How to retrieve the next key value pair in a json file with jq when I know the previous one",
      "I know the key value pair of the entry3 but not the next one (entry4 and value). How can I access them?",
      "to_entries | .[\n  to_entries[] | select(.value.value == \"value3\").key + 1\n] | .key, .value",
      "My goal is to retrieve the key values pairs for entry3 and entry4",
      "to_entries | while(. != []; .[1:])[:2]\n| select(first.value == \"value3\")\n| first.key, first.value, last.key, last.value",
      "to_entries\n| range(0;length-1) as $n\n| select( .[$n].key == \"entry3\" )\n| .[$n:$n+2][]\n| [.key, .value]"
    ],
    "utterance": "Return the key-value pair for the entry immediately after the key with value \"value3\".",
    "expressions": [
      "to_entries | .[\nto_entries[] | select(.value.value == \"value3\").key + 1\n] | .key, .value",
      "to_entries | while(. != []; .[1:])[:2]\n| select(first.value == \"value3\")\n| first.key, first.value, last.key, last.value",
      "to_entries\n| range(0;length-1) as $n\n| select( .[$n].key == \"entry3\" )\n| .[$n:$n+2][]\n| [.key, .value]"
    ],
    "data": [
      {
        "input": {
          "entry1": "",
          "entry2": "",
          "entry3": "value3",
          "entry4": "value4",
          "entry5": "",
          "entry6": " ",
          "entry7": "",
          "entry8": "false"
        },
        "output": [
          "entry4",
          "value4"
        ]
      }
    ],
    "identifier": 77481826
  },
  {
    "context": [
      "I want to parse it to a csv in the following format:",
      "id,prod,etype,bankName,accountType,openingBalance,fromDate,toDate,dateTime,description,amount,bal,type,accountid",
      "Parse the transactions into a proper csv and repeat the common info for each transaction.",
      "jq -r '\"id,prod,etype,bankName,accountType,openingBalance,fromDate,toDate,dateTime,description,amount,bal,type,accountid\", ( . as {$id,$accountid} | .details as {$prod, $etype} | .accounts[] | . as { $bankName,$accountType,$openingBalance,$fromDate,$toDate } | .transactions[] | [$id,$prod,$etype,$bankName,$accountType,$openingBalance,$fromDate,$toDate,.dateTime,.description,.amount,.bal? // .balanceAfterTransaction,.type,$accountid] | join(\",\"))' input.json",
      "[\"id\",\"prod\",\"etype\"] as $idHdrs | [\"bankName\", \"accountType\", \"openingBalance\", \"fromDate\", \"toDate\"] as $accountHdrs | [\"dateTime\", \"description\", \"amount\", \"bal\", \"type\"] as $txHdrs | $idHdrs + $accountHdrs + $txHdrs + [\"accountid\"],   # the header row,   ( . as {$id,$accountid} | .details as {$prod, $etype} | .accounts[] | [.[$accountHdrs[]]] as $accounts | .transactions[] | .bal //= .balanceAfterTransaction  # fiddle | [.[$txHdrs[]]] as $transactions | [$id,$prod,$etype] + $accounts + $transactions + [$accountid] ) | @csv"
    ],
    "utterance": "Extract one row per transaction with top-level fields, details, accounts properties, and transaction properties, filling in bal with balanceAfterTransaction if bal is missing.",
    "expressions": [
      "jq -r '\"id,prod,etype,bankName,accountType,openingBalance,fromDate,toDate,dateTime,description,amount,bal,type,accountid\", ( . as {$id,$accountid} | .details as {$prod, $etype} | .accounts[] | . as { $bankName,$accountType,$openingBalance,$fromDate,$toDate } | .transactions[] | [$id,$prod,$etype,$bankName,$accountType,$openingBalance,$fromDate,$toDate,.dateTime,.description,.amount,.bal? // .balanceAfterTransaction,.type,$accountid] | join(\",\"))' input.json",
      "[\"id\",\"prod\",\"etype\"] as $idHdrs | [\"bankName\", \"accountType\", \"openingBalance\", \"fromDate\", \"toDate\"] as $accountHdrs | [\"dateTime\", \"description\", \"amount\", \"bal\", \"type\"] as $txHdrs | $idHdrs + $accountHdrs + $txHdrs + [\"accountid\"],   ( . as {$id,$accountid} | .details as {$prod, $etype} | .accounts[] | [.[$accountHdrs[]]] as $accounts | .transactions[] | .bal //= .balanceAfterTransaction | [.[$txHdrs[]]] as $transactions | [$id,$prod,$etype] + $accounts + $transactions + [$accountid] ) | @csv"
    ],
    "data": [
      {
        "input": {
          "id": "id123",
          "details": {
            "prod": "prod123",
            "etype": "type1"
          },
          "accounts": [
            {
              "bankName": "bank123",
              "accountType": "account123",
              "openingBalance": "bal123",
              "fromDate": "2023-01-01",
              "toDate": "2023-01-01",
              "missingMonths": [],
              "transactions": [
                {
                  "dateTime": "2020-12-01",
                  "description": "a very long string",
                  "amount": -599.0,
                  "bal": 8154.83,
                  "type": "Debit"
                },
                {
                  "dateTime": "2020-12-01",
                  "description": "a very long string; a very long string",
                  "amount": -4000.0,
                  "balanceAfterTransaction": 4154.83,
                  "type": "Debit"
                }
              ]
            }
          ],
          "accountid": "sample123"
        },
        "output": [
          [
            "id",
            "prod",
            "etype",
            "bankName",
            "accountType",
            "openingBalance",
            "fromDate",
            "toDate",
            "dateTime",
            "description",
            "amount",
            "bal",
            "type",
            "accountid"
          ],
          [
            "id123",
            "prod123",
            "type1",
            "bank123",
            "account123",
            "bal123",
            "2023-01-01",
            "2023-01-01",
            "2020-12-01",
            "a very long string",
            -599,
            8154.83,
            "Debit",
            "sample123"
          ],
          [
            "id123",
            "prod123",
            "type1",
            "bank123",
            "account123",
            "bal123",
            "2023-01-01",
            "2023-01-01",
            "2020-12-01",
            "a very long string; a very long string",
            -4000,
            4154.83,
            "Debit",
            "sample123"
          ]
        ]
      }
    ],
    "identifier": 77445623
  },
  {
    "context": [
      "but \r\n\r\n```\r\nf=\"teststring\"\r\njq -n --argjson a ${f} '{\"test\":$a}'\r\n```\r\n\r\nyields\r\njq: invalid JSON text passed to --argjson",
      "The correct way to define your input is to add an extra level of quoting to make the double quotes part of the value:\r\n\r\n```sh\r\nf='\"teststring\"'\r\njq -n --argjson a \"${f}\" '{\"test\":$a}'\r\n```"
    ],
    "utterance": "Pass a shell string variable containing a string value as a variable using --argjson so that the string is correctly interpreted.",
    "expressions": [
      "f='\"teststring\"'\njq -n --argjson a \"${f}\" '{\"test\":$a}'"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "test": "teststring"
        }
      }
    ],
    "identifier": 77486468
  },
  {
    "context": [
      "i want select command to work i am trying to do filter latency but without select statment it is not working.",
      "You cannot use `&#39;` for strings in cmd.",
      "Use double quotes and escape the inner double quotes"
    ],
    "utterance": "Filter the data to include only entries where latency is greater than a specified value.",
    "expressions": [
      "jq \"select(.latency > 100)\"",
      "jq \"map(select(.latency > 100))\""
    ],
    "identifier": 77495696
  },
  {
    "context": [
      "I have an expression in JQ that looks like this:\r\n\r\n```\r\n[{  \"names\": .products[] | .name }]  |  length  > 200 as $qty |  if ($qty) then \"ok\" else \"not ok\" end\r\n```\r\n",
      "if (.products | length > 200) then \"ok\" else \"not ok\" end\r\n",
      ".products | if (length > 200) then \"ok\" else \"not ok\" end\r\n"
    ],
    "utterance": "Output \"ok\" if the number of items in the products array is greater than 200, otherwise output \"not ok\".",
    "expressions": [
      "if (.products | length > 200) then \"ok\" else \"not ok\" end",
      ".products | if (length > 200) then \"ok\" else \"not ok\" end"
    ],
    "identifier": 77490174
  },
  {
    "context": [
      "if jq -e '.changes.title.previous and .changes.title.current and .object_attributes.detailed_merge_status == \"mergeable\"' <<<\"$payload\"; then",
      "jqFilter='\n$j | (\n  .changes.title.previous and\n  .changes.title.current and\n  .object_attributes.detailed_merge_status == \"mergeable\"\n)'",
      "if jq --exit-status --null-input --argjson j \"$triggerPayload\" \"$jqFilter\" >/dev/null; then"
    ],
    "utterance": "Check if both .changes.title.previous and .changes.title.current are present and .object_attributes.detailed_merge_status equals \"mergeable\".",
    "expressions": [
      ".changes.title.previous and .changes.title.current and .object_attributes.detailed_merge_status == \"mergeable\"",
      "$j | (.changes.title.previous and .changes.title.current and .object_attributes.detailed_merge_status == \"mergeable\")"
    ],
    "data": [
      {
        "input": {
          "changes": {
            "title": {
              "previous": "test",
              "current": "test"
            }
          },
          "object_attributes": {
            "detailed_merge_status": "mergeable"
          }
        },
        "output": true
      },
      {
        "input": {
          "object_attributes": {
            "detailed_merge_status": "draft_status"
          },
          "changes": {}
        },
        "output": false
      }
    ],
    "identifier": 77489086
  },
  {
    "context": [
      "I would like to be able to access '1.25.3' from this list to tag the image in a build step of a CI-CD pipeline.",
      "But would like to know how to access the item 'NGINX_VERSION' by name instead of relying on the assumption that it will be the second environment variable.",
      "So filter NGINX_VERSION  from the array and remove it.\n\n    .[].Config.Env |\n    select(startswith(\"NGINX_VERSION=\")) |\n    sub(\"^NGINX_VERSION=\", \"\")",
      "But if you need to access multiple values, you might want to consider creating a lookup object using INDEX:\nINDEX(.[:index(\"=\")]) as $ix\nand then access the values by field name:\n| $ix[\"NGINX_VERSION\"]         # yields \"NGINX_VERSION=1.25.3\"\n| .[index(\"=\")+1:]             # yields \"1.25.3",
      "A solution to the stated problem can then be written as:\n\ntoObject(\"=\") | .NGINX_VERSION"
    ],
    "utterance": "Extract the value '1.25.3' for the key 'NGINX_VERSION' from an array of key=value strings where the order is not guaranteed.",
    "expressions": [
      ".[].Config.Env[] | select(startswith(\"NGINX_VERSION=\")) | sub(\"^NGINX_VERSION=\", \"\")",
      ".[].Config.Env | map(select(startswith(\"NGINX_VERSION=\"))) | .[0] | sub(\"^NGINX_VERSION=\", \"\")",
      ".[].Config.Env | map(select(startswith(\"NGINX_VERSION=\"))) | first | sub(\"^NGINX_VERSION=\", \"\")",
      ".[].Config.Env | INDEX(.[:index(\"=\")]) | .[\"NGINX_VERSION\"] | .[index(\"=\")+1:]",
      ".[].Config.Env | map(capture(\"(?<key>[^=]*)=(?<value>.*)\")) | from_entries | .NGINX_VERSION",
      ".[].Config.Env | (map(capture(\"(?<key>[^=]*)=(?<value>.*)\")) | from_entries).NGINX_VERSION"
    ],
    "data": [
      {
        "input": [
          "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
          "NGINX_VERSION=1.25.3",
          "NJS_VERSION=0.8.2",
          "PKG_RELEASE=1~bookworm"
        ],
        "output": "1.25.3"
      }
    ],
    "identifier": 77474072
  },
  {
    "context": [
      "I want to output only EventId in the json file above.",
      "Just iterate over the items of the `.Events` array, and extract the `.EventId`:\n```sh\njq -r '.Events[].EventId' test.json\n```\n```\nC7061BAC-AFDC-4513-B24B-AA5F13A16123\nC7061BAC-AFDC-4513-B24B-AA5F13A16123\n```",
      "you should use the following command:\n\n```bash\ncat test.json | jq -c '.Events[] | .EventId'\n```\n\nThis command will iterate through each element in the \"Events\" array and extract the \"EventId\" from each element."
    ],
    "utterance": "Extract all EventId values from each Events array in a stream of objects.",
    "expressions": [
      ".Events[].EventId",
      ".Events[] | .EventId"
    ],
    "data": [
      {
        "input": [
          {
            "DocumentIncarnation": 1,
            "Events": []
          },
          {
            "DocumentIncarnation": 2,
            "Events": [
              {
                "EventId": "C7061BAC-AFDC-4513-B24B-AA5F13A16123",
                "EventStatus": "Scheduled",
                "EventType": "Freeze",
                "ResourceType": "VirtualMachine",
                "Resources": [
                  "WestNO_0",
                  "WestNO_1"
                ],
                "NotBefore": "Mon, 11 Apr 2022 22:26:58 GMT",
                "Description": "Virtual machine is being paused because of a memory-preserving Live Migration operation.",
                "EventSource": "Platform",
                "DurationInSeconds": 5
              }
            ]
          },
          {
            "DocumentIncarnation": 3,
            "Events": [
              {
                "EventId": "C7061BAC-AFDC-4513-B24B-AA5F13A16123",
                "EventStatus": "Started",
                "EventType": "Freeze",
                "ResourceType": "VirtualMachine",
                "Resources": [
                  "WestNO_0",
                  "WestNO_1"
                ],
                "NotBefore": "",
                "Description": "Virtual machine is being paused because of a memory-preserving Live Migration operation.",
                "EventSource": "Platform",
                "DurationInSeconds": 5
              }
            ]
          },
          {
            "DocumentIncarnation": 4,
            "Events": []
          }
        ],
        "output": [
          "C7061BAC-AFDC-4513-B24B-AA5F13A16123",
          "C7061BAC-AFDC-4513-B24B-AA5F13A16123"
        ]
      }
    ],
    "identifier": 77486124
  },
  {
    "context": [
      "I want to be able to filter based on the nth `RespStatus` inside the `records` array.",
      "but sometimes I need to filter if only the nth `RespStatus` is `304`.",
      ".[] | select(nth(1;.records[]|select(.tag==\"RespStatus\")).value==\"304\")",
      ".[] | select(.records|map(select(.tag==\"RespStatus\"))[1].value==\"304\")"
    ],
    "utterance": "Select each object where the second occurrence of RespStatus in the records array has value 304.",
    "expressions": [
      ".[] | select(nth(1;.records[]|select(.tag==\"RespStatus\")).value==\"304\")",
      ".[] | select(.records|map(select(.tag==\"RespStatus\"))[1].value==\"304\")"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": 671731542,
              "type": "BeReq",
              "records": [
                {
                  "tag": "foo",
                  "value": "bar"
                },
                {
                  "tag": "foo",
                  "value": "bar"
                },
                {
                  "tag": "RespStatus",
                  "value": "200"
                },
                {
                  "tag": "RespReason",
                  "value": "OK"
                },
                {
                  "tag": "foo",
                  "value": "bar"
                },
                {
                  "tag": "RespStatus",
                  "value": "304"
                },
                {
                  "tag": "RespReason",
                  "value": "Not Modified"
                }
              ]
            }
          ],
          [
            {
              "id": 671731543,
              "type": "BeReq",
              "records": [
                {
                  "tag": "foo",
                  "value": "bar"
                },
                {
                  "tag": "foo",
                  "value": "bar"
                },
                {
                  "tag": "RespStatus",
                  "value": "200"
                },
                {
                  "tag": "RespReason",
                  "value": "OK"
                }
              ]
            }
          ]
        ],
        "output": [
          {
            "id": 671731542,
            "type": "BeReq",
            "records": [
              {
                "tag": "foo",
                "value": "bar"
              },
              {
                "tag": "foo",
                "value": "bar"
              },
              {
                "tag": "RespStatus",
                "value": "200"
              },
              {
                "tag": "RespReason",
                "value": "OK"
              },
              {
                "tag": "foo",
                "value": "bar"
              },
              {
                "tag": "RespStatus",
                "value": "304"
              },
              {
                "tag": "RespReason",
                "value": "Not Modified"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 77497862
  },
  {
    "context": [
      "I only know the value of the **secretValue5** and would like to retrieve the \n **secretName5** value and the next one (**secretName6** and **secretValue6**)",
      "The result expected is\n\n```none\nsecretName5\nsecretValue5\nsecretName6\nsecretValue6\n```",
      "Just work directly on the array `.globalSecrets` and the fields of its items (`.secretName` and `.secretValue`):",
      "```\n.globalSecrets | while(. != []; .[1:])[:2]\n| select(first.secretValue == \"secretValue5\")\n| first.secretName, first.secretValue, last.secretName, last.secretValue\n```"
    ],
    "utterance": "Given an array of secret objects, find the object with secretValue equal to \"secretValue5\", and print its secretName and secretValue followed by the secretName and secretValue of the next object in the array.",
    "expressions": [
      ".globalSecrets | while(. != []; .[1:])[:2]\n| select(first.secretValue == \"secretValue5\")\n| first.secretName, first.secretValue, last.secretName, last.secretValue"
    ],
    "data": [
      {
        "input": {
          "metadata": {
            "secretSchema": "3.0",
            "tenant": "MyTenantName"
          },
          "globalSecrets": [
            {
              "secretName": "secretName1",
              "secretValue": "secretValue1"
            },
            {
              "secretName": "secretName2",
              "secretValue": "secretValue2"
            },
            {
              "secretName": "secretName3",
              "secretValue": "secretValue3"
            },
            {
              "secretName": "secretName4",
              "secretValue": "secretValue4"
            },
            {
              "secretName": "secretName5",
              "secretValue": "secretValue5"
            },
            {
              "secretName": "secretName6",
              "secretValue": "secretValue6"
            },
            {
              "secretName": "secretName7",
              "secretValue": "secretValue7"
            }
          ]
        },
        "output": [
          "secretName5",
          "secretValue5",
          "secretName6",
          "secretValue6"
        ]
      }
    ],
    "identifier": 77499841
  },
  {
    "context": [
      "I want to find the services those have `criticality==MC` and depends from other services with `criticality==MC`.",
      "Output may look like the following: service and its dependencies",
      "My solution is:",
      "# find the MC services and put them into $mc",
      "[ .services[] | select(.criticality == \"MC\") | .name ] as $mc | ",
      "# filter links by having MC only in source and target",
      "[ .links[] | select(.from_name | IN($mc[])) | select(.to_name | IN($mc[])) ] |",
      "# group results by .from_name",
      "group_by(.from_name) | map({(.[0].from_name):map(.to_name)}) | add"
    ],
    "utterance": "Find all services with criticality equal to MC that depend on other services with criticality equal to MC, outputting each such service as a key and its MC dependencies as an array of names.",
    "expressions": [
      "[ .services[] | select(.criticality == \"MC\") | .name ] as $mc | [ .links[] | select(.from_name | IN($mc[])) | select(.to_name | IN($mc[])) ] | group_by(.from_name) | map({(.[0].from_name): map(.to_name)}) | add"
    ],
    "data": [
      {
        "input": {
          "services": [
            {
              "name": "B1",
              "criticality": "BC"
            },
            {
              "name": "B2",
              "criticality": "BC"
            },
            {
              "name": "M1",
              "criticality": "MC"
            },
            {
              "name": "M2",
              "criticality": "MC"
            },
            {
              "name": "M3",
              "criticality": "MC"
            },
            {
              "name": "M4",
              "criticality": "MC"
            }
          ],
          "links": [
            {
              "from_name": "B1",
              "to_name": "M1"
            },
            {
              "from_name": "M1",
              "to_name": "M2"
            },
            {
              "from_name": "M2",
              "to_name": "B2"
            },
            {
              "from_name": "M1",
              "to_name": "M3"
            },
            {
              "from_name": "M4",
              "to_name": "M2"
            }
          ]
        },
        "output": {
          "M1": [
            "M2",
            "M3"
          ],
          "M4": [
            "M2"
          ]
        }
      }
    ],
    "identifier": 77500958
  },
  {
    "context": [
      "I hope to merge this folder as\r\n{\r\n   \"folder1\": {\r\n      \"file1.json\": {\"a\":1,\"b\":[1,2]},\r\n      \"file2.json\": {\"a\":12,\"c\":[]}\r\n   },\r\n   \"folder2\": {\r\n      \"file1.json\": {\"ta\":1,\"tb\":[1,2]},\r\n      \"file2.json\": {\"ta\":12,\"tc\":1},\r\n      \"folder21\" : {\r\n        \"file3.json\": {\"test\":true}\r\n      }\r\n   }\r\n}",
      "jq -n 'reduce inputs as $s ({}; setpath(input_filename|split(\"/\");$s) )' */**/*.json",
      "My test output :\r\n{\r\n  \"folder1\": {\r\n    \"file1.json\": {\r\n      \"a\": 1,\r\n      \"b\": [\r\n        1,\r\n        2\r\n      ]\r\n    }\r\n  },\r\n  \"folder2\": {\r\n    \"folder21\": {\r\n      \"file3.json\": {\r\n        \"test\": true\r\n      }\r\n    }\r\n  }\r\n}"
    ],
    "utterance": "Merge a directory tree of files into a single object, using folder and file names as nested keys reflecting the original structure.",
    "expressions": [
      "jq -n 'reduce inputs as $s ({}; setpath(input_filename|split(\"/\");$s) )' */**/*.json"
    ],
    "data": [
      {
        "input": {
          "folder1": {
            "file1.json": {
              "a": 1,
              "b": [
                1,
                2
              ]
            },
            "file2.json": {
              "a": 12,
              "c": []
            }
          },
          "folder2": {
            "file1.json": {
              "ta": 1,
              "tb": [
                1,
                2
              ]
            },
            "file2.json": {
              "ta": 12,
              "tc": 1
            },
            "folder21": {
              "file3.json": {
                "test": true
              }
            }
          }
        },
        "output": {
          "folder1": {
            "file1.json": {
              "a": 1,
              "b": [
                1,
                2
              ]
            },
            "file2.json": {
              "a": 12,
              "c": []
            }
          },
          "folder2": {
            "file1.json": {
              "ta": 1,
              "tb": [
                1,
                2
              ]
            },
            "file2.json": {
              "ta": 12,
              "tc": 1
            },
            "folder21": {
              "file3.json": {
                "test": true
              }
            }
          }
        }
      }
    ],
    "identifier": 77504229
  },
  {
    "context": [
      "I try to convert all key environment to lowercase and replacing '_' by '-' like following:\n```json\n        \"watchtower-cleanup\": \"true\",\n        \"watchtower-debug\": \"false\",\n         ....\n```",
      "Please note that I want to keep the environment variable value to original case.",
      "Use [update-assignement `|=`](https://jqlang.github.io/jq/manual/#update-assignment) on all environment objects:\n\n```sh\ndocker-compose config --format json | jq '\n.services[].environment |= with_entries(\n  .key |= (ascii_downcase | gsub(\"_\";\"-\"))\n)\n'\n```",
      "To handle services without the `environment` key, [suppress errors with `?`](https://jqlang.github.io/jq/manual/#error-suppression-optional-operator):\n\n```\n.services[].environment |= with_entries(\n  .key |= (ascii_downcase | gsub(\"_\";\"-\"))\n)?\n```",
      "Output:\n\n```json\n{\n  \"name\": \"qualimarc-docker-prod\",\n  \"services\": {\n    \"qualimarc-watchtower\": {\n      ...\n      \"environment\": {\n        \"watchtower-cleanup\": \"true\",\n        \"watchtower-debug\": \"false\",\n        \"watchtower-notifications\": \"slack\",\n        ...\n"
    ],
    "utterance": "Transform all keys in the 'environment' objects of each service to lowercase and replace underscores '_' with dashes '-', keeping the values unchanged.",
    "expressions": [
      ".services[].environment |= with_entries(.key |= (ascii_downcase | gsub(\"_\";\"-\")))",
      ".services[].environment |= with_entries(.key |= (ascii_downcase | gsub(\"_\";\"-\")))?"
    ],
    "data": [
      {
        "input": {
          "name": "qualimarc-docker-prod",
          "services": {
            "qualimarc-watchtower": {
              "cpus": 0.5,
              "command": null,
              "container_name": "qualimarc-watchtower",
              "entrypoint": null,
              "environment": {
                "WATCHTOWER_CLEANUP": "true",
                "WATCHTOWER_DEBUG": "false",
                "WATCHTOWER_NOTIFICATIONS": "slack",
                "WATCHTOWER_NOTIFICATION_SLACK_CHANNEL": "#notif-qualimarc",
                "WATCHTOWER_NOTIFICATION_SLACK_HOOK_URL": "https://hooks.slack.com/services/TCRRETSQ4/B03QN4MTU3B/",
                "WATCHTOWER_NOTIFICATION_SLACK_IDENTIFIER": "diplotaxis1-prod qualimarc-watchtower",
                "WATCHTOWER_NO_STARTUP_MESSAGE": "true",
                "WATCHTOWER_POLL_INTERVAL": "60",
                "WATCHTOWER_RUN_ONCE": "false",
                "WATCHTOWER_SCOPE": "qualimarc-watchtower-scope",
                "WATCHTOWER_WARN_ON_HEAD_FAILURE": "never"
              },
              "image": "containrrr/watchtower:1.4.0",
              "labels": {
                "com.centurylinklabs.watchtower.scope": "qualimarc-watchtower-scope"
              },
              "mem_limit": "3221225472",
              "memswap_limit": "3221225472",
              "networks": {
                "default": null
              },
              "restart": "unless-stopped",
              "volumes": [
                {
                  "type": "bind",
                  "source": "/var/run/docker.sock",
                  "target": "/var/run/docker.sock",
                  "bind": {
                    "create_host_path": true
                  }
                }
              ]
            }
          }
        },
        "output": {
          "name": "qualimarc-docker-prod",
          "services": {
            "qualimarc-watchtower": {
              "cpus": 0.5,
              "command": null,
              "container_name": "qualimarc-watchtower",
              "entrypoint": null,
              "environment": {
                "watchtower-cleanup": "true",
                "watchtower-debug": "false",
                "watchtower-notifications": "slack",
                "watchtower-notification-slack-channel": "#notif-qualimarc",
                "watchtower-notification-slack-hook-url": "https://hooks.slack.com/services/TCRRETSQ4/B03QN4MTU3B/",
                "watchtower-notification-slack-identifier": "diplotaxis1-prod qualimarc-watchtower",
                "watchtower-no-startup-message": "true",
                "watchtower-poll-interval": "60",
                "watchtower-run-once": "false",
                "watchtower-scope": "qualimarc-watchtower-scope",
                "watchtower-warn-on-head-failure": "never"
              },
              "image": "containrrr/watchtower:1.4.0",
              "labels": {
                "com.centurylinklabs.watchtower.scope": "qualimarc-watchtower-scope"
              },
              "mem_limit": "3221225472",
              "memswap_limit": "3221225472",
              "networks": {
                "default": null
              },
              "restart": "unless-stopped",
              "volumes": [
                {
                  "type": "bind",
                  "source": "/var/run/docker.sock",
                  "target": "/var/run/docker.sock",
                  "bind": {
                    "create_host_path": true
                  }
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 77508932
  }
]