[
  {
    "context": [
      "version=$(jq -r '.version' package.json)",
      "echo version",
      "I couldn't get the '1.0.0', I got `version` printed on my terminal, any clue why?",
      "you are missing a dollar sign on this line:\r\n\r\n    echo $version"
    ],
    "utterance": "Extract the value of the 'version' field with the value '1.0.0' from a file.",
    "expressions": [
      ".version",
      "-r .version"
    ],
    "data": [
      {
        "input": {
          "version": "1.0.0"
        },
        "output": "1.0.0"
      }
    ],
    "identifier": 75082410
  },
  {
    "context": [
      "How can I extract two strings, from the same value/key ?",
      "You're looking for something like this:",
      "jq -r '.[].instance | split(\"/\") | \"\\(.[-1]) \\(.[-3])\"'"
    ],
    "utterance": "Extract both the instance name (last path segment) and the zone name (third from last path segment) from a path-like string in the 'instance' key.",
    "expressions": [
      ".[].instance | split(\"/\") | \"\\(.[-1]) \\(.[-3])\""
    ],
    "data": [
      {
        "input": "https://www.googleapis.com/compute/v1/projects/test-project-1/zones/europe-west1-b/instances/test-instance-1",
        "output": "test-instance-1 europe-west1-b"
      }
    ],
    "identifier": 75081092
  },
  {
    "context": [
      "How to get the value of filecode in",
      "\"{\"msg\": \"OK\", \"status\": 200, \"files\": [ { \"filecode\":\"am9kb3tw6hv1\", \"filename\": \"video.mp4\", \"status\": \"OK\" } ]}\"",
      "The printed output will be",
      "am9kb3tw6hv1",
      "jq '.files[0].filecode' test.json",
      "If you don't want the quotes, then use -r",
      "jq -r '.files[0].filecode' test.json",
      "output",
      "am9kb3tw6hv1"
    ],
    "utterance": "Extract the value of filecode from the first object in the files array where the expected result is am9kb3tw6hv1.",
    "expressions": [
      ".files[0].filecode"
    ],
    "data": [
      {
        "input": {
          "msg": "OK",
          "status": 200,
          "files": [
            {
              "filecode": "am9kb3tw6hv1",
              "filename": "video.mp4",
              "status": "OK"
            }
          ]
        },
        "output": "am9kb3tw6hv1"
      }
    ],
    "identifier": 75103172
  },
  {
    "context": [
      "export APEX_CLASSES=$(xq . < package/package.xml | jq '.Package.types | [.] | flatten | map(select(.name==\"ApexClass\")) | .[] | .members | [.] | flatten | map(select(. | index(\"*\") | not)) | unique | join(\",\")' -r)",
      "This is package.xml",
      "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Package xmlns=\"http://soap.sforce.com/2006/04/metadata\">\n    <types>\n        <members>AccountHelper</members>\n        <members>BoatHelper</members>\n        <members>CaseHelper</members>\n        <name>ApexClass</name>\n    </types>\n    <version>57.0</version>\n</Package>"
    ],
    "utterance": "Extract all member names from types where the name equals ApexClass, excluding any members containing an asterisk, and join them into a comma-separated string.",
    "expressions": [
      ".Package.types | [.] | flatten | map(select(.name==\"ApexClass\")) | .[] | .members | [.] | flatten | map(select(. | index(\"*\") | not)) | unique | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "Package": {
            "types": {
              "members": [
                "AccountHelper",
                "BoatHelper",
                "CaseHelper"
              ],
              "name": "ApexClass"
            },
            "version": "57.0"
          }
        },
        "output": "AccountHelper,BoatHelper,CaseHelper"
      }
    ],
    "identifier": 75110653
  },
  {
    "context": [
      "I am basically selecting each value from `name` property of each element in the json array",
      "cat json | jq '.contestants[].name' | tr '\\n' ' '",
      "this results in this basic format which should have worked as an array declaration",
      "I also went back and found out that the issue seems to be somewhere at the level of the array declaration.",
      "You could `declare` the Bash array using the `-a` option, and have jq [escape](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) its output using the `@sh` builtin:",
      "declare -a array=\"($(jq -r '.contestants[].name | @sh' json))\""
    ],
    "utterance": "Extract each value from the 'name' property of every object in the 'contestants' array, properly escaping for use as Bash array elements including those with spaces.",
    "expressions": [
      ".contestants[].name | @sh"
    ],
    "data": [
      {
        "input": {
          "start": 1689652086,
          "finish": 1679652100,
          "contestants": [
            {
              "name": "Joan-Juan Frank",
              "comment": "I reek of havoc."
            },
            {
              "name": "Kimi-Kinder Karten",
              "output": "I love chocolate."
            },
            {
              "name": "Peter-Parker Plays Piano",
              "output": "And I am tired of it"
            }
          ]
        },
        "output": [
          "'Joan-Juan Frank'",
          "'Kimi-Kinder Karten'",
          "'Peter-Parker Plays Piano'"
        ]
      }
    ],
    "identifier": 75088330
  },
  {
    "context": [
      "one file possessing the `certificate` and `issuing_ca` attributes, the other file containing the `private_key`.",
      "| tee >( jq -r '.data.certificate, .data.issuing_ca' > test.cert.pem) >(jq -r '.data.private_key' > test.key.pem) >/dev/null",
      "| jq -r '.data as $f | ($f.private_key | stderr) | ($f.certificate, $f.issuing_ca)' > test.cert.pem 2> test.key.pem",
      "jq -rc '\n .data\n | \"test.cert.pem\",\n      \"\\t\\(.certificate)\",\n      \"\\t\\(.issuing_ca)\", \n   \"test.key.pem\",\n      \"\\t\\(.private_key)\"\n' | awk -F\\t 'NF == 1 {fn=$1; next} {print $2 > fn}'"
    ],
    "utterance": "Separate the attributes so that certificate and issuing_ca are output together to one file, and private_key is output to a different file.",
    "expressions": [
      "jq -r '.data.certificate, .data.issuing_ca'",
      "jq -r '.data.private_key'",
      "jq -r '.data as $f | ($f.private_key | stderr) | ($f.certificate, $f.issuing_ca)'",
      "jq -rc '\n .data\n | \"test.cert.pem\",\n      \"\\t\\(.certificate)\",\n      \"\\t\\(.issuing_ca)\", \n   \"test.key.pem\",\n      \"\\t\\(.private_key)\"\n'"
    ],
    "data": [
      {
        "input": {
          "data": {
            "certificate": "foo",
            "issuing_ca": "bar",
            "private_key": "zoo"
          }
        },
        "output": {
          "test.cert.pem": "foo\nbar",
          "test.key.pem": "zoo"
        }
      }
    ],
    "identifier": 75098633
  },
  {
    "context": [
      "The JSON file in question is quite large (~1.5GB) but has some metadata at a known location (.meta.view.approvals) near the beginning.",
      "How can jq or gojq be used to extract the object at that location without having to load the whole file into memory, and without having to wait for the processing of the whole file to stop after the item of interest has been extracted?",
      "Use jq's (or gojq's) streaming parser in conjunction with `first/1` as shown below.",
      "`/usr/bin/time -lp jq -n --stream 'first(fromstream(3|truncate_stream(inputs| select(.[0][0:3] == [\"meta\",\"view\", \"approvals\"]) )))' rows.json`",
      "/usr/bin/time -lp jq .meta.view.approvals rows.json"
    ],
    "utterance": "Extract the object at .meta.view.approvals from a large file using a streaming method that stops as soon as this fragment is found to minimize memory and CPU usage.",
    "expressions": [
      "jq -n --stream 'first(fromstream(3|truncate_stream(inputs| select(.[0][0:3] == [\"meta\",\"view\", \"approvals\"]) )))' rows.json",
      "gojq -n --stream 'first(fromstream(3|truncate_stream(inputs| select(.[0][0:3] == [\"meta\",\"view\", \"approvals\"]) )))' rows.json"
    ],
    "identifier": 75116554
  },
  {
    "context": [
      "I want to specify in my jq command which fields to retreive, i.e. only \"datum\" and \"prijsTI\". But on another moment this selection will be different.",
      "I already tried using arguments, but this did not work :-(",
      "cat data.json |jq -r '.data[]|[.datum, .prijsTI]|@csv'",
      "jq -r '.data[] | [.[$ARGS.positional[]]] | @csv' data.json --args datum prijsTI",
      "\"2023-01-11 00:00:00\",\"0.160970\"",
      "\"2023-01-11 01:00:00\",\"0.154920\""
    ],
    "utterance": "Retrieve specified fields (such as \"datum\" and \"prijsTI\") for each element in the 'data' array, where the fields are provided as positional arguments to the command.",
    "expressions": [
      ".data[] | [.[$ARGS.positional[]]] | @csv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "datum": "2023-01-11 00:00:00",
              "prijs": "0.005000",
              "prijsZP": "0.161550",
              "prijsEE": "0.181484",
              "prijsTI": "0.160970"
            },
            {
              "datum": "2023-01-11 01:00:00",
              "prijs": "0.000000",
              "prijsZP": "0.155500",
              "prijsEE": "0.175434",
              "prijsTI": "0.154920"
            }
          ]
        },
        "output": [
          "\"2023-01-11 00:00:00\",\"0.160970\"",
          "\"2023-01-11 01:00:00\",\"0.154920\""
        ]
      }
    ],
    "identifier": 75115127
  },
  {
    "context": [
      "However:\n\n```\n$ jq '.system.%cpu' test.json\n\njq: error: syntax error, unexpected '%'...",
      "Question: How can I extract the lower two properties from the `system` object?",
      "You must quote it if it contains special characters such as `%`:\n\n* `jq '.system.\"%cpu\"' test.json`\n* or `jq '.system[\"%cpu\"]' test.json`"
    ],
    "utterance": "Extract the value associated with the %cpu key from the system object.",
    "expressions": [
      ".system[\"%cpu\"]",
      ".system.\"%cpu\""
    ],
    "data": [
      {
        "input": {
          "system": {
            "power": 10.5,
            "%mem": 0.5,
            "%cpu": 12.4
          }
        },
        "output": 12.4
      }
    ],
    "identifier": 75123612
  },
  {
    "context": [
      "Can I output the ip and source id only when source id is duplicate it should out put all ip in one array if no duplicate ip can be output with corresponding source id",
      "You should `group_by` to group all the matching `source_id`.",
      "Then you can create the desired output, for example:\n\n```\ngroup_by(.source_id)[] | { ip: map(.ip), source_id: (first.source_id) }\n```",
      "Use the `--slurp` option to combine those objects in to an array:\n```\njq --slurp 'group_by(.source_id)[] | { ip: map(.ip), source_id: (first.source_id) }'\n```",
      "you are trying to group IPs by source id like such:\n\n```\n{\n  \"2e74a68a-2fef-443544-815d-222\": [\n    \"182,555,44.44\"\n  ],\n  \"2e74a68a-2fef-443544-815d-87\": [\n    \"192.134.5.31\",\n    \"172.23.54.4\"\n  ]\n}\n```",
      "group_by(.source_id) | map({(.[0].source_id): map(.ip)}) | add",
      "def group(k): group_by(k) | map({key:first|k, value:.}) | from_entries;\ngroup(.source_id)  | map_values(map(.ip))",
      "def group(k;v): group_by(k) | map({key:first|k, value:map(v)}) | from_entries;\ngroup(.source_id;.ip)"
    ],
    "utterance": "Group objects by source_id so that each source_id is paired with an array of its ip values.",
    "expressions": [
      "group_by(.source_id)[] | { ip: map(.ip), source_id: (first.source_id) }",
      "group_by(.source_id) | map({(.[0].source_id): map(.ip)}) | add",
      "def group(k): group_by(k) | map({key:first|k, value:.}) | from_entries; group(.source_id)  | map_values(map(.ip))",
      "def group(k;v): group_by(k) | map({key:first|k, value:map(v)}) | from_entries; group(.source_id;.ip)"
    ],
    "data": [
      {
        "input": [
          {
            "ip": "192.134.5.31",
            "access_key": "223434354656767",
            "source_id": "2e74a68a-2fef-443544-815d-87"
          },
          {
            "ip": "172.23.54.4",
            "saccess_key": "223434354656767",
            "source_id": "2e74a68a-2fef-443544-815d-87"
          },
          {
            "ip": "182,555,44.44",
            "access_key": "223434354656767",
            "source_id": "2e74a68a-2fef-443544-815d-222"
          }
        ],
        "output": [
          {
            "ip": [
              "192.134.5.31",
              "172.23.54.4"
            ],
            "source_id": "2e74a68a-2fef-443544-815d-87"
          },
          {
            "ip": [
              "182,555,44.44"
            ],
            "source_id": "2e74a68a-2fef-443544-815d-222"
          }
        ]
      },
      {
        "input": [
          {
            "ip": "192.134.5.31",
            "access_key": "223434354656767",
            "source_id": "2e74a68a-2fef-443544-815d-87"
          },
          {
            "ip": "172.23.54.4",
            "saccess_key": "223434354656767",
            "source_id": "2e74a68a-2fef-443544-815d-87"
          },
          {
            "ip": "182,555,44.44",
            "access_key": "223434354656767",
            "source_id": "2e74a68a-2fef-443544-815d-222"
          }
        ],
        "output": {
          "2e74a68a-2fef-443544-815d-222": [
            "182,555,44.44"
          ],
          "2e74a68a-2fef-443544-815d-87": [
            "192.134.5.31",
            "172.23.54.4"
          ]
        }
      }
    ],
    "identifier": 75083362
  },
  {
    "context": [
      "My goal is to add a chunk of text before each element, like this:\n\n[\"example/AppBackend\",\"example/list-folder-action\"]",
      "How could I do this?",
      "jq -c --arg prefix example/ '[0].contents |= map($prefix + .name)'"
    ],
    "utterance": "Add the string 'example/' as a prefix to each directory name in a list while keeping the list structure.",
    "expressions": [
      "[0].contents |= map(\"example/\" + .name)",
      "--arg prefix example/ '[0].contents |= map($prefix + .name)'"
    ],
    "data": [
      {
        "input": [
          {
            "type": "directory",
            "name": ".",
            "contents": [
              {
                "type": "directory",
                "name": "AppBackend",
                "contents": []
              },
              {
                "type": "directory",
                "name": "list-folder-action",
                "contents": []
              }
            ]
          },
          {
            "type": "report",
            "directories": 2
          }
        ],
        "output": [
          {
            "type": "directory",
            "name": ".",
            "contents": [
              "example/AppBackend",
              "example/list-folder-action"
            ]
          },
          {
            "type": "report",
            "directories": 2
          }
        ]
      }
    ],
    "identifier": 75139419
  },
  {
    "context": [
      "Using the input given, I need to join the true \"user\" value from the tweets array with the id in the users array and display the users array object as part of the tweets array",
      "INDEX(.users[]; .id) as $idx | .tweets | map({ tweet, user: $idx[.user|tostring] })",
      "[JOIN(INDEX(.users[]; .id); .tweets[]; .user|tostring; .[0] + { user: .[1] })]",
      ".users as $users\n| .tweets\n| map({ tweet, user: (.user as $user | $users[] | select(.id == $user))})",
      "SAFE_INDEX(.users[]; .id) as $idx \n| .tweets\n| map({ tweet, user: (.user as $user | $idx |lookup($user)) })"
    ],
    "utterance": "For each tweet, replace the user field (an id) with the full user object whose id equals the tweet's user value.",
    "expressions": [
      "INDEX(.users[]; .id) as $idx | .tweets | map({ tweet, user: $idx[.user|tostring] })",
      "[JOIN(INDEX(.users[]; .id); .tweets[]; .user|tostring; .[0] + { user: .[1] })]",
      ".users as $users | .tweets | map({ tweet, user: (.user as $user | $users[] | select(.id == $user))})",
      "SAFE_INDEX(.users[]; .id) as $idx | .tweets | map({ tweet, user: (.user as $user | $idx |lookup($user)) })"
    ],
    "data": [
      {
        "input": {
          "tweets": [
            {
              "tweet": "Hey, i gonna release GPT4 soon",
              "user": 1
            },
            {
              "tweet": "We have launched falcon 10 yesterday, it was awesome, one step closer to Mars",
              "user": 2
            },
            {
              "tweet": "Databar acquires Statista.com, great news coming out",
              "user": 3
            },
            {
              "tweet": "Gpt4 is available",
              "user": 1
            }
          ],
          "users": [
            {
              "id": 1,
              "name": "a"
            },
            {
              "id": 2,
              "name": "b"
            },
            {
              "id": 3,
              "name": "c"
            }
          ]
        },
        "output": [
          {
            "tweet": "Hey, i gonna release GPT4 soon",
            "user": {
              "id": 1,
              "name": "a"
            }
          },
          {
            "tweet": "We have launched falcon 10 yesterday, it was awesome, one step closer to Mars",
            "user": {
              "id": 2,
              "name": "b"
            }
          },
          {
            "tweet": "Databar acquires Statista.com, great news coming out",
            "user": {
              "id": 3,
              "name": "c"
            }
          },
          {
            "tweet": "Gpt4 is available",
            "user": {
              "id": 1,
              "name": "a"
            }
          }
        ]
      }
    ],
    "identifier": 75119625
  },
  {
    "context": [
      "how to select the secondary \"name\" string, or removing the first \"name\" \"All_Internet\" of output",
      "the \"All_Internet\" is fixed string.",
      ".objects[].name | select(. != \"All_Internet\")",
      ".objects[1:][].name"
    ],
    "utterance": "Retrieve all name fields except the one equal to \"All_Internet\".",
    "expressions": [
      ".objects[].name | select(. != \"All_Internet\")"
    ],
    "data": [
      {
        "input": {
          "objects": [
            {
              "uid": "2272dba0-9ffb-49d4-88b7-0a18f38a3cdc",
              "name": "All_Internet"
            },
            {
              "uid": "b83fd31c-3cb3-406e-b46b-816a138e8ea1",
              "name": "Public FTP"
            }
          ]
        },
        "output": "Public FTP"
      }
    ],
    "identifier": 75154728
  },
  {
    "context": [
      "I'd like `minor` to take precedence over `patch` when there are only two version components.",
      "Try grouping `minor` and `patch` together like this:\n```\ncapture(\"^((?<compat_prefix>.*)-)?[Vv]?(?<version>(?<major>\\d+)(\\.(?<minor>\\d+)(\\.(?<patch>\\d+))?)?)(-(?<compat_suffix>.*))?$\")\n```"
    ],
    "utterance": "Extract version components so that when there are two numeric parts, the first is major and the second is minor; patch is only set if a third part exists.",
    "expressions": [
      "capture(\"^((?<compat_prefix>.*)-)?[Vv]?(?<version>(?<major>\\d+)(\\.(?<minor>\\d+)(\\.(?<patch>\\d+))?)?)(-(?<compat_suffix>.*))?$\")"
    ],
    "data": [
      {
        "input": [
          {
            "version": "v1.2.3"
          },
          {
            "version": "v1.2"
          },
          {
            "version": "foo-v1.2"
          },
          {
            "version": "v2.234324"
          },
          {
            "version": "4.5.0"
          },
          {
            "version": "v1.1.0-bar"
          },
          {
            "version": "v2.3-foo"
          },
          {
            "version": "V1"
          },
          {
            "version": "FEE-v1.0.2-fuu"
          }
        ],
        "output": [
          {
            "compat_prefix": null,
            "version": "1.2.3",
            "major": "1",
            "minor": "2",
            "patch": "3",
            "compat_suffix": null
          },
          {
            "compat_prefix": null,
            "version": "1.2",
            "major": "1",
            "minor": "2",
            "patch": null,
            "compat_suffix": null
          },
          {
            "compat_prefix": "foo",
            "version": "1.2",
            "major": "1",
            "minor": "2",
            "patch": null,
            "compat_suffix": null
          }
        ]
      }
    ],
    "identifier": 75131082
  },
  {
    "context": [
      "How can I get the id whose attributes value is 0fda6bb8-4fc9-4463-9d26-af2d503cb19c ?",
      "You could `select` on `.attributes[]` and display the `id` field only:",
      "jq '.[] | select(.attributes[] == \"0fda6bb8-4fc9-4463-9d26-af2d503cb19c\").id'",
      "With the input given, you'd get the same result with the more specific:",
      "jq '.[] | select(.attributes[\"1be40893-5dad-4b37-b70d-b830c4bd273f\"] == \"0fda6bb8-4fc9-4463-9d26-af2d503cb19c\").id'"
    ],
    "utterance": "Find the id of the object whose attributes contains the value 0fda6bb8-4fc9-4463-9d26-af2d503cb19c.",
    "expressions": [
      ".[] | select(.attributes[] == \"0fda6bb8-4fc9-4463-9d26-af2d503cb19c\").id",
      ".[] | select(.attributes[\"1be40893-5dad-4b37-b70d-b830c4bd273f\"] == \"0fda6bb8-4fc9-4463-9d26-af2d503cb19c\").id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "c3b1516d-5b2c-4838-b5eb-77d94d634832",
            "versionId": "c3b1516d-5b2c-4838-b5eb-77d94d634832",
            "name": "\u0432\u044b\u043f\u0438\u0441\u043a\u0430 \u043c\u0430\u043b\u0435\u043d\u044c\u043a\u0430\u044f \u0437\u0430\u044f\u0432\u043a\u0430 \u0441 \u043b\u0435\u043d\u0434\u0438\u043d\u0433\u0430 \u0418\u0411",
            "entityTypeName": "TestCases",
            "projectId": "6dfe2ace-dd40-4e36-b66e-4a655a855a2f",
            "sectionId": "bf7fbece-4fdf-466a-b041-2d830debc844",
            "isAutomated": false,
            "globalId": 264511,
            "duration": 300,
            "attributes": {
              "1be40893-5dad-4b37-b70d-b830c4bd273f": "0fda6bb8-4fc9-4463-9d26-af2d503cb19c",
              "f4b408ae-5418-4a8d-99d9-4a67cb34870b": "fa000fb2-375d-4eb5-901c-fb5df30785ad"
            },
            "createdById": "995b1f08-cc65-409c-aa1c-a16c82dabf1d",
            "modifiedById": "995b1f08-cc65-409c-aa1c-a16c82dabf1d",
            "createdDate": "2022-10-12T00:22:43.544Z",
            "modifiedDate": "2022-10-12T00:22:43.544Z",
            "state": "NeedsWork",
            "priority": "Medium",
            "isDeleted": false,
            "tagNames": [
              "master"
            ],
            "iterations": []
          },
          {
            "id": "ec423701-f2a8-4667-8459-939a6e079941",
            "versionId": "0dfe176e-b172-47ae-8049-e6974086d497",
            "name": "[iOS] \u0421\u0411\u041f\u044d\u0439 \u0444\u0438\u0447\u0430\u0442\u043e\u0433\u043b\u044b. Fts.SBPay.Settings \u0432\u044b\u043a\u043b\u044e\u0447\u0435\u043d Fts.C2B.Settings.Subscriptions \u0432\u043a\u043b\u044e\u0447\u0435\u043d",
            "entityTypeName": "TestCases",
            "projectId": "6dfe2ace-dd40-4e36-b66e-4a655a855a2f",
            "sectionId": "8626c9f5-a5aa-4584-bbca-e9cd60369a5e",
            "isAutomated": false,
            "globalId": 402437,
            "duration": 300,
            "attributes": {
              "1be40893-5dad-4b37-b70d-b830c4bd273f": "b52bfc88-9b13-41e1-8b4c-098ebfa673e0",
              "240b7589-9461-44dc-8b13-361132877c50": "cfd99bad-fb3f-43fe-be8a-cb745f2d4c78",
              "6639eb1a-1335-44ec-ba8b-c3c52bff9e79": "ed3bc553-e873-472f-8dc1-7f2720ad457d",
              "9ae36ef5-ca0e-4273-bb39-aedf289a119d": "6687017f-138b-4d75-91bd-c6465f1f5331",
              "b862c3ee-55eb-486f-8125-a7a034d69340": "IBANK5-37207",
              "f4b408ae-5418-4a8d-99d9-4a67cb34870b": "36dc55ac-359c-4312-9b1a-646ad5fd5aa9"
            },
            "createdById": "11a30c8b-73e2-4233-bbf5-7cc41556d3e0",
            "modifiedById": "11a30c8b-73e2-4233-bbf5-7cc41556d3e0",
            "createdDate": "2022-11-01T12:05:56.821Z",
            "modifiedDate": "2022-11-02T14:16:55.246Z",
            "state": "Ready",
            "priority": "Medium",
            "isDeleted": false,
            "tagNames": [],
            "iterations": []
          }
        ],
        "output": "c3b1516d-5b2c-4838-b5eb-77d94d634832"
      }
    ],
    "identifier": 75111251
  },
  {
    "context": [
      "Trying to filter only by the two key(`enabled` and `name like abc`):",
      "You can use a combination of `objects` and `arrays` to select the items to update with `|=`, then `with_entries` to access the `.key` which can be queried with `IN`:",
      "  (.[] | objects, (arrays[] | objects))\n    |= with_entries(select(.key | IN(\"enabled\", \"name\")))"
    ],
    "utterance": "Select only the keys \"enabled\" and \"name\" for every object at all top-level keys, whether the value is an object or an array of objects.",
    "expressions": [
      "(.[] | objects, (arrays[] | objects)) |= with_entries(select(.key | IN(\"enabled\", \"name\")))"
    ],
    "data": [
      {
        "input": {
          "abc": {
            "enabled": true
          },
          "def": {
            "enabled": false
          },
          "ghi": [
            {
              "enabled": false,
              "name": "HELLO",
              "useless": "DO NOT WANT THIS"
            }
          ],
          "jkl": [
            {
              "enabled": true,
              "name": "HI"
            }
          ],
          "mko": {
            "enabled": false,
            "something unwanted": 123
          },
          "pqr": {
            "enabled": true
          }
        },
        "output": {
          "abc": {
            "enabled": true
          },
          "def": {
            "enabled": false
          },
          "ghi": [
            {
              "enabled": false,
              "name": "HELLO"
            }
          ],
          "jkl": [
            {
              "enabled": true,
              "name": "HI"
            }
          ],
          "mko": {
            "enabled": false
          },
          "pqr": {
            "enabled": true
          }
        }
      }
    ],
    "identifier": 75140874
  },
  {
    "context": [
      "I need a utility that\r\n  - read from stdin, split as lines\r\n  - write to stdout json object, {\"cmd\": \"In\", \"lines\": [lines from stdin]}",
      "By default, `jq` reads from `stdin`. The `-R` flag lets you read raw input streamed linewise. Using `[inputs]` in combination with the `-n` flag lets you collect the lines into an array.",
      "\u2026 | jq -Rn '{cmd: \"In\", lines: [inputs]}'"
    ],
    "utterance": "Read each line from standard input and create an object with key 'cmd' equal to 'In' and key 'lines' containing the list of input lines.",
    "expressions": [
      "jq -Rn '{cmd: \"In\", lines: [inputs]}'"
    ],
    "data": [
      {
        "input": "foo\nbar\nbaz\n",
        "output": {
          "cmd": "In",
          "lines": [
            "foo",
            "bar",
            "baz"
          ]
        }
      }
    ],
    "identifier": 75196689
  },
  {
    "context": [
      "I need to write a jq command, which make changes in json file using the csv file, i.e., the final output of the json file should be like following:",
      "[ {\"a\":\"a11\",\"b\":\"b1\"}, {\"a\":\"a22\",\"b\":\"b2\"}, {\"a\":\"a33\",\"b\":\"b3\"}, {\"a\":\"a4\",\"b\":\"b4\"} ]",
      "jq --arg k1 $f1 --arg k2 $f2 '(.[] | select(.b == $k2) | .a) |= $k1' sample.json| sponge sample.json",
      "If your JSON object is like: [ { \"d\": { \"a\":\"a1\", \"c\":\"c1\"}, \"b\": \"b1\" } ] we can update the command to '(.[] | select(.b == $k2) | .d.a) |= $k1'."
    ],
    "utterance": "Update the value of each 'a' key where 'b' matches a value from a CSV file of replacement pairs.",
    "expressions": [
      "jq --arg k1 $f1 --arg k2 $f2 '(.[] | select(.b == $k2) | .a) |= $k1' sample.json",
      "jq --arg k1 $f1 --arg k2 $f2 '(.[] | select(.b == $k2) | .d.a) |= $k1' sample.json"
    ],
    "data": [
      {
        "input": [
          {
            "a": "a1",
            "b": "b1"
          },
          {
            "a": "a2",
            "b": "b2"
          },
          {
            "a": "a3",
            "b": "b3"
          },
          {
            "a": "a4",
            "b": "b4"
          }
        ],
        "output": [
          {
            "a": "a11",
            "b": "b1"
          },
          {
            "a": "a22",
            "b": "b2"
          },
          {
            "a": "a33",
            "b": "b3"
          },
          {
            "a": "a4",
            "b": "b4"
          }
        ]
      }
    ],
    "identifier": 75164791
  },
  {
    "context": [
      "a potentially huge json-lines file with objects of known structure is to be converted to csv with headers.",
      "I mainly don't want to use slurp because it will resort to load the whole file into memory",
      "add a fixed header and use `inputs` together with `-n`/`--null-input` to format the actual content:",
      "jq -n '[\"name\", \"value_a\", \"value_b\"],\n(inputs | [.name?, .value_a?, .value_b?])\n| @csv' input.json"
    ],
    "utterance": "Convert a large jsonlines file with objects containing keys name, value_a, and value_b to CSV with a header row, without loading the entire file into memory.",
    "expressions": [
      "[\"name\", \"value_a\", \"value_b\"], (inputs | [.name?, .value_a?, .value_b?]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "name_0",
            "value_a": "value_a_0",
            "value_b": "val_b_0"
          },
          {
            "name": "name_1",
            "value_a": "value_a_1",
            "value_b": "val_b_1"
          },
          {
            "name": "name_2",
            "value_a": "value_a_2",
            "value_b": "val_b_2"
          },
          {
            "name": "name_3",
            "value_a": "value_a_3",
            "value_b": "val_b_3"
          },
          {
            "name": "name_4",
            "value_a": "value_a_4",
            "value_b": "val_b_4"
          }
        ],
        "output": [
          "\"name\",\"value_a\",\"value_b\"",
          "\"name_0\",\"value_a_0\",\"val_b_0\"",
          "\"name_1\",\"value_a_1\",\"val_b_1\"",
          "\"name_2\",\"value_a_2\",\"val_b_2\"",
          "\"name_3\",\"value_a_3\",\"val_b_3\"",
          "\"name_4\",\"value_a_4\",\"val_b_4\""
        ]
      }
    ],
    "identifier": 75208673
  },
  {
    "context": [
      "I\u2019m trying to add a new field, called `extra` to the `issues` object that is a composite of the `.url` field and the `.number` fields.",
      "So the result should look like this",
      "{\n  \"url\": \"https::/abc/\",\n  \"issues\": {\n    \"1\": {\n      \"number\": 1,\n      \"extra\": \"https::/abc/1\"\n    },\n    \"2\": {\n      \"number\": 2,\n      \"extra\": \"https::/abc/2\"\n    }\n  }",
      ".url as $URL | .issues[] |= . + { \"extra\" : \"\\( $URL )\\( .number )\"  }",
      ".url as $url | .issues[] |= .number as $num | .extra = $url + ($num | tostring)",
      ". as {$url} | .issues[] |= (.extra = $url + \"\\(.number)\")"
    ],
    "utterance": "Add an 'extra' field to each object in 'issues', setting it to the value of 'url' concatenated with the corresponding 'number' property.",
    "expressions": [
      ".url as $URL | .issues[] |= . + { \"extra\" : \"\\($URL)\\(.number)\" }",
      ".url as $url | .issues[] |= .number as $num | .extra = $url + ($num | tostring)",
      ". as {$url} | .issues[] |= (.extra = $url + \"\\(.number)\")"
    ],
    "data": [
      {
        "input": {
          "url": "https::/abc/",
          "issues": {
            "1": {
              "number": 1
            },
            "2": {
              "number": 2
            }
          }
        },
        "output": {
          "url": "https::/abc/",
          "issues": {
            "1": {
              "number": 1,
              "extra": "https::/abc/1"
            },
            "2": {
              "number": 2,
              "extra": "https::/abc/2"
            }
          }
        }
      }
    ],
    "identifier": 75170352
  },
  {
    "context": [
      "And I want to access to `top_facts_mapping's` first key `AWS` and it's first key `ECS`",
      "You could use the `keys_unsorted` builtin, since the underlying object is a dictionary and _not_ a list",
      ".top_facts_mapping | keys_unsorted[0] as $k | .[$k] | .[keys_unsorted[0]]",
      "You could use `to_entries` to turn the object into an array of key-value pairs, then select the first value using `[0].value`\n\n.top_facts_mapping | to_entries[0].value | to_entries[0].value"
    ],
    "utterance": "Access the value at the first key of top_facts_mapping, then the first key within that object.",
    "expressions": [
      ".top_facts_mapping | keys_unsorted[0] as $k | .[$k] | .[keys_unsorted[0]]",
      ".top_facts_mapping | to_entries[0].value | to_entries[0].value"
    ],
    "data": [
      {
        "input": {
          "query": "rest ec",
          "elected_facts_mapping": {
            "AWS": {
              "ECS": {
                "attachments": [
                  "restart_ecs"
                ],
                "text": [
                  "Great!"
                ]
              }
            }
          },
          "top_facts_mapping": {
            "AWS": {
              "ECS": {
                "attachments": [
                  "restart_ecs"
                ],
                "text": [
                  "Great!"
                ]
              },
              "EC2": {
                "attachments": [
                  "create_ec2"
                ],
                "text": [
                  "Awesome"
                ]
              }
            },
            "GitHub": {
              "Pull": {
                "attachments": [
                  "pull_req"
                ],
                "text": [
                  "Be right on it"
                ]
              }
            },
            "testtttt": {
              "test": {
                "attachments": [
                  "hello_world"
                ],
                "text": [
                  "Be right on it"
                ]
              }
            },
            "fgjgh": {
              "fnfgj": {
                "attachments": [
                  "hello_world"
                ],
                "text": [
                  "Be right on it"
                ]
              }
            },
            "tessttertre": {
              "gfdgfdgfd": {
                "attachments": [
                  "hello_world"
                ],
                "text": [
                  "Great!"
                ]
              }
            }
          },
          "elected_facts_with_prefix_text": null
        },
        "output": {
          "attachments": [
            "restart_ecs"
          ],
          "text": [
            "Great!"
          ]
        }
      }
    ],
    "identifier": 75175190
  },
  {
    "context": [
      "Need to remove JSON element using jq tool if at least one key is not \"true\".",
      "But if, as your desired output suggests, you want to remove those items that are entirely `false`, meaning to keep only those where there is at least one value which is `true`, use the `any` aggregator:",
      "jq 'map(select(map(fromjson) | any))'"
    ],
    "utterance": "Filter the array to keep only objects where at least one of the values for the keys \"1\", \"2\", or \"3\" equals \"true\".",
    "expressions": [
      "map(select(map(fromjson) | any))"
    ],
    "data": [
      {
        "input": [
          {
            "1": "false",
            "2": "true",
            "3": "true"
          },
          {
            "1": "false",
            "2": "false",
            "3": "false"
          },
          {
            "1": "true",
            "2": "true",
            "3": "true"
          }
        ],
        "output": [
          {
            "1": "false",
            "2": "true",
            "3": "true"
          },
          {
            "1": "true",
            "2": "true",
            "3": "true"
          }
        ]
      }
    ],
    "identifier": 75212907
  },
  {
    "context": [
      "Or you could use some other text-mangling tool, such as jq:",
      "jq -Rr 'gsub(\"<(?<tag>kref|sub)>\"; \"!\\(.tag)>\") | gsub(\"</(?<tag>kref|sub)>\"; \"!\\(.tag)>\")' |",
      "jq -Rr 'gsub(\"!(?<tag>kref|sub)>\"); \"<\\(.tag)>\") | gsub(\"!/(&lt;tag&gt;kref|sub)&gt;\"; \"&lt;/\\(.tag)&gt;\")'"
    ],
    "utterance": "Replace all <kref> and <sub> tags in the input with placeholders before yq processing, then restore them afterward.",
    "expressions": [
      "jq -Rr 'gsub(\"<(?<tag>kref|sub)>\"; \"!\\(.tag)>\") | gsub(\"</(?<tag>kref|sub)>\"; \"!\\(.tag)>\")'",
      "jq -Rr 'gsub(\"!(?<tag>kref|sub)>\"); \"<\\(.tag)>\") | gsub(\"!/(&lt;tag&gt;kref|sub)&gt;\"; \"&lt;/\\(.tag)&gt;\")'"
    ],
    "identifier": 75161483
  },
  {
    "context": [
      "I want csv file as:\r\n\r\n```\r\nname  id  age  number\r\nalpha  1  23    xyz\r\n```",
      "jq -r '[\"name\", \"id\", \"age\", \"number\"],\n(.tables[].rows | [.[0,1], (.[2] | fromjson | .age, .number)])\n| @csv' input.json",
      "#### Filter:\r\n```sh\r\njq -r '\n  .tables[] | [.columns, .rows[]] | transpose | map(\n    if first.type == \"string\" then first |= .name\n    elif first.type == \"dynamic\" then\n      .[1:] | map(fromjson)\n      | (map(keys[]) | unique) as $keys\n      | [$keys, (.[] | [.[$keys[]]])] | transpose[]\n    else empty end\n  )\n  | transpose[] | @csv\n'"
    ],
    "utterance": "Convert nested structure with rows containing a string-encoded object as the last column into a CSV with all top-level and dynamically found sub-fields as columns.",
    "expressions": [
      "[\"name\", \"id\", \"age\", \"number\"],\n(.tables[].rows | [.[0,1], (.[2] | fromjson | .age, .number)])\n| @csv",
      ".tables[] | [.columns, .rows[]] | transpose | map(\n  if first.type == \"string\" then first |= .name\n  elif first.type == \"dynamic\" then\n    .[1:] | map(fromjson)\n    | (map(keys[]) | unique) as $keys\n    | [$keys, (.[] | [.[$keys[]]])] | transpose[]\n  else empty end\n) | transpose[] | @csv"
    ],
    "data": [
      {
        "input": {
          "tables": [
            {
              "name": "PrimaryResult",
              "columns": [
                {
                  "name": "name",
                  "type": "string"
                },
                {
                  "name": "id",
                  "type": "string"
                },
                {
                  "name": "custom",
                  "type": "dynamic"
                }
              ],
              "rows": [
                [
                  "Alpha",
                  "1",
                  "{\"age\":\"23\",\"number\":\"123\"}"
                ],
                [
                  "Beta",
                  "2",
                  "{\"age\":\"45\",\"word\":\"xyz\"}"
                ]
              ]
            }
          ]
        },
        "output": [
          "\"name\",\"id\",\"age\",\"number\",\"word\"",
          "\"Alpha\",\"1\",\"23\",\"123\",",
          "\"Beta\",\"2\",\"45\",,\"xyz\""
        ]
      }
    ],
    "identifier": 75210490
  },
  {
    "context": [
      "# print only specific fields from the response\n$ gh api repos/{owner}/{repo}/issues --jq '.[].title'",
      "GitHUb CLI (gh) can use the '-q' or '--jq' argument followed by a query string to _select values from the response_ and e.g. display only certain fields.",
      "The response is filtered on the client. You can verify yourself by taking a look at [the source code](https://github.com/cli/cli/blob/trunk/pkg/cmd/api/api.go#L390):",
      "if opts.FilterOutput != \"\" && serverError == \"\" {\n\t// TODO: reuse parsed query across pagination invocations\n\terr = jq.Evaluate(responseBody, bodyWriter, opts.FilterOutput)\n\tif err != nil {\n\t\treturn\n\t}\n\t}"
    ],
    "utterance": "Display only the title fields of each issue from the API response for repository issues.",
    "expressions": [
      ".[].title"
    ],
    "identifier": 75243413
  },
  {
    "context": [
      "I want to get all the keys using `jq` as a compressed response (using `jq -c \"keys\"`).",
      "How can I get all the keys of this JSON without the key \"key_to_filter\"?",
      "In other words, I need [\"a_key\", \"c_key\"]",
      "You could just subtract that one from the array of keys:\n```sh\njq -c 'keys - [\"key_to_filter\"]'\n```",
      "you could use a `map` to `select` what you want:\n```sh\njq -c 'keys | map(select(. != \"key_to_filter\"))'\n```",
      "you could also first `del`ete the item in question, and just then get all keys:\n```sh\njq -c 'del(.key_to_filter) | keys'\n```",
      "Output:\n```json\n[\"a_key\",\"c_key\"]\n```"
    ],
    "utterance": "Return all top-level keys except for \"key_to_filter\".",
    "expressions": [
      "keys - [\"key_to_filter\"]",
      "keys | map(select(. != \"key_to_filter\"))",
      "del(.key_to_filter) | keys"
    ],
    "data": [
      {
        "input": {
          "a_key": "A",
          "key_to_filter": "B",
          "c_key": "C"
        },
        "output": [
          "a_key",
          "c_key"
        ]
      }
    ],
    "identifier": 75230039
  },
  {
    "context": [
      "Data:\n```\n[\n  {\n    \"id\": \"1\",\n    \"userId\": \"fa51531d\"\n    }\n    ,\n    {\n    \"id\": \"2\",\n    \"userId\": \"a167869a\"\n  }\n]\n```",
      "Data above should be transformed to:\n```\n{\n  \"1\": {\n    \"userId\": \"fa51531d\",\n    \"id\": \"1\"\n  },\n  \"2\": {\n    \"userId\": \"a167869a\",\n    \"id\": \"2\"\n  },\n}\n```",
      "jq -n --stream 'fromstream(inputs) | INDEX(.id)'"
    ],
    "utterance": "Convert an array of objects to an object mapping each object's 'id' value to the object itself, using stream mode for large input.",
    "expressions": [
      "jq -n --stream 'fromstream(inputs) | INDEX(.id)'"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "userId": "fa51531d"
          },
          {
            "id": "2",
            "userId": "a167869a"
          }
        ],
        "output": {
          "1": {
            "id": "1",
            "userId": "fa51531d"
          },
          "2": {
            "id": "2",
            "userId": "a167869a"
          }
        }
      }
    ],
    "identifier": 75223364
  },
  {
    "context": [
      "I would like to get twice a one-line list of values, so that I could export each line to a variable and proceed it eventually:\n\n    images=[img1, img2, img3]\n    tags=[2.0.1, 1.4.0, 1.2.5]\n",
      "jq -r '.definition.services | map(.image.name)' input.json",
      "jq -r '\n  .definition.services\n  | \"images=[\\(map(.image.name) | join(\",\"))]\", \n    \"tags=[\\(map(.image.tag) | join(\",\"))]\"\n' input.json",
      "jq -r '\n  .definition.services\n  | \"images=\\(map(.image.name))\", \n    \"tags=\\(map(.image.tag))\"\n' input.json",
      "Output:\n\nimages=[\"img1\",\"img2\",\"img3\"]\ntags=[\"2.0.1\",\"1.4.0\",\"1.2.5\"]"
    ],
    "utterance": "Produce two one-line variable assignments: images contains all image names and tags contains all image tags from the services array, each as a bracketed one-line list.",
    "expressions": [
      ".definition.services | map(.image.name)",
      ".definition.services | map(.image.tag)",
      ".definition.services | \"images=[\\(map(.image.name) | join(\",\"))]\", \"tags=[\\(map(.image.tag) | join(\",\"))]\"",
      ".definition.services | \"images=\\(map(.image.name))\", \"tags=\\(map(.image.tag))\""
    ],
    "data": [
      {
        "input": {
          "definition": {
            "services": [
              {
                "image": {
                  "name": "img1",
                  "tag": "2.0.1"
                }
              },
              {
                "image": {
                  "name": "img2",
                  "tag": "1.4.0"
                }
              },
              {
                "image": {
                  "name": "img3",
                  "tag": "1.2.5"
                }
              }
            ]
          }
        },
        "output": [
          "images=[\"img1\",\"img2\",\"img3\"]",
          "tags=[\"2.0.1\",\"1.4.0\",\"1.2.5\"]"
        ]
      }
    ],
    "identifier": 75214867
  },
  {
    "context": [
      "I would like to delete from the Category[] array those element whose key starts with or contains \"Other\".",
      "If all the objects in your array only contain a single property:",
      ".Category |= map(select(keys_unsorted[0] | contains(\"Other\") | not))",
      "If you want to delete objects of which any property's key starts with \"Other\":",
      ".Category |= map(select(any(keys_unsorted[]; contains(\"Other\")) | not))",
      "It's also possible to use the `del` filter:",
      "del(.Category[] | select(keys_unsorted[0] | contains(\"Other\")))",
      "del(.Category[] | select(any(keys_unsorted[]; contains(\"Other\"))))"
    ],
    "utterance": "Remove all elements from the Category array where any key contains the substring \"Other\".",
    "expressions": [
      ".Category |= map(select(any(keys_unsorted[]; contains(\"Other\")) | not))",
      "del(.Category[] | select(any(keys_unsorted[]; contains(\"Other\"))))"
    ],
    "data": [
      {
        "input": {
          "Category": [
            {
              "SomeKey_1": {
                "Property1": 1,
                "Property2": false
              }
            },
            {
              "SomeKey_2": {
                "Property1": 2,
                "Property2": true
              }
            },
            {
              "OtherKey_1": {
                "Property1": 3,
                "Property2": false
              }
            },
            {
              "OtherKey_2": {
                "Property1": 4,
                "Property2": false
              }
            }
          ]
        },
        "output": {
          "Category": [
            {
              "SomeKey_1": {
                "Property1": 1,
                "Property2": false
              }
            },
            {
              "SomeKey_2": {
                "Property1": 2,
                "Property2": true
              }
            }
          ]
        }
      }
    ],
    "identifier": 75232983
  },
  {
    "context": [
      "jq -r '.fields.\"System.Title\"' <<< \"$jsonWithEscapedCharacters\"",
      "The \"title\" with double quotes"
    ],
    "utterance": "Extract the value of the field System.Title, including double quotes, from the data where fields[\"System.Title\"] is 'The \\\"title\\\" with double quotes'.",
    "expressions": [
      ".fields[\"System.Title\"]",
      ".fields.\"System.Title\""
    ],
    "data": [
      {
        "input": {
          "fields": {
            "System.AreaPath": "Here\\double-backslah",
            "System.IterationPath": "Ahother\\Double-backslash",
            "System.Title": "The \"title\" with double quotes"
          }
        },
        "output": "The \"title\" with double quotes"
      }
    ],
    "identifier": 75255995
  },
  {
    "context": [
      "I have two json files",
      "and I get just two Items objects, but I want to have one Items object and all item* merged like this",
      "I'm trying to merge them using jq",
      "Try `add`ing the `--slurp`ed array:",
      "jq -s '{Items: {objects: map(.outputs) | add}}' 1.json 2.json",
      "Another approach could be using `reduce` with `inputs` and the `-n` flag:",
      "jq -n 'reduce inputs.outputs as $i ({}; .Items.objects += $i)' 1.json 2.json",
      "Output:",
      "{\n  \"Items\": {\n    \"objects\": {\n      \"item1\": {\n        \"name\": \"name1\",\n        \"email\": \"email1\"\n      },\n      \"item2\": {\n        \"name\": \"name2\",\n        \"email\": \"email2\"\n      }\n    }\n  }\n}"
    ],
    "utterance": "Merge two files so that the result is an object with an 'Items.objects' key containing all keys from the input 'outputs' objects merged.",
    "expressions": [
      "jq -s '{Items: {objects: map(.outputs) | add}}' 1.json 2.json",
      "jq -n 'reduce inputs.outputs as $i ({}; .Items.objects += $i)' 1.json 2.json"
    ],
    "data": [
      {
        "input": {
          "file1": {
            "outputs": {
              "item1": {
                "name": "name1",
                "email": "email1"
              }
            }
          },
          "file2": {
            "outputs": {
              "item2": {
                "name": "name2",
                "email": "email2"
              }
            }
          }
        },
        "output": {
          "Items": {
            "objects": {
              "item1": {
                "name": "name1",
                "email": "email1"
              },
              "item2": {
                "name": "name2",
                "email": "email2"
              }
            }
          }
        }
      }
    ],
    "identifier": 75253182
  },
  {
    "context": [
      "I want to filter this array by all objects that have keys `location.is_shop` and `location.has_parking_space`. I then want to return the length of this filtered array.",
      "Function `map` is what you need :",
      "jq '.locations | map(select(has(\"is_shop\") and has(\"has_parking_space\"))) | length' my_locations.json",
      "If all you want is the number of matching objects, you could efficiently just iterate over the original array, and count on a match (which avoids creating another array that is only used to extract its length).",
      "reduce .locations[] as $loc (0;\n  if all($loc; has(\"is_shop\", \"has_parking_space\")) then . + 1 end\n)"
    ],
    "utterance": "Count the number of objects in the locations array that have both is_shop and has_parking_space keys.",
    "expressions": [
      ".locations | map(select(has(\"is_shop\") and has(\"has_parking_space\"))) | length",
      "reduce .locations[] as $loc (0; if all($loc; has(\"is_shop\", \"has_parking_space\")) then . + 1 else . end)"
    ],
    "identifier": 75261408
  },
  {
    "context": [
      "I now would like to get a one-line list of values:",
      "[img1:2.0.1, img2:1.4.0, img3:1.2. to store eventually in a COMPONENT_IMAGES variable.",
      "I am looking to get",
      "COMPONENT_IMAGES=\"img1:2.0.1, img2:1.4.0, img3:1.2.5\"",
      "Here, we descend to `.image`, and concatenate the value of `.name`, a literal colon `\":\"`, and the value of `.tag`. The mapped array can then be `join`ed with a glue string `\", \"`.",
      "jq -r '\n  .definition.services\n  | \"COMPONENT_IMAGES=\\\"\" + (map(.image | .name + \":\" + .tag) | join(\", \")) + \"\\\"\"\n'",
      "jq -r '\n  .definition.services\n  | \"COMPONENT_IMAGES=\\\"\\(map(.image | \"\\(.name):\\(.tag)\") | join(\", \"))\\\"\"\n' "
    ],
    "utterance": "Produce a single line assignment COMPONENT_IMAGES=\"img1:2.0.1, img2:1.4.0, img3:1.2.5\" by combining each service's image name and tag with a colon and separating items by commas.",
    "expressions": [
      ".definition.services | \"COMPONENT_IMAGES=\\\"\" + (map(.image | .name + \":\" + .tag) | join(\", \")) + \"\\\"\"",
      ".definition.services | \"COMPONENT_IMAGES=\\\"\\(map(.image | \"\\(.name):\\(.tag)\") | join(\", \"))\\\"\""
    ],
    "data": [
      {
        "input": {
          "definition": {
            "services": [
              {
                "image": {
                  "name": "img1",
                  "tag": "2.0.1"
                }
              },
              {
                "image": {
                  "name": "img2",
                  "tag": "1.4.0"
                }
              },
              {
                "image": {
                  "name": "img3",
                  "tag": "1.2.5"
                }
              }
            ]
          }
        },
        "output": "COMPONENT_IMAGES=\"img1:2.0.1, img2:1.4.0, img3:1.2.5\""
      }
    ],
    "identifier": 75251218
  },
  {
    "context": [
      "However, I now need the `id` field aswell and produce a csv like so:",
      "\"3233233233\", \"Title content, Hematology and Hepatology Honorary Fellow, Honorary Member, American  Society\"",
      "how do I combine the two queries to produce a single output consisting of `id` and `affiliation`?",
      "._id as $id | ._source.Bibtex.Article.AuthorList[].Affiliation.Affiliation | [ $id, .[0:rindex(\" Electronic address:\")] ] | @csv",
      "jq -r '[\n  ._id,\n  ._source.Bibtex.Article.AuthorList[]?.Affiliation.Affiliation[:rindex(\" Electronic address:\")]\n] | @csv'",
      "[._id]\n+ (._source.Bibtex.Article.AuthorList[]? | [ .Affiliation.Affiliation[0:rindex(\" Electronic address:\")] ])\n| @csv"
    ],
    "utterance": "Produce a CSV line containing the document's id and the affiliation string up to, but not including, ' Electronic address:'.",
    "expressions": [
      "._id as $id | ._source.Bibtex.Article.AuthorList[].Affiliation.Affiliation | [ $id, .[0:rindex(\" Electronic address:\")] ] | @csv",
      "[._id, ._source.Bibtex.Article.AuthorList[]?.Affiliation.Affiliation[:rindex(\" Electronic address:\")]] | @csv",
      "[._id]\n+ (._source.Bibtex.Article.AuthorList[]? | [ .Affiliation.Affiliation[0:rindex(\" Electronic address:\")] ])\n| @csv"
    ],
    "data": [
      {
        "input": {
          "_index": "indexeer",
          "_type": "_doc",
          "_id": "3233233233",
          "_score": 1,
          "_source": {
            "Bibtex": {
              "Article": {
                "AuthorList": [
                  {
                    "Affiliation": {
                      "Affiliation": "Title content, Hematology and Hepatology Honorary Fellow, Honorary Member, American  Society. xxxyyy@hotmail.com."
                    }
                  }
                ]
              }
            }
          }
        },
        "output": "\"3233233233\",\"Title content, Hematology and Hepatology Honorary Fellow, Honorary Member, American  Society. xxxyyy@hotmail.com.\""
      }
    ],
    "identifier": 75256906
  },
  {
    "context": [
      "Then I am trying to use jq to get the changes or updates using this:",
      "terraform show -json tfplan | jq '.resource_changes[] | select( .change.actions | contains(\"create\") or contains(\"update\") )'",
      "jq: error (at <stdin>:1): array ([\"no-op\"]) and string (\"create\") \n    cannot have their containment checked",
      "So for your concrete use case you would probably want something like the following:",
      "terraform show -json tfplan | jq '\n  .resource_changes[]\n  | select(\n    .change.actions as $actions\n    | \"create\" | IN($actions[])\n    or \"update\" | IN($actions[]))'",
      "Or using `any/2`:",
      "terraform show -json tfplan | jq '\n  .resource_changes[]\n  | select(any(.change.actions[]; .==\"create\" or .==\"update\"))'"
    ],
    "utterance": "List all resource changes where the actions include either 'create' or 'update'.",
    "expressions": [
      ".resource_changes[] | select((.change.actions as $actions | \"create\" | IN($actions[])) or (\"update\" | IN($actions[])))",
      ".resource_changes[] | select(any(.change.actions[]; .==\"create\" or .==\"update\"))"
    ],
    "identifier": 75263431
  },
  {
    "context": [
      "And I want a `jq` filter to kind of reverse the data structure, and get the names in an array:",
      "One way would be using `group_by` with some `map`s to bring the parts in place:",
      "map(.fruit = .fruits[]) | group_by(.fruit)\n| map({fruit: first.fruit, liked_by: map(.name)})",
      "Another way would be creating an index (dictionary) using nested `reduce`s, then `map`ping the result back to an array:",
      "reduce .[] as {$name, $fruits} ({}; reduce $fruits[] as $fruit (.;\n  .[$fruit] |= (.fruit = $fruit | .liked_by += [$name])\n)) | map(.)"
    ],
    "utterance": "Transform a list of people with their liked fruits into a list where each fruit has an array of people who like it.",
    "expressions": [
      "map(.fruit = .fruits[]) | group_by(.fruit)\n| map({fruit: first.fruit, liked_by: map(.name)})",
      "reduce .[] as {$name, $fruits} ({}; reduce $fruits[] as $fruit (.; .[$fruit] |= (.fruit = $fruit | .liked_by += [$name]))) | map(.)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Trevor",
            "fruits": [
              "apple",
              "banana"
            ]
          },
          {
            "name": "Lily",
            "fruits": [
              "apple",
              "haribo"
            ]
          }
        ],
        "output": [
          {
            "fruit": "apple",
            "liked_by": [
              "Trevor",
              "Lily"
            ]
          },
          {
            "fruit": "banana",
            "liked_by": [
              "Trevor"
            ]
          },
          {
            "fruit": "haribo",
            "liked_by": [
              "Lily"
            ]
          }
        ]
      }
    ],
    "identifier": 75266992
  },
  {
    "context": [
      "So for example I want to find all objects with type.name='pass', plus any object that is within X (say 2) of this object, either before or after.",
      "Would output a new JSON string:",
      "I can filter by \"type.name\" thanks to the answer quoted above, but I could not work out how to include surrounding objects.",
      "Putting it all together:\n\nto_entries\n| map(select(.value.type.name==\"Pass\").key + range(3) - 1) as $keys\n| map(select(.key|IN($keys[])).value)",
      "`range(3)-1` produces the stream `-1,0,1` which means that all indices within range 1 will be checked. To check all indices with a max distance of 2, use `range(5)-2`."
    ],
    "utterance": "Return all objects with type.name equal to \"Pass\", as well as any object within two positions before or after each matching object.",
    "expressions": [
      "to_entries | map(select(.value.type.name==\"Pass\").key + range(5) - 2) as $keys | map(select(.key|IN($keys[])).value)"
    ],
    "data": [
      {
        "input": [
          {
            "class": "Something1",
            "type": {
              "name": "Foul"
            }
          },
          {
            "class": "Something2",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something3",
            "type": {
              "name": "Pass"
            }
          },
          {
            "class": "Something4",
            "type": {
              "name": "Pass"
            }
          },
          {
            "class": "Something5",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something6",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something7",
            "type": {
              "name": "Other"
            }
          },
          {
            "class": "Something8",
            "type": {
              "name": "Other"
            }
          },
          {
            "class": "Something9",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something10",
            "type": {
              "name": "Pass"
            }
          },
          {
            "class": "Something1",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something2",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something3",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something4",
            "type": {
              "name": "Other"
            }
          },
          {
            "class": "Something5",
            "type": {
              "name": "Carry"
            }
          }
        ],
        "output": [
          {
            "class": "Something2",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something3",
            "type": {
              "name": "Pass"
            }
          },
          {
            "class": "Something4",
            "type": {
              "name": "Pass"
            }
          },
          {
            "class": "Something5",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something9",
            "type": {
              "name": "Carry"
            }
          },
          {
            "class": "Something10",
            "type": {
              "name": "Pass"
            }
          },
          {
            "class": "Something1",
            "type": {
              "name": "Carry"
            }
          }
        ]
      }
    ],
    "identifier": 75174502
  },
  {
    "context": [
      "Elements that I'm trying to fetch and get the end result from above raw output:\n\n\"name\" & \"rule-number\"\n\n**Expected Output from above raw data:**\n\nInternal Rules (1-3)\ncleanup rule (4)",
      "Jq transformation:\n\n```\n... | jq -r '.rulebase[]\n| if .from == .to then \"\\(.name) (\\(.from))\"\nelse \"\\(.name) (\\(.from)-\\(.to))\"\nend'\n```",
      "Output:\n\nInternal Rules (1-3)\ncleanup rule (4)"
    ],
    "utterance": "List each rulebase section's name followed by its from-to range in parentheses, using only the from number if from and to are equal.",
    "expressions": [
      ".rulebase[] | if .from == .to then \"\\(.name) (\\(.from))\" else \"\\(.name) (\\(.from)-\\(.to))\" end"
    ],
    "data": [
      {
        "input": {
          "uid": "38271c2f-ab44-4e25-9aa4-e219cb6e12cf",
          "name": "Network",
          "rulebase": [
            {
              "uid": "38acf747-85ee-4962-a3e7-d3cd678c388f",
              "name": "Internal Rules",
              "type": "access-section",
              "from": 1,
              "to": 3
            },
            {
              "uid": "da0fdbf6-360b-44a4-94a8-b01894d3b5a0",
              "name": "cleanup rule",
              "type": "access-section",
              "from": 4,
              "to": 4
            }
          ],
          "from": 1,
          "to": 4,
          "total": 4
        },
        "output": "Internal Rules (1-3)\ncleanup rule (4)"
      }
    ],
    "identifier": 75229438
  },
  {
    "context": [
      "The vanilla `jq` query is:",
      "jq --raw-output '._id as $id | ._source.CitationTextHeader.Article.AuthorList[]? | .Affiliation.Affiliation | [ $id, .[0:rindex(\" Electronic address:\")] ] | @csv' results.json > test.out",
      "An aexample (firstline) of the json file:",
      "{\n  \"_index\": \"corpuspm\",\n  \"_type\": \"_doc\",\n  \"_id\": \"6786777\",\n  \"_score\": 1,\n  \"_source\": {\n    \"CitationTextHeader\": {\n      \"Article\": {\n        \"AuthorList\": [\n          {\n            \"Affiliation\": {\n              \"Affiliation\": \"title, society, American Pediatric Society. address@hotmail.com.\"\n            }\n          }\n        ]\n      }\n    }\n  }\n}",
      "You could use `--spreadstdin` and `-n1` to linewise spread the input into your `jq` filter. Without knowing about the structure of your input JSONs, I have just copied over your \"vanilla\" filter:",
      "cat results.json | parallel --pipe doit > test.out",
      "doit() {\n  jq --raw-output '._id as $id | ._source.CitationTextHeader.Article.AuthorList[]? | .Affiliation.Affiliation | [ $id, .[0:rindex(\" Electronic address:\")] ] | @csv'\n}\nexport -f doit"
    ],
    "utterance": "Extract, for each object, the _id and the affiliation string up to (but not including) ' Electronic address:' from every author's affiliation within the AuthorList field.",
    "expressions": [
      "._id as $id | ._source.CitationTextHeader.Article.AuthorList[]? | .Affiliation.Affiliation | [ $id, .[0:rindex(\" Electronic address:\")] ] | @csv"
    ],
    "data": [
      {
        "input": {
          "_index": "corpuspm",
          "_type": "_doc",
          "_id": "6786777",
          "_score": 1,
          "_source": {
            "CitationTextHeader": {
              "Article": {
                "AuthorList": [
                  {
                    "Affiliation": {
                      "Affiliation": "title, society, American Pediatric Society. address@hotmail.com."
                    }
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 75268073
  },
  {
    "context": [
      "How to pair the keys with their values in a resilient way (not naming the keys) ? I want to \"prune\" the child objects so to only keep the value.",
      "You could use `map_values` which works like the outer `map` but for objects, i.e. it retains the object structure, including the field names:",
      "jq 'map(map_values(.value))'"
    ],
    "utterance": "Flatten each object so that every property maps directly to its .value, regardless of property names.",
    "expressions": [
      "map(map_values(.value))"
    ],
    "data": [
      {
        "input": [
          {
            "language": {
              "type": "uri",
              "value": "https://lingualibre.org/entity/Q100"
            },
            "wikidata": {
              "type": "literal",
              "value": "Q36157"
            },
            "code": {
              "type": "literal",
              "value": "lub"
            }
          },
          {
            "language": {
              "type": "uri",
              "value": "https://lingualibre.org/entity/Q101"
            },
            "wikidata": {
              "type": "literal",
              "value": "Q36284"
            },
            "code": {
              "type": "literal",
              "value": "srr"
            }
          }
        ],
        "output": [
          {
            "language": "https://lingualibre.org/entity/Q100",
            "wikidata": "Q36157",
            "code": "lub"
          },
          {
            "language": "https://lingualibre.org/entity/Q101",
            "wikidata": "Q36284",
            "code": "srr"
          }
        ]
      }
    ],
    "identifier": 75296612
  },
  {
    "context": [
      "desired output is below, where each stageId, submit, and completion times are compared with previous and next and the delay is added as another key/val per element.",
      "here the stageId 1 delayTillNextStageSubmit is difference between stageId 2 submitTime and stageId 1 completion time, 15 - 10 = 5.",
      "If `$data` holds your data, then based on my understanding of the question, you would invoke it like this:",
      "$data\n| derivative(-1; .completionTime_epoch_secs; .submitTime_epoch_secs; .delayTillNextStageSubmit)\n| derivative( 1; .submitTime_epoch_secs; .completionTime_epoch_secs; .delayFromPrevStageComplete)",
      ". as $array | to_entries | map(\n    .value.delayFromPrevStageComplete = .value.submitTime_epoch_secs - $array[.key - 1].completionTime_epoch_secs |\n    .value.delayTillNextStageSubmit = $array[(.key + 1) % length].submitTime_epoch_secs - .value.completionTime_epoch_secs |\n    .value\n) | (\n    .[0].delayFromPrevStageComplete,\n    .[-1].delayTillNextStageSubmit\n) = null"
    ],
    "utterance": "For each array element, add delayTillNextStageSubmit as the difference between the next element's submitTime and the current element's completion time, and delayFromPrevStageComplete as the difference between the current element's submitTime and the previous element's completion time; set these to null when neighboring elements don't exist.",
    "expressions": [
      "$data\n| derivative(-1; .completionTime_epoch_secs; .submitTime_epoch_secs; .delayTillNextStageSubmit)\n| derivative( 1; .submitTime_epoch_secs; .completionTime_epoch_secs; .delayFromPrevStageComplete)",
      ". as $array | to_entries | map(\n    .value.delayFromPrevStageComplete = .value.submitTime_epoch_secs - $array[.key - 1].completionTime_epoch_secs |\n    .value.delayTillNextStageSubmit = $array[(.key + 1) % length].submitTime_epoch_secs - .value.completionTime_epoch_secs |\n    .value\n) | (\n    .[0].delayFromPrevStageComplete,\n    .[-1].delayTillNextStageSubmit\n) = null"
    ],
    "data": [
      {
        "input": [
          {
            "stageId": 1,
            "submitTime_epoch_secs": 5,
            "completionTime_epoch_secs": 10
          },
          {
            "stageId": 2,
            "submitTime_epoch_secs": 15,
            "completionTime_epoch_secs": 17
          },
          {
            "stageId": 3,
            "submitTime_epoch_secs": 29,
            "completionTime_epoch_secs": 30
          }
        ],
        "output": [
          {
            "stageId": 1,
            "submitTime_epoch_secs": 5,
            "completionTime_epoch_secs": 10,
            "delayTillNextStageSubmit": 5,
            "delayFromPrevStageComplete": null
          },
          {
            "stageId": 2,
            "submitTime_epoch_secs": 15,
            "completionTime_epoch_secs": 17,
            "delayTillNextStageSubmit": 12,
            "delayFromPrevStageComplete": 5
          },
          {
            "stageId": 3,
            "submitTime_epoch_secs": 29,
            "completionTime_epoch_secs": 30,
            "delayTillNextStageSubmit": null,
            "delayFromPrevStageComplete": 12
          }
        ]
      }
    ],
    "identifier": 75272930
  },
  {
    "context": [
      "My attempt is to replace **TaskDefinition** key value from \"abc\" to  \"123\" and **ContainerName** key value from \"def\" to \"456 in one command and return the whole update json.",
      ".[].Resources[].TargetService.Properties |= (\n  .TaskDefinition = \"123\"\n  | .LoadBalancerInfo.ContainerName = \"456\"\n)",
      ".[].Resources[].TargetService.Properties.TaskDefinition = \"123\"\n| .[].Resources[].TargetService.Properties.LoadBalancerInfo.ContainerName = \"456\"",
      ".[].Resources[].TargetService.Properties |= (\n    .TaskDefinition |= \"123\"\n    | .LoadBalancerInfo.ContainerName |= \"456\"\n)",
      ".[].Resources[].TargetService.Properties *= {\n    TaskDefinition: \"123\",\n    LoadBalancerInfo: {\n        ContainerName: \"456\"\n    }\n}",
      "echo $APP_SPEC | jq --arg TASK_DEFINITION \"$NEW_TASK_DEFINITION_ARN\" --arg CONTAINER_NAME \"$CONTAINER_NAME\" '[].Resources[].TargetService.Properties |= (.TaskDefinition = $TASK_DEFINITION | .LoadBalancerInfo.ContainerName = $CONTAINER_NAME )'"
    ],
    "utterance": "Replace the value of TaskDefinition with \"123\" and ContainerName with \"456\" inside all TargetService.Properties in the data and return the full updated content.",
    "expressions": [
      ".[].Resources[].TargetService.Properties |= (.TaskDefinition = \"123\" | .LoadBalancerInfo.ContainerName = \"456\")",
      ".[].Resources[].TargetService.Properties.TaskDefinition = \"123\" | .[].Resources[].TargetService.Properties.LoadBalancerInfo.ContainerName = \"456\"",
      ".[].Resources[].TargetService.Properties |= (.TaskDefinition |= \"123\" | .LoadBalancerInfo.ContainerName |= \"456\")",
      ".[].Resources[].TargetService.Properties *= {TaskDefinition: \"123\", LoadBalancerInfo: {ContainerName: \"456\"}}"
    ],
    "data": [
      {
        "input": [
          {
            "version": 0.0,
            "Resources": [
              {
                "TargetService": {
                  "Type": "AWS::ECS::Service",
                  "Properties": {
                    "TaskDefinition": "abc",
                    "LoadBalancerInfo": {
                      "ContainerName": "def",
                      "ContainerPort": 8080
                    }
                  }
                }
              }
            ]
          }
        ],
        "output": [
          {
            "version": 0.0,
            "Resources": [
              {
                "TargetService": {
                  "Type": "AWS::ECS::Service",
                  "Properties": {
                    "TaskDefinition": "123",
                    "LoadBalancerInfo": {
                      "ContainerName": "456",
                      "ContainerPort": 8080
                    }
                  }
                }
              }
            ]
          }
        ]
      }
    ],
    "identifier": 75274375
  },
  {
    "context": [
      "I now just need to format this data into table like below or somewhat similar:",
      "| name              | IP              | NAT     | location   | method   |",
      "|-------------------|-----------------|---------|------------|----------|",
      "| H_103.109.135.25  | 103.109.135.25  | 1.1.1.1 | All        | static   |",
      "| H_103.109.135.250 | 103.109.135.250 | NA      | NA         | NA       |",
      "jq -r '\n  [\n    [\"name\",\"IP\",\"NAT\",\"location\",\"method\"],\n    ( .objects[]\n    | {\"nat-settings\": {\"ipv4-address\": \"NA\", \"install-on\": \"NA\", method: \"NA\"}} * .\n    | [.name, .\"ipv4-address\"] + (.\"nat-settings\" | [.\"ipv4-address\", .\"install-on\", .method])\n    )\n  ][] | join(\",\")\n' dump | column -s, -t",
      ".objects\n| map(\n    { name, IP: .\"ipv4-address\" } +\n    (.\"nat-settings\" | {\n      NAT: (.\"ipv4-address\" // \"NA\"), \n      location: (.\"install-on\" // \"NA\"), \n      method: (.method // \"NA\")\n    })\n  )",
      "< dump jq -r '\n  [\"name\",\"IP\",\"NAT\",\"location\",\"method\"], \n  (.objects[] | [.name, .\"ipv4-address\", .\"nat-settings\".\"ipv4-address\", .\"nat-settings\".\"install-on\", .\"nat-settings\".method]) \n  | @tsv' | column -t "
    ],
    "utterance": "Produce a table with columns name, IP, NAT, location, and method, substituting missing NAT, location, or method fields with NA.",
    "expressions": [
      "[[\"name\",\"IP\",\"NAT\",\"location\",\"method\"], (.objects[] | {\"nat-settings\": {\"ipv4-address\": \"NA\", \"install-on\": \"NA\", method: \"NA\"}} * . | [.name, .\"ipv4-address\"] + (.\"nat-settings\" | [.\"ipv4-address\", .\"install-on\", .method]))][] | join(\",\")",
      ".objects | map({ name, IP: .\"ipv4-address\" } + (.\"nat-settings\" | { NAT: (.\"ipv4-address\" // \"NA\"), location: (.\"install-on\" // \"NA\"), method: (.method // \"NA\")}))",
      "[\"name\",\"IP\",\"NAT\",\"location\",\"method\"], (.objects[] | [.name, .\"ipv4-address\", .\"nat-settings\".\"ipv4-address\", .\"nat-settings\".\"install-on\", .\"nat-settings\".method]) | @tsv"
    ],
    "data": [
      {
        "input": {
          "from": 1,
          "to": 2,
          "total": 2,
          "objects": [
            {
              "uid": "73b7036d-e8ec-47b7-99b5-19ca89eb5fd0",
              "name": "H_103.109.135.25",
              "type": "host",
              "domain": {
                "uid": "41e821a0-3720-11e3-aa6e-0800200c9fde",
                "name": "SMC User",
                "domain-type": "domain"
              },
              "ipv4-address": "103.109.135.25",
              "interfaces": [],
              "nat-settings": {
                "auto-rule": true,
                "ipv4-address": "1.1.1.1",
                "ipv6-address": "",
                "install-on": "All",
                "method": "static"
              },
              "comments": "",
              "color": "black",
              "icon": "Objects/host",
              "tags": [],
              "meta-info": {
                "lock": "unlocked",
                "validation-state": "ok",
                "last-modify-time": {
                  "posix": 1674820459413,
                  "iso-8601": "2023-01-27T17:24+0530"
                },
                "last-modifier": "admin",
                "creation-time": {
                  "posix": 1674818326777,
                  "iso-8601": "2023-01-27T16:48+0530"
                },
                "creator": "admin"
              },
              "read-only": false,
              "available-actions": {
                "edit": "true",
                "delete": "true",
                "clone": "true"
              }
            },
            {
              "uid": "7300c38a-a496-497a-b9e3-5701fa081393",
              "name": "H_103.109.135.250",
              "type": "host",
              "domain": {
                "uid": "41e821a0-3720-11e3-aa6e-0800200c9fde",
                "name": "SMC User",
                "domain-type": "domain"
              },
              "ipv4-address": "103.109.135.250",
              "interfaces": [],
              "nat-settings": {
                "auto-rule": false
              },
              "comments": "",
              "color": "black",
              "icon": "Objects/host",
              "tags": [],
              "meta-info": {
                "lock": "unlocked",
                "validation-state": "ok",
                "last-modify-time": {
                  "posix": 1674818341888,
                  "iso-8601": "2023-01-27T16:49+0530"
                },
                "last-modifier": "admin",
                "creation-time": {
                  "posix": 1674818341888,
                  "iso-8601": "2023-01-27T16:49+0530"
                },
                "creator": "admin"
              },
              "read-only": false,
              "available-actions": {
                "edit": "true",
                "delete": "true",
                "clone": "true"
              }
            }
          ]
        },
        "output": [
          [
            "name",
            "IP",
            "NAT",
            "location",
            "method"
          ],
          [
            "H_103.109.135.25",
            "103.109.135.25",
            "1.1.1.1",
            "All",
            "static"
          ],
          [
            "H_103.109.135.250",
            "103.109.135.250",
            "NA",
            "NA",
            "NA"
          ]
        ]
      }
    ],
    "identifier": 75259486
  },
  {
    "context": [
      "I tried\ncurl -X 'GET' \\\n  \"https://tsit-app1/api/v2/workItems/$case?versionNumber=0\" \\\n  -H 'accept: application/json' \\\n  -H \"Authorization: $apiKey\" | jq '\"boolStatus=\\(.isAutomated)\", \"name=\\(.name)\"'\n...\nbut in echo i get\n\"boolStatus=true\", \n\"name=bla bla\"\nneed to \necho $boolStatus \ntrue\necho $name \nbla bla",
      "vars=\"$(curl ... | jq -r '@sh \"boolStatus=\\(.isAutomated)\" , @sh \"name=\\(.name)\"')\"\neval \"$vars\"",
      "jq -r '@sh \"boolStatus=\\(.isAutomated)\\nname=\\(.name)\"'",
      "{ read boolStatus; read name; } < <(curl ... | jq -r '.isAutomated, .name')"
    ],
    "utterance": "Extract both .isAutomated and .name fields in a single query, assigning their values to separate shell variables.",
    "expressions": [
      "jq -r '.isAutomated, .name'",
      "jq -r '@sh \"boolStatus=\\(.isAutomated)\\nname=\\(.name)\"'"
    ],
    "identifier": 75297860
  },
  {
    "context": [
      "I want to generate a series of strings that combines the `id` field with each of the `values`. So output I need should look like this",
      "\"id1-one\"",
      "\"id1-two\"",
      "\"id2-three\"",
      "One final point. I tried the same code with `jq` and it worked fine.",
      "$ jq ' .[] | .id as $ID | .values[] | $ID + \"-\" + .  ' data.json",
      "\"id1-one\"",
      "\"id1-two\"",
      "\"id2-three\""
    ],
    "utterance": "Produce a string for each element in each object's values array by joining that object's id, a dash, and the value.",
    "expressions": [
      ".[] | .id + \"-\" + .values[]",
      ".[] | .id as $ID | .values[] | $ID + \"-\" + ."
    ],
    "data": [
      {
        "input": {
          "alpha": {
            "id": "id1",
            "values": [
              "one",
              "two"
            ]
          },
          "beta": {
            "id": "id2",
            "values": [
              "three"
            ]
          }
        },
        "output": [
          "id1-one",
          "id1-two",
          "id2-three"
        ]
      }
    ],
    "identifier": 75302792
  },
  {
    "context": [
      "I want to extract an array of key-value pairs from the below JSON, that is generated by the following AWS CLI script. The array should contain the load balancer names.",
      "cat output.json | jq '[.LoadBalancers[] | select(.LoadBalancerName | startswith(\"elb_name\")) | { LoadBalancerName: .LoadBalancerName } ]'",
      "[",
      "  {",
      "    \"LoadBalancerName\": \"elb_name_123\"",
      "  },",
      "  {",
      "    \"LoadBalancerName\": \"elb_name_456\"",
      "  },",
      "  {",
      "    \"LoadBalancerName\": \"elb_name_789\"",
      "  }",
      "]"
    ],
    "utterance": "Extract an array of objects each containing a LoadBalancerName key for load balancers whose name starts with 'elb_name'.",
    "expressions": [
      "[.LoadBalancers[] | select(.LoadBalancerName | startswith(\"elb_name\")) | { LoadBalancerName: .LoadBalancerName } ]"
    ],
    "data": [
      {
        "input": {
          "LoadBalancers": [
            {
              "LoadBalancerArn": "arn:aws:elasticloadbalancing...",
              "CreatedTime": "2023-01-26T22:26:42.313000+00:00",
              "LoadBalancerName": "elb_name_123"
            },
            {
              "LoadBalancerArn": "arn:aws:elasticloadbalancing...",
              "CreatedTime": "2023-01-26T22:26:42.313000+00:00",
              "LoadBalancerName": "elb_name_456"
            },
            {
              "LoadBalancerArn": "arn:aws:elasticloadbalancing...",
              "CreatedTime": "2023-01-26T22:26:42.313000+00:00",
              "LoadBalancerName": "elb_name_789"
            }
          ]
        },
        "output": [
          {
            "LoadBalancerName": "elb_name_123"
          },
          {
            "LoadBalancerName": "elb_name_456"
          },
          {
            "LoadBalancerName": "elb_name_789"
          }
        ]
      }
    ],
    "identifier": 75296879
  },
  {
    "context": [
      "How could I remove the same `house` entry from my nl-NL.json file with jq? I basically want to get the intersection of both files, based on key.",
      "You're looking for something like this:\n$ jq 'del(.[(keys - (input | keys))[]])' nl-NL.json en-US.json",
      "To reduce the `nl-NL.json` file to the keys present in `en-US.json`, you could read in the latter as reference, then [select](https://stedolan.github.io/jq/manual/#select%28boolean_expression%29) from the input turned into entries those keys that are present in the reference file. [in](https://stedolan.github.io/jq/manual/#in) checks \"whether or not the input key is in the given object\".",
      "jq --argfile ref en-US.json 'with_entries(select(.key | in($ref)))' nl-NL.json"
    ],
    "utterance": "Remove all key/value pairs from one translation file that are not present as keys in a reference translation file.",
    "expressions": [
      "jq 'del(.[(keys - (input | keys))[]])' nl-NL.json en-US.json",
      "jq --argfile ref en-US.json 'with_entries(select(.key | in($ref)))' nl-NL.json"
    ],
    "data": [
      {
        "input": {
          "nl-NL.json": {
            "car": "auto",
            "bike": "fiets",
            "tree": "boom",
            "house": "huis"
          },
          "en-US.json": {
            "car": "car",
            "bike": "bike",
            "tree": "tree"
          }
        },
        "output": {
          "car": "auto",
          "bike": "fiets",
          "tree": "boom"
        }
      }
    ],
    "identifier": 75308708
  },
  {
    "context": [
      "I want to filter with jq the objects from json content of this `fileA`",
      "Where the id appear in this json content of `fileB` called `theId`",
      "Is it possible ?",
      "Here is one way:\n$ jq 'map(.theId) as $ids | input | map(select(.id | IN($ids[])))' fileB fileA",
      "A simple solution using [`--slurpfile`](https://stedolan.github.io/jq/manual/#Invokingjq):\n\njq --slurpfile b fileB 'map(select(.id|IN($b[][].theId)))' fileA"
    ],
    "utterance": "Select all objects from fileA where the object's id matches any value of theId field in fileB.",
    "expressions": [
      "jq 'map(.theId) as $ids | input | map(select(.id | IN($ids[])))' fileB fileA",
      "jq --slurpfile b fileB 'map(select(.id|IN($b[][].theId)))' fileA"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": "bird",
              "content": {
                "key1": "a"
              }
            },
            {
              "id": "dog",
              "content": {
                "key1": "b"
              }
            },
            {
              "id": "cat",
              "content": {
                "key1": "c"
              }
            }
          ],
          [
            {
              "theId": "cat"
            },
            {
              "theId": "bird"
            }
          ]
        ],
        "output": [
          {
            "id": "cat",
            "content": {
              "key1": "c"
            }
          },
          {
            "id": "bird",
            "content": {
              "key1": "a"
            }
          }
        ]
      }
    ],
    "identifier": 75309624
  },
  {
    "context": [
      "What if we don't know the exact index position of this object and use a filter of 'Name=John'",
      "(map(.Name)| index(\"John\")) as $ix \n  | (select($ix)\n     | .[$ix] |= (.Name = \"Tom\" | .Pet = \"rabbit\")) // ."
    ],
    "utterance": "Update the object whose Name is \"John\" so that its Name becomes \"Tom\" and Pet becomes \"rabbit\", regardless of its position in the array.",
    "expressions": [
      "(map(.Name)| index(\"John\")) as $ix | (select($ix) | .[$ix] |= (.Name = \"Tom\" | .Pet = \"rabbit\")) // ."
    ],
    "data": [
      {
        "input": [
          {
            "Name": "James",
            "Mobile": 12345678,
            "Gender": "Male",
            "Boolean": true,
            "Pet": "cat"
          },
          {
            "Name": "John",
            "Mobile": 1234567875,
            "Gender": "Male",
            "Boolean": true,
            "Pet": "rat"
          },
          {
            "Name": "Jennifer",
            "Mobile": 1234567890,
            "Gender": "Female",
            "Boolean": true,
            "Pet": "Dog"
          },
          {
            "Name": "Julia",
            "Mobile": 1234567890,
            "Gender": "Female",
            "Boolean": true,
            "Pet": "Dog"
          },
          {
            "Name": "Jeff",
            "Mobile": 9871234567890,
            "Gender": "Male",
            "Boolean": true,
            "Pet": "Fish"
          },
          {
            "Name": "Jones",
            "Mobile": 79871234567890,
            "Gender": "Female",
            "Boolean": true,
            "Pet": "Parrot"
          }
        ],
        "output": [
          {
            "Name": "James",
            "Mobile": 12345678,
            "Gender": "Male",
            "Boolean": true,
            "Pet": "cat"
          },
          {
            "Name": "Tom",
            "Mobile": 1234567875,
            "Gender": "Male",
            "Boolean": true,
            "Pet": "rabbit"
          },
          {
            "Name": "Jennifer",
            "Mobile": 1234567890,
            "Gender": "Female",
            "Boolean": true,
            "Pet": "Dog"
          },
          {
            "Name": "Julia",
            "Mobile": 1234567890,
            "Gender": "Female",
            "Boolean": true,
            "Pet": "Dog"
          },
          {
            "Name": "Jeff",
            "Mobile": 9871234567890,
            "Gender": "Male",
            "Boolean": true,
            "Pet": "Fish"
          },
          {
            "Name": "Jones",
            "Mobile": 79871234567890,
            "Gender": "Female",
            "Boolean": true,
            "Pet": "Parrot"
          }
        ]
      }
    ],
    "identifier": 75303367
  },
  {
    "context": [
      "The goal is to map the `key` value onto each of the `source_records` values and output a two column TSV.",
      "jq -r '.key as $olid | .source_records | map([$olid, .])[] | @tsv'",
      "jq -r '.key + \"\\t\" + .source_records[]'",
      "jq -r '\"\u00005c(.key)\\t\\(.source_records[])\"'",
      "jq -r '[.key] + (.source_records[] | [.]) | @tsv'",
      "jq -r '.key as $olid | .source_records[] | [ $olid, . ] | @tsv'",
      "Output:\n/books/OL1000072M\tia:daywithtroubadou00pern\n/books/OL1000072M\tbwb:9780822519157\n/books/OL1000072M\tmarc:marc_loc_2016/BooksAll.2016.part25.utf8:103836014:1267"
    ],
    "utterance": "Produce a TSV where each line contains the value of 'key' and one value from 'source_records', for every 'source_records' element.",
    "expressions": [
      ".key as $olid | .source_records | map([$olid, .])[] | @tsv",
      "[.key] + (.source_records[] | [.]) | @tsv",
      ".key + \"\\t\" + .source_records[]",
      "\"\\(.key)\\t\\(.source_records[])\"",
      ".key as $olid | .source_records[] | [ $olid, . ] | @tsv"
    ],
    "data": [
      {
        "input": {
          "key": "/books/OL1000072M",
          "source_records": [
            "ia:daywithtroubadou00pern",
            "bwb:9780822519157",
            "marc:marc_loc_2016/BooksAll.2016.part25.utf8:103836014:1267"
          ]
        },
        "output": "/books/OL1000072M\tia:daywithtroubadou00pern\n/books/OL1000072M\tbwb:9780822519157\n/books/OL1000072M\tmarc:marc_loc_2016/BooksAll.2016.part25.utf8:103836014:1267"
      }
    ],
    "identifier": 75314344
  },
  {
    "context": [
      "This pipeline of jq invocations is a massively, _massively_ overcomplicated non-solution. Why convert back and forth between strings and JSON objects, parsing those strings again, when jq can already process the data directly?",
      "aws ... | jq -c '{ output: .Snapshots | map(.SnapshotId) | tostring }'",
      "If you have to use variables:",
      "aws ... | jq --arg top \"$top\" --arg next \"$next\" -c '{ output: .[$top] | map(.[$next]) | tostring }'",
      "or `.[$top] | map(.[$next]) | tostring | { output: . }` or `.[$top] | map(.[$next]) | { output: tostring }`.",
      "aws ... | jq --arg top \"$top\" --arg next \"$next\" '.[$top][][$next]' | jq -sc '{ output: tostring }'",
      "aws ... | jq --arg top \"$top\" --arg next \"$next\" '.[$top] | map(.[$next])' | jq -c '{ output: tostring }'"
    ],
    "utterance": "Extract all SnapshotId values from the Snapshots array in the API response and output them as a JSON string under the key output.",
    "expressions": [
      ".Snapshots | map(.SnapshotId) | tostring | { output: . }",
      "{ output: .Snapshots | map(.SnapshotId) | tostring }",
      "--arg top \"$top\" --arg next \"$next\" '{ output: .[$top] | map(.[$next]) | tostring }'",
      "--arg top \"$top\" --arg next \"$next\" '.[$top][][$next]' | jq -sc '{ output: tostring }'",
      "--arg top \"$top\" --arg next \"$next\" '.[$top] | map(.[$next])' | jq -c '{ output: tostring }'"
    ],
    "identifier": 75313913
  },
  {
    "context": [
      "value=\"value with spaces\"\necho {} | jq \". +={\"key\":\"'$value'\"}\"",
      "jq: error: syntax error, unexpected $end, expecting QQSTRING_TEXT or QQSTRING_INTERP_START or QQSTRING_END (Unix shell quoting issues?) at <top-level>, line 1:\n. +={\"key\":\"value            \njq: 1 compile error",
      "expected output*\n\n{\"key\":\"value with spaces\"}",
      "jq -n --arg myvar \"${VAL}\" '{key: $myvar}'\n{\n  \"key\": \"value with spaces\"\n}"
    ],
    "utterance": "Add a shell variable containing spaces as a value under the key 'key'.",
    "expressions": [
      "jq -n --arg myvar \"$value\" '{key: $myvar}'"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "key": "value with spaces"
        }
      }
    ],
    "identifier": 75337873
  },
  {
    "context": [
      "jq: error (at <stdin>:7): Cannot index string with string \"files\"",
      "cat \"$outputDir/decrypted_file.json\" | jq -r '.[] | .files[] | \"\\(.name)\"' | while read file ; do",
      "**The resulting Json after decrypting:**",
      "{\r\n  \"fake yaml file\\r\": \"fake yaml file\\r\",\r\n  \"Fakefile1.txt\": \"Fakecontents1=stuff1\\r\\nFakecontents2=stuff2\\r\\nFakecontents3=stuff3\\r\\nFakecontents4\\r\\nFakecontents5\\r\\nFakecontents6\",\r\n  \"Fakefile2.txt\": \"Fakecontents1=stuff1\\r\\nFakecontents2=stuff2\\r\\nFakecontents3=stuff3\\r\\nFakecontents4\\r\\nFakecontents5\\r\\nFakecontents6\",\r\n  \"Fakefile3.txt\": \"Fakecontents1=stuff1\\r\\nFakecontents2=stuff2\\r\\nFakecontents3=stuff3\\r\\nFakecontents4\\r\\nFakecontents5\\r\\nFakecontents6\",\r\n  \"Fakefile4.txt\": \"Fakecontents1=stuff1\\r\\nFakecontents2=stuff2\\r\\nFakecontents3=stuff3\\r\\nFakecontents4\\r\\nFakecontents5\\r\\nFakecontents6\"\r\n}",
      "**The Expected File Structure:**",
      "\u251c\u2500\u2500 Output_folder\n|   \u2514\u2500\u2500azure-pipelines.yaml\n|   \u2514\u2500\u2500 Config-Store\n\u2502\u00a0 \u00a0    \u2514\u2500\u2500 Fakefile1.txt\n\u2502\u00a0 \u00a0    \u2514\u2500\u2500 Fakefile2.txt\n\u2502    \u00a0 \u2514\u2500\u2500 Fakefile3.txt\n\u2502\u00a0 \u00a0    \u2514\u2500\u2500 Fakefile4.txt"
    ],
    "utterance": "Extract all top-level keys from an object, outputting each key name.",
    "expressions": [
      "keys[]"
    ],
    "data": [
      {
        "input": {
          "fake yaml file\r": "fake yaml file\r",
          "Fakefile1.txt": "Fakecontents1=stuff1\r\nFakecontents2=stuff2\r\nFakecontents3=stuff3\r\nFakecontents4\r\nFakecontents5\r\nFakecontents6",
          "Fakefile2.txt": "Fakecontents1=stuff1\r\nFakecontents2=stuff2\r\nFakecontents3=stuff3\r\nFakecontents4\r\nFakecontents5\r\nFakecontents6",
          "Fakefile3.txt": "Fakecontents1=stuff1\r\nFakecontents2=stuff2\r\nFakecontents3=stuff3\r\nFakecontents4\r\nFakecontents5\r\nFakecontents6",
          "Fakefile4.txt": "Fakecontents1=stuff1\r\nFakecontents2=stuff2\r\nFakecontents3=stuff3\r\nFakecontents4\r\nFakecontents5\r\nFakecontents6"
        },
        "output": [
          "fake yaml file\r",
          "Fakefile1.txt",
          "Fakefile2.txt",
          "Fakefile3.txt",
          "Fakefile4.txt"
        ]
      }
    ],
    "identifier": 75320082
  },
  {
    "context": [
      "jq 'map(select(.name == \"testtoken1\") |= (.header_1 = \"'${auth}'\" ))'",
      "should be",
      "jq 'map(select(.name == \"testtoken1\") |= (.header_1 = \"'\"${auth}\"'\" ))'",
      "But you shouldn't be interpolating the jq program/filter with shell variables in the first place. Define a jq variable instead and don't worry about messing up your jq filter:",
      "jq --arg auth \"$auth\" 'map(select(.name == \"testtoken1\") |= (.header_1 = $auth))'"
    ],
    "utterance": "Update the 'header_1' field of the object where name is 'testtoken1' with a string containing spaces, preserving all whitespace.",
    "expressions": [
      "jq --arg auth \"$auth\" 'map(select(.name == \"testtoken1\") |= (.header_1 = $auth))'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "testtoken1",
            "authType": "Token",
            "username": null,
            "password": "PASSWORD-MASKED",
            "header_1": "Authorization: Bearer {{@CmdCache | curl -s -d '{username: admin@qtech.ai, password: admin5665}' -H Content-Type:application/json -H Accept:application/json -X POST https://dev.qtech.ai/login | jq --raw-output .token}}",
            "header_2": null,
            "header_3": null,
            "clientId": null,
            "clientSecret": null,
            "id": null,
            "accessTokenUri": null,
            "authorizationScheme": null,
            "clientAuthenticationScheme": null,
            "tokenName": null,
            "scope": null,
            "grantType": null,
            "preEstablishedRedirectUri": null,
            "useCurrentUri": null,
            "userAuthorizationUri": null,
            "inactive": false,
            "invalid": false,
            "lastTestedOn": null,
            "passwordMasked": true
          },
          {
            "name": "Invalid_Auth",
            "authType": "Token",
            "username": null,
            "password": "PASSWORD-MASKED",
            "header_1": "Authorization:BearereyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c",
            "header_2": null,
            "header_3": null,
            "clientId": null,
            "clientSecret": null,
            "id": null,
            "accessTokenUri": null,
            "authorizationScheme": null,
            "clientAuthenticationScheme": null,
            "tokenName": null,
            "scope": null,
            "grantType": null,
            "preEstablishedRedirectUri": null,
            "useCurrentUri": null,
            "userAuthorizationUri": null,
            "inactive": false,
            "invalid": true,
            "lastTestedOn": null,
            "passwordMasked": true
          }
        ],
        "output": [
          {
            "name": "testtoken1",
            "authType": "Token",
            "username": null,
            "password": "PASSWORD-MASKED",
            "header_1": "Authorization: Bearer {{@CmdCache | curl -s -d '{\"username\":\"jackie@xxxx.com\",\"password\":\"Welcome123\"}' -H \"Content-Type: application/json\" -H \"Accept: application/json\" -X POST \"https://dev.qtech.ai/login\" | jq --raw-output \".token\" }}",
            "header_2": null,
            "header_3": null,
            "clientId": null,
            "clientSecret": null,
            "id": null,
            "accessTokenUri": null,
            "authorizationScheme": null,
            "clientAuthenticationScheme": null,
            "tokenName": null,
            "scope": null,
            "grantType": null,
            "preEstablishedRedirectUri": null,
            "useCurrentUri": null,
            "userAuthorizationUri": null,
            "inactive": false,
            "invalid": false,
            "lastTestedOn": null,
            "passwordMasked": true
          },
          {
            "name": "Invalid_Auth",
            "authType": "Token",
            "username": null,
            "password": "PASSWORD-MASKED",
            "header_1": "Authorization:BearereyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c",
            "header_2": null,
            "header_3": null,
            "clientId": null,
            "clientSecret": null,
            "id": null,
            "accessTokenUri": null,
            "authorizationScheme": null,
            "clientAuthenticationScheme": null,
            "tokenName": null,
            "scope": null,
            "grantType": null,
            "preEstablishedRedirectUri": null,
            "useCurrentUri": null,
            "userAuthorizationUri": null,
            "inactive": false,
            "invalid": true,
            "lastTestedOn": null,
            "passwordMasked": true
          }
        ]
      }
    ],
    "identifier": 75320078
  },
  {
    "context": [
      "I'm writing a bash script to read a JSON file and export the key-value pairs as environment variables. Though I could extract the key-value pairs, I'm struggling to skip those entries that failed to parse by `jq`.",
      "Perhaps there is an algorithm that will repair the broken JSON produced by the upstream system.  If not, the following is a horrible but possibly useful \"hack\" that will at least capture KEY1 and KEY2 in the example in the Q:",
      "jq -Rr '\n   capture(\"\\\"(?<key>[^\\\"]*)\\\"[ \\t]*:[ \\t]*(?<value>[^}]+)\") \n   | (.value |= sub(\"[ \\t]+$\"; \"\") )  # trailing whitespace\n   | if .value|test(\"^\\\".*\\\"\") then .value |= sub(\"\\\"[ \\t]*[,}[ \\t]*$\"; \"\\\"\") else . end\n   | select(.value | test(\"^\\\".*\\\"$\") or (contains(\"\\\"\")|not) )  # a string or not a string\n   | \"\\(.key)=\\(.value|@sh)\" \n'"
    ],
    "utterance": "Extract all valid top-level key-value pairs from a malformed input, ignoring any entries that fail to parse, and print them as shell assignments.",
    "expressions": [
      "jq -Rr '\n   capture(\"\\\"(?<key>[^\\\"]*)\\\"[ \\t]*:[ \\t]*(?<value>[^}]+)\") \n   | (.value |= sub(\"[ \\t]+$\"; \"\") )  # trailing whitespace\n   | if .value|test(\"^\\\".*\\\"\") then .value |= sub(\"\\\"[ \\t]*[,}[ \\t]*$\"; \"\\\"\") else . end\n   | select(.value | test(\"^\\\".*\\\"$\") or (contains(\"\\\"\")|not) )  # a string or not a string\n   | \"\\(.key)=\\(.value|@sh)\" \n'"
    ],
    "data": [
      {
        "input": "{\n \"KEY1\":\"ABC\",\n \"KEY2\":\"XYZ\",\n \"KEY3\":\"---ABC---\\n\r\ndskfjlksfj\"\n\n}\n",
        "output": [
          "KEY1='ABC'",
          "KEY2='XYZ'"
        ]
      }
    ],
    "identifier": 75328040
  },
  {
    "context": [
      "Is there a simple way to display a 2D JSON array using `jq`, so that each subarray is on its own line?",
      "I'm trying to use `jq` to print out:\n1 2 3\n4 5\n6 7 8 9",
      "$ jq -rc '.array[] | join(\" \")' test.json \n1 2 3\n4 5\n6 7 8 9"
    ],
    "utterance": "Print each subarray as a space-separated line, with each line corresponding to a subarray in the two-dimensional array with key 'array'.",
    "expressions": [
      ".array[] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "array": [
            [
              1,
              2,
              3
            ],
            [
              4,
              5
            ],
            [
              6,
              7,
              8,
              9
            ]
          ]
        },
        "output": "1 2 3\n4 5\n6 7 8 9"
      }
    ],
    "identifier": 75339646
  },
  {
    "context": [
      "I want to get all the `id` values where the \"parent\" key name matches the pattern `.*foo.*` or `.*bar.*`.",
      "you can use the following JQ expression:\n\n    jq 'to_entries[] | select(.key | test(\".*foo.*|.*bar.*\")) | .value[] | .id'\n",
      "You could go with:\n```sh\njq -r '.[keys_unsorted[] | select(test(\".*foo.*|.bar..\"))][].id'\n```"
    ],
    "utterance": "Return all id values from elements where the parent dictionary key matches the pattern .*foo.* or .*bar.*.",
    "expressions": [
      "to_entries[] | select(.key | test(\".*foo.*|.*bar.*\")) | .value[] | .id",
      ".[keys_unsorted[] | select(test(\".*foo.*|.*bar.*\"))][].id"
    ],
    "data": [
      {
        "input": {
          "key-foo-1.0": [
            {
              "key1": "foo",
              "key2": "bar",
              "id": "01"
            },
            {
              "key1": "foo",
              "key2": "bar",
              "id": "23"
            }
          ],
          "key-bar-1.0": [
            {
              "key1": "foo",
              "key2": "bar",
              "id": "45"
            },
            {
              "key1": "foo",
              "key2": "bar",
              "id": "67"
            }
          ],
          "key-baz-1.0": [
            {
              "key1": "foo",
              "key2": "bar",
              "id": "89"
            }
          ]
        },
        "output": [
          "01",
          "23",
          "45",
          "67"
        ]
      }
    ],
    "identifier": 75334848
  },
  {
    "context": [
      "jq -n '\"1971-08-01T01:00:00Z\" | fromdateiso8601'",
      "jq -n '\"1972-08-01T01:00:00Z\" | fromdateiso8601'",
      "On MacOS,   they give 49856400 and 81482400.",
      "On Ubuntu, they give 49856400 and 81478800.",
      "$ jqMaster -nM '\"1971-08-01T01:00:00Z\",\"1972-08-01T01:00:00Z\" | fromdateiso8601'",
      "49856400",
      "81478800",
      "$ gojq -n '\"1971-08-01T01:00:00Z\",\"1972-08-01T01:00:00Z\" | fromdateiso8601'",
      "49856400",
      "81478800"
    ],
    "utterance": "Convert the ISO8601 datetimes \"1971-08-01T01:00:00Z\" and \"1972-08-01T01:00:00Z\" to Unix timestamps, ensuring consistent results across platforms.",
    "expressions": [
      "\"1971-08-01T01:00:00Z\",\"1972-08-01T01:00:00Z\" | fromdateiso8601"
    ],
    "data": [
      {
        "input": [
          "1971-08-01T01:00:00Z",
          "1972-08-01T01:00:00Z"
        ],
        "output": [
          49856400,
          81478800
        ]
      }
    ],
    "identifier": 75351906
  },
  {
    "context": [
      "I\u2019m trying to remove objects in the array in the first file with the matching IDs in the second file so that the resultant output would be:\n\n[\n  {\n    \"data\": {\n      \"id\": \"2\",\n      \"nodes\": [\n        {\n          \"stuff\": \"foo\"\n        }\n      ]\n    }\n  },\n  {\n    \"data\": {\n      \"id\": \"6\",\n      \"nodes\": [\n        {\n          \"stuff\": \"bar\"\n        }\n      ]\n    }\n  }\n]\n",
      "You could compile a list of IDs from the second file using `input`, check against it using `IN`, and either use `del` to delete the matching, or `map` to keep those that do `not` match:",
      "jq '\n  (input | map(.data.id)) as $del | del(.[] | select(IN(.data.id; $del[])))\n' file1.json file2.json",
      "jq '\n  (input | map(.data.id)) as $del | map(select(IN(.data.id; $del[]) | not))\n' file1.json file2.json"
    ],
    "utterance": "Remove all objects from the first array whose data.id matches any data.id in the second array.",
    "expressions": [
      "(input | map(.data.id)) as $del | del(.[] | select(IN(.data.id; $del[])))",
      "(input | map(.data.id)) as $del | map(select(IN(.data.id; $del[]) | not))"
    ],
    "data": [
      {
        "input": [
          [
            {
              "data": {
                "id": "2",
                "nodes": [
                  {
                    "stuff": "foo"
                  }
                ]
              }
            },
            {
              "data": {
                "id": "6",
                "nodes": [
                  {
                    "stuff": "bar"
                  }
                ]
              }
            },
            {
              "data": {
                "id": "61",
                "nodes": [
                  {
                    "stuff": "baz"
                  }
                ]
              }
            },
            {
              "data": {
                "id": "63",
                "nodes": [
                  {
                    "stuff": "qux"
                  }
                ]
              }
            }
          ],
          [
            {
              "data": {
                "id": "61",
                "nodes": [
                  {
                    "stuff": "baz"
                  }
                ]
              }
            },
            {
              "data": {
                "id": "63",
                "nodes": [
                  {
                    "stuff": "qux"
                  }
                ]
              }
            }
          ]
        ],
        "output": [
          {
            "data": {
              "id": "2",
              "nodes": [
                {
                  "stuff": "foo"
                }
              ]
            }
          },
          {
            "data": {
              "id": "6",
              "nodes": [
                {
                  "stuff": "bar"
                }
              ]
            }
          }
        ]
      }
    ],
    "identifier": 75341938
  },
  {
    "context": [
      "How do I create a tabular output as follows? Basically, I need the value of house appear in the corresponding rows.",
      "With your input, the following jq program produces the output shown below:",
      "jq -r '\n  def lpad($len): tostring | ($len - length) as $l | (\" \" * $l)[:$l] + .;\n  ([\"Names\",\"Points\", \"House\"]\n   | ., map(length*\"_\")),\n  (.[] | (.users[] | [.name, .points]) +  [.house]) \n  | map(lpad(8)) | join(\"|\")'",
      "If it's OK to forego some formatting and decorations, this produces a simple table.",
      "$ jq -r '[\"Name\", \"Points\", \"House\"],(.[]|.house as $house|.users[]|[.name, .points, $house])|@tsv' test.json"
    ],
    "utterance": "Print each user's name, points, and their corresponding house as table rows, including the house value for each user.",
    "expressions": [
      "jq -r '[\"Name\", \"Points\", \"House\"],(.[]|.house as $house|.users[]|[.name, .points, $house])|@tsv'",
      "jq -r '([\"Names\",\"Points\", \"House\"] | ., map(length*\"_\")), (.[] | (.users[] | [.name, .points]) +  [.house]) | map(lpad(8)) | join(\"|\")' --argfile lpad 'def lpad($len): tostring | ($len - length) as $l | (\" \" * $l)[:$l] + .'"
    ],
    "data": [
      {
        "input": [
          {
            "users": [
              {
                "name": "alfred",
                "points": 10
              },
              {
                "name": "alice",
                "points": 11
              },
              {
                "name": "emma",
                "points": 33
              }
            ],
            "house": "red"
          },
          {
            "users": [
              {
                "name": "Logan",
                "points": 20
              },
              {
                "name": "Keith",
                "points": 19
              },
              {
                "name": "Lisa",
                "points": 18
              },
              {
                "name": "Julia",
                "points": 45
              }
            ],
            "house": "blue"
          }
        ],
        "output": [
          [
            "Name",
            "Points",
            "House"
          ],
          [
            "alfred",
            "10",
            "red"
          ],
          [
            "alice",
            "11",
            "red"
          ],
          [
            "emma",
            "33",
            "red"
          ],
          [
            "Logan",
            "20",
            "blue"
          ],
          [
            "Keith",
            "19",
            "blue"
          ],
          [
            "Lisa",
            "18",
            "blue"
          ],
          [
            "Julia",
            "45",
            "blue"
          ]
        ]
      }
    ],
    "identifier": 75342618
  },
  {
    "context": [
      "I want to duplicate it so that it gives me the values:\r\n\r\n\"Times Square, New York\"\r\n\"Times Square, New York\"\r\n\"Times Square, New York\"\r\n\"Times Square, New York\"",
      "One way could be to create a stream of 4 arbitrary items, e.g. numbers using `range`, store them in a variable to not affect the context, and provide your output for each:\r\n```sh\r\nrange(4) as $_ | .address\r\n```",
      "You can also use the [comma operator](https://stedolan.github.io/jq/manual/#Comma:,) `,` to manually compile your stream:\r\n```sh\r\n.address, .address, .address, .address\r\n```"
    ],
    "utterance": "Output the value of the address field four times as separate results.",
    "expressions": [
      "range(4) as $_ | .address",
      ".address, .address, .address, .address"
    ],
    "data": [
      {
        "input": {
          "address": "Times Square, New York"
        },
        "output": [
          "Times Square, New York",
          "Times Square, New York",
          "Times Square, New York",
          "Times Square, New York"
        ]
      }
    ],
    "identifier": 75373266
  },
  {
    "context": [
      "echo '{\"foo\": 1}' | jq '.foo + 2 as $bar | {$bar}'",
      "I would expect the output:",
      "{",
      "  \"bar\": 3",
      "}",
      "I can resolve this issue with parentheses but I'm still unclear as to what was happening in the original statement:",
      "echo '{\"foo\": 1}' | jq '(.foo + 2) as $bar | {$bar}' ",
      "{",
      "  \"bar\": 3",
      "}",
      "Your first filter was executed as if it had been parenthesized like this",
      "echo '{\"foo\": 1}' | jq '.foo + (2 as $bar | {$bar})'",
      "This is because the syntax for a variable binding, as noted in the manual's [corresponding section](https://stedolan.github.io/jq/manual/#Variable%2FSymbolicBindingOperator%3A...as%24identifier%7C...), takes on the form `... as $identifier | ...`.  It \"includes\" the pipe and the following expression."
    ],
    "utterance": "Assign the result of adding 2 to the value of 'foo' to a variable, then create an object with that value as a field named 'bar'.",
    "expressions": [
      "(.foo + 2) as $bar | {bar: $bar}"
    ],
    "data": [
      {
        "input": {
          "foo": 1
        },
        "output": {
          "bar": 3
        }
      }
    ],
    "identifier": 75367200
  },
  {
    "context": [
      "I want to pass this to jq and fetch or get an output of `IS_CR` value for the respective `prID`.",
      "`jq --argjson v \"$PRID\" '.[] | select(.prId == $v).IS_CR' services.json`",
      "`jq '.[] | select(.prId == '$PRID') | .IS_CR' services.json`",
      "Output: # PRID=6644 ... # jq '.[] | select(.prId == '$PRID') | .IS_CR' services.json\n\"Yes\""
    ],
    "utterance": "Retrieve the IS_CR value of the top-level object whose prId matches a given value.",
    "expressions": [
      ".[] | select(.prId == $v).IS_CR",
      ".[] | select(.prId == $PRID) | .IS_CR"
    ],
    "data": [
      {
        "input": {
          "checkout-serviceA": {
            "prId": 6644,
            "Sourcebranch": "",
            "HFX": false,
            "IS_CR": "Yes"
          },
          "checkout-serviceB": {
            "prId": 15826,
            "Sourcebranch": "",
            "HFX": false,
            "IS_CR": "no"
          },
          "checkout-toggle": {
            "prId": 8963,
            "Sourcebranch": "",
            "HFX": true,
            "IS_CR": "Yes"
          },
          "checkout-res": {
            "prId": 1104,
            "Sourcebranch": "",
            "HFX": false,
            "IS_CR": "Yes"
          }
        },
        "output": "Yes"
      }
    ],
    "identifier": 75374187
  },
  {
    "context": [
      "how to convert json data into single string with no spaces in between using bash scripting?",
      "we need to convert above json data into below single line json data with no spaces like below one.",
      "Let [tag:jq] do it: -c is the --compact-output option.",
      "mAuth=$(echo \"$Auth\" | jq -c .)"
    ],
    "utterance": "Convert the input to a single-line string without spaces between items or fields.",
    "expressions": [
      "jq -c ."
    ],
    "data": [
      {
        "input": [
          {
            "name": "Invalid_Auth",
            "authType": "Token",
            "username": null,
            "password": "PASSWORD-MASKED",
            "header_1": "Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c",
            "header_2": null,
            "header_3": null,
            "clientId": null,
            "clientSecret": null,
            "id": null,
            "accessTokenUri": null,
            "authorizationScheme": null,
            "clientAuthenticationScheme": null,
            "tokenName": null,
            "scope": null,
            "grantType": null,
            "preEstablishedRedirectUri": null,
            "useCurrentUri": null,
            "userAuthorizationUri": null,
            "inactive": false,
            "invalid": true,
            "lastTestedOn": null,
            "passwordMasked": true
          }
        ],
        "output": "[{\"name\":\"Invalid_Auth\",\"authType\":\"Token\",\"username\":null,\"password\":\"PASSWORD-MASKED\",\"header_1\":\"Authorization: Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.SflKxwRJSMeKKF2QT4fwpMeJf36POk6yJV_adQssw5c\",\"header_2\":null,\"header_3\":null,\"clientId\":null,\"clientSecret\":null,\"id\":null,\"accessTokenUri\":null,\"authorizationScheme\":null,\"clientAuthenticationScheme\":null,\"tokenName\":null,\"scope\":null,\"grantType\":null,\"preEstablishedRedirectUri\":null,\"useCurrentUri\":null,\"userAuthorizationUri\":null,\"inactive\":false,\"invalid\":true,\"lastTestedOn\":null,\"passwordMasked\":true}]"
      }
    ],
    "identifier": 75310489
  },
  {
    "context": [
      "I am trying to construct a json array using jq element by element. The elements are being generated by a certain process.",
      "I want the output from the code above to be a json array, such as for 3 elements:\n[{\"key_1\":1}, {\"key_1\":1}, {\"key_1\":1}]",
      "For smaller values of counter this would work but for large values like 10000 this leads to parse error or Aborted (core dumped). It seems that the script runs out of memory trying to build large arrays. What could be the reasonable approach to doing this using jq?",
      "If you have a loop (or any sequence of commands) which generates a stream of JSON objects, you can _slurp_ them with jq and get your array for free.",
      "for i in $(seq 100); do\n  echo '{\"key\": \"value\"}';\ndone | jq -s '.' > output.json"
    ],
    "utterance": "Combine a stream of generated objects into a single array, efficiently handling large numbers of elements.",
    "expressions": [
      "jq -s '.'"
    ],
    "data": [
      {
        "input": [
          {
            "key": "value"
          },
          {
            "key": "value"
          },
          {
            "key": "value"
          }
        ],
        "output": [
          {
            "key": "value"
          },
          {
            "key": "value"
          },
          {
            "key": "value"
          }
        ]
      }
    ],
    "identifier": 75384637
  },
  {
    "context": [
      "Now, if for some reason the key doesn't exist then I need to first create the key `D`. And I am not able to achieve this",
      "expected output\n\n``` \n{\n\t\"A\": \"123\",\n\t\"B\": \"456\",\n\t\"C\": \"789\",\n\t\"D\": []\n}\n```",
      "If your goal is to simply insert the key with a default value if it doesn't exist, but keep any existing value, the following simple jq program (and nothing else) should take care of that:\n\n```\njq '{D: []} + .' test.json\n```",
      "So, a slightly more complicated version which puts `D` at the end of the object, but keeps existing values would be:\n\n```\njq '.D |= (. // [])' test.json\n```"
    ],
    "utterance": "Ensure the object has a key D with value [], adding it if missing or keeping its value if it already exists.",
    "expressions": [
      "{D: []} + .",
      ".D |= (. // [])"
    ],
    "data": [
      {
        "input": {
          "A": "123",
          "B": "456",
          "C": "789"
        },
        "output": {
          "A": "123",
          "B": "456",
          "C": "789",
          "D": []
        }
      },
      {
        "input": {
          "A": "123",
          "B": "456",
          "C": "789",
          "D": [
            1,
            2,
            3
          ]
        },
        "output": {
          "A": "123",
          "B": "456",
          "C": "789",
          "D": [
            1,
            2,
            3
          ]
        }
      }
    ],
    "identifier": 75382353
  },
  {
    "context": [
      "I'm trying to find all Kubernetes deployments whose image (you can assume the container at index 0) is contained in a list of images.",
      "I'd like to keep the full Deployment spec for matches.",
      "I can get the list of images for Deployments using one of the images in my list ... I'd like to get the entire Deployment object though, not just the image, for any matches.",
      "map(select(.spec.template.spec.containers[0].image == $q[]))"
    ],
    "utterance": "Return all Deployment objects whose first container's image appears in a given list of images.",
    "expressions": [
      "(input.searchItems | unique) as $q | .items | map(select(.spec.template.spec.containers[0].image == $q[]))"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "kind": "List",
          "metadata": {
            "resourceVersion": ""
          },
          "items": [
            {
              "apiVersion": "apps/v1",
              "kind": "Deployment",
              "metadata": {
                "name": "nginx-deployment",
                "labels": {
                  "app": "nginx"
                }
              },
              "spec": {
                "replicas": 3,
                "selector": {
                  "matchLabels": {
                    "app": "nginx"
                  }
                },
                "template": {
                  "metadata": {
                    "labels": {
                      "app": "nginx"
                    }
                  },
                  "spec": {
                    "containers": [
                      {
                        "name": "nginx",
                        "image": "nginx:1.14.2",
                        "ports": [
                          {
                            "containerPort": 80
                          }
                        ]
                      }
                    ]
                  }
                }
              }
            },
            {
              "apiVersion": "apps/v1",
              "kind": "Deployment",
              "metadata": {
                "name": "myapp-deployment",
                "labels": {
                  "app": "myapp"
                }
              },
              "spec": {
                "replicas": 1,
                "selector": {
                  "matchLabels": {
                    "app": "myapp"
                  }
                },
                "template": {
                  "metadata": {
                    "labels": {
                      "app": "myapp"
                    }
                  },
                  "spec": {
                    "containers": [
                      {
                        "name": "myapp",
                        "image": "myapp:0.1.2",
                        "ports": [
                          {
                            "containerPort": 8080
                          }
                        ]
                      }
                    ]
                  }
                }
              }
            }
          ]
        },
        "output": [
          {
            "apiVersion": "apps/v1",
            "kind": "Deployment",
            "metadata": {
              "name": "nginx-deployment",
              "labels": {
                "app": "nginx"
              }
            },
            "spec": {
              "replicas": 3,
              "selector": {
                "matchLabels": {
                  "app": "nginx"
                }
              },
              "template": {
                "metadata": {
                  "labels": {
                    "app": "nginx"
                  }
                },
                "spec": {
                  "containers": [
                    {
                      "name": "nginx",
                      "image": "nginx:1.14.2",
                      "ports": [
                        {
                          "containerPort": 80
                        }
                      ]
                    }
                  ]
                }
              }
            }
          }
        ]
      },
      {
        "input": {
          "searchItems": [
            "nginx:1.13.1",
            "nginx:1.14.2"
          ]
        }
      }
    ],
    "identifier": 75377835
  },
  {
    "context": [
      "It's working but the `devDependencies` value from `$dev_dependencies` is wrote as string:",
      "How can I write it as raw JSON ?",
      "I think you want the `--argjson` option instead of `--arg`.",
      "To \"merge\" the contents of two files, read both files with jq and let jq do the work. This avoids all the complications that arise from jumping between jq and shell context. A single line is all that's needed:",
      "jq --slurpfile deps \"$dep_file\" '. + { devDependencies: $deps[0].devDependencies }' \"$source_file\" > \"$dest_file\"",
      "jq --slurpfile deps \"$dep_file\" '. + ($deps[0]|{devDependencies})' \"$source_file\" > \"$dest_file\"",
      "jq --slurpfile deps \"$dev_file\" '.devDependencies = $deps[0].devDependencies' \"$source_file\" > \"$dest_file\"",
      "jq '. + (input|{devDependencies})' \"$source_file\" \"$dep_file\" > \"$dest_file\""
    ],
    "utterance": "Add or update the devDependencies attribute with an object value from another file, ensuring the value is parsed as an object not a string.",
    "expressions": [
      ". + { devDependencies: $deps[0].devDependencies }",
      ". + ($deps[0]|{devDependencies})",
      ".devDependencies = $deps[0].devDependencies",
      ". + (input|{devDependencies})"
    ],
    "identifier": 75388052
  },
  {
    "context": [
      "I only want to transfer some properties of the second file (specifically only `version` and `dependencies`). `version` should overwrite the value in the original file and `dependencies` should be added to the new file. `name` must not be overwritten and the original name must be kept.",
      "jq --slurpfile b b.json '. + ($b[0] | {version,dependencies})' a.json",
      "jq '. + (input|{version, dependencies})' a.json b.json"
    ],
    "utterance": "Merge a file with another, copying only the version and dependencies properties from the second file so that version is overwritten and dependencies is added, without modifying name or copying other properties.",
    "expressions": [
      "jq --slurpfile b b.json '. + ($b[0] | {version,dependencies})' a.json",
      "jq '. + (input|{version, dependencies})' a.json b.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": "ZGVhZGJlZWY=",
            "name": "first file",
            "version": 1,
            "description": "just a simple json file"
          },
          {
            "version": 2,
            "name": "fake name",
            "dependencies": [
              4,
              2
            ],
            "comment": "I'm just sitting here, ignore me"
          }
        ],
        "output": {
          "id": "ZGVhZGJlZWY=",
          "name": "first file",
          "version": 2,
          "description": "just a simple json file",
          "dependencies": [
            4,
            2
          ]
        }
      }
    ],
    "identifier": 75391973
  },
  {
    "context": [
      "I need to validate in a field that if it is null, assign a default value, I can't find how to perform a validation with if conditional",
      "jq '.timeout |= if . == null then 200 else . end'",
      "jq '.timeout //= 200' file.json"
    ],
    "utterance": "Assign a default value of 200 to the timeout field if its value is null.",
    "expressions": [
      ".timeout |= if . == null then 200 else . end",
      ".timeout //= 200"
    ],
    "data": [
      {
        "input": {
          "timeout": null
        },
        "output": {
          "timeout": 200
        }
      },
      {
        "input": {
          "timeout": 100
        },
        "output": {
          "timeout": 100
        }
      }
    ],
    "identifier": 75403756
  },
  {
    "context": [
      "I have two datasets:\r\n\r\ndata1='[\r\n    { \"bookings\": 2984, \"timestamp\": 1675854900 },\r\n    { \"bookings\": 2967, \"timestamp\": 1675855200 }\r\n]'\r\n\r\ndata2='[\r\n    { \"errors\": 51, \"timestamp\": 1675854900 },\r\n    { \"errors\": 90, \"timestamp\": 1675855200 }\r\n]'\r\n",
      "I want the output to be:\r\n```\r\ncombined='[\r\n    { \"errors\": 51, bookings: 2984, \"timestamp\": 1675854900 },\r\n    { \"errors\": 90, bookings: 2967, \"timestamp\": 1675855200 }\r\n]'\r\n```",
      "Assume that timestamp will always be present and will always have a common value across two datasets. Even the order is same.",
      "jq -n --argjson data1 \"$data1\" --argjson data2 \"$data2\" '\n  [JOIN(INDEX($data1[]; .timestamp); $data2[]; .timestamp | @text; add)]\n'",
      "jq -n --argjson data1 \"$data1\" --argjson data2 \"$data2\" '\n  ($data1 | with_entries(.key = (.value.timestamp | @text))) as $ix\n  | $data2 | map(. + $ix[.timestamp | @text])\n'",
      "jq -n --argjson d1 \"$data1\" --argjson d2 \"$data2\" '\n  [ $d1, $d2 ] | transpose[] | group_by(.timestamp) | map(\n    reduce .[] as $i ({}; . * $i)\n  )\n'",
      "jq -n --argjson data1 \"$data1\"  --argjson data2 \"$data2\" '\n  INDEX($data1[]; .timestamp) as $dict\n  | $data2 | map( . + $dict[.timestamp|tostring])\n'",
      "jq -n --argjson data1 \"$data1\" --argjson data2 \"$data2\" '\n  $data1 | [keys[] | $data2[.] + $data1[.]]\n'"
    ],
    "utterance": "Merge two arrays of objects based on a common 'timestamp' key so that each result object has both the 'bookings' and 'errors' values for the same timestamp.",
    "expressions": [
      "jq -n --argjson data1 \"$data1\" --argjson data2 \"$data2\" '[JOIN(INDEX($data1[]; .timestamp); $data2[]; .timestamp | @text; add)]'",
      "jq -n --argjson data1 \"$data1\" --argjson data2 \"$data2\" '($data1 | with_entries(.key = (.value.timestamp | @text))) as $ix | $data2 | map(. + $ix[.timestamp | @text])'",
      "jq -n --argjson d1 \"$data1\" --argjson d2 \"$data2\" '[ $d1, $d2 ] | transpose[] | group_by(.timestamp) | map(reduce .[] as $i ({}; . * $i))'",
      "jq -n --argjson data1 \"$data1\"  --argjson data2 \"$data2\" 'INDEX($data1[]; .timestamp) as $dict | $data2 | map( . + $dict[.timestamp|tostring])'",
      "jq -n --argjson data1 \"$data1\" --argjson data2 \"$data2\" '$data1 | [keys[] | $data2[.] + $data1[.]]'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "bookings": 2984,
              "timestamp": 1675854900
            },
            {
              "bookings": 2967,
              "timestamp": 1675855200
            }
          ],
          [
            {
              "errors": 51,
              "timestamp": 1675854900
            },
            {
              "errors": 90,
              "timestamp": 1675855200
            }
          ]
        ],
        "output": [
          {
            "errors": 51,
            "bookings": 2984,
            "timestamp": 1675854900
          },
          {
            "errors": 90,
            "bookings": 2967,
            "timestamp": 1675855200
          }
        ]
      }
    ],
    "identifier": 75387570
  },
  {
    "context": [
      "Desired output is CSV format like this:\n\n```\nValue1,Value2,nArrayCount\nData1-0,Data2-0,Data3-0,3\nData1-1,Data2-1,Data3-1,2\n```",
      "All I need is a count.",
      "$ jq -r '[\"Value1\", \"Value2\", \"count\"],\n(.[] | [.value1, .value2, (.nArray|length)])\n| @csv' input.json",
      "jq -r '[\"Value1\", \"Value2\", \"Value3\", \"nArrayCount\"],\n       (.[] | [.value1, .value2, .value3, (.nArray|length)])\n       | join(\",\")' input.json"
    ],
    "utterance": "Produce a CSV listing value1, value2, value3, and the count of items in nArray for each object in the input.",
    "expressions": [
      "[\"Value1\", \"Value2\", \"Value3\", \"nArrayCount\"], (.[] | [.value1, .value2, .value3, (.nArray|length)]) | @csv",
      "[\"Value1\", \"Value2\", \"Value3\", \"nArrayCount\"], (.[] | [.value1, .value2, .value3, (.nArray|length)]) | join(\",\")"
    ],
    "data": [
      {
        "input": [
          {
            "value1": "Data1-0",
            "value2": "Data2-0",
            "nArray": [
              {
                "nValue1": "nData1-0a",
                "nValue2": "nData2-0a"
              },
              {
                "nValue1": "nData1-0b",
                "nValue2": "nData2-0a"
              },
              {
                "nValue1": "nData1-0c",
                "nValue2": "nData2-0a"
              }
            ],
            "value3": "Data3-0"
          },
          {
            "value1": "Data1-1",
            "value2": "Data2-1",
            "nArray": [
              {
                "nValue1": "nData1-1a",
                "nValue2": "nData2-1a"
              },
              {
                "nValue1": "nData1-1b",
                "nValue2": "nData2-1a"
              }
            ],
            "value3": "Data3-1"
          }
        ],
        "output": [
          [
            "Value1",
            "Value2",
            "Value3",
            "nArrayCount"
          ],
          [
            "Data1-0",
            "Data2-0",
            "Data3-0",
            3
          ],
          [
            "Data1-1",
            "Data2-1",
            "Data3-1",
            2
          ]
        ]
      }
    ],
    "identifier": 75391528
  },
  {
    "context": [
      "How to filter all messages with pattern \"DHCPREQUEST\" in comand line?",
      "The result I need to get is: DHCPREQUEST received (STATE_RENEWING) for 192.168.0.12 from b1:00:00:02:e1:2f.",
      "You can use `index` for testing if a string contains another.",
      "jq -r '.log[].message.message | select(index(\"DHCPREQUEST\"))'"
    ],
    "utterance": "Return all values of the message field containing the substring DHCPREQUEST.",
    "expressions": [
      ".log[].message.message | select(index(\"DHCPREQUEST\"))"
    ],
    "data": [
      {
        "input": {
          "log": {
            "52911": {
              "message": {
                "level": "Info",
                "label": "I",
                "message": "DHCPREQUEST received (STATE_RENEWING) for 192.168.0.12 from b1:00:00:02:e1:2f. "
              },
              "timestamp": "Feb 10 13:06:14",
              "ident": "ndhcps",
              "id": 52911
            },
            "52912": {
              "message": {
                "level": "Info",
                "label": "I",
                "message": "sending ACK of 192.168.0.12 to b1:00:00:02:e1:2f. "
              },
              "timestamp": "Feb 10 13:06:14",
              "ident": "ndhcps",
              "id": 52912
            }
          }
        },
        "output": "DHCPREQUEST received (STATE_RENEWING) for 192.168.0.12 from b1:00:00:02:e1:2f. "
      }
    ],
    "identifier": 75409608
  },
  {
    "context": [
      "I am required to print each objects under \"Metrics\" in a single line like below -\nCWAgent|disk_used_percent|path:/aem|host:uat2-author01.uat.cloud.abc.com.au|device:mapper/aem-aem|fstype:ext4\nCWAgent|mem_used_percent|host:uat2-dispatch02.uat.cloud.abc.com.au",
      "jq -r '.Metrics[] | [.Namespace, .MetricName] + (.Dimensions | map(\"\\(.Name):\\(.Value)\")) | join(\"|\")' input.json"
    ],
    "utterance": "Print each object under Metrics as a single line, listing Namespace, MetricName, and all Dimensions as Name:Value pairs separated by vertical bars.",
    "expressions": [
      ".Metrics[] | [.Namespace, .MetricName] + (.Dimensions | map(\"\u001b[38;5;245m\\(.Name):\\(.Value)\u001b[0m\")) | join(\"|\")"
    ],
    "data": [
      {
        "input": {
          "Metrics": [
            {
              "Namespace": "CWAgent",
              "MetricName": "disk_used_percent",
              "Dimensions": [
                {
                  "Name": "path",
                  "Value": "/aem"
                },
                {
                  "Name": "host",
                  "Value": "uat2-author01.uat.cloud.abc.com.au"
                },
                {
                  "Name": "device",
                  "Value": "mapper/aem-aem"
                },
                {
                  "Name": "fstype",
                  "Value": "ext4"
                }
              ]
            },
            {
              "Namespace": "CWAgent",
              "MetricName": "mem_used_percent",
              "Dimensions": [
                {
                  "Name": "host",
                  "Value": "uat2-dispatch02.uat.cloud.abc.com.au"
                }
              ]
            }
          ]
        },
        "output": [
          "CWAgent|disk_used_percent|path:/aem|host:uat2-author01.uat.cloud.abc.com.au|device:mapper/aem-aem|fstype:ext4",
          "CWAgent|mem_used_percent|host:uat2-dispatch02.uat.cloud.abc.com.au"
        ]
      }
    ],
    "identifier": 75406356
  },
  {
    "context": [
      "Now I want to update array `C` with new key:value pair. But, if the any of the key already exists then it's value should be updated.",
      "In this case the item `Z` already exists in `test_data.json` but `update` has new value for the item.",
      "The `.C` array and the `$update` array both have arrays as items. You need to consider their first item to be a unique key, so that clashes can lead to overwrites.",
      "One way could be turning them into an `INDEX` object first, then `add` up those, and retrieve their items back into an array:",
      "jq --argjson val \"$update\" '.C |= [[., $val | INDEX(.[0])] | add[]]' test_data.json"
    ],
    "utterance": "Update array C by merging in new items; if an item's key (first value) exists, replace its value with the update, else add the new item.",
    "expressions": [
      ".C |= [[., $val] | INDEX(.[0]) | add[]]"
    ],
    "data": [
      {
        "input": {
          "A": "12",
          "B": "34",
          "C": [
            [
              "X",
              "test1"
            ],
            [
              "Y",
              "test2"
            ],
            [
              "Z",
              "test3"
            ]
          ]
        },
        "output": {
          "A": "12",
          "B": "34",
          "C": [
            [
              "X",
              "test1"
            ],
            [
              "Y",
              "test2"
            ],
            [
              "Z",
              "test4"
            ],
            [
              "D",
              "test5"
            ],
            [
              "E",
              "test6"
            ]
          ]
        }
      }
    ],
    "identifier": 75412631
  },
  {
    "context": [
      "Normally, the output of that command contains a JSON key/value pair like the following:\r\n\r\n    \"path\": \"Test\\\\Sprint1\"",
      "But after capturing the STDOUT into that iteration variable, if I do\r\n\r\n    echo \"$iteration\"\r\nThat key/value pair becomes\r\n\r\n    \"path\": \"Test\\Sprint1\"",
      "And if I attempt to use jq on that output, it breaks because it's not recognized as valid JSON any longer.",
      "The portable way to deal with such problems is to use `printf` instead of `echo`:\r\n\r\n    printf %s\\\\n \"$iteration\""
    ],
    "utterance": "Preserve all backslashes in string values captured from a command's output to ensure validity for further processing.",
    "expressions": [
      "printf %s\\n \"$iteration\" | jq ..."
    ],
    "identifier": 75415079
  },
  {
    "context": [
      "What I want is to take all those messages out from the three arrays, put them in one array while adding an extra attribute to know where each message came from (`error`, `info` or `success`) and finally order them in asc order by their id.",
      "jq '._internal_messages |= (to_entries | map({type: .key} + .value[]) | sort_by(.id))'"
    ],
    "utterance": "Combine all messages from the 'error', 'info', and 'success' arrays into a single array, add a 'type' field indicating their origin, and sort the result in ascending order by id.",
    "expressions": [
      "._internal_messages |= (to_entries | map({type: .key} + .value[]) | sort_by(.id))"
    ],
    "data": [
      {
        "input": {
          "_internal_messages": {
            "error": [
              {
                "date": "16:12:30 - 07/02/2023",
                "id": 1,
                "origin": "A",
                "text": "This is an error message"
              },
              {
                "date": "16:12:31 - 07/02/2023",
                "id": 5,
                "origin": "A",
                "text": "This is a second error message"
              }
            ],
            "info": [
              {
                "date": "16:12:29 - 07/02/2023",
                "id": 0,
                "origin": "A",
                "text": "This is an info message"
              },
              {
                "date": "16:12:30 - 07/02/2023",
                "id": 4,
                "origin": "C",
                "text": "This is a second info message"
              }
            ],
            "success": [
              {
                "date": "16:12:30 - 07/02/2023",
                "id": 2,
                "origin": "B",
                "text": "This is a success message"
              },
              {
                "date": "16:12:30 - 07/02/2023",
                "id": 3,
                "origin": "B",
                "text": "This is a second success message"
              },
              {
                "date": "16:12:31 - 07/02/2023",
                "id": 6,
                "origin": "C",
                "text": "This is a third success message"
              }
            ]
          }
        },
        "output": {
          "_internal_messages": [
            {
              "type": "info",
              "date": "16:12:29 - 07/02/2023",
              "id": 0,
              "origin": "A",
              "text": "This is an info message"
            },
            {
              "type": "error",
              "date": "16:12:30 - 07/02/2023",
              "id": 1,
              "origin": "A",
              "text": "This is an error message"
            },
            {
              "type": "success",
              "date": "16:12:30 - 07/02/2023",
              "id": 2,
              "origin": "B",
              "text": "This is a success message"
            },
            {
              "type": "success",
              "date": "16:12:30 - 07/02/2023",
              "id": 3,
              "origin": "B",
              "text": "This is a second success message"
            },
            {
              "type": "info",
              "date": "16:12:30 - 07/02/2023",
              "id": 4,
              "origin": "C",
              "text": "This is a second info message"
            },
            {
              "type": "error",
              "date": "16:12:31 - 07/02/2023",
              "id": 5,
              "origin": "A",
              "text": "This is a second error message"
            },
            {
              "type": "success",
              "date": "16:12:31 - 07/02/2023",
              "id": 6,
              "origin": "C",
              "text": "This is a third success message"
            }
          ]
        }
      }
    ],
    "identifier": 75379682
  },
  {
    "context": [
      "But you\u2019d want to use assignment rather than the sort of `{ ... }` syntax like so:",
      "jq --argjson node_bootstrap_status \"$value\" '.node_bootstrap_status = $node_bootstrap_status' \"$node_info_file.tmp\" > \"$node_info_file\"",
      "Set property key with: '.node_bootstrap_status = ...'",
      "I tested this with empty JSON, and with other contents, and it worked as expected."
    ],
    "utterance": "Update or add a field named node_bootstrap_status with a given boolean value, preserving all other existing fields in the object.",
    "expressions": [
      ".node_bootstrap_status = $node_bootstrap_status"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "config_version": 2
        },
        "output": {
          "foo": "bar",
          "config_version": 2,
          "node_bootstrap_status": true
        }
      },
      {
        "input": {},
        "output": {
          "node_bootstrap_status": false
        }
      }
    ],
    "identifier": 75417863
  },
  {
    "context": [
      "I\u2019m trying to extract all the IDs (`id`) of objects without the `contentType` attribute from the following `JSON`:",
      "Expected result:",
      "[\"BT-03\", \"BT-Care\"] or even better to iterate down in the nested object [\"BT-03\", \"BT-Care\", \"BT-10\"]",
      "You could traverse the document tree using `..`, filter for `objects`, and `select` by all your filters.",
      "Wrap that in array brackets to get an array.",
      "[.. | objects | select(\n  (has(\"contentType\") | not) and has(\"id\") and (.id | startswith(\"BT\"))\n).id]"
    ],
    "utterance": "Get all id values that start with BT from objects that do not have a contentType attribute, including in nested structures.",
    "expressions": [
      "[.. | objects | select((has(\"contentType\") | not) and has(\"id\") and (.id | startswith(\"BT\"))).id]"
    ],
    "data": [
      {
        "input": {
          "version": "1.5.0",
          "metadata": {
            "version": "1.5.0",
            "createdOn": "2023-01-01"
          },
          "fileId": "1",
          "CanBeAnyName": [
            {
              "id": "BT-02",
              "contentType": "file",
              "readOnly": true
            },
            {
              "id": "BT-03",
              "readOnly": true
            }
          ],
          "AlsoCanBeAnyName": [
            {
              "id": "BT",
              "contentType": "empty"
            },
            {
              "contentType": "group",
              "content": [
                {
                  "id": "BT-Care",
                  "_repeatable": true,
                  "content": [
                    {
                      "id": "BT-90-care",
                      "contentType": "group",
                      "content": [
                        {
                          "id": "GR-300-analyze",
                          "contentType": "field"
                        },
                        {
                          "id": "BT-10"
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "BT-03",
          "BT-Care",
          "BT-10"
        ]
      }
    ],
    "identifier": 75413221
  },
  {
    "context": [
      "How to make a bash array from this JSON using jq",
      "I need to get all object values with a loop (3000 objects) so I will be like this :",
      "index(0) username: abc.com , name: ABC",
      "index(1) username: def.com , name: DEF"
    ],
    "utterance": "Extract the username and name values from each object, outputting them in order for use in a loop.",
    "expressions": [
      ".[] | \"username: \"+.username+\", name: \"+.name"
    ],
    "data": [
      {
        "input": [
          {
            "username": "abc@com",
            "name": "ABC",
            "given_name": "DotCom",
            "password": "iDWtCEKiA#!@345",
            "email": "abc@com"
          },
          {
            "username": "def@com",
            "name": "DEF",
            "given_name": "DotCom",
            "password": "iDWtCEKiA#!@345",
            "email": "def@com"
          }
        ],
        "output": [
          "username: abc@com, name: ABC",
          "username: def@com, name: DEF"
        ]
      }
    ],
    "identifier": 75419387
  },
  {
    "context": [
      "I want to create a file with 830 values in each file and create as many files as it creates. In order to achieve this I need it in the below format.",
      "Each step, however, is very easy.",
      "The first step uses jq with the -c option to create a JSONLines file with the JSON objects you want:",
      "< input.json jq -c '\n  (.Changes | _nwise(830)) as $C   # 830 per problem statement\n  | .Changes = $C\n' > output.jsonl"
    ],
    "utterance": "Split the top-level object so that each output contains the original 'Comment' key and a 'Changes' array with at most 830 items, producing as many files as needed.",
    "expressions": [
      "jq -c '(.Changes | _nwise(830)) as $C | .Changes = $C' input.json"
    ],
    "data": [
      {
        "input": {
          "Comment": "json data",
          "Changes": [
            {
              "Action": "DELETE",
              "ResourceRecordSet": {
                "Name": "record1",
                "Type": "CNAME",
                "SetIdentifier": "record1-ap-northeast",
                "GeoLocation": {
                  "CountryCode": "JP"
                },
                "TTL": 60,
                "ResourceRecords": [
                  {
                    "Value": "record1"
                  }
                ],
                "HealthCheckId": "ID"
              }
            },
            {
              "Action": "DELETE",
              "ResourceRecordSet": {
                "Name": "record2",
                "Type": "CNAME",
                "SetIdentifier": "record2-ap-south",
                "GeoLocation": {
                  "CountryCode": "SG"
                },
                "TTL": 60,
                "ResourceRecords": [
                  {
                    "Value": "record2"
                  }
                ],
                "HealthCheckId": "ID"
              }
            },
            {
              "Action": "DELETE",
              "ResourceRecordSet": {
                "Name": "record3",
                "Type": "CNAME",
                "SetIdentifier": "record3-ap-west",
                "GeoLocation": {
                  "CountryCode": "IN"
                },
                "TTL": 60,
                "ResourceRecords": [
                  {
                    "Value": "record3"
                  }
                ],
                "HealthCheckId": "ID"
              }
            },
            {
              "Action": "DELETE",
              "ResourceRecordSet": {
                "Name": "record4.",
                "Type": "CNAME",
                "SetIdentifier": "record4",
                "GeoLocation": {
                  "CountryCode": "*"
                },
                "TTL": 60,
                "ResourceRecords": [
                  {
                    "Value": "record4-ap-west"
                  }
                ],
                "HealthCheckId": "ID"
              }
            }
          ]
        },
        "output": [
          {
            "Comment": "json data",
            "Changes": [
              {
                "Action": "DELETE",
                "ResourceRecordSet": {
                  "Name": "record1",
                  "Type": "CNAME",
                  "SetIdentifier": "record1-ap-northeast",
                  "GeoLocation": {
                    "CountryCode": "JP"
                  },
                  "TTL": 60,
                  "ResourceRecords": [
                    {
                      "Value": "record1"
                    }
                  ],
                  "HealthCheckId": "ID"
                }
              },
              {
                "Action": "DELETE",
                "ResourceRecordSet": {
                  "Name": "record2",
                  "Type": "CNAME",
                  "SetIdentifier": "record2-ap-south",
                  "GeoLocation": {
                    "CountryCode": "SG"
                  },
                  "TTL": 60,
                  "ResourceRecords": [
                    {
                      "Value": "record2"
                    }
                  ],
                  "HealthCheckId": "ID"
                }
              },
              {
                "Action": "DELETE",
                "ResourceRecordSet": {
                  "Name": "record3",
                  "Type": "CNAME",
                  "SetIdentifier": "record3-ap-west",
                  "GeoLocation": {
                    "CountryCode": "IN"
                  },
                  "TTL": 60,
                  "ResourceRecords": [
                    {
                      "Value": "record3"
                    }
                  ],
                  "HealthCheckId": "ID"
                }
              },
              {
                "Action": "DELETE",
                "ResourceRecordSet": {
                  "Name": "record4.",
                  "Type": "CNAME",
                  "SetIdentifier": "record4",
                  "GeoLocation": {
                    "CountryCode": "*"
                  },
                  "TTL": 60,
                  "ResourceRecords": [
                    {
                      "Value": "record4-ap-west"
                    }
                  ],
                  "HealthCheckId": "ID"
                }
              }
            ]
          }
        ]
      }
    ],
    "identifier": 75350077
  },
  {
    "context": [
      "And I want to convert into this\n\n```\n {\n\t\"model\": [{\n\t\t\t\"id\": \"an-id\",\n\t\t\t\"path\": [\n\t\t\t\t\"mypath1.txt\"\n\t\t\t],\n\t\t\t\"model\": \"foo\",\n\t\t\t\"alternative_model\": \"I am a computed value out of <foo>\"\n\t\t},\n\t\t{\n\t\t\t\"id\": \"an-id2\",\n\t\t\t\"path\": [\n\t\t\t\t\"mypath1.txt\"\n\t\t\t],\n\t\t\t\"model\": \"foo2\",\n\t\t\t\"alternative_model\": \"I am a computed value out of <foo2>\"\n\t\t}\n\t]\n}\n```",
      "here I'd like to do something like \"eval ./myscript $model\"",
      "As `jq` does not allow to evaluate shell commands, you need something like :",
      "jq --argjson amodels \"$(alternative-models)\" '.model|map({\n        id, path, model, \"alternative_model\": $amodels[.id] }\n)' $input"
    ],
    "utterance": "For each object in 'model', add an 'alternative_model' field whose value is the output of an external script called with the object's 'model' value as an argument.",
    "expressions": [
      ".model|map({id, path, model, \"alternative_model\": $amodels[.id]})"
    ],
    "data": [
      {
        "input": {
          "model": [
            {
              "id": "an-id",
              "path": [
                "mypath1.txt"
              ],
              "model": "foo"
            },
            {
              "id": "an-id2",
              "path": [
                "mypath1.txt"
              ],
              "model": "foo2"
            }
          ]
        },
        "output": [
          {
            "id": "an-id",
            "path": [
              "mypath1.txt"
            ],
            "model": "foo",
            "alternative_model": "I am a computed value out of <foo>"
          },
          {
            "id": "an-id2",
            "path": [
              "mypath1.txt"
            ],
            "model": "foo2",
            "alternative_model": "I am a computed value out of <foo2>"
          }
        ]
      }
    ],
    "identifier": 75419250
  },
  {
    "identifier": 75447527
  },
  {
    "context": [
      "I\u2019d like to use JQ (with some incantation) to change this to put all the `datapoints` objects on a single line. E.g.",
      "[ { \"target\": \"some-string\", \"datapoints\": [[ 123, 456 ], [ 789, 101112 ]] } ]",
      "jq '[].datapoints |= \"<q>\\(tojson)</q>\"' |",
      "jq -Rr 'sub(\"<q>(?&<s>.*)</q>\"; .s)'",
      "jq 'map(.datapoints |= \"\\u001b\\(tojson)\\u001b\")' test.json |  perl -pe 's/\"\\\\u001b(.*?)\\\\u001b\"/$1/g'"
    ],
    "utterance": "Format the output to print the 'datapoints' array as a single-line array, leaving other object fields formatted as usual.",
    "expressions": [
      "jq '.[].datapoints |= \"<q>\\(tojson)</q>\"' | jq -Rr 'sub(\"<q>(?<s>.*)</q>\"; .s)'",
      "jq 'map(.datapoints |= \"\\u001b\\(tojson)\\u001b\")' test.json | perl -pe 's/\"\\\\u001b(.*?)\\\\u001b\"/$1/g'"
    ],
    "data": [
      {
        "input": [
          {
            "target": "some-string",
            "datapoints": [
              [
                123,
                456
              ],
              [
                789,
                101112
              ]
            ]
          }
        ],
        "output": [
          {
            "target": "some-string",
            "datapoints": [
              [
                123,
                456
              ],
              [
                789,
                101112
              ]
            ]
          }
        ]
      }
    ],
    "identifier": 75428312
  },
  {
    "context": [
      "I am trying to extract the data to a nested JSON-tree structure like",
      "And I am trying to extract the data to a nested JSON-tree structure like",
      "[ .[] |  { name: .Key, description: .Value, children: ( [.Key | split(\"/\")] | .[0] | to_entries ) } ]",
      "Other than that, you can rest assured that jq is up to the task, though it would require some expertise in programming generally, or at least fluency with jq."
    ],
    "utterance": "Transform a flat list of objects with slash-delimited key strings into a deeply nested tree where each path segment becomes a hierarchy level and each node has a unique id and path.",
    "expressions": [],
    "data": [
      {
        "input": [
          {
            "Key": "fruits/red/apple",
            "Value": "Red apples"
          },
          {
            "Key": "fruits/green/lime",
            "Value": "Green Limes"
          },
          {
            "Key": "fruits/blue/berries/blueberry",
            "Value": "Blue Berries"
          },
          {
            "Key": "vegetables/red/tomato",
            "Value": "Red Tomatoes"
          },
          {
            "Key": "vegetables/green/cucumber",
            "Value": "Green Cucumbers"
          }
        ],
        "output": {
          "fruits": {
            "id": 1,
            "name": "fruits",
            "children": [
              {
                "id": 2,
                "name": "red",
                "path": "1.2",
                "children": [
                  {
                    "id": 3,
                    "name": "apple",
                    "path": "1.2.3"
                  }
                ]
              },
              {
                "id": 4,
                "name": "green",
                "path": "1.4",
                "children": [
                  {
                    "id": 5,
                    "name": "lime",
                    "path": "1.4.5"
                  }
                ]
              },
              {
                "id": 6,
                "name": "blue",
                "path": "1.6",
                "children": [
                  {
                    "id": 7,
                    "name": "berries",
                    "path": "1.6.7",
                    "children": [
                      {
                        "id": 8,
                        "name": "blueberry",
                        "path": "1.6.7.8"
                      }
                    ]
                  }
                ]
              }
            ]
          },
          "vegetables": {
            "id": 9,
            "name": "vegetables",
            "children": [
              {
                "id": 10,
                "name": "red",
                "path": "9.10",
                "children": [
                  {
                    "id": 11,
                    "name": "tomato",
                    "path": "9.10.11"
                  }
                ]
              },
              {
                "id": 12,
                "name": "green",
                "path": "9.12",
                "children": [
                  {
                    "id": 13,
                    "name": "cucumber",
                    "path": "9.12.13"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 75425014
  },
  {
    "context": [
      "I have a bash `$string` containing the values: `abc,def` and a *file.json* looking like this:",
      "I'm trying to update the city field with the values from the string to get this result:",
      "I'm trying this code but it doesn't work, any suggestions?",
      "$ string=abc,def",
      "jq --arg cities \"$string\" '[., ($cities / \",\")] | transpose | map(.[0] + {city: .[1]})' file.json",
      "string=\"abc,def\"",
      "jq --arg var \"$string\" '\n  reduce ($var / \",\" | to_entries)[] as {$key, $value} (.;\n    .[$key].city = $value\n  )\n'",
      "jq --arg var \"$string\" '\n  reduce ($var / \",\" | to_entries)[] as $item (.;\n    .[$item.key].city = $item.value\n  )\n'"
    ],
    "utterance": "Update each object's city field to the corresponding value from the comma-separated string abc,def.",
    "expressions": [
      "[., ($cities / \",\")] | transpose | map(.[0] + {city: .[1]})",
      "reduce ($var / \",\" | to_entries)[] as {$key, $value} (.;\n  .[$key].city = $value\n)",
      "reduce ($var / \",\" | to_entries)[] as $item (.;\n  .[$item.key].city = $item.value\n)"
    ],
    "data": [
      {
        "input": [
          {
            "loc": "51.12345, 12.12345",
            "city": "CityName1"
          },
          {
            "loc": "65.12345, 15.12345",
            "city": "CityName2"
          }
        ],
        "output": [
          {
            "loc": "51.12345, 12.12345",
            "city": "abc"
          },
          {
            "loc": "65.12345, 15.12345",
            "city": "def"
          }
        ]
      }
    ],
    "identifier": 75435133
  },
  {
    "context": [
      "I want to append some content by using shell script.",
      "I want to append the content and output as following by using shell script (*.sh) How can I achieve this ?",
      ".components[].content |= .[0:1] + [{ link: \"test\" }] + .[1:]",
      "jq '.components[].content[1:1] = [{\"link\": \"test\"}]' test.json"
    ],
    "utterance": "Insert an object with specific content at index 1 of all 'components[].content' arrays, shifting existing elements to the right.",
    "expressions": [
      ".components[].content |= .[0:1] + [{ link: \"test\" }] + .[1:]",
      ".components[].content |= splice(1; {link: \"test\"})",
      ".components[].content[1:1] = [{\"link\": \"test\"}]",
      ".components[].content |= insertAt(1; {\"link\": \"test\"})"
    ],
    "data": [
      {
        "input": {
          "reference": "Json Test",
          "title": {
            "a": "Json Test"
          },
          "components": [
            {
              "reference": "Json Test",
              "type": "panel",
              "content": [
                {
                  "link": "abc/123",
                  "label": {
                    "a": "for test 123 - a",
                    "b": "for test 123 - b"
                  }
                },
                {
                  "link": "abc/456",
                  "label": {
                    "a": "for test 456 - a",
                    "b": "for test 456 - b"
                  }
                },
                {
                  "link": "abc/789",
                  "label": {
                    "a": "for test 789 - a",
                    "b": "for test 789 - b"
                  }
                }
              ]
            }
          ]
        },
        "output": {
          "reference": "Json Test",
          "title": {
            "a": "Json Test"
          },
          "components": [
            {
              "reference": "Json Test",
              "type": "panel",
              "content": [
                {
                  "link": "abc/123",
                  "label": {
                    "a": "for test 123 - a",
                    "b": "for test 123 - b"
                  }
                },
                {
                  "link": "abc/101112",
                  "label": {
                    "a": "for test 101112 - a",
                    "b": "for test 101112 - b"
                  }
                },
                {
                  "link": "abc/456",
                  "label": {
                    "a": "for test 456 - a",
                    "b": "for test 456 - b"
                  }
                },
                {
                  "link": "abc/789",
                  "label": {
                    "a": "for test 789 - a",
                    "b": "for test 789 - b"
                  }
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 75445788
  },
  {
    "context": [
      "I have a json file `input.json` thus:\r\n\r\n    {\r\n       \"foo\":{\r\n           \"prefix\":\"abc\",\r\n           \"body\":[1,2,3]\r\n       },\r\n       \"bar\":{\r\n           \"prefix\":\"def\",\r\n           \"body\":[4,5,6]    \r\n       }\r\n    }\r\n\r\nI would like to sort it by the outer object names, with `\"bar\"` coming before `\"foo\"` in alphabetical order like so:\r\n\r\n    {\r\n       \"bar\":{\r\n           \"prefix\":\"def\",\r\n           \"body\":[4,5,6]    \r\n       },\r\n       \"foo\":{\r\n           \"prefix\":\"abc\",\r\n           \"body\":[1,2,3]\r\n       }\r\n    }\r\n\r\nto produce file `output.json`.",
      "Using `jq`, you could use the `keys` built-in to get the key names in sorted order and form the corresponding value object",
      "Note that `jq` does have a field `--sort-keys` option, which **cannot** be used here, as it internally sorts the inner level objects as well.",
      "Here's a variable-free jq solution:\r\nto_entries | sort_by(.key) | from_entries"
    ],
    "utterance": "Sort the top-level object by its property names so that outer keys are in alphabetical order.",
    "expressions": [
      "to_entries | sort_by(.key) | from_entries",
      "keys[] as $k | { ($k): .[$k] }"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "prefix": "abc",
            "body": [
              1,
              2,
              3
            ]
          },
          "bar": {
            "prefix": "def",
            "body": [
              4,
              5,
              6
            ]
          }
        },
        "output": {
          "bar": {
            "prefix": "def",
            "body": [
              4,
              5,
              6
            ]
          },
          "foo": {
            "prefix": "abc",
            "body": [
              1,
              2,
              3
            ]
          }
        }
      }
    ],
    "identifier": 75450348
  },
  {
    "context": [
      "USERNAME=$(echo \"$OUTPUT\" | jq -r '.[] | .name')",
      "My restapi result has the below output.",
      "[\n  {\n    \"url\": \"#/systemadm/groups/uuid-d6e4e05\",\n    \"options\": {},\n    \"group_id\": 313,\n    \"owner\": \"abc-123-mec\",\n    \"owner_id\": \"ad1337884\",\n    \"id\": \"c258d7b330\",\n    \"name\": \"abc-group\"\n  },\n  {\n    \"options\": {},\n    \"id\": \"global%3Regmebers\",\n    \"name\": \"Udata-123\"\n  },\n  {\n    \"url\": \"#/systemadm/groups/uuid-38943000\",\n    \"options\": {},\n    \"group_id\": 910,\n    \"owner\": \"framework-abcc\",\n    \"owner_id\": \"78d4472b738bc\",\n    \"id\": \"38943000057a\",\n    \"name\": \"def-group\"\n  }",
      "jq can only process valid JSON."
    ],
    "utterance": "Extract all values of the 'name' field from each element in an array of objects.",
    "expressions": [
      ".[] | .name",
      ".[].name"
    ],
    "data": [
      {
        "input": [
          {
            "url": "#/systemadm/groups/uuid-d6e4e05",
            "options": {},
            "group_id": 313,
            "owner": "abc-123-mec",
            "owner_id": "ad1337884",
            "id": "c258d7b330",
            "name": "abc-group"
          },
          {
            "options": {},
            "id": "global%3Regmebers",
            "name": "Udata-123"
          },
          {
            "url": "#/systemadm/groups/uuid-38943000",
            "options": {},
            "group_id": 910,
            "owner": "framework-abcc",
            "owner_id": "78d4472b738bc",
            "id": "38943000057a",
            "name": "def-group"
          }
        ],
        "output": [
          "abc-group",
          "Udata-123",
          "def-group"
        ]
      }
    ],
    "identifier": 75458568
  },
  {
    "context": [
      "I want to replace the host objects value with an array of different values, so it looks like this:",
      "You can do it with a single jq command:",
      "jq --arg value \"$objectshost\" '.objects.host = ($value / \",\")' ./test.json > ./test.json.tmp",
      "If you already have a JSON array, you must use `--argjson` and not `--arg`. `--arg` always creates a variable of type string, `--argjson` however parses the value as JSON entity.",
      "jq --argjson value \"$objectshost_array\" '.objects.host = $value' ./test.json > ./test.json.tmp"
    ],
    "utterance": "Replace the value of the 'host' key inside 'objects' with an array of specified strings instead of a single value.",
    "expressions": [
      ".objects.host = ($value / \",\")",
      ".objects.host = $value"
    ],
    "data": [
      {
        "input": {
          "objects": {
            "type": "foo",
            "host": "1.1.1.1",
            "port": "1234"
          }
        },
        "output": {
          "objects": {
            "type": "foo",
            "host": [
              "1.1.1.1",
              "2.2.2.2"
            ],
            "port": "1234"
          }
        }
      }
    ],
    "identifier": 75459038
  },
  {
    "context": [
      "Id like to modify each element of the reference array so that the reference appears twice. I&#39;d like to achieve:\r\n```\r\n[\r\n    {\r\n        &quot;title&quot;: &quot;Title1&quot;,\r\n        &quot;reference&quot;: [\r\n            &quot;123 is 123&quot;\r\n        ]\r\n    },\r\n    {\r\n        &quot;title&quot;: &quot;Title2&quot;,\r\n        &quot;reference&quot;: [\r\n            &quot;234 is 234&quot;,\r\n            &quot;345 is 345&quot;\r\n        ]\r\n    }\r\n]\r\n```",
      "map(.reference |= map(. + \" is \" + .))",
      "jq '[].reference[] |= \"\\(.) is \\(.)\"'"
    ],
    "utterance": "Modify each element of the reference field so that each value becomes '<value> is <value>' in every object of the array.",
    "expressions": [
      "map(.reference |= map(. + \" is \" + .))",
      ".[].reference[] |= \"\\(.) is \\(.)\""
    ],
    "data": [
      {
        "input": [
          {
            "title": "Title1",
            "reference": [
              "123"
            ]
          },
          {
            "title": "Title2",
            "reference": [
              "234",
              "345"
            ]
          }
        ],
        "output": [
          {
            "title": "Title1",
            "reference": [
              "123 is 123"
            ]
          },
          {
            "title": "Title2",
            "reference": [
              "234 is 234",
              "345 is 345"
            ]
          }
        ]
      }
    ],
    "identifier": 75461609
  },
  {
    "context": [
      "Each file has a json property called qlist that i want to remove from that file.",
      ".\\jq.exe 'del(.qlist)' $file",
      "the jq part works fine",
      "./jq 'del(.qlist)' $file > $file"
    ],
    "utterance": "Remove the qlist property from each file in a directory.",
    "expressions": [
      "del(.qlist)"
    ],
    "identifier": 75478107
  },
  {
    "context": [
      "Take the first item using `.`, and the second using `input` (prepended by `try` to handle cases of not enough input items). Then, wrap them both into array brackets, and provide the `-c` option for compact output. jq will work through its whole input one by one (or two by two).",
      "./messages.sh | jq -c '[., try input]'",
      "What if I want more objects in the array than 2? For example, 3, 10, 100?",
      "You can surround the array body with `limit`, and use `inputs` instead (note the `s`) to fetch more than just one item:",
      "./messages.sh | jq -c '[limit(3; ., try inputs)]'",
      "Use `slurp` with `_nwise(2)` to chunk into parts of 2:",
      "jq --slurp --compact-output '_nwise(2)' <<< $(./messages.sh)",
      "Here is a stream-oriented, generic and portable def of nwise:",
      "def nwise(stream; $n):",
      "nwise(inputs; 2)"
    ],
    "utterance": "Group consecutive objects from the input stream into arrays of a specified size, outputting each array on its own line.",
    "expressions": [
      "[., try input]",
      "[limit(3; ., try inputs)]",
      "_nwise(2)",
      "nwise(inputs; 2)"
    ],
    "data": [
      {
        "input": [
          {
            "a": "v1"
          },
          {
            "b": "v2"
          },
          {
            "c": "v3"
          },
          {
            "d": "v4"
          }
        ],
        "output": [
          [
            {
              "a": "v1"
            },
            {
              "b": "v2"
            }
          ],
          [
            {
              "c": "v3"
            },
            {
              "d": "v4"
            }
          ]
        ]
      },
      {
        "input": [
          {
            "a": "v1"
          },
          {
            "b": "v2"
          },
          {
            "c": "v3"
          },
          {
            "d": "v4"
          }
        ],
        "output": [
          [
            {
              "a": "v1"
            },
            {
              "b": "v2"
            },
            {
              "c": "v3"
            }
          ],
          [
            {
              "d": "v4"
            }
          ]
        ]
      }
    ],
    "identifier": 75473591
  },
  {
    "context": [
      "Looking to take Source JSON and output to CSV as shown:",
      "Desired CSV:",
      "\"NewYork\",\"Jetta\",\"Steve;Roger\",\"Home;Office\",\"9a-7p;3p-6p\"",
      "\"NewYork\",\"Ford\",\"John\",\"Home\",\"12p-5p\"",
      "You\u2019re looking for something like this:\n``` jq\n.[] | [.State] + (\n  .Drivers | group_by(.Car)[] | [.[0].Car] + (\n    map(.Users) | add | [\n      map(.Name),\n      map(.Details.Location),\n      map(.Details.Time)\n    ] | map(join(\";\"))\n  )\n) | @csv\n```",
      "Output (with `--raw-output`:\n```json\n\"NewYork\",\"John\",\"Home\",\"12p-5p\"\n\"NewYork\",\"Steve;Roger\",\"Home;Office\",\"9a-7p;3p-6p\"\n```"
    ],
    "utterance": "Output each state and car, concatenating all user names, locations, and times for each car, each field joined by semicolons, as CSV rows.",
    "expressions": [
      ".[] | [.State] + ( .Drivers | group_by(.Car)[] | [.[0].Car] + ( map(.Users) | add | [ map(.Name), map(.Details.Location), map(.Details.Time) ] | map(join(\";\")) ) ) | @csv",
      "map(.State as $s | (.Drivers | group_by(.Car))[] | [ $s, (map(.Users[].Name) | join(\";\")), (map(.Users[].Details.Location) | join(\";\")), (map(.Users[].Details.Time) | join(\";\")) ])[] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "State": "NewYork",
            "Drivers": [
              {
                "Car": "Jetta",
                "Users": [
                  {
                    "Name": "Steve",
                    "Details": {
                      "Location": "Home",
                      "Time": "9a-7p"
                    }
                  }
                ]
              },
              {
                "Car": "Jetta",
                "Users": [
                  {
                    "Name": "Roger",
                    "Details": {
                      "Location": "Office",
                      "Time": "3p-6p"
                    }
                  }
                ]
              },
              {
                "Car": "Ford",
                "Users": [
                  {
                    "Name": "John",
                    "Details": {
                      "Location": "Home",
                      "Time": "12p-5p"
                    }
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          "\"NewYork\",\"Jetta\",\"Steve;Roger\",\"Home;Office\",\"9a-7p;3p-6p\"",
          "\"NewYork\",\"Ford\",\"John\",\"Home\",\"12p-5p\""
        ]
      }
    ],
    "identifier": 75474323
  },
  {
    "context": [
      "I have this data:",
      "{ \"data\": [ { \"a\": 11, \"b\": 12, \"c\": 13 }, { \"a\": 21, \"b\": 22, \"c\": 23 }, { \"a\": 31, \"b\": 32, \"c\": 33 } ] }",
      "I want to collate it into arrays based on the key names like this:",
      "{ \"data\": [ { \"a\": [ 11, 21, 31 ] }, { \"b\": [ 12, 22, 32 ] }, { \"c\": [ 13, 23, 33 ] } ] }",
      "How do I do this for all keys?",
      "One way would be using `to_entries` to access the keys, then `group_by` for the grouping, and `map` to construct the final structure:",
      ".data |= (map(to_entries[]) | group_by(.key) | map({(first.key): map(.value)}))"
    ],
    "utterance": "Collate all values for each key in the array of objects under 'data', so that for each key there is an array of its values, each as a single-key object in the resulting data array.",
    "expressions": [
      ".data |= (map(to_entries[]) | group_by(.key) | map({(first.key): map(.value)}))"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "a": 11,
              "b": 12,
              "c": 13
            },
            {
              "a": 21,
              "b": 22,
              "c": 23
            },
            {
              "a": 31,
              "b": 32,
              "c": 33
            }
          ]
        },
        "output": {
          "data": [
            {
              "a": [
                11,
                21,
                31
              ]
            },
            {
              "b": [
                12,
                22,
                32
              ]
            },
            {
              "c": [
                13,
                23,
                33
              ]
            }
          ]
        }
      }
    ],
    "identifier": 75477628
  },
  {
    "context": [
      "Using JQ I am trying to turn this JSON:\n\n        [{\"field\": \"F1\",\"results\": [{\"details\": [\n        \t{\"name\": \"P1\",\"matches\": [\n        \t\t{\"displayName\": \"User1\",\"smtpAddress\": \"user1@foo.bar\"},\n        \t\t{\"displayName\": \"User2\",\"smtpAddress\": \"user2@foo.bar\"}\n        \t\t]\n        \t},\n        \t{\"name\": \"P2\",\"matches\": [\n        \t\t{\"displayName\": \"User3\",\"smtpAddress\": \"user3@foo.bar\"},\n        \t\t{\"displayName\": \"User4\",\"smtpAddress\": \"user4@foo.bar\"}\n        \t\t]\n        \t}]}]},\n        {\"field\": \"F2\",\"results\": [{\"details\": [\n        \t{\"name\": \"P3\",\"matches\": [\n        \t\t{\"displayName\": \"User1\",\"smtpAddress\": \"user1@foo.bar\"},\n        \t\t{\"displayName\": \"User5\",\"smtpAddress\": \"user5@foo.bar\"}\n        \t\t]\n        \t},\n        \t{\"name\": \"P4\",\"matches\": [\n        \t\t{\"displayName\": \"User6\",\"smtpAddress\": \"user6@foo.bar\"},\n        \t\t{\"displayName\": \"User7\",\"smtpAddress\": \"user7@foo.bar\"}\n        \t\t]\n        \t}]}]}]\n\ninto CSV like this.\n\n    \"F1\",\"P1\",\"User1 <user1@foo.bar>;User2 <user2@foo.bar>\"\n    \"F1\",\"P2\",\"User3 <user3@foo.bar>;User4 <user4@foo.bar>\"\n    \"F2\",\"P3\",\"User1 <user1@foo.bar>;User5 <user5@foo.bar>\"\n    \"F2\",\"P4\",\"User6 <user6@foo.bar>;User7 <user7@foo.bar>\"",
      "jq -r '.[]\n  | .field as $field\n  | (.results[].details[]\n     | [$field, .name] + \n       [([.matches[] | \"\\(.displayName) <\\(.smtpAddress)>\" ] | join(\";\")) ])\n  | @csv'"
    ],
    "utterance": "Produce a CSV where each row contains the field value, detail name, and a semicolon-separated list of formatted matches as \"Name <email>\".",
    "expressions": [
      ".[]\n  | .field as $field\n  | (.results[].details[]\n     | [$field, .name] + \n       [([.matches[] | \"\\(.displayName) <\\(.smtpAddress)>\" ] | join(\";\")) ])\n  | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "field": "F1",
            "results": [
              {
                "details": [
                  {
                    "name": "P1",
                    "matches": [
                      {
                        "displayName": "User1",
                        "smtpAddress": "user1@foo.bar"
                      },
                      {
                        "displayName": "User2",
                        "smtpAddress": "user2@foo.bar"
                      }
                    ]
                  },
                  {
                    "name": "P2",
                    "matches": [
                      {
                        "displayName": "User3",
                        "smtpAddress": "user3@foo.bar"
                      },
                      {
                        "displayName": "User4",
                        "smtpAddress": "user4@foo.bar"
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "field": "F2",
            "results": [
              {
                "details": [
                  {
                    "name": "P3",
                    "matches": [
                      {
                        "displayName": "User1",
                        "smtpAddress": "user1@foo.bar"
                      },
                      {
                        "displayName": "User5",
                        "smtpAddress": "user5@foo.bar"
                      }
                    ]
                  },
                  {
                    "name": "P4",
                    "matches": [
                      {
                        "displayName": "User6",
                        "smtpAddress": "user6@foo.bar"
                      },
                      {
                        "displayName": "User7",
                        "smtpAddress": "user7@foo.bar"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          "\"F1\",\"P1\",\"User1 <user1@foo.bar>;User2 <user2@foo.bar>\"",
          "\"F1\",\"P2\",\"User3 <user3@foo.bar>;User4 <user4@foo.bar>\"",
          "\"F2\",\"P3\",\"User1 <user1@foo.bar>;User5 <user5@foo.bar>\"",
          "\"F2\",\"P4\",\"User6 <user6@foo.bar>;User7 <user7@foo.bar>\""
        ]
      }
    ],
    "identifier": 75477073
  },
  {
    "context": [
      "I want to translate all the title values and message values (I use shell translate).",
      "I've noticed that this results in all the title values being the same, and all the message values being the same.",
      "I'm clearly using `jq` the wrong way, but am unsure how to correct."
    ],
    "utterance": "Individually update the title and message fields for each updateItem within content.macOS.releases using their index.",
    "expressions": [
      ".content.macOS.releases |= map(.updateItems |= map(.title = \"NEW_TITLE\" | .message = \"NEW_MESSAGE\"))"
    ],
    "data": [
      {
        "input": {
          "content": {
            "macOS": {
              "releases": [
                {
                  "version": "3.21",
                  "updateItems": [
                    {
                      "id": 1,
                      "title": "Automatic detection for inactivity is here",
                      "message": "We've finally added a feature long requested - Orby now detects when you've been inactive on your computer.  You can modify the maximum allowable inactive time through settings, or just turn it off if you don't need it",
                      "image": "https://static.image.png"
                    },
                    {
                      "id": 2,
                      "title": "In case you missed it... We have an iOS app \ud83e\uddd1\u200d\ud83d\udcbb \ud83d\ude4c",
                      "message": "It's far from perfect, but it's come a long way since we first pushed out version 1.0.  We don't that many users on it so far, but I'm hoping that it's useful.  Please send any feedback and feature requests my way",
                      "image": "https://static.image.png"
                    }
                  ]
                }
              ]
            },
            "iOS": {
              "releases": [
                {
                  "version": "1.31",
                  "updateItems": [
                    {
                      "image": "https://static.image.png",
                      "id": 1,
                      "link": "orbit://com.orbit:/settings",
                      "message": "Strict mode offers a fantastic new way to keep your focus and get more done.  To enable it, go to settings and toggle it on.  Now when you want to run a timer, put your device face down on a surface.  The timer will stop if you pick it up.",
                      "title": "Strict mode is here \ud83d\ude4c \u26a0\ufe0f \u26a0\ufe0f \u26a0\ufe0f"
                    }
                  ]
                }
              ]
            }
          }
        },
        "output": {
          "content": {
            "macOS": {
              "releases": [
                {
                  "version": "3.21",
                  "updateItems": [
                    {
                      "id": 1,
                      "title": "NEW_TITLE",
                      "message": "NEW_MESSAGE",
                      "image": "https://static.image.png"
                    },
                    {
                      "id": 2,
                      "title": "NEW_TITLE",
                      "message": "NEW_MESSAGE",
                      "image": "https://static.image.png"
                    }
                  ]
                }
              ]
            },
            "iOS": {
              "releases": [
                {
                  "version": "1.31",
                  "updateItems": [
                    {
                      "image": "https://static.image.png",
                      "id": 1,
                      "link": "orbit://com.orbit:/settings",
                      "message": "Strict mode offers a fantastic new way to keep your focus and get more done.  To enable it, go to settings and toggle it on.  Now when you want to run a timer, put your device face down on a surface.  The timer will stop if you pick it up.",
                      "title": "Strict mode is here \ud83d\ude4c \u26a0\ufe0f \u26a0\ufe0f \u26a0\ufe0f"
                    }
                  ]
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 75479247
  },
  {
    "context": [
      "I need a jq command, that will be executable in a shell, that outputs: the \"master.service\" (so that the certificate that will be running out is identifyable), followed by the hosts, followed by only \"cert_cn\", \"days_remaining\" and \"expiry\", as shown above.",
      "The problems i had so far, are the dots in \"master.service\" which made it impossible to to directly adress them.",
      "Also, first time posting, so if anything else is needed, or I need to remove something, please tell me!",
      "oscar@toreyes-i7:/tmp$ jq -r '.data[\"master.services\"] | keys_unsorted | .[]'  duda_jq_stackoverflow.json",
      "oscar@toreyes-i7:/tmp$ jq -r '.data[\"master.services\"][\"host1\"][] as $nodo | \"\\(\"cert_cn = \" + $nodo.cert_cn + \"\\n\" + \"days_remaining = \" +  ($nodo.days_remaining | tostring) + \"\\n\" + \"expiry \" + $nodo.expiry + \"\\n\")'  duda_jq_stackoverflow.json",
      "for CLAVE in $(jq -r '. as $datos | .data | keys_unsorted[] | select ( endswith(\".services\") )' $FICHERO_JSON)",
      "jq -r \".data[\\\"$CLAVE\\\"].$CLAVE2[] | \\\"  cert = \\(.cert_cn)\\\",\\\"  days_remaining = \\(.days_remaining)\\\",\\\"  expiry = \\(.expiry)\\\",\\\"  -----\\\" \"  $FICHERO_JSON"
    ],
    "utterance": "Extract for each service ending with '.services', the host names and for each host, list cert_cn, days_remaining, and expiry for all certificates.",
    "expressions": [
      ".data[\"master.services\"] | to_entries[] | {host: .key, certs: [.value[] | {cert_cn, days_remaining, expiry}]}",
      ".data[\"master.services\"] | to_entries[] | . as {key: $host, value: $certs} | $certs[] | {host: $host, cert_cn, days_remaining, expiry}",
      ".data[\"master.services\"] | to_entries[] | \"\\(.key): \\n\" + ( [.value[] | \"  cert_cn: \\(.cert_cn)\\n  days_remaining: \\(.days_remaining)\\n  expiry: \\(.expiry)\\n\" ] | join(\"\\n\") )"
    ],
    "data": [
      {
        "input": {
          "data": {
            "master.services": {
              "host1": [
                {
                  "cert_cn": "CN=host1-signer1:",
                  "days_remaining": 412,
                  "expiry": "2024-03-18 17:21:41",
                  "health": "ok",
                  "issuer": "CN=host1-signer1",
                  "path": "/etc/host1/ca.crt",
                  "serial": "xxxxxxxxxxx",
                  "serial_hex": "xxxxxxxx"
                },
                {
                  "cert_cn": "CN=host1-signer2",
                  "days_remaining": 544,
                  "expiry": "2024-07-28 12:47:50",
                  "health": "ok",
                  "issuer": "CN=host1-signer2",
                  "path": "/etc/host1/server.crt",
                  "serial": 12,
                  "serial_hex": "0xc"
                }
              ],
              "host4": [
                {
                  "cert_cn": "CN=host4-signer1",
                  "days_remaining": 729,
                  "expiry": "2025-01-29 17:10:11",
                  "health": "ok",
                  "issuer": "xxxxxxxxxxxxxxxxxxxxxxxxx",
                  "path": "/etc/origin/master/admin.host4",
                  "serial": 6,
                  "serial_hex": "0x6"
                }
              ]
            }
          }
        },
        "output": [
          {
            "host": "host1",
            "certs": [
              {
                "cert_cn": "CN=host1-signer1:",
                "days_remaining": 412,
                "expiry": "2024-03-18 17:21:41"
              },
              {
                "cert_cn": "CN=host1-signer2",
                "days_remaining": 544,
                "expiry": "2024-07-28 12:47:50"
              }
            ]
          },
          {
            "host": "host4",
            "certs": [
              {
                "cert_cn": "CN=host4-signer1",
                "days_remaining": 729,
                "expiry": "2025-01-29 17:10:11"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 75434304
  },
  {
    "context": [
      "I got errors because the array was nested and I got those errors to go away by changing -r to -R and adding try, but then nothing printed to github. Since these attempts are all in CI and the jest tests are flaky, changing one thing and waiting is getting cumbersome. Does anyone happen to have a script that does this already? Not picky about how it's formatted, I'd just like it to look less like json and more like markdown.",
      "You can pretty quickly present it as a list of path/value pairs by streaming in the input. You could then join the paths to a more readable form and dump it.",
      "$ jq -r --stream 'select(length == 2)|\"\\(.[0]|join(\"_\\"
    ],
    "utterance": "Print each path and its value from a nested summary object, joining the path with underscores, and formatting as plain lines for easier reading in CI logs.",
    "expressions": [
      "jq -r --stream 'select(length == 2)|\"\\(.[0]|join(\"_\")): \\t\\(.[1])\"' input.json"
    ],
    "data": [
      {
        "input": {
          "total": {
            "lines": {
              "total": 52,
              "covered": 11,
              "skipped": 0,
              "pct": 21.15
            },
            "statements": {
              "total": 54,
              "covered": 11,
              "skipped": 0,
              "pct": 20.37
            },
            "functions": {
              "total": 16,
              "covered": 4,
              "skipped": 0,
              "pct": 25
            },
            "branches": {
              "total": 18,
              "covered": 11,
              "skipped": 0,
              "pct": 61.11
            },
            "branchesTrue": {
              "total": 0,
              "covered": 0,
              "skipped": 0,
              "pct": 100
            }
          }
        },
        "output": [
          "total_lines_total:\t52",
          "total_lines_covered:\t11",
          "total_lines_skipped:\t0",
          "total_lines_pct:\t21.15",
          "total_statements_total:\t54",
          "total_statements_covered:\t11",
          "total_statements_skipped:\t0",
          "total_statements_pct:\t20.37",
          "total_functions_total:\t16",
          "total_functions_covered:\t4",
          "total_functions_skipped:\t0",
          "total_functions_pct:\t25",
          "total_branches_total:\t18",
          "total_branches_covered:\t11",
          "total_branches_skipped:\t0",
          "total_branches_pct:\t61.11",
          "total_branchesTrue_total:\t0",
          "total_branchesTrue_covered:\t0",
          "total_branchesTrue_skipped:\t0",
          "total_branchesTrue_pct:\t100"
        ]
      }
    ],
    "identifier": 75251868
  },
  {
    "context": [
      "I want to get the following result\n\n[\n  {\n    \"key\": \"matrixId\",\n    \"value\": \"matrix-2h44ka21lln62\"\n  },\n  {\n    \"key\": \"state\",\n    \"value\": \"FINISHED\"\n  },\n  {\n    \"key\": \"details\",\n    \"value\": \"0 test cases failed\"\n  },\n  {\n    \"key\": \"device\",\n    \"value\": \"iphone8-15.7-en-portrait\"\n  },\n  {\n    \"key\": \"webLink\",\n    \"value\": \"https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4663013071689981858/details\"\n  }\n], ...",
      "If you want an array of arrays, then don't iterate `to_entries` and simply map to the entries array:\n\n```\njq 'map({matrixId, state, details: .axes[].details, device: .axes[].device, webLink} | to_entries)'\n```"
    ],
    "utterance": "For each top-level object, output an array of key-value entry objects containing the matrixId, state, details from the first element of axes, device from the first element of axes, and webLink fields.",
    "expressions": [
      "map({matrixId, state, details: .axes[].details, device: .axes[].device, webLink} | to_entries)"
    ],
    "data": [
      {
        "input": {
          "matrix-2h44ka21lln62": {
            "projectId": "app-54934",
            "matrixId": "matrix-2h44ka21lln62",
            "state": "FINISHED",
            "gcsPath": "App-ios-runner/2023-02-07_13-55-43.444360_CdCC/shard_0",
            "webLink": "https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4663013071689981858/details",
            "downloaded": true,
            "billableMinutes": {
              "virtual": 0,
              "physical": 1
            },
            "clientDetails": {
              "Flank Version": "v23.01.0",
              "Flank Revision": "7ad3d5ba4097f189965110ca52b93fd0645715e0"
            },
            "gcsPathWithoutRootBucket": "2023-02-07_13-55-43.444360_CdCC/shard_0",
            "gcsRootBucket": "App-ios-runner",
            "axes": [
              {
                "device": "iphone8-15.7-en-portrait",
                "outcome": "failure",
                "details": "0 test cases failed",
                "suiteOverview": {
                  "total": 0,
                  "errors": 0,
                  "failures": 0,
                  "flakes": 0,
                  "skipped": 0,
                  "elapsedTime": 0,
                  "overheadTime": 0
                }
              }
            ],
            "appFileName": "App-UISmokeTests.zip",
            "testFileName": "App-UISmokeTests_iphoneos16.2-arm64_shard_0.xctestrun",
            "isCompleted": false,
            "testExecutions": [
              {
                "id": "matrix-2h44ka21lln62_execution-clgfpxn2zgrta",
                "modelId": "iphone8",
                "deviceVersion": "15.7",
                "state": "FINISHED",
                "errorMessage": "",
                "progress": [
                  "Starting attempt 1.",
                  "Checking Internet connection...",
                  "Internet connection stable!",
                  "Starting iOS test.",
                  "Completed iOS test.",
                  "Done. Test time = 14 (secs)",
                  "Starting results processing. Attempt: 1",
                  "Completed results processing. Time taken = 3 (secs)"
                ],
                "toolResultsStep": {
                  "executionId": "4663013071689981858",
                  "historyId": "bh.388190097b1eab25",
                  "projectId": "app-54934",
                  "stepId": "bs.2b9b72bccab868fa"
                }
              }
            ],
            "testTimeout": 2700,
            "isRoboTest": false,
            "historyId": "",
            "executionId": "",
            "invalidMatrixDetails": "UNKNOWN",
            "outcome": "failure"
          },
          "matrix-8hj1qx8udleaa": {
            "projectId": "app-54934",
            "matrixId": "matrix-8hj1qx8udleaa",
            "state": "FINISHED",
            "gcsPath": "App-ios-runner/2023-02-07_13-55-43.444360_CdCC/shard_1",
            "webLink": "https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/5654175129805154564/details",
            "downloaded": true,
            "billableMinutes": {
              "virtual": 0,
              "physical": 1
            },
            "clientDetails": {
              "Flank Version": "v23.01.0",
              "Flank Revision": "7ad3d5ba4097f189965110ca52b93fd0645715e0"
            },
            "gcsPathWithoutRootBucket": "2023-02-07_13-55-43.444360_CdCC/shard_1",
            "gcsRootBucket": "App-ios-runner",
            "axes": [
              {
                "device": "iphone8-15.7-en-portrait",
                "outcome": "failure",
                "details": "0 test cases failed",
                "suiteOverview": {
                  "total": 0,
                  "errors": 0,
                  "failures": 0,
                  "flakes": 0,
                  "skipped": 0,
                  "elapsedTime": 0,
                  "overheadTime": 0
                }
              }
            ],
            "appFileName": "App-UISmokeTests.zip",
            "testFileName": "App-UISmokeTests_iphoneos16.2-arm64_shard_1.xctestrun",
            "isCompleted": false,
            "testExecutions": [
              {
                "id": "matrix-8hj1qx8udleaa_execution-10jy4hq8i62g4",
                "modelId": "iphone8",
                "deviceVersion": "15.7",
                "state": "FINISHED",
                "errorMessage": "",
                "progress": [
                  "Starting attempt 1.",
                  "Checking Internet connection...",
                  "Internet connection stable!",
                  "Starting iOS test.",
                  "Completed iOS test.",
                  "Done. Test time = 15 (secs)",
                  "Starting results processing. Attempt: 1",
                  "Completed results processing. Time taken = 4 (secs)"
                ],
                "toolResultsStep": {
                  "executionId": "5654175129805154564",
                  "historyId": "bh.388190097b1eab25",
                  "projectId": "app-54934",
                  "stepId": "bs.b7d2f90beed6230a"
                }
              }
            ],
            "testTimeout": 2700,
            "isRoboTest": false,
            "historyId": "",
            "executionId": "",
            "invalidMatrixDetails": "UNKNOWN",
            "outcome": "failure"
          },
          "matrix-2i6y9uq9i0ext": {
            "projectId": "app-54934",
            "matrixId": "matrix-2i6y9uq9i0ext",
            "state": "FINISHED",
            "gcsPath": "App-ios-runner/2023-02-07_13-55-43.444360_CdCC/shard_2",
            "webLink": "https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4958041021718608851/details",
            "downloaded": true,
            "billableMinutes": {
              "virtual": 0,
              "physical": 1
            },
            "clientDetails": {
              "Flank Version": "v23.01.0",
              "Flank Revision": "7ad3d5ba4097f189965110ca52b93fd0645715e0"
            },
            "gcsPathWithoutRootBucket": "2023-02-07_13-55-43.444360_CdCC/shard_2",
            "gcsRootBucket": "App-ios-runner",
            "axes": [
              {
                "device": "iphone8-15.7-en-portrait",
                "outcome": "failure",
                "details": "0 test cases failed",
                "suiteOverview": {
                  "total": 0,
                  "errors": 0,
                  "failures": 0,
                  "flakes": 0,
                  "skipped": 0,
                  "elapsedTime": 0,
                  "overheadTime": 0
                }
              }
            ],
            "appFileName": "App-UISmokeTests.zip",
            "testFileName": "App-UISmokeTests_iphoneos16.2-arm64_shard_2.xctestrun",
            "isCompleted": false,
            "testExecutions": [
              {
                "id": "matrix-2i6y9uq9i0ext_execution-1zvntyq5awzyv",
                "modelId": "iphone8",
                "deviceVersion": "15.7",
                "state": "FINISHED",
                "errorMessage": "",
                "progress": [
                  "Starting attempt 1.",
                  "Checking Internet connection...",
                  "Internet connection stable!",
                  "Starting iOS test.",
                  "Completed iOS test.",
                  "Done. Test time = 13 (secs)",
                  "Starting results processing. Attempt: 1",
                  "Completed results processing. Time taken = 5 (secs)"
                ],
                "toolResultsStep": {
                  "executionId": "4958041021718608851",
                  "historyId": "bh.388190097b1eab25",
                  "projectId": "app-54934",
                  "stepId": "bs.283070cfe31b0c"
                }
              }
            ],
            "testTimeout": 2700,
            "isRoboTest": false,
            "historyId": "",
            "executionId": "",
            "invalidMatrixDetails": "UNKNOWN",
            "outcome": "failure"
          }
        },
        "output": [
          [
            {
              "key": "matrixId",
              "value": "matrix-2h44ka21lln62"
            },
            {
              "key": "state",
              "value": "FINISHED"
            },
            {
              "key": "details",
              "value": "0 test cases failed"
            },
            {
              "key": "device",
              "value": "iphone8-15.7-en-portrait"
            },
            {
              "key": "webLink",
              "value": "https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4663013071689981858/details"
            }
          ],
          [
            {
              "key": "matrixId",
              "value": "matrix-8hj1qx8udleaa"
            },
            {
              "key": "state",
              "value": "FINISHED"
            },
            {
              "key": "details",
              "value": "0 test cases failed"
            },
            {
              "key": "device",
              "value": "iphone8-15.7-en-portrait"
            },
            {
              "key": "webLink",
              "value": "https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/5654175129805154564/details"
            }
          ],
          [
            {
              "key": "matrixId",
              "value": "matrix-2i6y9uq9i0ext"
            },
            {
              "key": "state",
              "value": "FINISHED"
            },
            {
              "key": "details",
              "value": "0 test cases failed"
            },
            {
              "key": "device",
              "value": "iphone8-15.7-en-portrait"
            },
            {
              "key": "webLink",
              "value": "https://console.firebase.google.com/project/app-54934/testlab/histories/bh.388190097b1eab25/matrices/4958041021718608851/details"
            }
          ]
        ]
      }
    ],
    "identifier": 75376637
  }
]