[
  {
    "context": [
      "I want to map this to an array of objects with only the top-level scalar values present in each modified object (i.e. keys containing values like arrays and objects should disappear\u2014I\u2019m not interested in the contents of anything nested here):",
      "The `with_entries` builtin lets you select upon the value while retaining the object-field structure.",
      "jq '.data | map(with_entries(select(.value | scalars)))'",
      "You can do",
      "[.data[] | to_entries | map(select(.value | scalars)) | from_entries]",
      "Which is the same as",
      "[.data[] | with_entries(select(.value | scalars))]"
    ],
    "utterance": "Return an array where each object from the input contains only its top-level keys whose values are scalars; keys with arrays or objects as values are omitted.",
    "expressions": [
      ".data | map(with_entries(select(.value | scalars)))",
      "[.data[] | to_entries | map(select(.value | scalars)) | from_entries]",
      "[.data[] | with_entries(select(.value | scalars))]"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "blah",
              "foo": "bar",
              "array": [
                1,
                2,
                3
              ]
            },
            {
              "id": "blah",
              "foo": "bar",
              "array": [
                4,
                5,
                6
              ]
            }
          ]
        },
        "output": [
          {
            "id": "blah",
            "foo": "bar"
          },
          {
            "id": "blah",
            "foo": "bar"
          }
        ]
      }
    ],
    "identifier": 70647376
  },
  {
    "context": [
      "But would like to automate it so the name of the zip includes the version.",
      "echo \"build_$(cat manifest.json | jq .version).zip\" | sed s/\\\"//g",
      "zip \"build_$(jq -r .version manifest.json).zip\" src/*.js src/assets/icons/*.png *.json",
      "Replace `build.zip` with `\"build_$(jq -r .version manifest.json).zip\"`.",
      "Finally, rather than trying to convert the JSON literal into the string it produces using `sed`, we can use `--raw-output` aka `-r`.",
      "zip \"build_$( jq -r .version manifest.json ).zip\" ..."
    ],
    "utterance": "Extract the value of the version field from manifest.json as a raw string.",
    "expressions": [
      "jq -r .version manifest.json"
    ],
    "data": [
      {
        "input": {
          "version": "1.1.0"
        },
        "output": "1.1.0"
      }
    ],
    "identifier": 70636530
  },
  {
    "context": [
      "When I add the extra field I need it ends up looking like this:",
      "This is the same command, except it adds the container name to the json output.  However, when I do that, it adds extra results (as well as my extra field):",
      "The extra results are the rows with the container set to istio-proxy.  This seems to be because there are 2 entries in each instance of `.status.containerStatuses`.",
      "But when I look at the data for the istio-proxy instance, it does not match the criteria.",
      "is there a way to get the extra field, but not the extra rows?",
      "You&#39;re filtering the wrong thing.",
      "```jq\n.items |\nmap (\n   .status.containerStatuses |= map(\n      select(\n         (  .state.waiting\n         or .state.terminated and .state.terminated.reason != \"Completed\"\n         )\n      )\n   ) |\n   {\n      pod:       .metadata.name,\n      namespace: .metadata.namespace,\n      container: .status.containerStatuses[].name\n   }\n)\n```"
    ],
    "utterance": "Show pods with any container in a waiting state or terminated for a reason other than Completed, including the pod's name, namespace, and the affected container's name, and exclude containers that do not match the condition.",
    "expressions": [
      ".items |\nmap (\n   .status.containerStatuses |= map(\n      select(\n         (  .state.waiting\n         or .state.terminated and .state.terminated.reason != \"Completed\"\n         )\n      )\n   ) |\n   {\n      pod:       .metadata.name,\n      namespace: .metadata.namespace,\n      container: .status.containerStatuses[].name\n   }\n)\n"
    ],
    "identifier": 70629071
  },
  {
    "context": [
      "But now I want to add one more column to the results.  The column I want is located in one (and only one) of two places:",
      "* .status.containerStatuses[].state.*waiting*.reason",
      "* .status.containerStatuses[].state.*terminated*.reason",
      "I first tried adding `.status.containerStatuses[].state.*.reason` to the results fields array.  But that gave me an `unexpected '*'` compile error.",
      "jq has a counterpart to 'coalesce' in the form of `//`.",
      "Perhaps:\n.status.containerStatuses[].state | (.waiting // .terminated) | .reason",
      "or\n.status.containerStatuses[].state | (.waiting.reason // .terminated.reason )",
      "If `//` is inapplicable for some reason, then the obvious alternative would be an `if ... then ... else ... end` statement, which is quite like C's '_ ? _ : _' in that it can be used to produce a value, e.g. ...\n.status.containerStatuses[].state\n| if has(\"waiting\") then .waiting.reason\n  else .terminated.reason\n  end",
      "In case you want to go with `coalesce`:\ndef coalesce(s):\n  first(s | select(. != null)) // null;",
      "you could write something along the lines you had in mind with the wildcard, e.g.\ncoalesce(.status.containerStatuses[].state[].reason?)"
    ],
    "utterance": "Return the reason field from either the waiting or terminated state within each containerStatuses entry, selecting the first non-null value.",
    "expressions": [
      ".status.containerStatuses[].state | (.waiting // .terminated) | .reason",
      ".status.containerStatuses[].state | (.waiting.reason // .terminated.reason )",
      ".status.containerStatuses[].state | if has(\"waiting\") then .waiting.reason else .terminated.reason end",
      "coalesce(.status.containerStatuses[].state[].reason?)"
    ],
    "identifier": 70628716
  },
  {
    "context": [
      "Here\u2019s what I\u2019m looking to do.",
      "Expected output after running jq",
      "Use `--argfile` to read in the second file into a variable, then `+=` to add it to the existing array in `.item`",
      "jq --argfile f file2.json '.item += $f' file1.json"
    ],
    "utterance": "Append all entries from the top-level array in file2 to the 'item' array in file1 and output the result.",
    "expressions": [
      "jq --argfile f file2.json '.item += $f' file1.json"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "info": {
              "id": "",
              "name": "Text Fields",
              "schema": "url"
            },
            "item": [
              {
                "name": "CompanyName Field",
                "item": [
                  {
                    "name": "CompanyName is CompanyName1"
                  }
                ]
              }
            ]
          },
          "file2.json": [
            {
              "name": "Phone Field",
              "item": [
                {
                  "name": "Phone is 1234"
                }
              ]
            },
            {
              "name": "Job Field",
              "item": [
                {
                  "name": "Job is Job1"
                }
              ]
            }
          ]
        },
        "output": {
          "info": {
            "id": "",
            "name": "Text Fields",
            "schema": "url"
          },
          "item": [
            {
              "name": "CompanyName Field",
              "item": [
                {
                  "name": "CompanyName is CompanyName1"
                }
              ]
            },
            {
              "name": "Phone Field",
              "item": [
                {
                  "name": "Phone is 1234"
                }
              ]
            },
            {
              "name": "Job Field",
              "item": [
                {
                  "name": "Job is Job1"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 70631790
  },
  {
    "context": [
      "i want to merge these two files into 1 file to get output that looks like this:\n{\n    \"ubuntu\": {\n      \"os_ver\": \"focal\",\n      \"image\": \"abcdef\",\n      \"image_tag\": \"3.33.3\",\n      \"docker_compiler_image\": \"abc\",\n      \"image_compiler_tag\": \"4.44.4\"\n    },\n      \"os_ver\": \"bionic\",\n      \"image\": \"xxxx\",\n      \"image_tag\": \"3.33.3\",\n      \"docker_compiler_image\": \"xxxx\",\n      \"image_compiler_tag\": \"4.44.4\"\n\n  }",
      "i tried jq -s add ubuntufocal.json ubuntubionic.json > all_os.json\nbut i'm getting that bionic is overwriting focal",
      "If you want to pull out the `ubuntu` field name, and have each object's values (which happen to be objects as well) merged into an array, also use the `map` builtin:",
      "jq -s '{ubuntu: map(.ubuntu)}' ubuntubionic.json ubuntufocal.json"
    ],
    "utterance": "Combine the 'ubuntu' objects from two files so that the output contains an array under the key 'ubuntu', with each array item being the original 'ubuntu' object from each file.",
    "expressions": [
      "jq -s '{ubuntu: map(.ubuntu)}' ubuntubionic.json ubuntufocal.json"
    ],
    "data": [
      {
        "input": [
          {
            "ubuntu": {
              "os_ver": "bionic",
              "image": "abcdef",
              "image_tag": "3.33.3",
              "docker_compiler_image": "abc",
              "image_compiler_tag": "4.44.4"
            }
          },
          {
            "ubuntu": {
              "os_ver": "focal",
              "image": "xxxx",
              "image_tag": "3.33.3",
              "docker_compiler_image": "xxxx",
              "image_compiler_tag": "4.44.4"
            }
          }
        ],
        "output": {
          "ubuntu": [
            {
              "os_ver": "bionic",
              "image": "abcdef",
              "image_tag": "3.33.3",
              "docker_compiler_image": "abc",
              "image_compiler_tag": "4.44.4"
            },
            {
              "os_ver": "focal",
              "image": "xxxx",
              "image_tag": "3.33.3",
              "docker_compiler_image": "xxxx",
              "image_compiler_tag": "4.44.4"
            }
          ]
        }
      }
    ],
    "identifier": 70631402
  },
  {
    "context": [
      "I have to read element of json \"target-hosts\",",
      "How escape character \"-\"?",
      "Just need to quote the key name such as\n```\njq '.\"target-hosts\"' deploy.json  \n```",
      "You need to enclose in double quotes:\n\n    jq '.\"target-hosts\"'",
      "```\n.\"target-hosts\"\n```\n\nor\n\n```\n.[\"target-hosts\"]\n```"
    ],
    "utterance": "Extract the value of the key target-hosts, where the key contains a hyphen.",
    "expressions": [
      ".\"target-hosts\"",
      ".[\"target-hosts\"]"
    ],
    "data": [
      {
        "input": {
          "name": "view1",
          "version": "1.1.1",
          "target-dir": "/opt/project/spark-jobs/",
          "target-hosts": {
            "dev": [
              "host1",
              "host2"
            ],
            "prod": [
              "host3",
              "host4"
            ]
          }
        },
        "output": {
          "dev": [
            "host1",
            "host2"
          ],
          "prod": [
            "host3",
            "host4"
          ]
        }
      }
    ],
    "identifier": 70658004
  },
  {
    "context": [
      "I\u2019m unable to get the value which have reporter only.",
      "the output should be jhoncena only which should written into a file.",
      "jq -r '.values[].name | select(.|split(\"-\")[0]==\"reporter\")|split(\"-\")[1]' response.json > outfile.txt",
      "jq -r '.values[]\n  | select(.name|index(\"reporter\"))\n  | .name\n  | sub(\"reporter-\";\"\")' in.json > out.txt",
      "jq -r '.values[].name\n  | capture(\"^reporter-(?<name>.*)\").name\n  ' response.json"
    ],
    "utterance": "Extract the value 'jhoncena' by finding the entry in 'values' array where 'name' starts with 'reporter-' and writing only the part after the hyphen to a file.",
    "expressions": [
      ".values[].name | select(.|split(\"-\")[0]==\"reporter\") | split(\"-\")[1]",
      ".values[] | select(.name|index(\"reporter\")) | .name | sub(\"reporter-\";\"\")",
      ".values[].name | capture(\"^reporter-(?<name>.*)\").name"
    ],
    "data": [
      {
        "input": {
          "size": 3,
          "limit": 25,
          "isLastPage": true,
          "values": [
            {
              "name": "hello-world"
            },
            {
              "name": "test-frame"
            },
            {
              "name": "reporter-jhoncena"
            }
          ],
          "start": 0
        },
        "output": "jhoncena"
      }
    ],
    "identifier": 70648582
  },
  {
    "context": [
      "I would like the output to be the contents of entryB:",
      "How can I format the JQ Query to not include a **`null`** output for `entryA`?",
      "One option would be using `to_entries` such as\n```\njq '.list[] | to_entries[] | select(.key==\"entryB\") | .value' example.json\n```",
      "By using the [alternative operator](https://stedolan.github.io/jq/manual/v1.6/#Alternativeoperator://) `//` you can defect to `empty` if the first alternative does not exist. \n```sh\njq '.list[] | .entryB // empty' example.json\n```"
    ],
    "utterance": "Return only the value of entryB for each element in the list, omitting null results for other entries.",
    "expressions": [
      ".list[] | .entryB // empty",
      ".list[] | to_entries[] | select(.key==\"entryB\") | .value"
    ],
    "data": [
      {
        "input": {
          "list": [
            {
              "entryA": {
                "item1": "foo",
                "item2": "bar"
              }
            },
            {
              "entryB": {
                "item1": "oof",
                "item2": "rab"
              }
            }
          ]
        },
        "output": {
          "item1": "oof",
          "item2": "rab"
        }
      }
    ],
    "identifier": 70656590
  },
  {
    "context": [
      "But I want to collect (as jq calls it) this stream into an array in order to `group_by`.",
      "if I just specify `[{ UserName, Url, Duration }]`, I don't get a single array; instead I get",
      "I know that I can use `jq \"my rules\" | jq -s` and it works. But there should be a way to create an array inside the rules themselves!",
      "As you start off with a stream of objects, you may either use the `--slurp` (or `-s`) flag to read in the objects as array members (you don't have to use another call, just begin with `jq -s '<your filter, maybe using a map>'`)",
      "or use `inputs` in conjunction with the `--null-input` (or `-n`) flag, which lets you construct the array more flexibly: `jq -n '[inputs]'` or even  `jq -n '[inputs | \u2026]'`, depending on your actual processing pipeline.",
      "In order to convert a stream of values into a single array, you need to use the `-s` option first."
    ],
    "utterance": "Collect a stream of objects, after filtering and shaping, into a single array for further processing like group_by.",
    "expressions": [
      "jq -s '{ UserName, Url, Duration }'",
      "jq -n '[inputs | { UserName, Url, Duration }]'"
    ],
    "data": [
      {
        "input": [
          {
            "UserName": "John",
            "Url": "http://bla-bla/method1",
            "Duration": 10,
            "ReturnCode": 200
          },
          {
            "UserName": "Bob",
            "Url": "http://bla-bla/method2",
            "Duration": 15,
            "ReturnCode": 500
          }
        ],
        "output": [
          {
            "UserName": "John",
            "Url": "http://bla-bla/method1",
            "Duration": 10
          },
          {
            "UserName": "Bob",
            "Url": "http://bla-bla/method2",
            "Duration": 15
          }
        ]
      }
    ],
    "identifier": 70627822
  },
  {
    "context": [
      "I have a script that a user will enter a \"name\" and I want to be able to look for and extract the metadata for the name they entered if it exists.",
      "Assuming those input objects are in an array, \n\n```\n.[] | select(.metadata.name == \"run2\") | .metadata\n```\n\nWill select the object where `.metadata.name === run2`.\n\nThen it shows the `.metadata` of that object so the output becomes:\n```json\n{\n  \"name\": \"run2\",\n  \"uid\": \"9b0af3\",\n  \"creationTimestamp\": \"2021-01-01T01:01:01Z\"\n}\n```"
    ],
    "utterance": "Extract the metadata object for the element whose metadata.name equals run2.",
    "expressions": [
      ".[] | select(.metadata.name == \"run2\") | .metadata"
    ],
    "data": [
      {
        "input": [
          {
            "metadata": {
              "name": "run1",
              "uid": "b2c0ce",
              "creationTimestamp": "2021-01-01T01:01:01Z"
            },
            "spec": {
              "arguments": {}
            },
            "status": {
              "phase": "Failed",
              "startedAt": "2021-01-01T01:01:01Z",
              "finishedAt": "2021-01-01T01:01:01Z"
            }
          },
          {
            "metadata": {
              "name": "run2",
              "uid": "9b0af3",
              "creationTimestamp": "2021-01-01T01:01:01Z"
            },
            "spec": {
              "arguments": {}
            },
            "status": {
              "phase": "Succeeded",
              "startedAt": "2021-01-01T01:01:01Z",
              "finishedAt": "2021-01-01T01:01:01Z"
            }
          }
        ],
        "output": {
          "name": "run2",
          "uid": "9b0af3",
          "creationTimestamp": "2021-01-01T01:01:01Z"
        }
      }
    ],
    "identifier": 70666454
  },
  {
    "context": [
      "I want to replace every IP by a corresponding IP address. So imagine I want to replace the IP 10.1.1.49 with 10.10.10.10",
      "You *can* update the relevant IP addresses using\n```sh\njq '(.. | .ip? | select(. == \"10.1.1.49\")) |= \"10.10.10.10\"'\n```",
      "Now suppose I have a mapping table (mapping.json) with the following structure:\n\n    {\n     \"10.2.1.49\":\"10.10.10.10\",\n     \"10.15.15.15\":\"10.10.10.10\"\n    }\n\nCan I provide and combine this mapping table with jq for a find and replace?",
      "Read in the mappings e.g. using `--argfile` and update using a lookup in combination with the alternative operator `//` to fall back to the original value, if it doesn't exist in the mapping\n\n```sh\njq --argfile mapping mapping.json '(.. | .ip? // empty) |= ($mapping[.]? // .)'\n```"
    ],
    "utterance": "Replace all .ip fields' values according to a provided mapping table; if the value exists as a key in the mapping, substitute it with the mapping value, otherwise keep the original.",
    "expressions": [
      "(.. | .ip? // empty) |= ($mapping[.]? // .)"
    ],
    "data": [
      {
        "input": {
          "destination": {
            "port": 53,
            "bytes": 100,
            "ip": "1.1.1.1"
          },
          "source": {
            "port": 54894,
            "bytes": 84,
            "ip": "10.2.1.49"
          },
          "related": {
            "ip": "10.5.5.45"
          },
          "event": {
            "code": "0000000013",
            "action": "accept",
            "type": [
              "allowed",
              "connection",
              "end",
              "protocol"
            ],
            "outcome": "success"
          },
          "@timestamp": "2021-08-29T04:47:10.000+02:00"
        },
        "output": {
          "destination": {
            "port": 53,
            "bytes": 100,
            "ip": "1.1.1.1"
          },
          "source": {
            "port": 54894,
            "bytes": 84,
            "ip": "10.10.10.10"
          },
          "related": {
            "ip": "10.5.5.45"
          },
          "event": {
            "code": "0000000013",
            "action": "accept",
            "type": [
              "allowed",
              "connection",
              "end",
              "protocol"
            ],
            "outcome": "success"
          },
          "@timestamp": "2021-08-29T04:47:10.000+02:00"
        }
      }
    ],
    "identifier": 70665995
  },
  {
    "context": [
      "How to get just the raw values i.e., a,b,c without open close brackets and double quotes?",
      "You can just un-wrap the list generated form unique operation using `unique[]` and still use the raw output mode `-r`",
      "jq -nr '[inputs | keys_unsorted[]] | unique[]'"
    ],
    "utterance": "List all unique object keys from multiple inputs, one per line, as plain text without quotes or brackets.",
    "expressions": [
      "[inputs | keys_unsorted[]] | unique[]"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 2,
            "c": 3
          },
          {
            "a": 4,
            "b": 5,
            "d": 6
          }
        ],
        "output": [
          "a",
          "b",
          "c",
          "d"
        ]
      }
    ],
    "identifier": 70677758
  },
  {
    "context": [
      "I want to merge to arrays together.",
      "$ cat file.json\n[1,2,3,4]\n[5,6,7,8]\n$ # command\n[1,2,3,4,5,6,7,8]",
      "jq -s 'flatten(1)' file.json",
      "jq -s 'add' input.json",
      "$ jq -s 'add' input.json\n[\n  1,\n  2,\n  3,\n  4,\n  5,\n  6,\n  7,\n  8\n]",
      "jq -n '[inputs[]]' file.json",
      "jq -cn '[inputs[]] | sort' file.json"
    ],
    "utterance": "Combine two arrays from separate lines in a file into a single array containing all their elements in sequence.",
    "expressions": [
      "jq -s 'flatten(1)' file.json",
      "jq -s 'add' file.json",
      "jq -n '[inputs[]]' file.json",
      "jq -cn '[inputs[]] | sort' file.json"
    ],
    "data": [
      {
        "input": [
          [
            1,
            2,
            3,
            4
          ],
          [
            5,
            6,
            7,
            8
          ]
        ],
        "output": [
          1,
          2,
          3,
          4,
          5,
          6,
          7,
          8
        ]
      }
    ],
    "identifier": 70681151
  },
  {
    "context": [
      "If it is infact a stream of objects (the latter case), then you could use `jq --slurp '\u2026'` or `jq -n '[inputs] | \u2026'` to make it an array (surrounded by brackets and with commas in between)",
      "`jq --stream '\u2026'` and handle the document (which has a different format then) according to the [documentation for processing streams](https://stedolan.github.io/jq/manual/v1.6/#Streaming)."
    ],
    "utterance": "Combine a stream of JSON objects into a single array with each object as an element.",
    "expressions": [
      "jq --slurp '.'",
      "jq -n '[inputs]'"
    ],
    "identifier": 70694042
  },
  {
    "context": [
      "In some cases, dbname is present and in some cases, it is not. Now, I want if dbname is not present then it should exit code without doing anything.",
      "jq -r --arg dbname \"$dbname\" '(.[$dbname] // empty) |.db_sid_list' \"$CRSOUT\"",
      "(.[$dbname] // empty) | .db_sid_list/\",\" | .[]"
    ],
    "utterance": "Return the value of the db_sid_list key for a given variable key if it exists; do nothing if the key is absent.",
    "expressions": [
      "(.[$dbname] // empty) | .db_sid_list",
      "(.[$dbname] // empty) | .db_sid_list/\",\" | .[]"
    ],
    "data": [
      {
        "input": {
          "phx4fo": {
            "db_name": "phx4fo",
            "db_unique_name": "phx4fo",
            "db_crs_state": "OFFLINE",
            "db_sid_list": "phx4fo1,phx4fo2",
            "db_host_list": "epxa25-swlke1,epxa25-swlke2",
            "db_home": "/u02/app/oracle/product/12.1.0/dbhome_2"
          },
          "phx68r": {
            "db_name": "phx68r",
            "db_unique_name": "phx68r",
            "db_crs_state": "OFFLINE",
            "db_sid_list": "phx68r1,phx68r2",
            "db_host_list": "epxa25-swlke1,epxa25-swlke2",
            "db_home": "/u02/app/oracle/product/19.0.0.0/dbhome_6"
          }
        },
        "output": "phx4fo1,phx4fo2"
      }
    ],
    "identifier": 70691571
  },
  {
    "context": [
      "I would like to filter the **paths** values, so that I can get only the paths that contain a specific tag inside the **tags** array.",
      "For example: if I want to get the paths for the **account-tag** the JSON should look like this after filtering:",
      "If that assumption doesn't hold, we'll need to filter at two levels.",
      "```jq\n.paths |= with_entries(\n   .value |= with_entries(\n      select( .value.tags | index(\"account-tag\") )\n   ) |\n   select( .value | length > 0 )\n)\n```"
    ],
    "utterance": "Keep only paths and methods whose tags array contains the value \"account-tag\".",
    "expressions": [
      ".paths |= with_entries(\n   .value |= with_entries(\n      select( .value.tags | index(\"account-tag\") )\n   ) |\n   select( .value | length > 0 )\n)",
      ".paths |= with_entries(\n   .value = (\n      .value |\n      with_entries(\n         select( .value.tags | index(\"account-tag\") )\n      ) |\n      select( length > 0 )\n   )\n)"
    ],
    "data": [
      {
        "input": {
          "swagger": "2.0",
          "info": {
            "version": "1.0.2",
            "title": "Some API"
          },
          "host": "example.com",
          "basePath": "/",
          "paths": {
            "/api/companies": {
              "get": {
                "tags": [
                  "company-tag"
                ],
                "responses": {
                  "200": {
                    "description": "OK",
                    "schema": {
                      "$ref": "#/definitions/CompanyDTO"
                    }
                  }
                }
              }
            },
            "/api/account": {
              "get": {
                "tags": [
                  "account-tag"
                ],
                "operationId": "getAccount",
                "responses": {
                  "200": {
                    "description": "OK",
                    "schema": {
                      "$ref": "#/definitions/UserDTO"
                    }
                  }
                }
              },
              "post": {
                "tags": [
                  "account-tag"
                ],
                "operationId": "createAccount",
                "responses": {
                  "200": {
                    "description": "OK",
                    "schema": {
                      "$ref": "#/definitions/UserDTO"
                    }
                  }
                }
              }
            }
          }
        },
        "output": {
          "swagger": "2.0",
          "info": {
            "version": "1.0.2",
            "title": "Some API"
          },
          "host": "example.com",
          "basePath": "/",
          "paths": {
            "/api/account": {
              "get": {
                "tags": [
                  "account-tag"
                ],
                "operationId": "getAccount",
                "responses": {
                  "200": {
                    "description": "OK",
                    "schema": {
                      "$ref": "#/definitions/UserDTO"
                    }
                  }
                }
              },
              "post": {
                "tags": [
                  "account-tag"
                ],
                "operationId": "createAccount",
                "responses": {
                  "200": {
                    "description": "OK",
                    "schema": {
                      "$ref": "#/definitions/UserDTO"
                    }
                  }
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 70668174
  },
  {
    "context": [
      "The command then takes that woeid and sends it to the other API endpoint. The second API takes that woeid, uses it to find your location, and responds with the following info:",
      "It then parses that response and fetches the wind speed and temperature from that data using this command:",
      "jq '.consolidated_weather[0].wind_speed,.consolidated_weather[0].the_temp'"
    ],
    "utterance": "Extract the wind speed and temperature from the first element of the consolidated_weather array.",
    "expressions": [
      ".consolidated_weather[0].wind_speed, .consolidated_weather[0].the_temp"
    ],
    "data": [
      {
        "input": {
          "consolidated_weather": [
            {
              "id": 4943876231004160,
              "weather_state_name": "Showers",
              "weather_state_abbr": "s",
              "wind_direction_compass": "SSE",
              "created": "2022-01-10T04:50:35.034292Z",
              "applicable_date": "2022-01-10",
              "min_temp": 19.145,
              "max_temp": 27.775,
              "the_temp": 25.700000000000003,
              "wind_speed": 4.491323107826295,
              "wind_direction": 154.44033101452658,
              "air_pressure": 1015.0,
              "humidity": 70,
              "visibility": 9.777586395450568,
              "predictability": 73
            },
            {
              "id": 6357293160464384,
              "weather_state_name": "Light Rain",
              "weather_state_abbr": "lr",
              "wind_direction_compass": "SSE",
              "created": "2022-01-10T04:50:38.005159Z",
              "applicable_date": "2022-01-11",
              "min_temp": 18.205,
              "max_temp": 28.07,
              "the_temp": 25.89,
              "wind_speed": 6.292207290389459,
              "wind_direction": 154.50026675861483,
              "air_pressure": 1014.5,
              "humidity": 67,
              "visibility": 11.256760518571543,
              "predictability": 75
            }
          ],
          "time": "2022-01-10T11:04:08.669337+05:30",
          "sun_rise": "2022-01-10T06:49:03.997088+05:30",
          "sun_set": "2022-01-10T17:58:25.214998+05:30",
          "timezone_name": "LMT",
          "parent": {
            "title": "India",
            "location_type": "Country",
            "woeid": 23424848,
            "latt_long": "21.786600,82.794762"
          },
          "sources": [
            {
              "title": "BBC",
              "slug": "bbc",
              "url": "http://www.bbc.co.uk/weather/",
              "crawl_rate": 360
            }
          ],
          "title": "Hyderabad",
          "location_type": "City",
          "woeid": 2295414,
          "latt_long": "17.508829,78.434578",
          "timezone": "Asia/Kolkata"
        },
        "output": [
          4.491323107826295,
          25.700000000000003
        ]
      }
    ],
    "identifier": 70648113
  },
  {
    "context": [
      "In the case of jq, simply presenting the JSON to `jq .` (e.g. `curl ... | jq .`) will pretty-print it, unless it is ridiculously large (i.e., too large to fit into the computer's memory), in which case you probably won't want to pretty-print it anyway.",
      "curl .... | jq -f schema.jq"
    ],
    "utterance": "Format the output from a REST API to make it human-readable.",
    "expressions": [
      "jq ."
    ],
    "identifier": 70703157
  },
  {
    "context": [
      "I need to sort following JSON file by keys with natural order but keys that a listed in the 'required` section should go first, how to do that?",
      "Expected output should be like:",
      "you are not guaranteed that after any follow-up processing the order will stay the same as objects typically *do not have* an order, arrays do.",
      "You *can* do something along the lines of\n```\n.Request.required as $req\n| .Request.properties |= (\n    to_entries\n    | sort_by(.key)\n    | group_by(IN(.key; $req[]) | not)\n    | map(from_entries)\n    | add\n  )",
      "Here's a straightforward and fairly efficient approach that takes advantage of the fact that `keys` produces the key names as a sorted array:\n```\n. as $in\n| .Request\n| (.required|sort) as $required\n| (.properties|keys) as $all\n| ($all - $required) as $optional\n| .properties as $p\n| $in\n| .Request.properties = reduce ($required[], $optional[]) as $key ({}; . + {($key): $p[$key]} )"
    ],
    "utterance": "Sort the 'properties' object so that keys listed in 'required' come first in their listed order, followed by the optional keys in sorted order.",
    "expressions": [
      ".Request.required as $req\n| .Request.properties |= (\n    to_entries\n    | sort_by(.key)\n    | group_by(IN(.key; $req[]) | not)\n    | map(from_entries)\n    | add\n  )",
      ". as $in\n| .Request\n| (.required|sort) as $required\n| (.properties|keys) as $all\n| ($all - $required) as $optional\n| .properties as $p\n| $in\n| .Request.properties = reduce ($required[], $optional[]) as $key ({}; . + {($key): $p[$key]} )"
    ],
    "data": [
      {
        "input": {
          "Request": {
            "properties": {
              "capacity": {
                "$ref": "SubscriptionCapacity"
              },
              "metadata": {
                "$ref": "MeterDefinitionsAndPolicy"
              },
              "data": {
                "type": "string"
              },
              "avs": {
                "pattern": "standard:v2",
                "type": "string"
              }
            },
            "required": [
              "data",
              "avs"
            ],
            "type": "object"
          }
        },
        "output": {
          "Request": {
            "properties": {
              "avs": {
                "pattern": "standard:v2",
                "type": "string"
              },
              "data": {
                "type": "string"
              },
              "capacity": {
                "$ref": "SubscriptionCapacity"
              },
              "metadata": {
                "$ref": "MeterDefinitionsAndPolicy"
              }
            },
            "required": [
              "data",
              "avs"
            ],
            "type": "object"
          }
        }
      }
    ],
    "identifier": 70688524
  },
  {
    "context": [
      "I\u0019m trying to flatten a json file to .csv.  I\u0019d like to use jqplay for this in stead of programming it in python for example.",
      "My desired output is one line entry on the 2nd array:",
      "so",
      "OPEN, NR1, ....",
      "",
      "CLOSED, NR2, ...",
      "",
      "....",
      "",
      "Can anyone help me with a good jq command for this?",
      "",
      "Are you looking for something like this?",
      "jq -r '.[].lock_doors[] | [.[]] | @csv'",
      "\"OPEN\",\"NR1\",\"NO_DATA\",\"2021-12-29T16:32:23Z\",4.28214,51.34426",
      "\"CLOSED\",\"NR2\",\"WORKING\",\"2022-01-12T12:32:52Z\",\"2021-12-22T13:13:57Z\",4.28247,51.34424"
    ],
    "utterance": "Flatten each lock_door entry in the array to a single CSV line containing all its values in order, one line per lock_door.",
    "expressions": [
      ".[].lock_doors[] | [.[]] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "description": "Berendrechtsluis",
            "lock_id": "BES",
            "longitude_wgs84": 4.28561,
            "latitude_wgs84": 51.34414,
            "lock_doors": [
              {
                "state": "OPEN",
                "lock_door_id": "NR1",
                "operational_state": "NO_DATA",
                "state_since_in_utc": "2021-12-29T16:32:23Z",
                "longitude_wgs84": 4.28214,
                "latitude_wgs84": 51.34426
              },
              {
                "state": "CLOSED",
                "lock_door_id": "NR2",
                "operational_state": "WORKING",
                "state_since_in_utc": "2022-01-12T12:32:52Z",
                "operational_state_since_in_utc": "2021-12-22T13:13:57Z",
                "longitude_wgs84": 4.28247,
                "latitude_wgs84": 51.34424
              }
            ]
          }
        ],
        "output": [
          "\"OPEN\",\"NR1\",\"NO_DATA\",\"2021-12-29T16:32:23Z\",4.28214,51.34426",
          "\"CLOSED\",\"NR2\",\"WORKING\",\"2022-01-12T12:32:52Z\",\"2021-12-22T13:13:57Z\",4.28247,51.34424"
        ]
      }
    ],
    "identifier": 70694772
  },
  {
    "context": [
      "Selected is the dict containing the max timestamp and the name added to it, being the last created backup of a database. There are multiple databases possible. How can I form the output to a cleanly formatted array?",
      "Instead of `.[] | \u2026` use `map(\u2026)` to retain the array.",
      "jq 'map([.backup[] + {name}] | max_by(.timestamp.stop))'"
    ],
    "utterance": "Return an array where each element is the backup with the largest timestamp.stop value for each database, including the associated name.",
    "expressions": [
      "map([.backup[] + {name}] | max_by(.timestamp.stop))"
    ],
    "data": [
      {
        "input": [
          {
            "backup": [
              {
                "timestamp": {
                  "start": 1642144383,
                  "stop": 1642144386
                },
                "info": {
                  "size": 1200934840
                },
                "type": "full"
              },
              {
                "timestamp": {
                  "start": 1642144388,
                  "stop": 1642144392
                },
                "info": {
                  "size": 1168586300
                },
                "type": "incr"
              }
            ],
            "name": "dbname1"
          },
          {
            "backup": [
              {
                "timestamp": {
                  "start": 1642144383,
                  "stop": 1642144386
                },
                "info": {
                  "size": 1200934840
                },
                "type": "full"
              },
              {
                "timestamp": {
                  "start": 1642144388,
                  "stop": 1642144392
                },
                "info": {
                  "size": 1168586300
                },
                "type": "incr"
              }
            ],
            "name": "dbname2"
          }
        ],
        "output": [
          {
            "timestamp": {
              "start": 1642144388,
              "stop": 1642144392
            },
            "info": {
              "size": 1168586300
            },
            "type": "incr",
            "name": "dbname1"
          },
          {
            "timestamp": {
              "start": 1642144388,
              "stop": 1642144392
            },
            "info": {
              "size": 1168586300
            },
            "type": "incr",
            "name": "dbname2"
          }
        ]
      }
    ],
    "identifier": 70711416
  },
  {
    "context": [
      "produces output with `\"time_in_seconds\": null` if there was no `\"time_in_seconds\"` in source JSON. How to eliminate this:",
      "To remove one field if it is `null`, use `.time_in_seconds |= select(.)`.",
      "To remove all fields that are `null`, use `.[] |= select(.)`.",
      "jq 'map({\u2026} | .[] |= select(.))'",
      "Note: This will also delete fields with value `false`. If you want to restrict to `null`, make `select(.)` more explicit and change it to `select(. != null)`.",
      "To remove all `null` values (or any arbitrary condition) in your input, you could make use of `recurse/0` (`..`) and `del/1`.",
      "del(.. | select(. == null))"
    ],
    "utterance": "Exclude attributes from each object in an array if their value is null, specifically avoiding 'time_in_seconds': null when that key is missing in the input.",
    "expressions": [
      "map({\"author_id\": .author.id, \"author\": .author.name, \"badge\": .author.badges[0].title, \"message\", \"timestamp\", \"time_in_seconds\", \"time_text\"} | with_entries(select(.value != null)))",
      "map({\"author_id\": .author.id, \"author\": .author.name, \"badge\": .author.badges[0].title, \"message\", \"timestamp\", \"time_in_seconds\", \"time_text\"} | del(.time_in_seconds | select(. == null)))",
      "map({\"author_id\": .author.id, \"author\": .author.name, \"badge\": .author.badges[0].title, \"message\", \"timestamp\", \"time_in_seconds\", \"time_text\"} | .[] |= select(. != null))"
    ],
    "identifier": 70718004
  },
  {
    "context": [
      "And I need to get sum of counters for distinct Action where Status > 1. Result should replace summarized elements.",
      "As you can see, field Count in element with \"Action\": \"1\" and \"Status\": \"2\" was increased on value of object with \"Action\": \"1\" and \"Status\": \"6\"",
      "`group_by` groups the items to aggregate, which is determined by a `.Status` greater `1` and the content of `.Action`. Then, with `map` each grouped list's first (`.[0]`) item's `.Count` field is calculated by `add`ing up all `.Count` fields' values. The output within each group is the first (`.[0]`) element.",
      "As `.Status` and `.Count` are strings, not numbers, it was necessary to convert them back and forth using `tonumber` and `tostring`. You may want to, especially if you have more calculations to process, first convert them into numbers, then do all the (now simpler) processing, and finally convert them back (if necessary)."
    ],
    "utterance": "Aggregate Count for each Action where Status > 1 by summing their Counts, and replace those elements in the array with a single object per Action/Status group reflecting the summed Count.",
    "expressions": [
      "group_by([(.Status | tonumber > 1), .Action])\n| map(.[0].Count = (map(.Count | tonumber) | add | tostring) | .[0])",
      "map((.Status, .Count) |= tonumber)\n| group_by([(.Status > 1), .Action])\n| map(.[0].Count = (map(.Count) | add) | .[0])\n| map((.Status, .Count) |= tostring)"
    ],
    "data": [
      {
        "input": [
          {
            "Count": "226",
            "Action": "1",
            "Status": "1",
            "Client": "26"
          },
          {
            "Count": "224",
            "Action": "1",
            "Status": "2",
            "Client": "26"
          },
          {
            "Count": "3",
            "Action": "1",
            "Status": "6",
            "Client": "26"
          },
          {
            "Count": "233",
            "Action": "2",
            "Status": "1",
            "Client": "26"
          },
          {
            "Count": "7",
            "Action": "2",
            "Status": "2",
            "Client": "26"
          }
        ],
        "output": [
          {
            "Count": "226",
            "Action": "1",
            "Status": "1",
            "Client": "26"
          },
          {
            "Count": "233",
            "Action": "2",
            "Status": "1",
            "Client": "26"
          },
          {
            "Count": "227",
            "Action": "1",
            "Status": "2",
            "Client": "26"
          },
          {
            "Count": "7",
            "Action": "2",
            "Status": "2",
            "Client": "26"
          }
        ]
      }
    ],
    "identifier": 70712566
  },
  {
    "context": [
      "Using bash and jq I want to trim it down this this:\r\n\r\n{\r\n  \"TaskDefinitionArn\": \"arn:aws:ecs:eu-west-2:000000000000:task-definition/xxx-cron:55\",\r\n  \"TaskCount\": 1,\r\n  \"EnableECSManagedTags\": false,\r\n  \"EnableExecuteCommand\": false,\r\n  \"PropagateTags\": \"TASK_DEFINITION\"\r\n}\r\n",
      "I have tried this but it does not output the keys:\r\n\r\ncat rule-target.json | jq '(.Targets[] .EcsParameters[])'",
      "I think you want:\r\n\r\njq '(.Targets[]|.EcsParameters)' rule-target.json",
      "You can use\njq '.Targets[] | .EcsParameters' rule-target.json",
      "$ jq '.Targets[].EcsParameters' rule-target.json \r\n{\r\n  \"TaskDefinitionArn\": \"arn:aws:ecs:eu-west-2:000000000000:task-definition/xxx-cron:55\",\r\n  \"TaskCount\": 1,\r\n  \"EnableECSManagedTags\": false,\r\n  \"EnableExecuteCommand\": false,\r\n  \"PropagateTags\": \"TASK_DEFINITION\"\r\n}\r\n",
      "As `EcsParameters` isn't an array, you shouldn't unwrap it (`[]`)."
    ],
    "utterance": "Extract the EcsParameters object from the first entry in the Targets array, including all its keys and values.",
    "expressions": [
      ".Targets[].EcsParameters",
      ".Targets[] | .EcsParameters",
      "(.Targets[]|.EcsParameters)"
    ],
    "data": [
      {
        "input": {
          "Targets": [
            {
              "Id": "xxx_hourly_cron",
              "Arn": "arn:aws:ecs:eu-west-2:000000000000:cluster/drupal-cluster",
              "RoleArn": "arn:aws:iam::000000000000:role/ecsEventsRole",
              "EcsParameters": {
                "TaskDefinitionArn": "arn:aws:ecs:eu-west-2:000000000000:task-definition/xxx-cron:55",
                "TaskCount": 1,
                "EnableECSManagedTags": false,
                "EnableExecuteCommand": false,
                "PropagateTags": "TASK_DEFINITION"
              }
            }
          ]
        },
        "output": {
          "TaskDefinitionArn": "arn:aws:ecs:eu-west-2:000000000000:task-definition/xxx-cron:55",
          "TaskCount": 1,
          "EnableECSManagedTags": false,
          "EnableExecuteCommand": false,
          "PropagateTags": "TASK_DEFINITION"
        }
      }
    ],
    "identifier": 70734127
  },
  {
    "context": [
      "How to transform this:",
      "I have no idea how to map nested arrays in \"emotes\" nodes.",
      "Use `(\u001b[39m...)? // empty` to filter for in-depth existence, `unique` to remove duplicates, and `|=` to update:",
      "jq 'map(.author |= .name | ((.emotes[].images)? // empty) |= (map(.url) | unique))'"
    ],
    "utterance": "Transform an array of objects by setting each object's author field to the author's name, and for objects with emotes, set each emote's images field to a unique list of image URLs instead of image objects.",
    "expressions": [
      "map(.author |= .name | ((.emotes[].images)? // empty) |= (map(.url) | unique))"
    ],
    "data": [
      {
        "input": [
          {
            "author": {
              "name": "Alice"
            },
            "message": "Text 1"
          },
          {
            "author": {
              "name": "Bob"
            },
            "message": "Text 2"
          },
          {
            "author": {
              "name": "Charlie"
            },
            "emotes": [
              {
                "images": [
                  {
                    "url": "https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f600.svg"
                  },
                  {
                    "url": "https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f600.svg"
                  },
                  {
                    "url": "https://some-host.com/some-url.svg"
                  }
                ],
                "name": ":grinning_face:"
              }
            ],
            "message": "Text 3"
          },
          {
            "author": {
              "name": "Dave"
            },
            "message": "Text 4"
          },
          {
            "author": {
              "name": "Erin"
            },
            "message": "Text 5"
          },
          {
            "author": {
              "name": "Faythe"
            },
            "emotes": [
              {
                "images": [
                  {
                    "url": "https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f44b.svg"
                  },
                  {
                    "url": "https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f44b.svg"
                  },
                  {
                    "url": "https://some-host.com/some-other-url.svg"
                  }
                ],
                "name": ":waving_hand:"
              }
            ],
            "message": "Text 6"
          }
        ],
        "output": [
          {
            "author": "Alice",
            "message": "Text 1"
          },
          {
            "author": "Bob",
            "message": "Text 2"
          },
          {
            "author": "Charlie",
            "emotes": [
              {
                "name": ":grinning_face:",
                "images": [
                  "https://some-host.com/some-url.svg",
                  "https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f600.svg"
                ]
              }
            ],
            "message": "Text 3"
          },
          {
            "author": "Dave",
            "message": "Text 4"
          },
          {
            "author": "Erin",
            "message": "Text 5"
          },
          {
            "author": "Faythe",
            "emotes": [
              {
                "name": ":waving_hand:",
                "images": [
                  "https://some-host.com/some-other-url.svg",
                  "https://www.youtube.com/s/gaming/emoji/828cb648/emoji_u1f44b.svg"
                ]
              }
            ],
            "message": "Text 6"
          }
        ]
      }
    ],
    "identifier": 70718421
  },
  {
    "context": [
      "I have the following object: [ { \"a\": 1, \"b\": 2 }, { \"a\": 11, \"b\": 12 }, { \"a\": 21, \"b\": 22 } ] and the following array: [3,13,33,44] I want to add the array items to the object according to their order as an extra field, it should also work when array is longer/shorter than the array of objects.",
      "the result should look like this: [ { \"a\": 1, \"b\": 2, \"c\": 3 }, { \"a\": 11, \"b\": 12, \"c\": 13 }, { \"a\": 21, \"b\": 22, \"c\": 33 } ]",
      "jq --argjson c '[3,13,33,44]' -f program.jq objects.json",
      "({$c}|keys[0]) as $k | [., ($c | map ( {($k): .} ))] | transpose | map(add)",
      "jq --argjson c '[4,13,33,44]'\\ 'to_entries| map( .value + (if .key<($c|length) then {c:$c[.key]} else {} end) )' objects.json"
    ],
    "utterance": "Add elements from a numbered array as field c to objects in an array by their order, matching by index, handling cases where either array is longer or shorter.",
    "expressions": [
      "({$c}|keys[0]) as $k | [., ($c | map ( {($k): .} ))] | transpose | map(add)",
      "to_entries | map(.value + (if .key<($c|length) then {c:$c[.key]} else {} end))"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 2
          },
          {
            "a": 11,
            "b": 12
          },
          {
            "a": 21,
            "b": 22
          }
        ],
        "output": [
          {
            "a": 1,
            "b": 2,
            "c": 3
          },
          {
            "a": 11,
            "b": 12,
            "c": 13
          },
          {
            "a": 21,
            "b": 22,
            "c": 33
          }
        ]
      }
    ],
    "identifier": 70751435
  },
  {
    "context": [
      "I have a .json file which I want to read, take all the contents.. and append it to a json string that's in a bash variable",
      "OUR_BIG_JSON=$(echo \"${OUR_BIG_JSON}\" |./jq '.myarray += [{\"date\":\"today\"}]')  # This worked.. ",
      "next line fails",
      "OUR_BIG_JSON=$(echo \"${OUR_BIG_JSON}\" |./jq '.myarray += ' $inputs_json)",
      "Using the `--argjson` option to read in the contents of your shell variable enables you to use it as variable inside the jq filter, too. Your input file can normally be read in via parameter.",
      "jq --argjson v \"${OUR_BIG_JSON}\" '$v + {myarray: ($v.myarray + .)}' input.json",
      "jq --argjson v \"${OUR_BIG_JSON}\" '. as $in | $v | .myarray += $in' input.json",
      "jq --argjson v \"${OUR_BIG_JSON}\" -n '$v | .myarray += input' input.json",
      "jq --argfile in input.json '.myarray += $in' <<< \"${OUR_BIG_JSON}\""
    ],
    "utterance": "Append the array from a file to the myarray property of an object stored in a shell variable.",
    "expressions": [
      "jq --argjson v \"${OUR_BIG_JSON}\" '$v + {myarray: ($v.myarray + .)}' input.json",
      "jq --argjson v \"${OUR_BIG_JSON}\" '. as $in | $v | .myarray += $in' input.json",
      "jq --argjson v \"${OUR_BIG_JSON}\" -n '$v | .myarray += input' input.json",
      "jq --argfile in input.json '.myarray += $in' <<< \"${OUR_BIG_JSON}\""
    ],
    "data": [
      {
        "input": {
          "OUR_BIG_JSON": {
            "name": "",
            "myarray": [
              {
                "generic": {
                  "package": "somepymodule"
                }
              },
              {
                "rcann": {
                  "package": "anothermodule==3.0.0"
                }
              }
            ]
          },
          "input.json": [
            {
              "maven": {
                "coordinates": "somelib",
                "repo": "somerepo"
              }
            },
            {
              "maven": {
                "coordinates": "anotherlib",
                "exclusions": [
                  "exclude:this",
                  "*:and-all-that"
                ]
              }
            }
          ]
        },
        "output": {
          "name": "",
          "myarray": [
            {
              "generic": {
                "package": "somepymodule"
              }
            },
            {
              "rcann": {
                "package": "anothermodule==3.0.0"
              }
            },
            {
              "maven": {
                "coordinates": "somelib",
                "repo": "somerepo"
              }
            },
            {
              "maven": {
                "coordinates": "anotherlib",
                "exclusions": [
                  "exclude:this",
                  "*:and-all-that"
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 70744916
  },
  {
    "context": [
      "I need to strip the quotes, commas and brackets..",
      "Use `[]` to turn the list into a series of individual strings, and [`--raw-output` / `-r`](https://stedolan.github.io/jq/manual/v1.6/) to output them without quotes:",
      "aws eks list-clusters | jq -r '.clusters[]' | while read cluster; do something; done"
    ],
    "utterance": "Print each value in the clusters array as an individual unquoted string, separated by newlines.",
    "expressions": [
      ".clusters[]",
      "-r .clusters[]"
    ],
    "identifier": 70759687
  },
  {
    "context": [
      "How can I filter this file by date range and specific period of time?",
      "Doesn't a simple `select` do what you want? For example using plain string comparison makes easy date ranges inclusive on the left and exclusive on the right:",
      "jq 'select(.time > \"2022-01-01\" and .time < \"2022-01-03\")'",
      "You could also convert the date string into e.g. [Unix time](https://en.wikipedia.org/wiki/Unix_time) (\"seconds since the Epoch\") using `fromdate` and operate on that as a number (after employing `sub` to cut off second fractions in order to obtain an [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) compatible date):",
      "jq 'select(.time | sub(\"\\\\.\\\\d+\"; \"\") | fromdate < 1641100000)'",
      "Or, for the sake of another example, using `strptime` to convert the date into a broken-down array (containing in this order: year, (zero-based) month, day, hour, minute, second, day of week, and day of year) and then filtering e.g. for Mondays (represented as `1` in that array at the (zero-based) position `6`):",
      "jq 'select(.time | sub(\"\\\\.\\\\d+\"; \"\") | strptime(\"%FT%TZ\") | .[6] == 1)'"
    ],
    "utterance": "Select all objects where the time field is between \"2022-01-01\" and \"2022-01-03\" (exclusive) or filter for a specific weekday such as Monday.",
    "expressions": [
      "select(.time > \"2022-01-01\" and .time < \"2022-01-03\")",
      "select(.time | sub(\"\\.\\d+\"; \"\") | fromdate < 1641100000)",
      "select(.time | sub(\"\\.\\d+\"; \"\") | strptime(\"%FT%TZ\") | .[6] == 1)"
    ],
    "data": [
      {
        "input": {
          "Name": "Alex",
          "Id": 1,
          "time": "2022-01-01T04:29:18.9099882Z"
        }
      },
      {
        "input": {
          "Name": "Homer",
          "Id": 2,
          "time": "2022-01-02T04:29:18.9099882Z"
        }
      },
      {
        "input": {
          "Name": "Bart",
          "Id": 3,
          "time": "2022-01-03T04:29:18.9099882Z"
        }
      }
    ],
    "identifier": 70754307
  },
  {
    "context": [
      "in SQL this would be something like max(.timestamp.stop) group by .name,.type",
      "Hoping for output like:\n\n[\n  {\n    \"timestamp\": {\n      \"start\": 1642144383,\n      \"stop\": 1642144386\n    },\n    \"info\": {\n      \"size\": 1200934840\n    },\n    \"type\": \"full\",\n    \"name\": \"dbname1\"\n  },\n  {\n    \"timestamp\": {\n      \"start\": 1642145388,\n      \"stop\": 1642145392\n    },\n    \"info\": {\n      \"size\": 1168586330\n    },\n    \"type\": \"incr\",\n    \"name\": \"dbname1\"\n  },\n  {\n    \"timestamp\": {\n      \"start\": 1642144383,\n      \"stop\": 1642144386\n    },\n    \"info\": {\n      \"size\": 1200934840\n    },\n    \"type\": \"full\",\n    \"name\": \"dbname2\"\n  },\n  {\n    \"timestamp\": {\n      \"start\": 1642144388,\n      \"stop\": 1642144392\n    },\n    \"info\": {\n      \"size\": 1168586300\n    },\n    \"type\": \"incr\",\n    \"name\": \"dbname2\"\n  }\n]",
      "Remove the inner brackets to flatten the array, then `group_by` both criteria (which makes your criteria an array), and `map` your `max_by` onto the result array:\n\n```sh\njq 'map(.backup[] + {name}) | group_by([.name, .type]) | map(max_by(.timestamp.stop))'\n```"
    ],
    "utterance": "For each combination of name and type, return the backup with the highest timestamp.stop.",
    "expressions": [
      "map(.backup[] + {name}) | group_by([.name, .type]) | map(max_by(.timestamp.stop))"
    ],
    "data": [
      {
        "input": [
          {
            "backup": [
              {
                "timestamp": {
                  "start": 1642144383,
                  "stop": 1642144386
                },
                "info": {
                  "size": 1200934840
                },
                "type": "full"
              },
              {
                "timestamp": {
                  "start": 1642144388,
                  "stop": 1642144392
                },
                "info": {
                  "size": 1168586300
                },
                "type": "incr"
              },
              {
                "timestamp": {
                  "start": 1642145388,
                  "stop": 1642145392
                },
                "info": {
                  "size": 1168586330
                },
                "type": "incr"
              }
            ],
            "name": "dbname1"
          },
          {
            "backup": [
              {
                "timestamp": {
                  "start": 1642144383,
                  "stop": 1642144386
                },
                "info": {
                  "size": 1200934840
                },
                "type": "full"
              },
              {
                "timestamp": {
                  "start": 1642144388,
                  "stop": 1642144392
                },
                "info": {
                  "size": 1168586300
                },
                "type": "incr"
              }
            ],
            "name": "dbname2"
          }
        ],
        "output": [
          {
            "timestamp": {
              "start": 1642144383,
              "stop": 1642144386
            },
            "info": {
              "size": 1200934840
            },
            "type": "full",
            "name": "dbname1"
          },
          {
            "timestamp": {
              "start": 1642145388,
              "stop": 1642145392
            },
            "info": {
              "size": 1168586330
            },
            "type": "incr",
            "name": "dbname1"
          },
          {
            "timestamp": {
              "start": 1642144383,
              "stop": 1642144386
            },
            "info": {
              "size": 1200934840
            },
            "type": "full",
            "name": "dbname2"
          },
          {
            "timestamp": {
              "start": 1642144388,
              "stop": 1642144392
            },
            "info": {
              "size": 1168586300
            },
            "type": "incr",
            "name": "dbname2"
          }
        ]
      }
    ],
    "identifier": 70752174
  },
  {
    "context": [
      "I want to be able to select on specific items based on the appname.",
      "So i can do for example\n\njq .[] app3 \n\nresponse should be ***READY***",
      "jq -r --arg q \"app3\" '\n  .[]\n  | select(.[] | .field.name == \"appname\" and .value.value == $q)\n  | .[]\n  | select(.field.name == \"appstat\").value.value\n'",
      "That way, your lookup would be as simple as\njq -r --arg q \"app3\" '.[] | select(.appname == $q).appstat'"
    ],
    "utterance": "Retrieve the appstat value for the item where the appname is app3 and output its status.",
    "expressions": [
      "jq -r --arg q \"app3\" '.[] | select(.[] | .field.name == \"appname\" and .value.value == $q) | .[] | select(.field.name == \"appstat\").value.value'",
      "jq -r --arg q \"app3\" '.[] | select(.appname == $q).appstat'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "field": {
                "name": "appname"
              },
              "value": {
                "value": "app1"
              }
            },
            {
              "field": {
                "name": "appstat"
              },
              "value": {
                "value": "UP"
              }
            }
          ],
          [
            {
              "field": {
                "name": "appname"
              },
              "value": {
                "value": "app2"
              }
            },
            {
              "field": {
                "name": "appstat"
              },
              "value": {
                "value": "DOWN"
              }
            }
          ],
          [
            {
              "field": {
                "name": "appname"
              },
              "value": {
                "value": "app3"
              }
            },
            {
              "field": {
                "name": "appstat"
              },
              "value": {
                "value": "READY"
              }
            }
          ]
        ],
        "output": "READY"
      },
      {
        "input": [
          {
            "appname": "app1",
            "appstat": "UP"
          },
          {
            "appname": "app2",
            "appstat": "DOWN"
          },
          {
            "appname": "app3",
            "appstat": "READY"
          }
        ],
        "output": "READY"
      }
    ],
    "identifier": 70757309
  },
  {
    "context": [
      "I'm trying to combine files (simplified from Elasticsearch's ILM Explain & ILM Policy API responses):",
      "Where ie1 is base JSON and for a child-object, its sub-element `policy` should line up to ip1's key and copy its sub-elements into itself.",
      "Does anyone have an idea how to get the filter part working?",
      "jq '\n  input as $ip | .indices | with_entries(.value += $ip[.key | sub(\"-[^-]*$\";\"\")])\n' ie1.json ip1.json",
      "{\n  \".siem-signals-default-000001\": {\n    \"action\": \"complete\",\n    \"index\": \".siem-signals-default-000001\",\n    \"policy\": \".siem-signals-default\",\n    \"modified_date\": \"siem\",\n    \"version\": 1\n  }\n}",
      "jq '\n  input as $ip | .indices | map_values(. += $ip[.index | sub(\"-[^-]*$\";\"\")])\n'ie1.json ip1.json",
      "$ jq '.indices | map(. * input[.policy])' ie1.json ip1.json",
      "[\n  {\n    \"action\": \"complete\",\n    \"index\": \".siem-signals-default-000001\",\n    \"policy\": \".siem-signals-default\",\n    \"modified_date\": \"siem\",\n    \"version\": 1\n  }\n]"
    ],
    "utterance": "For each entry in the indices object, merge in corresponding properties from another object whose key matches the value of the policy property or the index property (with the suffix after the last dash removed).",
    "expressions": [
      "input as $ip | .indices | with_entries(.value += $ip[.key | sub(\"-[^-]*$\";\"\")])",
      "input as $ip | .indices | map_values(. += $ip[.index | sub(\"-[^-]*$\";\"\")])",
      ".indices | map(. * input[.policy])"
    ],
    "data": [
      {
        "input": {
          "ip1.json": {
            ".siem-signals-default": {
              "modified_date": "siem",
              "version": 1
            },
            "kibana-event-log-policy": {
              "modified_date": "kibana",
              "version": 1
            }
          },
          "ie1.json": {
            "indices": {
              ".siem-signals-default-000001": {
                "action": "complete",
                "index": ".siem-signals-default-000001",
                "policy": ".siem-signals-default"
              }
            }
          }
        },
        "output": {
          ".siem-signals-default-000001": {
            "action": "complete",
            "index": ".siem-signals-default-000001",
            "policy": ".siem-signals-default",
            "modified_date": "siem",
            "version": 1
          }
        }
      }
    ],
    "identifier": 70714377
  },
  {
    "context": [
      "What should I do to get the results as follows?",
      "CPU20\": [\r\n        { \"instance\": \"10.0.20.1\", \"value\": 12 },\r\n        { \"instance\": \"10.0.20.2\", \"value\": 22 },\r\n        { \"instance\": \"10.0.20.3\", \"value\": 13 },\r\n        { \"instance\": \"10.0.20.4\", \"value\": 11 },\r\n        { \"instance\": \"10.0.20.5\", \"value\": 14 }",
      "jq -Rn '\r\n  [inputs | select(. != \"\") / \" \"]\r\n  | group_by(.[0])\r\n  | map({(.[0][0]): map({instance: .[1], value: .[2]})})\r\n  | add\r\n'",
      "jq -Rn '\r\n  reduce (inputs | select(. != \"\") / \" \") as [$cpu, $instance, $value] ({};\r\n    .[$cpu] += [{$instance, $value}]\r\n  )\r\n'"
    ],
    "utterance": "Group lines by the first field and produce an object where each key is the group name and its value is a list of objects with fields instance as the second value and value as the third value (as a number).",
    "expressions": [
      "jq -Rn '\n  [inputs | select(. != \"\") / \" \"]\n  | group_by(.[0])\n  | map({(.[0][0]): map({instance: .[1], value: .[2]})})\n  | add\n'",
      "jq -Rn '\n  reduce (inputs | select(. != \"\") / \" \") as [$cpu, $instance, $value] ({};\n    .[$cpu] += [{$instance, $value}]\n  )\n'"
    ],
    "data": [
      {
        "input": [
          "CPU20 10.0.20.1 12",
          "CPU20 10.0.20.2 22",
          "CPU20 10.0.20.3 13",
          "CPU20 10.0.20.4 11",
          "CPU20 10.0.20.5 14",
          "CPU21 10.0.21.1 15",
          "CPU21 10.0.21.2 24",
          "CPU21 10.0.21.3 21",
          "CPU21 10.0.21.4 15",
          "CPU21 10.0.21.5 16",
          "CPU22 10.0.22.1 12",
          "CPU22 10.0.22.2 18",
          "CPU22 10.0.22.3 19",
          "CPU22 10.0.22.4 12",
          "CPU22 10.0.22.5 13",
          "CPU23 10.0.20.1 17",
          "CPU23 10.0.20.2 15",
          "CPU23 10.0.20.3 21",
          "CPU23 10.0.20.4 22",
          "CPU23 10.0.20.5 25"
        ],
        "output": {
          "CPU20": [
            {
              "instance": "10.0.20.1",
              "value": 12
            },
            {
              "instance": "10.0.20.2",
              "value": 22
            },
            {
              "instance": "10.0.20.3",
              "value": 13
            },
            {
              "instance": "10.0.20.4",
              "value": 11
            },
            {
              "instance": "10.0.20.5",
              "value": 14
            }
          ],
          "CPU21": [
            {
              "instance": "10.0.21.1",
              "value": 15
            },
            {
              "instance": "10.0.21.2",
              "value": 24
            },
            {
              "instance": "10.0.21.3",
              "value": 21
            },
            {
              "instance": "10.0.21.4",
              "value": 15
            },
            {
              "instance": "10.0.21.5",
              "value": 16
            }
          ],
          "CPU22": [
            {
              "instance": "10.0.22.1",
              "value": 12
            },
            {
              "instance": "10.0.22.2",
              "value": 18
            },
            {
              "instance": "10.0.22.3",
              "value": 19
            },
            {
              "instance": "10.0.22.4",
              "value": 12
            },
            {
              "instance": "10.0.22.5",
              "value": 13
            }
          ],
          "CPU23": [
            {
              "instance": "10.0.20.1",
              "value": 17
            },
            {
              "instance": "10.0.20.2",
              "value": 15
            },
            {
              "instance": "10.0.20.3",
              "value": 21
            },
            {
              "instance": "10.0.20.4",
              "value": 22
            },
            {
              "instance": "10.0.20.5",
              "value": 25
            }
          ]
        }
      }
    ],
    "identifier": 70666584
  },
  {
    "context": [
      "now I need to update every objects version: \"$version-dev\" where name starts from `jack` while retaining rest of the json intact.",
      "in the above command I'm only getting the that particular object with updated value in the new.json but I need the whole json too.",
      "You need to put parantheses around the whole selection to be updated: `(\u2026 | .version) += \u2026`",
      "jq '(.B[] | select(.name|test(\"jack.\")) | .version) += \"-dev\"' old.json > new.json"
    ],
    "utterance": "Append '-dev' to the version of each object in array B whose name starts with 'jack', leaving the rest unchanged.",
    "expressions": [
      "(.B[] | select(.name|test(\"^jack\")) | .version) += \"-dev\"",
      "(.B[] | select(.name|startswith(\"jack\")) | .version) += \"-dev\""
    ],
    "data": [
      {
        "input": {
          "A": "jack",
          "B": [
            {
              "name": "jack/jil",
              "version": "0.1"
            },
            {
              "name": "went/well",
              "version": "1.2"
            }
          ]
        },
        "output": {
          "A": "jack",
          "B": [
            {
              "name": "jack/jil",
              "version": "0.1-dev"
            },
            {
              "name": "went/well",
              "version": "1.2"
            }
          ]
        }
      }
    ],
    "identifier": 70760535
  },
  {
    "context": [
      "Sample JSON. I will have to fetch the value of the city and I do not know the position of it as I will have to search and fetch the value.",
      "The `city` field is located within the `address` field  of the outermost object. Therefore, using jq, you can access it with the filter `.address.city`.",
      "You could get all occurrences of the values corresponding to a key named \"city\" by:\r\n\r\n    jq '..|objects|.city  // empty'"
    ],
    "utterance": "Get all values for keys named 'city', regardless of their location in the object hierarchy.",
    "expressions": [
      "..|objects|.city // empty"
    ],
    "data": [
      {
        "input": {
          "firstName": "Rajesh",
          "lastName": "Kumar",
          "gender": "man",
          "age": 24,
          "address": {
            "streetAddress": "126 Udhna",
            "city": "Surat",
            "state": "WB",
            "postalCode": "394221"
          },
          "phoneNumbers": [
            {
              "type": "home",
              "number": "7383627627"
            }
          ]
        },
        "output": "Surat"
      }
    ],
    "identifier": 70774649
  },
  {
    "context": [
      "but i want the result\n\n[\n\t{\n\t  \"Distributor ID:\": \"Ubuntu\"\n\t},\n\t{\n\t  \"Description:\": \"Ubuntu 20.04.3 LTS\"\n\t},\n\t{\n\t  \"Release:\": \"20.04\"\n\t},\n\t{\n\t  \"Codename:\": \"focal\"\n\t}\n]",
      "jq -nR '[ inputs | split(\"\\t\") | { (.[0]) : .[1] } ]'",
      "Input\nDistributor ID:\tUbuntu\nDescription:\tUbuntu 20.04.3 LTS\nRelease:\t20.04\nCodename:\tfocal"
    ],
    "utterance": "Combine tab-separated key-value data, with keys ending in a colon, into an array of objects each mapping the key to its value.",
    "expressions": [
      "[ inputs | split(\"\\t\") | { (.[0]) : .[1] } ]",
      "jq -nR '[ inputs | split(\"\\t\") | { (.[0]) : .[1] } ]'"
    ],
    "data": [
      {
        "input": "Distributor ID:\tUbuntu\nDescription:\tUbuntu 20.04.3 LTS\nRelease:\t20.04\nCodename:\tfocal",
        "output": [
          {
            "Distributor ID:": "Ubuntu"
          },
          {
            "Description:": "Ubuntu 20.04.3 LTS"
          },
          {
            "Release:": "20.04"
          },
          {
            "Codename:": "focal"
          }
        ]
      }
    ],
    "identifier": 70804610
  },
  {
    "context": [
      "Given I have a list of objects:\n\n```json\n{\n  \"alpha\": {\n    \"bytes\": {\n      \"value\": 4789440\n    },\n    \"doc_count\": 7723\n  },\n  \"beta\": {\n    \"bytes\": {\n      \"value\": 4416862639\n      },\n    \"doc_count\": 1296\n  }\n}\n```",
      "Is there a way using `jq` to get an array representation of this, such as:\n\n```json\n  [\n    {\n      \"key\": \"alpha\",\n      \"bytes\": {\n        \"value\": 4789440\n      },\n      \"doc_count\": 7723\n    },\n    {\n      \"key\": \"beta\",\n      \"bytes\": {\n        \"value\": 4416862639\n      },\n      \"doc_count\": 1296\n    }\n  ]\n```",
      "Using `to_entries` would be one way. By accessing `.key` and `.value`, the composition would be:\n\n```sh\njq '[to_entries[] | {key} + .value]' input.json\n```",
      "```jq\n[ keys_unsorted[] as $key | { $key } + .[$key] ]\n```",
      "or\n\n```jq\nto_entries | map( { key } + .value )\n```"
    ],
    "utterance": "Convert an object with unknown top-level keys into an array of objects, each including its key as a property along with its original contents.",
    "expressions": [
      "[to_entries[] | {key} + .value]",
      "[keys_unsorted[] as $key | { key: $key } + .[$key] ]",
      "to_entries | map({key} + .value)"
    ],
    "data": [
      {
        "input": {
          "alpha": {
            "bytes": {
              "value": 4789440
            },
            "doc_count": 7723
          },
          "beta": {
            "bytes": {
              "value": 4416862639
            },
            "doc_count": 1296
          }
        },
        "output": [
          {
            "key": "alpha",
            "bytes": {
              "value": 4789440
            },
            "doc_count": 7723
          },
          {
            "key": "beta",
            "bytes": {
              "value": 4416862639
            },
            "doc_count": 1296
          }
        ]
      }
    ],
    "identifier": 70771975
  },
  {
    "context": [
      "The question is, what would be the best way to add new element to array \"services\" if the file contains \"b4fd044b9a7ab1146bb638ea42219b99\" value in the \"tags\" array. If this value does not exists in the \"tags\" array skip the file, else add \"NEWVALUETOADD\" to \"services\".",
      "If \"NEWVALUETOADD\" already exists we can also skip the file.",
      "A simple `if \u2026 then \u2026 else \u2026 end` might do:\n\n```sh\njq --arg q \"b4fd044b9a7ab1146bb638ea42219b99\" --arg n \"NEWVALUETOADD\" '\n  if IN(.tags[]; $q) and (IN(.services[]; $n) | not)\n  then .services += [$n] else . end\n'\n```",
      "jq --arg nv \"NEWVALUETOADD\" 'select(.tags[] | select(. == \"b4fd044b9a7ab1146bb638ea42219b99\") ).services += [$nv]'",
      "jq '(select(.tags | index(\"b4fd044b9a7ab1146bb638ea42219b99\")).services )+=[\"New Value\"]' yourfile"
    ],
    "utterance": "Add \"NEWVALUETOADD\" to the beginning of \"services\" array in all files where \"tags\" contains \"b4fd044b9a7ab1146bb638ea42219b99\" and \"services\" does not already contain \"NEWVALUETOADD\"; otherwise, skip the file.",
    "expressions": [
      "jq --arg q \"b4fd044b9a7ab1146bb638ea42219b99\" --arg n \"NEWVALUETOADD\" 'if IN(.tags[]; $q) and (IN(.services[]; $n) | not) then .services += [$n] else . end'",
      "jq --arg nv \"NEWVALUETOADD\" 'select(.tags[] | select(. == \"b4fd044b9a7ab1146bb638ea42219b99\") ).services += [$nv]'",
      "jq '(select(.tags | index(\"b4fd044b9a7ab1146bb638ea42219b99\")).services )+=[\"NEWVALUETOADD\"]'"
    ],
    "data": [
      {
        "input": {
          "enabled": true,
          "services": [
            "933579ee8caafc4e818ddfe02ab58fdc"
          ],
          "tags": [
            "2a521880b86a0f043eb65cff37fac679",
            "b4fd044b9a7ab1146bb638ea42219b99"
          ],
          "bouquet": ""
        },
        "output": {
          "enabled": true,
          "services": [
            "933579ee8caafc4e818ddfe02ab58fdc",
            "NEWVALUETOADD"
          ],
          "tags": [
            "2a521880b86a0f043eb65cff37fac679",
            "b4fd044b9a7ab1146bb638ea42219b99"
          ],
          "bouquet": ""
        }
      }
    ],
    "identifier": 70762485
  },
  {
    "context": [
      "I have a database of resumes in json format that I want to reshape so that each row corresponds to a person's employment history at a given company:",
      "personid, company_name, start_date, end_date",
      "However, running the following jq command\n\n```{personid:.personid, company_name: .experience[].company.name, sdate: .experience[].start_date, edate: .experience[].end_date}```\n\nproduces the cartesian product of all the fields (3 jobs x 3 fields).",
      "You might want to pull out the iteration, maybe save it in a variable, and reference that instead:\n```\n.experience[] as $experience | {\n  personid: .personid,\n  company_name: $experience.company.name,\n  sdate: $experience.start_date,\n  edate: $experience.end_date\n}\n```",
      "Depending on the outer structure of your construction, also the other way around may be appropriate, ie. storing the `.person` field instead in a variable:\n```\n.personid as $id | .experience[] | {\n  personid: $id,\n  company_name: .company.name,\n  sdate: .start_date,\n  edate: .end_date\n}\n```"
    ],
    "utterance": "Produce one row per employment entry, containing personid, company name, start date, and end date for each job held by a person.",
    "expressions": [
      ".experience[] as $experience | { personid: .personid, company_name: $experience.company.name, sdate: $experience.start_date, edate: $experience.end_date }",
      ".personid as $id | .experience[] | { personid: $id, company_name: .company.name, sdate: .start_date, edate: .end_date }"
    ],
    "identifier": 70806656
  },
  {
    "context": [
      "I'd like to be able to modify the ConnectionString, the SqlCommandTimeout and the ServiceAccountPrincipal values.  For brevity, I am just showing the change to the ConnectionString.",
      "jq '.SecretString |= (fromjson | .ConnectionString = \"MyNewConnectionString\" | tojson)' json.txt",
      "To manipulate more than just one value, simply add them after the first: .ConnectionString = \"\u2026\" | .SqlCommandTimeout = \"\u2026\" | .ServiceAccountPrincipal = \"\u2026\"",
      "We have to use fromjson and tojson on the value of SecretString.",
      "(.SecretString | fromjson | .ConnectionString |= \"MyNewConnectionString\" | tojson) as $secret | .SecretString |= $secret",
      "You can see that ConnectionString is updated with the new value MyNewConnectionString as *json string*."
    ],
    "utterance": "Update the value of the ConnectionString key inside the SecretString field to MyNewConnectionString and output the modified object.",
    "expressions": [
      ".SecretString |= (fromjson | .ConnectionString = \"MyNewConnectionString\" | tojson)",
      "(.SecretString | fromjson | .ConnectionString |= \"MyNewConnectionString\" | tojson) as $secret | .SecretString |= $secret"
    ],
    "data": [
      {
        "input": {
          "ARN": "MyArn",
          "Name": "MySecret",
          "SecretString": "{\"ConnectionString\":\"MyConnectionString\",\"SqlCommandTimeout\":\"60\",\"ServiceAccountPrincipal\":\"MyServicePrincipal\"}",
          "VersionStages": [
            "AWSCURRENT"
          ],
          "CreatedDate": "2022-01-13T09:08:55.442000-08:00"
        },
        "output": {
          "ARN": "MyArn",
          "Name": "MySecret",
          "SecretString": "{\"ConnectionString\":\"MyNewConnectionString\",\"SqlCommandTimeout\":\"60\",\"ServiceAccountPrincipal\":\"MyServicePrincipal\"}",
          "VersionStages": [
            "AWSCURRENT"
          ],
          "CreatedDate": "2022-01-13T09:08:55.442000-08:00"
        }
      }
    ],
    "identifier": 70760147
  },
  {
    "context": [
      "I want to remove field 2 from key5 array and add another field say field3  in key5 array using jq",
      "jq --arg delkey 'field2' --argjson addobj '{\"field3\": \"new\"}' '\n  .key5[] |= delpaths([[$delkey]]) + $addobj\n' input.json",
      "jq --arg delkey 'field2' --arg addkey 'field3' --arg addval 'new' '\n  .key5[] |= (delpaths([[$delkey]]) | .[$addkey] = $addval)\n' input.json",
      "jq '.key5[] |= ( del( .field2 ) | .field3 = \"foo\" )'",
      "jq --arg val foo '.key5[] |= ( del( .field2 ) | .field3 = $val )'",
      "del(.key5[0].field2) | .key5[0] |= .+{field3:\"foo\"}"
    ],
    "utterance": "Remove field2 from each object in key5 array and add field3 with value 'foo' or 'new' to each object in that array.",
    "expressions": [
      ".key5[] |= (del(.field2) | .field3 = \"foo\")",
      "jq --arg val foo '.key5[] |= (del(.field2) | .field3 = $val)'",
      ".key5[] |= delpaths([[\"field2\"]]) + {\"field3\": \"new\"}",
      "jq --arg delkey 'field2' --argjson addobj '{\"field3\": \"new\"}' '.key5[] |= delpaths([[$delkey]]) + $addobj'",
      "jq --arg delkey 'field2' --arg addkey 'field3' --arg addval 'new' '.key5[] |= (delpaths([[$delkey]]) | .[$addkey] = $addval)'"
    ],
    "data": [
      {
        "input": {
          "key1": [
            "value1"
          ],
          "key2": [
            "value2"
          ],
          "key3": [
            "value3"
          ],
          "key4": {
            "name": "value4"
          },
          "key5": [
            {
              "field1": "abc",
              "field2": "xyz"
            }
          ]
        },
        "output": {
          "key1": [
            "value1"
          ],
          "key2": [
            "value2"
          ],
          "key3": [
            "value3"
          ],
          "key4": {
            "name": "value4"
          },
          "key5": [
            {
              "field1": "abc",
              "field3": "foo"
            }
          ]
        }
      }
    ],
    "identifier": 70805891
  },
  {
    "context": [
      "$ TZ=America/New_York jq -r '((./1000 | floor | strflocaltime(\"%Y-%m-%d %H:%M:%S\") + \".\" + (.%1000 | tostring | (\"0\" * (3 - length)) + .)))' <<< 1642812926681 # Time is in the number of epoch millisecond.",
      "If your system/environment implements the placeholder `%N` for nanoseconds, you could use `%3N` to get the padded milliseconds:",
      "def mydate:\n  ./1000 | strflocaltime(\"%Y-%m-%d %H:%M:%S.%3N\");",
      "If it doesn't, you could still do some tweaks to shorten it:",
      "def mydate:\n  (./1000 | strflocaltime(\"%F %T.\")) + \"00\\(.%1000)\"[-3:];"
    ],
    "utterance": "Convert an epoch time in milliseconds to an ISO-like string with milliseconds in the America/New_York time zone.",
    "expressions": [
      "def mydate: ./1000 | strflocaltime(\"%Y-%m-%d %H:%M:%S.%3N\"); mydate",
      "def mydate: (./1000 | strflocaltime(\"%F %T.\")) + \"00\\(.%1000)\"[-3:]; mydate"
    ],
    "data": [
      {
        "input": 1642812926681,
        "output": "2022-01-21 19:55:26.681"
      }
    ],
    "identifier": 70819375
  },
  {
    "context": [
      "I am trying to fetch message field from below json file in comma separated value",
      "My attempt to do that with jq: `jq -r '.message | join(\",\")'`",
      "It keeps throwing following error:\r\n`jq: error (at <stdin>:0): Cannot index array with string \"message\"`",
      "$ jq -r 'map(.message) | join(\",\")'\r\nsecond bad commit,first bad commit"
    ],
    "utterance": "Output the values of the 'message' field in a comma-separated list",
    "expressions": [
      "map(.message) | join(\",\")"
    ],
    "data": [
      {
        "input": [
          {
            "title": "second bad commit",
            "message": "second bad commit"
          },
          {
            "title": "first bad commit",
            "message": "first bad commit"
          }
        ],
        "output": "second bad commit,first bad commit"
      }
    ],
    "identifier": 70830757
  },
  {
    "context": [
      ". += [$json_data]",
      "jq: error: $json_data is not defined at <top-level>, line 1:",
      "json_data=\"$json_data\" jq '. += [ env.json_data ]' <<<\"$requestArray\"",
      "export json_data\njq '. += [ env.json_data ]' <<<\"$requestArray\"",
      "jq --arg json_data \"$json_data\" '. += [ $json_data ]' <<<\"$requestArray\"",
      "jq '.data | map( { deliveryRegionId, deliverableDistance: 5000 } )' <<<\"$data\""
    ],
    "utterance": "Append the value of a shell variable as a new object to an existing array, ensuring the value is passed correctly from the shell variable into the jq process.",
    "expressions": [
      "json_data=\"$json_data\" jq '. += [ env.json_data ]' <<<\"$requestArray\"",
      "export json_data\njq '. += [ env.json_data ]' <<<\"$requestArray\"",
      "jq --arg json_data \"$json_data\" '. += [ $json_data ]' <<<\"$requestArray\""
    ],
    "identifier": 70828977
  },
  {
    "context": [
      "My goals is to get all the keys where:\r\n\r\n 1. Max history_ban date is smaller than \"2022-01-16 09:00\"\r\n 2. Max history_unban date is empty/non-existent or smaller then Max history_ban date",
      "Just to be sure, my expected result in this example is\r\n\r\n - \"2.2.2.2\"\r\n - \"3.3.3.3\"",
      "You could use the update operator // to introduce another constraint if history_unban is existent and not empty.",
      "jq -r '\r\n  to_entries[] | select(.value\r\n    | (.history_ban | max) as $maxban\r\n    | $maxban > \"2022-01-16 09:00\"\r\n      and (.history_unban | length == 0 // $maxban > max)\r\n  ).key\r\n'"
    ],
    "utterance": "Select all keys where the latest history_ban date is less than \"2022-01-16 09:00\" and either history_unban is missing or empty, or its latest date is earlier than the latest history_ban date.",
    "expressions": [
      "to_entries[] | select((.value.history_ban | max) < \"2022-01-16 09:00\" and ((.value.history_unban | length == 0) or ((.value.history_unban | max) < (.value.history_ban | max)))) | .key"
    ],
    "data": [
      {
        "input": {
          "1.1.1.1": {
            "history_ban": [
              "2021-05-02 14:30",
              "2022-01-01 12:00"
            ],
            "history_unban": [
              "2021-05-09 14:30",
              "2022-01-08 12:00"
            ]
          },
          "2.2.2.2": {
            "history_ban": [
              "2022-01-16 07:00"
            ],
            "history_unban": []
          },
          "3.3.3.3": {
            "history_ban": [
              "2022-01-15 22:40"
            ]
          }
        },
        "output": [
          "2.2.2.2",
          "3.3.3.3"
        ]
      }
    ],
    "identifier": 70820479
  },
  {
    "context": [
      "I want to add ```json_data``` to ```requestArray```, but it seems not to work.",
      "Or this, if you want to have the resulting object's field renamed to `requestArray`:",
      "jq --argjson deliverableDistance 5000 '{requestArray: (.data | map(. += {$deliverableDistance}))}' <<< \"$data\"",
      "~~~json\n{\n  \"requestArray\": [\n    {\n      \"deliveryRegionId\": 2,\n      \"deliverableDistance\": 5000\n    },\n    {\n      \"deliveryRegionId\": 3,\n      \"deliverableDistance\": 5000\n    }\n  ]\n}\n~~~"
    ],
    "utterance": "Produce an object with a field named requestArray containing data objects, each appended with a deliverableDistance field set to 5000.",
    "expressions": [
      "{requestArray: (.data | map(. += {\"deliverableDistance\": 5000}))}"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "deliveryRegionId": 2
            },
            {
              "deliveryRegionId": 3
            }
          ]
        },
        "output": {
          "requestArray": [
            {
              "deliveryRegionId": 2,
              "deliverableDistance": 5000
            },
            {
              "deliveryRegionId": 3,
              "deliverableDistance": 5000
            }
          ]
        }
      }
    ],
    "identifier": 70828479
  },
  {
    "context": [
      "I have following json input file. I need to get the 2 and 3rd keys like below.",
      "Need out put as: \n\n    test, 2021.1.2\n    dev, 2021.2.2\n    test, 2021.1.2\n    dev, 2021.2.1\n    test, 2021.3.1",
      ".[].builds | to_entries[] | \"\\(.key), \\(.value | keys[])\"",
      "jq -r '[].builds | paths | select(length == 2) | join(\", \")'",
      "jq -r 'path([].builds[][])[2:] | join(\", \")'"
    ],
    "utterance": "List all pairs of build type and version, such as 'test, 2021.1.2', for each entry in the input.",
    "expressions": [
      ".[].builds | to_entries[] | \"\\(.key), \\(.value | keys[])\"",
      ".[].builds | to_entries[] | \"\\(.key), \\(.value | keys[])\"",
      ".[].builds | paths | select(length == 2) | join(\", \")",
      "path([].builds[][])[2:] | join(\", \")"
    ],
    "data": [
      {
        "input": [
          {
            "builds": {
              "test": {
                "2021.1.2": {
                  "stages": [
                    "functional",
                    "integration"
                  ]
                }
              },
              "dev": {
                "2021.2.2": {
                  "stages": [
                    "junit",
                    "nls"
                  ]
                }
              }
            },
            "dockertag": "0.1.1"
          },
          {
            "builds": {
              "test": {
                "2021.1.2": {
                  "stages": [
                    "functional"
                  ]
                }
              },
              "dev": {
                "2021.2.1": {
                  "stages": [
                    "junit",
                    "nls"
                  ]
                }
              }
            },
            "dockertag": "0.1.2"
          },
          {
            "builds": {
              "test": {
                "2021.3.1": {
                  "stages": [
                    "functional",
                    "integration"
                  ]
                }
              }
            },
            "dockertag": "0.1.3"
          }
        ],
        "output": [
          "test, 2021.1.2",
          "dev, 2021.2.2",
          "test, 2021.1.2",
          "dev, 2021.2.1",
          "test, 2021.3.1"
        ]
      }
    ],
    "identifier": 70817244
  },
  {
    "context": [
      "now I need to append `-dev` to those key/values where key starts with `jok`.",
      ".re |= with_entries(select(.key|startswith(\"jok\")).value += \"-dev\")"
    ],
    "utterance": "Append '-dev' to values for all keys in the object 're' that start with 'jok'.",
    "expressions": [
      ".re |= with_entries(select(.key|startswith(\"jok\")).value += \"-dev\")"
    ],
    "data": [
      {
        "input": {
          "A": "a",
          "re": {
            "jok/pok": "^20.0",
            "sok/dok": "^23.0",
            "jok/ssd": "^32.0"
          }
        },
        "output": {
          "A": "a",
          "re": {
            "jok/pok": "^20.0-dev",
            "sok/dok": "^23.0",
            "jok/ssd": "^32.0-dev"
          }
        }
      }
    ],
    "identifier": 70852574
  },
  {
    "context": [
      "I have json file `env.json` having following content:\r\n\r\n```\r\n{\r\n  \"parameters\": {\r\n    \"name\": \"www\",\r\n    \"dev\" : \"\",\r\n    \"prod\": \"\"\r\n  }\r\n}\r\n```",
      "You could do a multi-value replacement with `jq` to prevent overwriting the same file again and again.",
      "echo -e \"$(jq --arg name $NAME --arg dev $DEV --arg prod $PROD '.parameters.name = ($name) | .parameters.dev = ($dev) | .parameters.prod = ($prod)' env.json)\" > env.json",
      "jq \\\r\n   --arg name \"$NAME\" \\\r\n   --arg prod \"$PROD\" \\\r\n   --arg dev  \"$DEV\"  \\\r\n'\r\n  .parameters.name = $name |\r\n  .parameters.prod = $prod |\r\n  .parameters.dev  = $dev\r\n' <<<\"$ENVJSON\" >env.json"
    ],
    "utterance": "Update the 'name', 'dev', and 'prod' fields under 'parameters' with specified values in a single operation.",
    "expressions": [
      ".parameters.name = $name | .parameters.dev = $dev | .parameters.prod = $prod",
      ".parameters.name = $name | .parameters.prod = $prod | .parameters.dev = $dev"
    ],
    "data": [
      {
        "input": {
          "parameters": {
            "name": "www",
            "dev": "",
            "prod": ""
          }
        },
        "output": {
          "parameters": {
            "name": "newName",
            "dev": "newDev",
            "prod": "newProd"
          }
        }
      }
    ],
    "identifier": 70844334
  },
  {
    "context": [
      "I need to generate a different json file, that would be an array of used `tag`s, and each tag would have extra information which `object`s use it:\r\n\r\n    [\r\n      { \r\n        \"tag\": \"A\",\r\n        \"objects\": [\"object1\", \"object2\", \"object4\"]\r\n      },\r\n      { \r\n        \"tag\": \"B\",\r\n        \"objects\": [\"object2\"]\r\n      },\r\n      { \r\n        \"tag\": \"C\",\r\n        \"objects\": [\"object3\"]\r\n      }\r\n    ]",
      "jq -s '\n  add | reduce to_entries[] as $e ({}; .[$e.value.tags[]] += [$e.key])\n  | to_entries | map({tag:.key, objects:.value})\n' *.json"
    ],
    "utterance": "Produce an array where each entry contains a tag used as 'tag' and a list of all objects that include that tag as 'objects'.",
    "expressions": [
      "jq -s '\n  add | reduce to_entries[] as $e ({}; .[$e.value.tags[]] += [$e.key])\n  | to_entries | map({tag:.key, objects:.value})\n' *.json"
    ],
    "data": [
      {
        "input": [
          {
            "object1": {
              "tags": [
                "A"
              ],
              "something": "else",
              "other": "data"
            },
            "object2": {
              "tags": [
                "A",
                "B"
              ]
            }
          },
          {
            "object3": {
              "tags": [
                "C"
              ],
              "something": "else",
              "other": "data"
            },
            "object4": {
              "tags": [
                "A"
              ]
            }
          }
        ],
        "output": [
          {
            "tag": "A",
            "objects": [
              "object1",
              "object2",
              "object4"
            ]
          },
          {
            "tag": "B",
            "objects": [
              "object2"
            ]
          },
          {
            "tag": "C",
            "objects": [
              "object3"
            ]
          }
        ]
      }
    ],
    "identifier": 70845507
  },
  {
    "context": [
      "\".o |= with_entries( if .key | tonumber? // false then .value |= . + 100 else . end )\"",
      "\"As applied to the example:\"",
      "\"( .o | .[ keys_unsorted[] | select( tonumber? ) ] ) |= . + 100\"",
      "\"Same idea, but using `to_entries` to give the query access to both the key and the value:\"",
      "\"( .o | .[ to_entries[] | select( .key | tonumber? ) | .key ] ) |= . + 100\""
    ],
    "utterance": "Increase the values of object members whose keys are numeric strings by 100.",
    "expressions": [
      ".o |= with_entries( if .key | tonumber? // false then .value |= . + 100 else . end )",
      "( .o | .[ keys_unsorted[] | select( tonumber? ) ] ) |= . + 100",
      "( .o | .[ to_entries[] | select( .key | tonumber? ) | .key ] ) |= . + 100"
    ],
    "data": [
      {
        "input": {
          "o": {
            "a": 3,
            "b": 4,
            "1": 3,
            "2": 4
          }
        },
        "output": {
          "o": {
            "a": 3,
            "b": 4,
            "1": 103,
            "2": 104
          }
        }
      }
    ],
    "identifier": 70855081
  },
  {
    "context": [
      "Now, I would like to zip the two arrays and keep the rest to arrive at:",
      "You can use the `transpose` builtin, which converts an array of arrays into a zipped array, and `map` to generate an object within each paired array element.",
      "jq '{\n  \"hash_md5\": .metadata[] | select(.tool == \"hash\") | .tool_metadata.md5,\n  \"assertions\": (\n    [\n      [.assertions[] | .engine.name],\n      [.assertions[] | .metadata.malware_family]\n    ]\n    | transpose\n    | map({\"engine\": .[0], \"malware\": .[1]})\n  )\n}' file.json",
      "you could simply pull out the iteration and make it implicit by using a `map`:",
      "jq '{\n  \"hash_md5\": .metadata[] | select(.tool == \"hash\") | .tool_metadata.md5,\n  \"assertions\": (\n    .assertions\n    | map({\n        \"engine\": .engine.name,\n        \"malware\": .metadata.malware_family\n      })\n  )\n}' file.json"
    ],
    "utterance": "Combine arrays of engine names and malware families in each assertion into an array of objects containing both engine and malware fields, while preserving the hash_md5 field.",
    "expressions": [
      "{\n  \"hash_md5\": .metadata[] | select(.tool == \"hash\") | .tool_metadata.md5,\n  \"assertions\": (\n    [\n      [.assertions[] | .engine.name],\n      [.assertions[] | .metadata.malware_family]\n    ]\n    | transpose\n    | map({\"engine\": .[0], \"malware\": .[1]})\n  )\n}",
      "{\n  \"hash_md5\": .metadata[] | select(.tool == \"hash\") | .tool_metadata.md5,\n  \"assertions\": (\n    .assertions\n    | map({\n        \"engine\": .engine.name,\n        \"malware\": .metadata.malware_family\n      })\n  )\n}"
    ],
    "data": [
      {
        "input": {
          "metadata": [
            {
              "tool": "hash",
              "tool_metadata": {
                "md5": "799c748fe5fbc1900594d6d79bb9f803"
              }
            }
          ],
          "assertions": [
            {
              "engine": {
                "name": "A"
              },
              "metadata": {
                "malware_family": "1"
              }
            },
            {
              "engine": {
                "name": "B"
              },
              "metadata": {
                "malware_family": "2"
              }
            },
            {
              "engine": {
                "name": "C"
              },
              "metadata": {
                "malware_family": "3"
              }
            }
          ]
        },
        "output": {
          "hash_md5": "799c748fe5fbc1900594d6d79bb9f803",
          "assertions": [
            {
              "engine": "A",
              "malware": "1"
            },
            {
              "engine": "B",
              "malware": "2"
            },
            {
              "engine": "C",
              "malware": "3"
            }
          ]
        }
      }
    ],
    "identifier": 70831992
  },
  {
    "context": [
      "var jq =  \".data[] | select(.name==\\\"mytest\\\") | .id == \\\"adxd\\\"\";",
      "However, the arguments turn out as:",
      "-c \".data[] | select(.name==\"mytest\") | .id == \"adxd\"\" json.json",
      "It should turn out as:",
      "-c \".data[] | select(.name==\\\"mytest\\\") | .id == \\\"adxd\\\"\" json.json",
      "Inside jp.exe, the value should be `\"`.",
      "This means that whatever we send to it (the command line arguments) need to be escaped: `\\\"`."
    ],
    "utterance": "Select objects where the name is exactly mytest and the id is exactly adxd.",
    "expressions": [
      ".data[] | select(.name==\"mytest\" and .id==\"adxd\")"
    ],
    "identifier": 70864270
  },
  {
    "context": [
      "And I am trying to get this filtered output from it using **jq**",
      "{\r\n  \"name\": \"somewebsite.com\",\r\n  \"type\": \"secondary\",\r\n  \"plan\": {\r\n    \"name\": \"Enterprise Website\",\r\n    \"id\": \"77777777777777777777777777\"\r\n  }\r\n}",
      "I can filter the first layer of labels like this",
      "cat some-json-file | jq '.result[] | {name,type,plan}'",
      "That gets me close, but I can't further filter the child labels under **.plan** so that I see just the **.name** and **.id**.",
      "jq '.result[] | {name,type,plan: .plan | {name,id}}' some-json-file"
    ],
    "utterance": "Select the name and type fields and, for the plan object, include only its name and id fields for each item in the result array.",
    "expressions": [
      ".result[] | {name,type,plan: .plan | {name,id}}"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "id": "1234567812345678",
              "name": "somewebsite.com",
              "status": "active",
              "type": "secondary",
              "activated_on": "2021-12-12T15:44:40.444433Z",
              "plan": {
                "id": "77777777777777777777777777",
                "name": "Enterprise Website",
                "is_subscribed": true,
                "legacy_id": "enterprise",
                "externally_managed": true
              }
            }
          ],
          "result_info": {
            "page": 1,
            "total_pages": 1
          },
          "success": true,
          "messages": []
        },
        "output": {
          "name": "somewebsite.com",
          "type": "secondary",
          "plan": {
            "name": "Enterprise Website",
            "id": "77777777777777777777777777"
          }
        }
      }
    ],
    "identifier": 70858064
  },
  {
    "context": [
      "i want to add an element(\"image\": \"<IMAGE1_NAME>\",) in the json as specified in the expected output.",
      "To add { \"image\":\"IMAGE1_NAME\" } on each item in the containerDefinitions key",
      "if you wanted to merge that object into one of the array items (if to all of them, use [] instead of [0]), go with",
      "jq '.containerDefinitions[0] += {\"image\":\"<IMAGE1_NAME>\"}'"
    ],
    "utterance": "Add a field \"image\" with value \"<IMAGE1_NAME>\" to each object inside the containerDefinitions array.",
    "expressions": [
      ".containerDefinitions[] += { \"image\": \"<IMAGE1_NAME>\" }",
      ".containerDefinitions |= map(. + {\"image\":\"<IMAGE1_NAME>\"})"
    ],
    "data": [
      {
        "input": {
          "taskDefinitionArn": "arn:aws",
          "containerDefinitions": [
            {
              "name": "dev-service",
              "cpu": 0,
              "portMappings": [
                {
                  "containerPort": 8080,
                  "hostPort": 8080,
                  "protocol": "tcp"
                }
              ],
              "essential": true,
              "environment": [
                {
                  "name": "message",
                  "value": "Hi, EMC!!"
                }
              ]
            }
          ]
        },
        "output": {
          "taskDefinitionArn": "arn:aws",
          "containerDefinitions": [
            {
              "name": "dev-service",
              "cpu": 0,
              "portMappings": [
                {
                  "containerPort": 8080,
                  "hostPort": 8080,
                  "protocol": "tcp"
                }
              ],
              "essential": true,
              "environment": [
                {
                  "name": "message",
                  "value": "Hi, EMC!!"
                }
              ],
              "image": "<IMAGE1_NAME>"
            }
          ]
        }
      }
    ],
    "identifier": 70876734
  },
  {
    "context": [
      "I have this JSON input to JQjq\n\n{\n  \"names\": [{\n    \"name\": \"John Smith\"\n  },{\n    \"name\": \"Jane Doe\"\n  },{\n    \"name\": \"Jackson Longfellow\"\n  }]\n}",
      "I\u2019d like to use jq to select all the items where the length of the name is > 10 characters.  This means the output would be:\n\n{\n  \"names\": [{\n    \"name\": \"Jackson Longfellow\"\n  }]\n}",
      "Update `|=` the `names` array by `select`ing only those items that match. `length` applied to a string will output its length counting Unicode codepoints.\n\n~~~sh\njq '.names |= map(select(.name | length > 10))'\n~~~"
    ],
    "utterance": "Select objects in the 'names' array whose 'name' value has more than 10 characters.",
    "expressions": [
      ".names |= map(select(.name | length > 10))"
    ],
    "data": [
      {
        "input": {
          "names": [
            {
              "name": "John Smith"
            },
            {
              "name": "Jane Doe"
            },
            {
              "name": "Jackson Longfellow"
            }
          ]
        },
        "output": {
          "names": [
            {
              "name": "Jackson Longfellow"
            }
          ]
        }
      }
    ],
    "identifier": 70886385
  },
  {
    "context": [
      "I need to get:\r\n\r\n```\r\n{\r\n\"78081181\": \"06b6751f-5125-4e48-b588-fcc8ff56004f\",\r\n\"77834021\": \"4bdcf9e9-4a3e-4e13-963d-1270b94955dc\"\r\n}\r\n```",
      "jq --slurp 'reduce .[] as $k ({}; .[$k.dni] = $k.id)'",
      "jq  -s '[ .[] | { (.dni) : (.id) } ] | add' doc.json",
      "jq -n 'reduce inputs as $in ({}; . + ($in | {(.dni): .id}))' input.jstream"
    ],
    "utterance": "Create an object that maps each dni value to its corresponding id value from a stream of objects.",
    "expressions": [
      "jq --slurp 'reduce .[] as $k ({}; .[$k.dni] = $k.id)'",
      "jq -s '[ .[] | { (.dni) : (.id) } ] | add'",
      "jq -n 'reduce inputs as $in ({}; . + ($in | {(.dni): .id}))'"
    ],
    "data": [
      {
        "input": [
          {
            "id": "06b6751f-5125-4e48-b588-fcc8ff56004f",
            "dni": "78081181"
          },
          {
            "id": "4bdcf9e9-4a3e-4e13-963d-1270b94955dc",
            "dni": "77834021"
          }
        ],
        "output": {
          "78081181": "06b6751f-5125-4e48-b588-fcc8ff56004f",
          "77834021": "4bdcf9e9-4a3e-4e13-963d-1270b94955dc"
        }
      }
    ],
    "identifier": 70886182
  },
  {
    "context": [
      "My question is, how do I include the `vars` key as a field in the output, i.e.\r\n\r\n```\r\n{\r\n  \"node\": \"node1\",\r\n  \"field1\": \"a\",\r\n  \"field2\": \"b\"\r\n}\r\n{\r\n  \"node\": \"node2\",\r\n  \"field1\": \"x\",\r\n  \"field2\": \"y\"\r\n}\r\n```",
      "Store the `nodes` array's elements in a variable for reference. Storing the elements rather than the whole array automatically also iterates for the next step. Then, just compose your desired output objects using the `nodes` array item as object `{$node}` added to the looked-up object in `.vars[$node]`.",
      "~~~sh\r\njq '.nodes[] as $node | {$node} + .vars[$node]'\r\n~~~"
    ],
    "utterance": "For each key in the nodes array, output an object with the key as the property 'node' and merge in its corresponding fields from vars.",
    "expressions": [
      ".nodes[] as $node | {node: $node} + .vars[$node]"
    ],
    "data": [
      {
        "input": {
          "vars": {
            "node1": {
              "field1": "a",
              "field2": "b"
            },
            "node2": {
              "field1": "x",
              "field2": "y"
            },
            "unrelated": {
              "blah": "blah"
            }
          },
          "nodes": [
            "node1",
            "node2"
          ]
        },
        "output": [
          {
            "node": "node1",
            "field1": "a",
            "field2": "b"
          },
          {
            "node": "node2",
            "field1": "x",
            "field2": "y"
          }
        ]
      }
    ],
    "identifier": 70893769
  },
  {
    "context": [
      "I need to pick only `.identifier[where .system.value == \"urn:oid:1.3.6.1.4.1.19126.3\"]` and project `.identifier.value.value`.",
      "Desired output:",
      "[\n  {\n    \"id\": \"9f0e27fe-3b8f-4857-8e1d-e57e7a3f4c31\",\n    \"identifier\": \"Y3454867M\"\n  }\n]",
      "jq -r '.[] | [{id: .id, identifier: .identifier | .[] | select(.system.value | contains(\"urn:oid:1.3.6.1.4.1.19126.3\")) | .value.value }]'",
      "jq --arg v \"urn:oid:1.3.6.1.4.1.19126.3\" '\n  map(.identifier |= first(.[] | select(.system.value == $v).value.value))\n'"
    ],
    "utterance": "For each object, select the 'identifier' entry where 'system.value' equals 'urn:oid:1.3.6.1.4.1.19126.3' and set 'identifier' to its 'value.value'.",
    "expressions": [
      ".[] | {id: .id, identifier: (.identifier[] | select(.system.value == \"urn:oid:1.3.6.1.4.1.19126.3\") | .value.value)}",
      "map(.identifier |= (first(.[] | select(.system.value == \"urn:oid:1.3.6.1.4.1.19126.3\").value.value)))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "9f0e27fe-3b8f-4857-8e1d-e57e7a3f4c31",
            "identifier": [
              {
                "system": {
                  "value": "urn:oid:1.3.6.1.4.1.19126.3"
                },
                "value": {
                  "value": "Y3454867M"
                }
              },
              {
                "system": {
                  "value": "urn:oid:2.16.724.4.9.10.2"
                },
                "value": {
                  "value": "108505134"
                }
              }
            ]
          }
        ],
        "output": [
          {
            "id": "9f0e27fe-3b8f-4857-8e1d-e57e7a3f4c31",
            "identifier": "Y3454867M"
          }
        ]
      }
    ],
    "identifier": 70885782
  },
  {
    "context": [
      "I need to find id of object having .profile.extensions[].name having values containing string AAAAAA or BBBBBB.",
      "Because in the first one the is AAAAAA and in second BBBBBB",
      "Regarding your update which altered the output to include the matching search string, and your additional comment stating that the target string is indeed a slash-separated list, the approach now is as follows:",
      "In order to test *and* output the search string, i.e. to use *and* to reference it again, we need to store it in a variable (using $s here), which has to happen outside the select filter in order to have its scope reach until the output reference."
    ],
    "utterance": "Find ids and matching strings for objects where the last part after '/' in any profile.extensions[].name equals AAAAAA or BBBBBB.",
    "expressions": [
      ".[] | (\"AAAAAA\", \"BBBBBB\") as $s | select(IN(.profile.extensions[].name / \"/\" | last; $s)) | \"\\(.id) \\($s)\""
    ],
    "data": [
      {
        "input": [
          {
            "id": "00001",
            "profile": {
              "extensions": [
                {
                  "name": "/somepath1...../AAAAAA"
                },
                {
                  "name": "/somepath2...../xxxxxx"
                }
              ]
            }
          },
          {
            "id": "00002",
            "profile": {
              "extensions": [
                {
                  "name": "/somepath1...../zzzzzz"
                },
                {
                  "name": "/somepath2...../BBBBBB"
                }
              ]
            }
          },
          {
            "id": "00003",
            "profile": {
              "extensions": [
                {
                  "name": "/somepath1...../yyyyyy"
                }
              ]
            }
          },
          {
            "id": "00004",
            "profile": {
              "extensions": []
            }
          }
        ],
        "output": [
          "00001 AAAAAA",
          "00002 BBBBBB"
        ]
      }
    ],
    "identifier": 70910624
  },
  {
    "context": [
      "Currently, I'm aplying this jq filter:",
      "map(\n    {\n        id,\n        dni: .identifier[] | (select(.system.value == \"urn:oid:1.3.6.1.4.1.19126.3\") | .value.value)\n    }\n)",
      "However, I'm getting this message:",
      "> jq: error (at practitioner-mongoexport.json:146715): Cannot iterate over null (null)",
      "problem arises processing second object where .identifier: null.",
      "My desired output would be:\n[\n   {\n      \"id\":\"f3b8c257-9950-45e7-9e79-ace19ec8905e\",\n      \"dni\": \"10839812\"\n   }\n]",
      "map(\n    select(.identifier?[]?.system.value == \"urn:oid:2.16.724.4.9.10.2\") \n    | { id, \"dni\": .identifier[].value.value }\n)",
      "The trick here is `.identifier?[]?.system.value` where the `?` will ignore `.identifier` if it's `null`",
      "jq 'map({id, dni: (.identifier[]? | select(.system.value == \"urn:oid:2.16.724.4.9.10.2\")).value.value})'",
      "[   {      \"id\": \"f3b8c257-9950-45e7-9e79-ace19ec8905e\",      \"dni\": \"10839812\"   } ]"
    ],
    "utterance": "Extract objects with a given system.value in identifier where identifier may be null, mapping to id and dni fields where dni is the matching identifier's value.value.",
    "expressions": [
      "map(\n    select(.identifier?[]?.system.value == \"urn:oid:2.16.724.4.9.10.2\") \n    | { id, \"dni\": .identifier[].value.value }\n)",
      "map({id, dni: (.identifier[]? | select(.system.value == \"urn:oid:2.16.724.4.9.10.2\")).value.value})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "f3b8c257-9950-45e7-9e79-ace19ec8905e",
            "identifier": [
              {
                "system": {
                  "value": "urn:oid:2.16.724.4.9.10.2"
                },
                "value": {
                  "value": "10839812"
                }
              }
            ]
          },
          {
            "id": "f0a1e3ae-826f-4a03-b29e-10ef3bc86ea0",
            "identifier": null
          }
        ],
        "output": [
          {
            "id": "f3b8c257-9950-45e7-9e79-ace19ec8905e",
            "dni": "10839812"
          }
        ]
      }
    ],
    "identifier": 70891949
  },
  {
    "context": [
      "I try this:\r\n\r\n    jq -r '.issues[] | [\"key\",\"component\", \"textRange\"], [.key,.component, .textRange[]] | @csv' test.issues.json",
      "Result:\r\n\r\n    \"key\",\"component\",\"textRange\"\r\n    \"key_1\",\"my_component\",1,11,111,1111\r\n    \"key\",\"component\",\"textRange\"\r\n    \"key2\",\"my component 2\",2,22,222,2222\r\n    \"key\",\"component\",\"textRange\"\r\n    \"my_key3\",\"my component 3\",548,548,14,15",
      "You are creating the headers inside the iteration. Pull them up front",
      "[\"key\",\"component\", \"textRange\"],\n(.issues[] | [.key,.component, .textRange[]])\n| @csv",
      "\"key\",\"component\",\"textRange\"\n\"key_1\",\"my_component\",1,11,111,1111\n\"key2\",\"my component 2\",2,22,222,2222\n\"my_key3\",\"my component 3\",548,548,14,15"
    ],
    "utterance": "Output the fields key, component, and all values from textRange for each issue as a single CSV file with headers appearing only once at the top.",
    "expressions": [
      "[\"key\",\"component\", \"textRange\"], (.issues[] | [.key,.component, .textRange[]]) | @csv"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "key": "key_1",
              "component": "my_component",
              "textRange": {
                "startLine": 1,
                "endLine": 11,
                "startOffset": 111,
                "endOffset": 1111
              }
            },
            {
              "key": "key2",
              "component": "my component 2",
              "textRange": {
                "startLine": 2,
                "endLine": 22,
                "startOffset": 222,
                "endOffset": 2222
              }
            },
            {
              "key": "my_key3",
              "component": "my component 3",
              "textRange": {
                "startLine": 548,
                "endLine": 548,
                "startOffset": 14,
                "endOffset": 15
              }
            }
          ]
        },
        "output": "\"key\",\"component\",\"textRange\"\n\"key_1\",\"my_component\",1,11,111,1111\n\"key2\",\"my component 2\",2,22,222,2222\n\"my_key3\",\"my component 3\",548,548,14,15"
      }
    ],
    "identifier": 70913725
  },
  {
    "context": [
      "Is there a way to move my `template_id` column back to the end of the file instead of in the middle?",
      "jq does (unless otherwise instructed) preserve the ordering of keys.  Apart from the headers, you could do worse than:",
      "    jq -r '(.[0]|keys_unsorted) as $keys | [.[][$keys[]]] | @csv' output.json"
    ],
    "utterance": "Reorder the object keys so that template_id appears as the last key",
    "expressions": [
      "jq 'map({\"from/email\": .[\"from/email\"], \"to/email\": .[\"to/email\"], \"template_id\": .[\"template_id\"]})' output.json"
    ],
    "data": [
      {
        "input": [
          {
            "from/email": "me@x.com",
            "to/email": "mike@x.com",
            "template_id": "12345"
          },
          {
            "from/email": "me@x.com",
            "to/email": "pete@x.com",
            "template_id": "12345"
          }
        ],
        "output": [
          {
            "from/email": "me@x.com",
            "to/email": "mike@x.com",
            "template_id": "12345"
          },
          {
            "from/email": "me@x.com",
            "to/email": "pete@x.com",
            "template_id": "12345"
          }
        ]
      }
    ],
    "identifier": 70920280
  },
  {
    "context": [
      "I need to get the value from \"gherkin\" field and write it into another file keeping the same format as in the original json.",
      "it throws an error:\nparse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 9, column 1",
      "So, you could chain the two.\n\nperl -pe's/[\\x00-\\x1F]/ sprintf \"\\\\u%04X\", ord $& /eg' output.json |\n   jq .data.gherkin",
      "The point being that once you have valid JSON, you can use jq or any other JSON-oriented tool."
    ],
    "utterance": "Extract the value of the gherkin field while preserving line breaks, tabs, and original formatting.",
    "expressions": [
      "jq .data.gherkin"
    ],
    "data": [
      {
        "input": {
          "data": {
            "gherkin": "Given user successful login\nAnd status is '<currentStatus>'\nWhen user clicks '<nextStatus>'\nThen status message should change to '<message>'\n\tExamples:\n\t\t| currentStatus | nextStatus    | message       |\n\t\t| READY         | PROCESS  \t| ready to process |\n\t\t| PROCESS       | COMPLETE \t| ready to complete |\n"
          }
        },
        "output": "Given user successful login\nAnd status is '<currentStatus>'\nWhen user clicks '<nextStatus>'\nThen status message should change to '<message>'\n\tExamples:\n\t\t| currentStatus | nextStatus    | message       |\n\t\t| READY         | PROCESS  \t| ready to process |\n\t\t| PROCESS       | COMPLETE \t| ready to complete |\n"
      }
    ],
    "identifier": 70930666
  },
  {
    "context": [
      "I need to extract the ID of my server to use it later in a command.",
      "The answer for the cURL command is this :",
      "{...\"droplets\":[{\"id\":012345678,...}]}",
      "I only need to save as a variable the first ID the cURL command gives me, the ideal would be that when I enter :",
      "echo $DROPLETID",
      "I get :",
      "01234678",
      "You can use [jq](https://stedolan.github.io/jq/)",
      "DROPLETID=\"$(curl -X GET ... | jq '.droplets[0].id')\""
    ],
    "utterance": "Extract the id of the first object in the droplets array.",
    "expressions": [
      ".droplets[0].id"
    ],
    "data": [
      {
        "input": {
          "droplets": [
            {
              "id": 12345678,
              "name": "ppg-active",
              "memory": 1024
            }
          ],
          "links": {},
          "meta": {
            "total": 1
          }
        },
        "output": 12345678
      }
    ],
    "identifier": 70914110
  },
  {
    "context": [
      "How can i parse the name and id using jq?",
      "I tried to use `[].name`",
      "The program should be\n\n```jq\n.[].name\n```",
      "Use filter\n\n```\n.[] | .name, .id\n```"
    ],
    "utterance": "Extract the name and id fields from each object in the array.",
    "expressions": [
      ".[].name",
      ".[] | .name, .id"
    ],
    "data": [
      {
        "input": [
          {
            "_class": "hudson.model.FreeStyleProject",
            "name": "my-name",
            "id": "123"
          },
          {
            "_class": "hudson.model.FreeStyleProject",
            "name": "my-name2",
            "id": "456"
          },
          {
            "_class": "hudson.model.FreeStyleProject",
            "name": "my-name3",
            "id": "789"
          }
        ],
        "output": [
          "my-name",
          "my-name2",
          "my-name3"
        ]
      }
    ],
    "identifier": 70931571
  },
  {
    "context": [
      "As you can see, I'm getting above objects with nested array. I need to get it as: ... [{ \"city\": \"2505300\", \"postalCode\": \"25132\", \"state\": \"25\" }, { \"city\": \"2521700\", \"postalCode\": \"25300\", \"state\": \"25\" }]",
      "just apply it directly onto its elements: map(.address[] | pick_address)",
      "jq --slurp 'map(.address[] | with_entries(.value |= .value))'"
    ],
    "utterance": "Produce an array where each element contains the city, state, and postalCode values from every address object in the input documents, without nested arrays.",
    "expressions": [
      "map(.address[] | pick_address)",
      "map(.address[] | {city: .city.value, state: .state.value, postalCode: .postalCode.value})",
      "map(.address[] | with_entries(.value |= .value))"
    ],
    "data": [
      {
        "input": [
          {
            "_id": "a6c8004c-efdc-4462-b474-31df2d417be3",
            "address": [
              {
                "city": {
                  "value": "2505300"
                },
                "state": {
                  "value": "25"
                },
                "postalCode": {
                  "value": "25132"
                }
              }
            ]
          },
          {
            "_id": "aa4b4ba9-32e3-4384-8cd8-0852bae0029b",
            "address": [
              {
                "city": {
                  "value": "2521700"
                },
                "state": {
                  "value": "25"
                },
                "postalCode": {
                  "value": "25300"
                }
              }
            ]
          }
        ],
        "output": [
          {
            "city": "2505300",
            "postalCode": "25132",
            "state": "25"
          },
          {
            "city": "2521700",
            "postalCode": "25300",
            "state": "25"
          }
        ]
      }
    ],
    "identifier": 70923511
  },
  {
    "context": [
      "Would like to add a new json element to it with incrementing sequence number based on length of original array along with filter/unique per few columns.",
      "After performing filter (by State, City, Postal) and slice per array size of 2",
      "One could use\n\n```jq\n.add |= [ range(length) as $i | .[$i] | .rownum = $i+1 ]\n```",
      ".add |= ( to_entries | map( .value.rownum = .key+1 | .value ) )",
      ".add |= [enumerate(uniques_by(.[]; {city,state,postal}); \"rownum\")]"
    ],
    "utterance": "Remove duplicate objects in the 'add' array based on 'city', 'state', and 'postal', assign a 'rownum' starting from 1 to each remaining object, and split the 'add' array into chunks of 2 elements in separate outputs.",
    "expressions": [
      ".add |= [enumerate(uniques_by(.[]; {city,state,postal}); \"rownum\")] | del(.add) as $object | (.add|_nwise($size) | (\"\\t\", $object + {add:.} ))",
      ".add |= [ range(length) as $i | .[$i] | .rownum = $i+1 ]",
      ".add |= ( to_entries | map( .value.rownum = .key+1 | .value ) )"
    ],
    "data": [
      {
        "input": {
          "recDt": "2021-01-05",
          "country": "US",
          "name": "ABC",
          "number": "9828",
          "add": [
            {
              "evnCd": "O",
              "rngNum": "1",
              "state": "TX",
              "city": "ANDERSON",
              "postal": "77830"
            },
            {
              "evnCd": "O",
              "rngNum": "2",
              "state": "TX",
              "city": "ANDERSON",
              "postal": "77830"
            },
            {
              "evnCd": "O",
              "rngNum": "3",
              "state": "TX",
              "city": "ANDERSON",
              "postal": "77831"
            },
            {
              "evnCd": "O",
              "rngNum": "4",
              "state": "TX",
              "city": "ANDERSON",
              "postal": "77832"
            }
          ]
        },
        "output": [
          {
            "recDt": "2021-01-05",
            "country": "US",
            "name": "ABC",
            "number": "9828",
            "add": [
              {
                "rownum": 1,
                "evnCd": "O",
                "rngNum": "1",
                "state": "TX",
                "city": "ANDERSON",
                "postal": "77830"
              },
              {
                "rownum": 2,
                "evnCd": "O",
                "rngNum": "3",
                "state": "TX",
                "city": "ANDERSON",
                "postal": "77831"
              }
            ]
          },
          {
            "recDt": "2021-01-05",
            "country": "US",
            "name": "ABC",
            "number": "9828",
            "add": [
              {
                "rownum": 3,
                "evnCd": "O",
                "rngNum": "4",
                "state": "TX",
                "city": "ANDERSON",
                "postal": "77832"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 70864798
  },
  {
    "context": [
      "I need to convert to csv.",
      "I try this:\r\n\r\n    jq -r '.issues[] | [.key,.component,.textRange[], (.flows[].locations[]), .status, .type, .scope] | @csv' test.issues.json",
      "But I get error:\r\n\r\n\r\n    \"key_1\",\"my_component\",1,11,111,1111,\"OPEN\",\"BUG\",\"MAIN\"\r\n    jq: error (at test.issues.json:100): object ({\"component...) is not valid in a csv row",
      "I need to get smt like this:\r\n\r\n    key,component,textRange,startLine,endLine,startOffset,endOffset,status,type,scope,flows,locations,component,textRange,startLine,endLine,startOffset,endOffset,msg\r\n    key_1,my_component,,1,11,111,1111,OPEN,BUG,MAIN,,,,,,,,,\r\n    key2,my component 2,,2,22,222,2222,,,,,,some component,,35,35,3,50,any  message\r\n    ,,,,,,,,,,,,another component,,36,36,3,71,message custom\r\n    ,,,,,,,,,,,Alarm.java,,37,37,3,76,message number 2\r\n    ,,,,,,,,,,,Alarm.java,,38,38,3,50,message number 3\r\n    my_key3,my component 3,,548,548,14,15,OPEN,CODE_SMELL,LOCAL,,,,,,,,,",
      "Try this for starters",
      "jq -r '\n  .issues[]\n  | (.flows |= first), (.flows[1:][] | {flows:.})\n  | [\n      .key, .component, (\n        .textRange | null, .startLine, .endLine, .startOffset, .endOffset\n      ), .status, .type, .scope, (\n        .flows.locations[]? // {} | null, null, .component, (\n          .textRange | null, .startLine, .endLine, .startOffset, .endOffset\n        ), .msg\n      )\n    ]\n  | join(\",\")\n'"
    ],
    "utterance": "Output each issue as one or more CSV rows, flattening nested flows and locations, with empty fields where appropriate, matching a specified wide-column layout.",
    "expressions": [
      ".issues[]\n  | (.flows |= first), (.flows[1:][] | {flows:.})\n  | [\n      .key, .component, (\n        .textRange | null, .startLine, .endLine, .startOffset, .endOffset\n      ), .status, .type, .scope, (\n        .flows.locations[]? // {} | null, null, .component, (\n          .textRange | null, .startLine, .endLine, .startOffset, .endOffset\n        ), .msg\n      )\n    ]\n  | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "key": "key_1",
              "component": "my_component",
              "textRange": {
                "startLine": 1,
                "endLine": 11,
                "startOffset": 111,
                "endOffset": 1111
              },
              "flows": [],
              "status": "OPEN",
              "type": "BUG",
              "scope": "MAIN"
            },
            {
              "key": "key2",
              "component": "my component 2",
              "textRange": {
                "startLine": 2,
                "endLine": 22,
                "startOffset": 222,
                "endOffset": 2222
              },
              "flows": [
                {
                  "locations": [
                    {
                      "component": "some component",
                      "textRange": {
                        "startLine": 35,
                        "endLine": 35,
                        "startOffset": 3,
                        "endOffset": 50
                      },
                      "msg": "any  message"
                    }
                  ]
                },
                {
                  "locations": [
                    {
                      "component": "another component",
                      "textRange": {
                        "startLine": 36,
                        "endLine": 36,
                        "startOffset": 3,
                        "endOffset": 71
                      },
                      "msg": "message custom"
                    }
                  ]
                },
                {
                  "locations": [
                    {
                      "component": "Alarm.java",
                      "textRange": {
                        "startLine": 37,
                        "endLine": 37,
                        "startOffset": 3,
                        "endOffset": 76
                      },
                      "msg": "message number 2"
                    }
                  ]
                },
                {
                  "locations": [
                    {
                      "component": "Alarm.java",
                      "textRange": {
                        "startLine": 38,
                        "endLine": 38,
                        "startOffset": 3,
                        "endOffset": 50
                      },
                      "msg": "message number 3"
                    }
                  ]
                }
              ]
            },
            {
              "key": "my_key3",
              "component": "my component 3",
              "textRange": {
                "startLine": 548,
                "endLine": 548,
                "startOffset": 14,
                "endOffset": 15
              },
              "flows": [],
              "status": "OPEN",
              "type": "CODE_SMELL",
              "scope": "LOCAL"
            }
          ]
        },
        "output": [
          "key_1,my_component,,1,11,111,1111,OPEN,BUG,MAIN,,,,,,,,,",
          "key2,my component 2,,2,22,222,2222,,,,,,some component,,35,35,3,50,any  message",
          ",,,,,,,,,,,,another component,,36,36,3,71,message custom",
          ",,,,,,,,,,,Alarm.java,,37,37,3,76,message number 2",
          ",,,,,,,,,,,Alarm.java,,38,38,3,50,message number 3",
          "my_key3,my component 3,,548,548,14,15,OPEN,CODE_SMELL,LOCAL,,,,,,,,,"
        ]
      }
    ],
    "identifier": 70894977
  },
  {
    "context": [
      "\u276f kubectl get pods -l app=mssql-primary -o json | jq -r '.items[0].metadata.name'",
      "You could explicitly add a newline to the jsonpath output if you want it:",
      "kubectl get pods -l app=mssql-primary -o json | jq -j '.items[0].metadata.name'"
    ],
    "utterance": "Extract the name of the first pod from the items array where the app label is mssql-primary.",
    "expressions": [
      ".items[0].metadata.name"
    ],
    "identifier": 70950803
  },
  {
    "context": [
      "I am trying print each json block on a new line with fields separated by `#`",
      "jq -r '.[] | join(\"#\")' contents.json",
      "Update: If in the input objects the keys cannot be guaranteed to always be in the same order, just specify their order explicitly using an array.",
      "jq -r '.[] | [.Code,.Name,.Country,.Cost,.Type] | join(\"#\")' contents.json"
    ],
    "utterance": "Print each object in an array with its Code, Name, Country, Cost, and Type fields joined by '#' on separate lines.",
    "expressions": [
      ".[] | join(\"#\")",
      ".[] | [.Code,.Name,.Country,.Cost,.Type] | join(\"#\")"
    ],
    "data": [
      {
        "input": [
          {
            "Code": "some code",
            "Name": "some name",
            "Country": "some country",
            "Cost": "some cost",
            "Type": "Some type"
          },
          {
            "Code": "some code",
            "Name": "some name",
            "Country": "some country",
            "Cost": "some cost",
            "Type": "Some type"
          },
          {
            "Code": "some code",
            "Name": "some name",
            "Country": "some country",
            "Cost": "some cost",
            "Type": "Some type"
          }
        ],
        "output": "some code#some name#some country#some cost#Some type\nsome code#some name#some country#some cost#Some type\nsome code#some name#some country#some cost#Some type"
      }
    ],
    "identifier": 70933470
  },
  {
    "context": [
      "Trying to extract John and Smith.",
      "$ jq -r '.content.list[][][1]?' test.json",
      "Which will extract the second field from the array third nested arrays, and ignore the numeric literal.",
      "$ jq '.content.list | map(map({ (.[0]): .[1] }?) | add)'",
      "[{ \"name\": \"John\", \"surname\": \"Smith\" }]",
      "$ jq '.content.list | map(map({ (.[0]): .[1] }?) | add) | [].name'",
      "\"John\""
    ],
    "utterance": "Extract the values 'John' and 'Smith' from deeply nested arrays where keys and values are paired in subarrays.",
    "expressions": [
      ".content.list[][][1]?",
      ".content.list | map(map({ (.[0]): .[1] }?) | add) | .[] | .name, .surname"
    ],
    "data": [
      {
        "input": {
          "content": {
            "list": [
              [
                [
                  [
                    "name",
                    "John",
                    123
                  ],
                  [
                    "surname",
                    "Smith",
                    345
                  ],
                  1
                ]
              ]
            ]
          }
        },
        "output": [
          "John",
          "Smith"
        ]
      }
    ],
    "identifier": 70938826
  },
  {
    "context": [
      "I have JSONPath:\n\n```none\n$.endpointAgents[?(@.clients.userName=~ 'a')].agentId\n```",
      "If I understand correctly, you want to produce the agent id of endpoints with a client whose name matches `a`.",
      "```jq\n.endpointAgents[] |\nselect( any( .clients[].userProfile.userName; test(\"a\") ) ) |\n.agentId\n```"
    ],
    "utterance": "Return the agentId for each endpointAgent where any client has a userProfile.userName that matches the pattern 'a'.",
    "expressions": [
      ".endpointAgents[] | select( any( .clients[].userProfile.userName; test(\"a\") ) ) | .agentId"
    ],
    "data": [
      {
        "input": {
          "endpointAgents": [
            {
              "agentId": "MyId",
              "agentName": "MYNAME",
              "location": {
                "locationName": "location"
              },
              "clients": [
                {
                  "userProfile": {
                    "userName": "Name"
                  },
                  "browserExtensions": [
                    {
                      "active": false
                    }
                  ]
                }
              ],
              "totalMemory": "16222 MB",
              "agentType": "enterprise"
            }
          ]
        },
        "output": "MyId"
      }
    ],
    "identifier": 70957827
  },
  {
    "context": [
      "And i am able to parse it as \r\n```\r\ndata=`curl http://some.ur;l`\r\necho \"$data\" | jq -rc '.name[] | select(.type==\"B\") | .class=true'\r\n```\r\nit returns data as \r\n```\r\n{\"first\": \"first\",\"class\": true, \"type\": \"B\"}\r\n{\"first\": \"second\", \"class\": true, \"type\": \"B\"}\r\n```",
      "\".name[] | select(.type == \\\"B\\\") | .class = true\""
    ],
    "utterance": "Select objects where type is \"B\" from the name array, set their class field to true, and output each modified object separately.",
    "expressions": [
      ".name[] | select(.type == \"B\") | .class = true"
    ],
    "data": [
      {
        "input": {
          "name": [
            {
              "first": "first",
              "class": false,
              "type": "B"
            },
            {
              "first": "second",
              "class": false,
              "type": "B"
            },
            {
              "first": "third",
              "class": false,
              "type": "A"
            }
          ]
        },
        "output": [
          {
            "first": "first",
            "class": true,
            "type": "B"
          },
          {
            "first": "second",
            "class": true,
            "type": "B"
          }
        ]
      }
    ],
    "identifier": 70957230
  },
  {
    "context": [
      "I need to return the **agentId** value with the value **userName**.",
      "To get the `agentId` values from **all** items of the `endpointAgents` array where in the same object **at least one** object in the `clients` array has a `userProfile.userName` string value that **contains** a given substring, I\u2019d go with",
      "jq -r '\n  .endpointAgents[]\n  | select(.clients | map(.userProfile.userName | contains(\"a\")) | any)\n  | .agentId\n'"
    ],
    "utterance": "Return the agentId for each endpointAgents entry where at least one client's userProfile.userName contains the substring 'a'.",
    "expressions": [
      ".endpointAgents[] | select(.clients | map(.userProfile.userName | contains(\"a\")) | any) | .agentId"
    ],
    "data": [
      {
        "input": {
          "endpointAgents": [
            {
              "agentId": "MyId",
              "agentName": "MYNAME",
              "location": {
                "locationName": "location"
              },
              "clients": [
                {
                  "userProfile": {
                    "userName": "Name"
                  },
                  "browserExtensions": [
                    {
                      "active": false
                    }
                  ]
                }
              ],
              "totalMemory": "16222 MB",
              "agentType": "enterprise"
            }
          ]
        },
        "output": "MyId"
      }
    ],
    "identifier": 70960472
  },
  {
    "context": [
      "How can I use different names for \"key\" and \"value\", e.g.:",
      "Create a new object and assign the fields correspondigly",
      "\u2026 | .[] |= {ParameterKey: .key, ParameterValue: .value}",
      "Instead of the update operator `|=` you could also use `map`",
      "\u2026 | map({ParameterKey: .key, ParameterValue: .value})",
      "jq -s --arg key \"ParameterKey\" --arg value \"ParameterValue\" '\n  \u2026 {($key):.key, ($value):.value} \u2026\n'"
    ],
    "utterance": "Rename each object's \"key\" and \"value\" fields to \"ParameterKey\" and \"ParameterValue\", respectively, after merging.",
    "expressions": [
      ". | map({ParameterKey: .key, ParameterValue: .value})",
      ".[] |= {ParameterKey: .key, ParameterValue: .value}",
      "{($key): .key, ($value): .value}"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "abc",
            "bar": 123
          },
          {
            "baz": "def"
          },
          {
            "bar": 456
          }
        ],
        "output": [
          {
            "ParameterKey": "foo",
            "ParameterValue": "abc"
          },
          {
            "ParameterKey": "bar",
            "ParameterValue": 456
          },
          {
            "ParameterKey": "baz",
            "ParameterValue": "def"
          }
        ]
      }
    ],
    "identifier": 70962045
  },
  {
    "context": [
      "How can I transform this output:\n[\n  {\n    \"key\" : \"SimpleNumber\",\n    \"value\" : \"123\"\n  },\n  {\n    \"key\" : \"SimpleString\",\n    \"value\" : \"Hello\"\n  },\n  {\n    \"key\" : \"ComplexString\",\n    \"value\" : \"Hello World\"\n  }\n]\n\nto:\n1)\n\n\"SimpleNumber=123\" \"SimpleString=Hello\" \"ComplexString=Hello World\"\n\nand\n\n2)\n\nSimpleNumber=\"123\" SimpleString=\"Hello\" ComplexString=\"Hello World\"",
      "jq --raw-output 'map(\"\\\"\\(.key)=\\(.value)\\\"\") | join(\" \")'",
      "jq --raw-output 'map(\"\\(.key)=\\\"\\(.value)\\\"\") | join(\" \")'"
    ],
    "utterance": "Format a list of key/value objects as either a space-separated list of quoted key=value pairs or a space-separated list where only the values are quoted.",
    "expressions": [
      "map(\"\\\"\\(.key)=\\(.value)\\\"\") | join(\" \")",
      "map(\"\\(.key)=\\\"\\(.value)\\\"\") | join(\" \")"
    ],
    "data": [
      {
        "input": [
          {
            "key": "SimpleNumber",
            "value": "123"
          },
          {
            "key": "SimpleString",
            "value": "Hello"
          },
          {
            "key": "ComplexString",
            "value": "Hello World"
          }
        ],
        "output": "\"SimpleNumber=123\" \"SimpleString=Hello\" \"ComplexString=Hello World\""
      },
      {
        "input": [
          {
            "key": "SimpleNumber",
            "value": "123"
          },
          {
            "key": "SimpleString",
            "value": "Hello"
          },
          {
            "key": "ComplexString",
            "value": "Hello World"
          }
        ],
        "output": "SimpleNumber=\"123\" SimpleString=\"Hello\" ComplexString=\"Hello World\""
      }
    ],
    "identifier": 70964556
  },
  {
    "context": [
      "I\u0019d like to have a comma separated list with fixVersions\u0019 elements being comma separated. I\u0019ve gotten this far.",
      "Output:\r\n\r\n    JIRAISSUE-369,In Progress,MR1\r\n    JIRAISSUE-369,In Progress,MR2\r\n\r\nDesired output:\r\n\r\n    JIRAISSUE-369,In Progress,MR1,MR2",
      "How do I take each .issues.fixVersions[].name and comma separate them at the end?",
      "You can use [`join()`](https://stedolan.github.io/jq/manual/#example61) such as\r\n```\r\njq '.issues[] | [.key , .fields.status.name , .fields.fixVersions[].name] | join(\",\")'\r\n```"
    ],
    "utterance": "Produce a single, comma-separated line for each issue, concatenating the key, status name, and all fixVersions names.",
    "expressions": [
      ".issues[] | [.key , .fields.status.name , (.fields.fixVersions[].name)] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "expand": "names,schema",
          "startAt": 0,
          "maxResults": 50,
          "total": 1,
          "issues": [
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "42202",
              "self": "https://www.myjira.com/jira/rest/api/2/issue/42202",
              "key": "JIRAISSUE-369",
              "fields": {
                "fixVersions": [
                  {
                    "self": "https://www.myjira.com/jira/rest/api/2/version/15701",
                    "id": "15701",
                    "name": "MR1",
                    "archived": false,
                    "released": false,
                    "releaseDate": "2014-06-10"
                  },
                  {
                    "self": "https://www.myjira.com/jira/rest/api/2/version/15702",
                    "id": "15702",
                    "name": "MR2",
                    "archived": false,
                    "released": false,
                    "releaseDate": "2014-04-14"
                  }
                ],
                "status": {
                  "self": "https://www.myjira.com/jira/rest/api/2/status/3",
                  "description": "This issue is being actively worked on at the moment by the assignee.",
                  "iconUrl": "https://www.myjira.com/jira/images/icons/statuses/inprogress.png",
                  "name": "In Progress",
                  "id": "3",
                  "statusCategory": {
                    "self": "https://www.myjira.com/jira/rest/api/2/statuscategory/4",
                    "id": 4,
                    "key": "indeterminate",
                    "colorName": "yellow",
                    "name": "In Progress"
                  }
                }
              }
            }
          ]
        },
        "output": "JIRAISSUE-369,In Progress,MR1,MR2"
      }
    ],
    "identifier": 70963091
  },
  {
    "context": [
      "Perferred Format - I am trying to move the object up one layer.",
      "If you&#39;re looking for a solution using `jq`, then it should be just updating the `entities` array using `add`:",
      "jq '.entities |= add' input.json"
    ],
    "utterance": "Convert the top-level object so that the 'entities' field is changed from an array of single-key objects to a single object with those keys directly under 'entities'.",
    "expressions": [
      ".entities |= add"
    ],
    "data": [
      {
        "input": {
          "entities": [
            {
              "chuck123": {
                "type": "barebone",
                "data": {
                  "customer_name": "Batman",
                  "subdomain": "Gotham",
                  "console": "radio",
                  "portal_url": "blue",
                  "subdomain_partner": "Bking",
                  "platform": "arch",
                  "group": "DC Squad",
                  "endpoint_type": "bridge",
                  "operating_system": "ubuntu"
                }
              }
            },
            {
              "sam123": {
                "type": "barebone",
                "data": {
                  "customer_name": "Robin",
                  "subdomain": "Circus",
                  "console": "radio",
                  "portal_url": "purple",
                  "subdomain_partner": "BurgerNFries",
                  "platform": "arch",
                  "group": "DC Squad",
                  "endpoint_type": "carbank",
                  "operating_system": "debian"
                }
              }
            }
          ]
        },
        "output": {
          "entities": {
            "chuck123": {
              "type": "barebone",
              "data": {
                "customer_name": "Batman",
                "subdomain": "Gotham",
                "console": "radio",
                "portal_url": "blue",
                "subdomain_partner": "Bking",
                "platform": "arch",
                "group": "DC Squad",
                "endpoint_type": "bridge",
                "operating_system": "ubuntu"
              }
            },
            "sam123": {
              "type": "barebone",
              "data": {
                "customer_name": "Robin",
                "subdomain": "Circus",
                "console": "radio",
                "portal_url": "purple",
                "subdomain_partner": "BurgerNFries",
                "platform": "arch",
                "group": "DC Squad",
                "endpoint_type": "carbank",
                "operating_system": "debian"
              }
            }
          }
        }
      }
    ],
    "identifier": 70982029
  },
  {
    "context": [
      "The one issue is that the output is rendering a full json with newlines and tabs.  Easy on the eyes, but not great for cloud logging services.",
      "How would I modify to render the output on one line like so?",
      "`{\"timestamp\": \"20220203T171908\",\"log_level\": \"INFO\",\"message\": \"Hello, World!\"}`",
      "Use the `--compact-output` or `-c` option: `jq -c --arg \u2026 '\u2026' >> logs.log`",
      "In case anyone else was curious, the solution is here:",
      "jq  --monochrome-output \\",
      "    --compact-output \\",
      "    --raw-output \\",
      "    --arg timestamp \"$(__timestamp)\" \\",
      "    --arg log_level \"$log_level\" \\",
      "    --arg message \"$message\" \\",
      "    '.timestamp=$timestamp|.log_level=$log_level|.message=$message'"
    ],
    "utterance": "Output a single logging object per line, without newlines or indentation, containing the fields timestamp, log_level, and message with specific values.",
    "expressions": [
      "jq -c --arg timestamp \"$(__timestamp)\" --arg log_level \"$log_level\" --arg message \"$message\" '.timestamp=$timestamp|.log_level=$log_level|.message=$message'",
      "jq --monochrome-output --compact-output --raw-output --arg timestamp \"$(__timestamp)\" --arg log_level \"$log_level\" --arg message \"$message\" '.timestamp=$timestamp|.log_level=$log_level|.message=$message'"
    ],
    "data": [
      {
        "input": {
          "timestamp": "20210812T191730",
          "log_level": "INFO",
          "message": "Hello, World!"
        },
        "output": "{\"timestamp\":\"20210812T191730\",\"log_level\":\"INFO\",\"message\":\"Hello, World!\"}"
      }
    ],
    "identifier": 70979212
  },
  {
    "context": [
      "Now I want to convert field (array)  **flows**. I try this:",
      "jq -r '.issues[] | [.key ,.component, .textRange[], .flows[], .status] | @csv' test.json",
      "jq: error (at test.json:91): object ({\"locations...) is not valid in a csv row",
      "How fix convert? Array (**locations**) in array (**flows**)",
      "Seems you need stringify, then you can use **tostring** such as\n```\njq -r '.issues[] \n        | [.key ,.component, .textRange[], (.flows[].locations[]|tostring), .status] \n        | @csv'\n```",
      "Do you want the objects in `.flows[].locations[]` to be **appended** as separate rows?\n~~~sh\njq -r '.issues[]\n  | .key as $key | ., .flows[].locations[]\n  | [$key ,.component, .textRange[], .status]\n  | @csv\n'\n~~~"
    ],
    "utterance": "Output each object inside issues[].flows[].locations[] as a separate CSV row together with its parent issue's fields, flattening array fields.",
    "expressions": [
      ".issues[] | .key as $key | ., .flows[].locations[] | [$key, .component, .textRange[], .status] | @csv"
    ],
    "data": [
      {
        "input": {
          "total": 2040,
          "created_at": "2022-01-27T09:50:59+0200",
          "project": "my project",
          "issues": [
            {
              "key": "key_1",
              "component": "my_component",
              "textRange": {
                "startLine": 35,
                "endLine": 35,
                "startOffset": 46,
                "endOffset": 84
              },
              "flows": [],
              "status": "OPEN",
              "creationDate": "2022-01-24T06:42:58+0200",
              "updateDate": "2022-01-24T06:42:58+0200",
              "type": "BUG",
              "scope": "MAIN"
            },
            {
              "key": "key2",
              "component": "my component 2",
              "textRange": {
                "startLine": 34,
                "endLine": 34,
                "startOffset": 3,
                "endOffset": 52
              },
              "flows": [
                {
                  "locations": [
                    {
                      "component": "some component",
                      "textRange": {
                        "startLine": 35,
                        "endLine": 35,
                        "startOffset": 3,
                        "endOffset": 50
                      },
                      "msg": "any  message"
                    }
                  ]
                },
                {
                  "locations": [
                    {
                      "component": "another component",
                      "textRange": {
                        "startLine": 36,
                        "endLine": 36,
                        "startOffset": 3,
                        "endOffset": 71
                      },
                      "msg": "message custom"
                    }
                  ]
                },
                {
                  "locations": [
                    {
                      "component": "Alarm.java",
                      "textRange": {
                        "startLine": 37,
                        "endLine": 37,
                        "startOffset": 3,
                        "endOffset": 76
                      },
                      "msg": "message number 2"
                    }
                  ]
                },
                {
                  "locations": [
                    {
                      "component": "Alarm.java",
                      "textRange": {
                        "startLine": 38,
                        "endLine": 38,
                        "startOffset": 3,
                        "endOffset": 50
                      },
                      "msg": "message number 3"
                    }
                  ]
                }
              ]
            },
            {
              "key": "my_key3",
              "component": "my component 3",
              "textRange": {
                "startLine": 548,
                "endLine": 548,
                "startOffset": 14,
                "endOffset": 15
              },
              "flows": [],
              "status": "OPEN",
              "creationDate": "2022-01-21T17:16:06+0200",
              "updateDate": "2022-01-21T17:16:06+0200",
              "type": "CODE_SMELL",
              "scope": "LOCAL"
            }
          ]
        },
        "output": [
          "\"1\",\"my_component\",35,35,46,84,\"OPEN\"",
          "\"2\",\"my component 2\",34,34,3,52,",
          "\"2\",\"some component\",35,35,3,50,",
          "\"2\",\"another component\",36,36,3,71,",
          "\"2\",\"Alarm.java\",37,37,3,76,",
          "\"2\",\"Alarm.java\",38,38,3,50,"
        ]
      }
    ],
    "identifier": 70880255
  },
  {
    "context": [
      "kubectl get cm aws-auth -n kube-system -o json | jq --arg add \"`cat additional_roles_aws_auth.yaml`\" '.data.mapRoles += $add' | kubectl apply -f -",
      "kubectl get cm aws-auth -n kube-system -o json | jq --arg add \"`cat ${path.root}/additional_roles_aws_auth.yaml`\" '.data.mapRoles += $add' | kubectl apply -f -"
    ],
    "utterance": "Append the content of additional_roles_aws_auth.yaml to the mapRoles field within the data object of the aws-auth config map.",
    "expressions": [
      ".data.mapRoles += $add"
    ],
    "identifier": 70992268
  },
  {
    "context": [
      "[",
      " \"key1.childk2\",",
      " \"key2.childk3\"",
      "]",
      "I would like to turn this into a readable json format itself as list of lists like below:",
      "[ ",
      "  [\"key1\",\"childk2\"],",
      "  [\"key2\",\"childk3\"]",
      "]",
      "You can use jq `split` filter:",
      "jq '[.[] | split(\".\")]'",
      "[",
      "  [",
      "    \"key1\",",
      "    \"childk2\"",
      "  ],",
      "  [",
      "    \"key2\",",
      "    \"childk3\"",
      "  ]",
      "]"
    ],
    "utterance": "Separate each string containing a period into a two-element list at the period, for every element in the input list.",
    "expressions": [
      "[.[] | split(\".\")]",
      "map(split(\".\"))"
    ],
    "data": [
      {
        "input": [
          "key1.childk2",
          "key2.childk3"
        ],
        "output": [
          [
            "key1",
            "childk2"
          ],
          [
            "key2",
            "childk3"
          ]
        ]
      }
    ],
    "identifier": 71001996
  },
  {
    "context": [
      "I am using this command `[\"a\",\"b\"], (.[] | [.k1.k2,.k3.k2]) | @csv` to extract two keys and adding two headers (`a`, `b`) to the csv. But The output to this is a header in every other line",
      "As you have stream in your json, you need `inputs` instead of `.[]`",
      "jq -nr '[\"a\",\"b\"], (inputs | map(.k1.k2,.k3.k2))) | @csv'",
      "One solution would be to use the `--slurp` or `-s` option to read in the stream as an array. This, however, would necessitate to go one level deeper in your iteration (`.[][]` instead of just `.[]`):",
      "jq -s '[\"a\",\"b\"], (.[][] | [.k1.k2,.k3.k2]) | @csv'",
      "Another way would be to use `inputs` which gives you all input documents at once. This, however, would necessitate to iterate over that (`input[]` instead of `.[]`) and use the `--null-input` or `-n` flag to avoid swallowing up the first elemment:",
      "jq -n '[\"a\",\"b\"], (inputs[] | [.k1.k2,.k3.k2]) | @csv'"
    ],
    "utterance": "Produce CSV output with a single header row 'a','b' followed by rows containing values of k1.k2 and k3.k2 from all items across multiple top-level JSON arrays in a multi-document stream.",
    "expressions": [
      "[\"a\",\"b\"], (.[][] | [.k1.k2,.k3.k2]) | @csv",
      "[\"a\",\"b\"], (inputs[] | [.k1.k2,.k3.k2]) | @csv",
      "[\"a\",\"b\"], (inputs | map(.k1.k2,.k3.k2))) | @csv"
    ],
    "data": [
      {
        "input": [
          [
            {
              "k1": {
                "k2": 4
              },
              "k3": {
                "k2": 6
              }
            }
          ],
          [
            {
              "k1": {
                "k2": 4
              },
              "k3": {
                "k2": 6
              }
            }
          ]
        ],
        "output": [
          "\"a\",\"b\"",
          "4,6",
          "4,6"
        ]
      }
    ],
    "identifier": 71005490
  },
  {
    "context": [
      "I'm trying to identify object elements which a key starting with `@t`. My goal is to delete them from the object all together.",
      "Example Input\n```\n{\n  \"process_state\": {\n    \"@user_id\": \"john smith\",\n    \"@t39ee396f50\": 1,\n    \"@t375b0311e8\": 1,\n    \"@t12dd92bf45\": 1\n     }\n}\n```\n\nExpected Output\n\n```\n{\n  \"process_state\": {\n    \"@user_id\": \"john smith\",\n     }\n}\n```",
      "We're going to use `test(\"^@t\")` instead of `contains(\"@t\")` since we want to check for a *leading* `@t`.",
      "Using filtering (like you were attempting):\n\n    ```jq\n    .process_state |= with_entries(\n       select( .key | test(\"^@t\") | not )\n    )\n    ```",
      "Using deletion:\n\n    ```jq\n    .process_state |= del(\n       .[\n          keys_unsorted[] |\n          select( test(\"^@t\") )\n       ]\n    )\n    ```"
    ],
    "utterance": "Remove all entries from 'process_state' where the key starts with '@t'",
    "expressions": [
      ".process_state |= with_entries(select(.key | test(\"^@t\") | not))",
      ".process_state |= del(.[keys_unsorted[] | select(test(\"^@t\"))])"
    ],
    "data": [
      {
        "input": {
          "process_state": {
            "@user_id": "john smith",
            "@t39ee396f50": 1,
            "@t375b0311e8": 1,
            "@t12dd92bf45": 1
          }
        },
        "output": {
          "process_state": {
            "@user_id": "john smith"
          }
        }
      }
    ],
    "identifier": 71001713
  },
  {
    "context": [
      "I'm trying to simplify a nested JSON structure using JQ",
      "Desired Output",
      "{ \"nameWithOwner\": \"KyleMit/stack-posts\", \"defaultBranchName\": \"main\" }, ...",
      "one way to combine is to use Object Construction like",
      "[.[]|{nameWithOwner, defaultBranchName: .defaultBranchRef.name}]"
    ],
    "utterance": "For each object in the array, create a new object including nameWithOwner and renaming defaultBranchRef.name to defaultBranchName.",
    "expressions": [
      "[.[] | {nameWithOwner, defaultBranchName: .defaultBranchRef.name}]"
    ],
    "data": [
      {
        "input": [
          {
            "defaultBranchRef": {
              "name": "main"
            },
            "nameWithOwner": "KyleMit/stack-posts"
          },
          {
            "defaultBranchRef": {
              "name": "master"
            },
            "nameWithOwner": "KyleMit/HelloSERN"
          }
        ],
        "output": [
          {
            "nameWithOwner": "KyleMit/stack-posts",
            "defaultBranchName": "main"
          },
          {
            "nameWithOwner": "KyleMit/HelloSERN",
            "defaultBranchName": "master"
          }
        ]
      }
    ],
    "identifier": 71008416
  },
  {
    "context": [
      "I'm trying to get an array from a json file.",
      "Then I want to pass each of these items to a curl request and possibly handle that in parralel with xargs",
      "I'm still stumbling on getting one item to the curl endpoint.",
      "This is the end result. The issue was I was not familiar with the jq utility and my json kept coming in wrong.",
      "cat CurlArgsFile.json | jq -r '.Requests[]|tojson' | xargs -0 -I % curl -d % -H \"Content-Type: application/json\" -X POST http://localhost:53391/mySVC/writeData",
      "jq '.Requests[]' -rc file.json | xargs -d '\\n' -0 -P0 -I@ curl -X POST -H 'Content-Type: application/json' -d @ http://localhost:53391/mySVC/writeData",
      "jq '.Requests[]' -rc file.json | tr '\\n' '\\0' | xargs -0 -P0 -I@ curl -X POST -H 'Content-Type: application/json' -d @ http://localhost:53391/mySVC/writeData"
    ],
    "utterance": "Extract each element from the Requests array as a compact object and pass it as input to a POST endpoint, one at a time.",
    "expressions": [
      ".Requests[] | tojson",
      ".Requests[]"
    ],
    "data": [
      {
        "input": {
          "Requests": [
            {
              "Item1": "2020-01-27 16:24:49",
              "Item2": "203i1Kj2gTEQgfdsfds23",
              "Item3": 1603,
              "Item4": "generic"
            },
            {
              "Item1": "2020-01-27 16:24:49",
              "Item2": "203i1Kj2gTEQgfdsfds23",
              "Item3": 1603,
              "Item4": "generic"
            },
            {
              "Item1": "2020-01-27 16:24:49",
              "Item2": "203i1Kj2gTEQgfdsfds23",
              "Item3": 1603,
              "Item4": "generic"
            },
            {
              "Item1": "2020-01-27 16:24:49",
              "Item2": "203i1Kj2gTEQgfdsfds23",
              "Item3": 1603,
              "Item4": "generic"
            }
          ]
        },
        "output": [
          "{\"Item1\":\"2020-01-27 16:24:49\",\"Item2\":\"203i1Kj2gTEQgfdsfds23\",\"Item3\":1603,\"Item4\":\"generic\"}",
          "{\"Item1\":\"2020-01-27 16:24:49\",\"Item2\":\"203i1Kj2gTEQgfdsfds23\",\"Item3\":1603,\"Item4\":\"generic\"}",
          "{\"Item1\":\"2020-01-27 16:24:49\",\"Item2\":\"203i1Kj2gTEQgfdsfds23\",\"Item3\":1603,\"Item4\":\"generic\"}",
          "{\"Item1\":\"2020-01-27 16:24:49\",\"Item2\":\"203i1Kj2gTEQgfdsfds23\",\"Item3\":1603,\"Item4\":\"generic\"}"
        ]
      }
    ],
    "identifier": 70992275
  },
  {
    "context": [
      "In the below output I only want to get the Id of the CloudFront Origin Access ID with the comment ```Created for Nackle Shared CF in pprd```.",
      "Navigate to the items using `.CloudFrontOriginAccessIdentityList.Items[]`, then choose only the matching ones using `select` and output the part you&#39;re interested in. Using the `-r` flag turns the output into raw text (rather than JSON).",
      "\u2026 | jq -r '\n    .CloudFrontOriginAccessIdentityList.Items[]\n    | select(.Comment == \"Created for Nackle Shared CF in pprd\").Id\n  '",
      "To import the query string into the filter, use the `--arg` option:\n\u2026 | jq -r --arg q \"Created for Nackle Shared CF in pprd\" '\n    .CloudFrontOriginAccessIdentityList.Items[]\n    | select(.Comment == $q).Id\n  '"
    ],
    "utterance": "Extract the Id where the Comment is exactly \"Created for Nackle Shared CF in pprd\".",
    "expressions": [
      ".CloudFrontOriginAccessIdentityList.Items[] | select(.Comment == \"Created for Nackle Shared CF in pprd\").Id",
      ".CloudFrontOriginAccessIdentityList.Items[] | select(.Comment == $q).Id"
    ],
    "data": [
      {
        "input": {
          "CloudFrontOriginAccessIdentityList": {
            "Items": [
              {
                "Id": "E3IQ5CFYM436DX",
                "S3CanonicalUserId": "0301338e0173a8fa18a117f8234f7f30ddf87fcf45fcf70412a374414d592bee3eea9697f41d06b284617232122dd",
                "Comment": "Created for Nackle Shared CF in qa"
              },
              {
                "Id": "E1P6ZIBDB6I6FZ",
                "S3CanonicalUserId": "c21bc4e37661a49846db7dd6798b25a71ce81decb4f6403b5c6602da6e49f6a831ca3a0f682f87fc4b15285785b9c",
                "Comment": "Created for Nackle Shared CF in pprd"
              },
              {
                "Id": "EMLFRR2NYMLFT",
                "S3CanonicalUserId": "5123661394e931636d038d3370399d6cb110844505f4058aa2ee0aab21e52d09ced60fffa2fb438d2872366821eb1",
                "Comment": "Created for Nackle Shared CF in prod"
              },
              {
                "Id": "E1EXEX5YNA4N51",
                "S3CanonicalUserId": "e5c969d27e56434c73c3b7509ffa51c8a29cf690eeb1f3c85db8c6f85b09f5efb3c5d3f891ea5b9f6c5729af2f5c3",
                "Comment": "Do Not Want"
              },
              {
                "Id": "E1RDNKSTCZ8CTF",
                "S3CanonicalUserId": "d5a6931f306807e37ec245f87a4f8ef247fbc362ab016f9b02e5136029ce8b7a79e1d1d5e4fe4b751cf0fa66832ad",
                "Comment": "Also do not want"
              }
            ]
          }
        },
        "output": "E1P6ZIBDB6I6FZ"
      }
    ],
    "identifier": 70947832
  },
  {
    "context": [
      "How can I delete whole blocks with domains? For example if I will want to delete whole block in json for domain `domain.tld`?",
      "To delete domain block \"www.some_domain.tld\" :",
      "jq '.\"http-01\".Certificates |= map(select(.domain.main != \"www.some_domain.tld\"))' input.json"
    ],
    "utterance": "Remove all entries from Certificates where main equals www.some_domain.tld.",
    "expressions": [
      ".\"http-01\".Certificates |= map(select(.domain.main != \"www.some_domain.tld\"))"
    ],
    "data": [
      {
        "input": {
          "http-01": {
            "Account": {
              "Email": "mail@placeholder.tld",
              "Registration": {
                "body": {
                  "status": "valid",
                  "contact": [
                    "mailto:mail@placeholder.tld"
                  ]
                },
                "uri": "https://acme-v02.api.letsencrypt.org/acme/acct/110801506"
              },
              "PrivateKey": "main_priv_key_string",
              "KeyType": "4096"
            },
            "Certificates": [
              {
                "domain": {
                  "main": "www.some_domain.tld"
                },
                "certificate": "cert_string",
                "key": "key_string",
                "Store": "default"
              },
              {
                "domain": {
                  "main": "some_domain.tld"
                },
                "certificate": "cert_string",
                "key": "key_string",
                "Store": "default"
              },
              {
                "domain": {
                  "main": "www.some_domain2.tld"
                },
                "certificate": "cert_string",
                "key": "key_string",
                "Store": "default"
              },
              {
                "domain": {
                  "main": "some_domain2.tld"
                },
                "certificate": "cert_string",
                "key": "key_string",
                "Store": "default"
              }
            ]
          }
        },
        "output": {
          "http-01": {
            "Account": {
              "Email": "mail@placeholder.tld",
              "Registration": {
                "body": {
                  "status": "valid",
                  "contact": [
                    "mailto:mail@placeholder.tld"
                  ]
                },
                "uri": "https://acme-v02.api.letsencrypt.org/acme/acct/110801506"
              },
              "PrivateKey": "main_priv_key_string",
              "KeyType": "4096"
            },
            "Certificates": [
              {
                "domain": {
                  "main": "some_domain.tld"
                },
                "certificate": "cert_string",
                "key": "key_string",
                "Store": "default"
              },
              {
                "domain": {
                  "main": "www.some_domain2.tld"
                },
                "certificate": "cert_string",
                "key": "key_string",
                "Store": "default"
              },
              {
                "domain": {
                  "main": "some_domain2.tld"
                },
                "certificate": "cert_string",
                "key": "key_string",
                "Store": "default"
              }
            ]
          }
        }
      }
    ],
    "identifier": 71007765
  },
  {
    "context": [
      "However, I want `.key1,.key2` to be dynamic since these keys can change. So I want to pass a variable to `jq`. Something like:\r\n\r\n    $KEYS=.key1,.key2\r\n    cat file.json | jq -r --arg var \"$KEYS\" '.[] | [$var]'",
      "Furthermore, jq lacks the facility to take a string, compile it as jq code, and evaluate the result. (This is commonly known as `eval`.)",
      "For example,\r\n\r\n```sh\r\nkeys='key1.childkey,key2.childkey2'\r\njq --arg keys \"$keys\" '\r\n   ( ( $keys / \",\" ) | map( . / \".\" ) ) as $keys |\r\n   .[] | [ getpath( $keys[] ) ]\r\n' file.json\r\n```",
      "Elaborating on ikegami's answer.\r\n\r\nTo start with here\u2019s my version of the answer:\r\n\r\n```\r\n$ in='key1.a,key2.b'; jq -c --arg keys \"$in\" '($keys/\",\"|map(./\".\")) as $paths | .[] | [getpath($paths[])]' <<<$'[{\"key1\":{\"a\":1},\"key2\":{\"b\":2}}] [{\"key1\":{\"a\":3},\"key2\":{\"b\":4}}]'\r\n```\r\n\r\nThis gives output\r\n\r\n```\r\n[1,2]\r\n[3,4]\r\n```"
    ],
    "utterance": "Extract specific values specified by a variable containing comma-separated key paths such as 'key1.a,key2.b', returning an array of those values for each record in the input data.",
    "expressions": [
      "jq --arg keys \"$keys\" '($keys/\",\"|map(./\".\")) as $paths | .[] | [getpath($paths[])]' file.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "key1": {
                "a": 1
              },
              "key2": {
                "b": 2
              }
            }
          ],
          [
            {
              "key1": {
                "a": 3
              },
              "key2": {
                "b": 4
              }
            }
          ]
        ],
        "output": [
          [
            1,
            2
          ],
          [
            3,
            4
          ]
        ]
      }
    ],
    "identifier": 70989639
  },
  {
    "context": [
      "from/email,to/0/email,personalization/0/email,personalization/0/data/first_name,personalization/0/data/company_name,personalization/0/data/job_title,template_id",
      "me@x.com,mike@x.com,mike@x.com,Mike,X.com,Chef,123456",
      "In order to treat the first one (the headers) separately, you could use the `--slurp` or `-s` option which turns the input stream into an array whose elements can then be accessed using indices. Also, the `setpath` builtin comes in handy as it can set values within a JSON structure described as an array of strings and integers representing object fields and array indices, just as you do in your headers. This leaves you turning the header strings into such arrays by splitting at \"/\" and converting number-like segments into actual numbers. Finally, to successively build up your JSON objects you could iterate through the record fields using a `reduce` statement and align the record fields to their corresponding header fields using `transpose`:",
      "\u2026 | jq -s '\n  (.[0] | map(. / \"/\" | map(tonumber? // .))) as $headers\n  | .[1:] | map(\n    reduce ([$headers, .] | transpose[]) as [$path, $value] (\n      {}; setpath($path; $value)\n    )\n  )\n'",
      "Notes\n- My showcase disregards the fact that your sample JSON output also provides an additional field `name` under the top-level field `from` because your sample CSV input headers don't include a matching field `from/name`"
    ],
    "utterance": "Convert CSV records where headers use '/' as object or array path delimiters into deeply nested data structures matching the header paths, with array indices if a path segment is numeric.",
    "expressions": [
      "jq -s '  (.[0] | map(. / \"/\" | map(tonumber? // .))) as $headers\n  | .[1:] | map(\n    reduce ([$headers, .] | transpose[]) as [$path, $value] (\n      {}; setpath($path; $value)\n    )\n  )\n'"
    ],
    "data": [
      {
        "input": [
          [
            "from/email",
            "to/0/email",
            "personalization/0/email",
            "personalization/0/data/first_name",
            "personalization/0/data/company_name",
            "personalization/0/data/job_title",
            "template_id"
          ],
          [
            "me@x.com",
            "mike@x.com",
            "mike@x.com",
            "Mike",
            "X.com",
            "Chef",
            "123456"
          ]
        ],
        "output": [
          {
            "from": {
              "email": "me@x.com"
            },
            "to": [
              {
                "email": "mike@x.com"
              }
            ],
            "personalization": [
              {
                "email": "mike@x.com",
                "data": {
                  "first_name": "Mike",
                  "company_name": "X.com",
                  "job_title": "Chef"
                }
              }
            ],
            "template_id": "123456"
          }
        ]
      }
    ],
    "identifier": 70988508
  },
  {
    "context": [
      "But I want to get both list in dropdown(display, value).",
      "How can I get both list 1- main_roles and 2- cc_roles in 1 jq using map?",
      ".invoice | .main_roles, .cc_roles | map({ display: .name , value: .name })",
      ".invoice | .main_roles + .cc_roles | map({ display: .name , value: .name })"
    ],
    "utterance": "Transform both main_roles and cc_roles into arrays of objects with display and value fields set to the name property.",
    "expressions": [
      ".invoice | .main_roles, .cc_roles | map({ display: .name, value: .name })",
      ".invoice | .main_roles + .cc_roles | map({ display: .name, value: .name })"
    ],
    "data": [
      {
        "input": {
          "invoice": {
            "invoice_id": "b494a46396e47726873708f71a71a228ba2782fa",
            "main_roles": [
              {
                "name": "Agent"
              },
              {
                "name": "Customer"
              }
            ],
            "cc_roles": [
              {
                "name": "Manager"
              }
            ]
          }
        },
        "output": [
          {
            "display": "Agent",
            "value": "Agent"
          },
          {
            "display": "Customer",
            "value": "Customer"
          },
          {
            "display": "Manager",
            "value": "Manager"
          }
        ]
      }
    ],
    "identifier": 71024899
  },
  {
    "context": [
      "I want to check if each element in the input array is found in this list.",
      "Maybe you were looking for the `IN` (not `in`) function. Also, it takes a stream of elements, not an array.",
      "map(IN(\"ms\", \"is\", \"bad\"))",
      "[false,true,true]"
    ],
    "utterance": "Determine whether each element of [\"apple\",\"is\",\"bad\"] exactly matches any value in [\"ms\",\"is\",\"bad\"] and return [false,true,true].",
    "expressions": [
      "map(IN(\"ms\", \"is\", \"bad\"))"
    ],
    "data": [
      {
        "input": [
          "apple",
          "is",
          "bad"
        ],
        "output": [
          false,
          true,
          true
        ]
      }
    ],
    "identifier": 71027805
  },
  {
    "context": [
      "- I want to extract the duration from the json object with key `@type`=`General`.",
      "jq '.media.track[] | select(.\"@type\" == \"General\") | .Duration'"
    ],
    "utterance": "Extract the value of the Duration field from the object where @type is General.",
    "expressions": [
      ".media.track[] | select(.\"@type\" == \"General\") | .Duration"
    ],
    "data": [
      {
        "input": {
          "media": {
            "track": [
              {
                "@type": "General",
                "Duration": "1531.263"
              },
              {
                "@type": "Video",
                "Duration": "1531.238"
              }
            ]
          }
        },
        "output": "1531.263"
      }
    ],
    "identifier": 71011322
  },
  {
    "context": [
      "So, I need to nest into first documents, which ones parent.oid1 == nest.oid1 && parent.oid2 == nest.oid2.",
      "jq --slurpfile others others.json '\n  . as $mine\n  | . + {ids: ($others | map(          \n    select(.oid1 == $mine.oid1 and .oid2 == $mine.oid2)\n    | {id, info}\n  ))}\n' mine.json"
    ],
    "utterance": "For each object, add an 'ids' array containing all items from another set where both oid1 and oid2 match, including only their id and info fields.",
    "expressions": [
      ". as $mine | . + {ids: ($others | map(select(.oid1 == $mine.oid1 and .oid2 == $mine.oid2) | {id, info}))}"
    ],
    "data": [
      {
        "input": [
          {
            "name": "name1",
            "oid1": "oid1-1",
            "oid2": "oid2-1"
          },
          {
            "name": "name2",
            "oid1": "oid1-2",
            "oid2": "oid2-2"
          }
        ],
        "output": [
          {
            "name": "name1",
            "oid1": "oid1-1",
            "oid2": "oid2-1",
            "ids": [
              {
                "id": "id1",
                "info": "info1"
              },
              {
                "id": "id2",
                "info": "info2"
              }
            ]
          },
          {
            "name": "name2",
            "oid1": "oid1-2",
            "oid2": "oid2-2",
            "ids": [
              {
                "id": "id3",
                "info": "info3"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 71025169
  },
  {
    "context": [
      "However, I\u0019d like to have this result inside an array like the following:",
      "How can I add the brackets [] and the proper commas , with jq to form this last flat JSON file?",
      "You could wrap your whole filter into brackets",
      "jq '[.features[].properties]' file.geojson",
      "Or take advantage of the fact that `.features` is already an array and just `map` its contents.",
      "jq '.features | map(.properties)' file.geojson",
      "Both output",
      "[ { \"id\": 1, \"value1\": 4.7557783e-06, \"value2\": 0 }, { \"id\": 1, \"value1\": 1.4931199e-05, \"value2\": 5 } ]"
    ],
    "utterance": "Extract all properties objects from features and output them as a single array.",
    "expressions": [
      "[.features[].properties]",
      ".features | map(.properties)"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "name": "geojson",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "id": 1,
                "value1": 4.7557783e-06,
                "value2": 0
              },
              "geometry": null
            },
            {
              "type": "Feature",
              "properties": {
                "id": 1,
                "value1": 1.4931199e-05,
                "value2": 5
              },
              "geometry": null
            }
          ]
        },
        "output": [
          {
            "id": 1,
            "value1": 4.7557783e-06,
            "value2": 0
          },
          {
            "id": 1,
            "value1": 1.4931199e-05,
            "value2": 5
          }
        ]
      }
    ],
    "identifier": 71029053
  },
  {
    "context": [
      "Here my current jq script:",
      "My jq command is:",
      "As you can see, I'm getting $dict three times.",
      "I don't quite figure out why it's generating three $dict instead of one.",
      "Your program input, `reduced_pacient.json` is a stream of three objects. As you have set the `--slurp` flag, the initial context of your script is an array of three elements.",
      "First, you're calling `reduce_generateId` which by iteration `.[]` decomposes the array into its three items. Thus `reduce_generateId` has three outputs.",
      "Next, these are fed by pipe into your `reduce_generalPractitioner` function which consequently is run three times. Each run produces your `$dict` once, yielding three times in total."
    ],
    "utterance": "Combine an array of patient objects with a general practitioner array to produce a single merged object keyed by practitioner IDs, rather than multiple outputs.",
    "expressions": [
      "reduce_generalPractitioner($generalPractitioner)"
    ],
    "data": [
      {
        "input": [
          {
            "UAB_UP": "00003",
            "UAB_COD_UAB": "3212",
            "INVENTAT": "02"
          },
          {
            "UAB_UP": "00006",
            "UAB_COD_UAB": "5881",
            "INVENTAT": "102"
          },
          {
            "UAB_UP": "00006",
            "UAB_COD_UAB": "5751",
            "INVENTAT": "102"
          }
        ],
        "output": {
          "04374-INFP3": {
            "generalPractitioner": [
              "3e67b455-8cdb-4bc0-a5e1-f90253870fc9"
            ]
          },
          "04376-INF07": {
            "generalPractitioner": [
              "0f22e5ff-70bc-457f-bdaf-7afe86d478de"
            ]
          }
        }
      }
    ],
    "identifier": 71031043
  },
  {
    "context": [
      "Required output:\r\n\r\n    osd.7 /dev/sde /dev/nvme0n1p5 /dev/nvme0n1p6\r\n    osd.41 /dev/nvme1n1p13 n/a n/a\r\n    osd.9 /dev/sdf /dev/nvme0n1p7 /dev/nvme0n1p7",
      "And the final problem is how do I transpose it from columns to rows, as detailed in the required output?",
      "Would this do what you want?\r\n\r\n~~~sh\r\njq --raw-output '\r\n  to_entries[] | [\r\n    \"osd.\" + .key,\r\n    ( .value[0]\r\n    | .devices[],\r\n      ( .tags\r\n      | .\"ceph.db_device\" // \"n/a\",\r\n        .\"ceph.wal_device\" // \"n/a\"\r\n      )\r\n    )\r\n  ]\r\n  | @tsv\r\n'\r\n~~~",
      "osd.7\t/dev/sde\t/dev/nvme0n1p5\t/dev/nvme0n1p6\r\nosd.41\t/dev/nvme1n1p13\tn/a\tn/a\r\nosd.9\t/dev/sdf\t/dev/nvme0n1p7\t/dev/nvme0n1p8"
    ],
    "utterance": "Output each top-level OSD key as 'osd.<key>', its first object's device (or 'n/a'), its ceph.db_device tag value (or 'n/a'), and ceph.wal_device tag value (or 'n/a'), as separate rows.",
    "expressions": [
      "to_entries[] | [\n  \"osd.\" + .key,\n  ( .value[0]\n    | .devices[],\n      ( .tags\n        | .\"ceph.db_device\" // \"n/a\",\n          .\"ceph.wal_device\" // \"n/a\"\n      )\n  )\n] | @tsv"
    ],
    "data": [
      {
        "input": {
          "7": [
            {
              "devices": [
                "/dev/sde"
              ],
              "name": "osd-block-dcc9b386-529c-451e-9d84-8ccc4091102b",
              "tags": {
                "ceph.crush_device_class": "None",
                "ceph.db_device": "/dev/nvme0n1p5",
                "ceph.wal_device": "/dev/nvme0n1p6"
              },
              "type": "block",
              "vg_name": "ceph-c4de9e90-853e-4569-b04f-8677ef9a8c7a"
            },
            {
              "path": "/dev/nvme0n1p5",
              "tags": {
                "PARTUUID": "69712eb4-be52-4618-ba46-e317d6d3d76e"
              },
              "type": "db"
            }
          ],
          "41": [
            {
              "devices": [
                "/dev/nvme1n1p13"
              ],
              "name": "osd-block-97bce07f-ae98-4fdb-83a9-9fa2f35cee60",
              "tags": {
                "ceph.crush_device_class": "None"
              },
              "type": "block",
              "vg_name": "ceph-c1d48671-2a33-4615-95e3-cc1b18783f0c"
            }
          ],
          "9": [
            {
              "devices": [
                "/dev/sdf"
              ],
              "name": "osd-block-35323eb8-17c1-460d-8cc5-565f549e6991",
              "tags": {
                "ceph.crush_device_class": "None",
                "ceph.db_device": "/dev/nvme0n1p7",
                "ceph.wal_device": "/dev/nvme0n1p8"
              },
              "type": "block",
              "vg_name": "ceph-9488e8b8-ec18-4860-93d3-6a1ad91c698c"
            },
            {
              "path": "/dev/nvme0n1p7",
              "tags": {
                "PARTUUID": "ef0e9588-2a20-4c2c-8b62-d73945e01322"
              },
              "type": "db"
            }
          ]
        },
        "output": [
          "osd.7\t/dev/sde\t/dev/nvme0n1p5\t/dev/nvme0n1p6",
          "osd.41\t/dev/nvme1n1p13\tn/a\tn/a",
          "osd.9\t/dev/sdf\t/dev/nvme0n1p7\t/dev/nvme0n1p8"
        ]
      }
    ],
    "identifier": 71011349
  },
  {
    "context": [
      "I need to filter `.identifier` where `system.value=\"urn:oid:2.16.724.4.9.20.91-INVENTAT\"`  or `system.value=\"urn:oid:2.16.724.4.9.20.2-INVENTAT\"` and pick `.value.value`.",
      "Desired output:",
      "[",
      "  {",
      "    \"id\": \"3e67b455-8cdb-4bc0-a5e1-f90253870fc9\",",
      "    \"oid1\": \"04374\",",
      "    \"oid2\": \"INFP3\"",
      "  },",
      "  {",
      "    \"id\": \"0f22e5ff-70bc-457f-bdaf-7afe86d478de\",",
      "    \"oid1\": \"04376\",",
      "    \"oid2\": \"INF07\"",
      "  },",
      "  {",
      "    \"id\": \"a1ea574c-438b-443c-ad87-d31d09d581f0\",",
      "    \"oid1\": \"08096\",",
      "    \"oid2\": \"INF04\"",
      "  }",
      "]",
      "This uses `IN` to check for your query strings, and `with_entries` on an array to generate the indeces for the `oid` keys.",
      "jq '",
      "  map({id} + (.identifier | map(select(IN(.system.value; ",
      "    \"urn:oid:2.16.724.4.9.20.91-INVENTAT\",",
      "    \"urn:oid:2.16.724.4.9.20.2-INVENTAT\"",
      "  )).value.value) | with_entries(.key |= \"oid\\(. + 1)\")))",
      "'"
    ],
    "utterance": "For each object, extract the values of identifiers where system.value is \"urn:oid:2.16.724.4.9.20.91-INVENTAT\" or \"urn:oid:2.16.724.4.9.20.2-INVENTAT\", assign them as oid1 and oid2, and include the id in the result.",
    "expressions": [
      "map({id} + (.identifier | map(select(IN(.system.value; \"urn:oid:2.16.724.4.9.20.91-INVENTAT\", \"urn:oid:2.16.724.4.9.20.2-INVENTAT\")).value.value) | with_entries(.key |= \"oid\\(. + 1)\")))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "3e67b455-8cdb-4bc0-a5e1-f90253870fc9",
            "identifier": [
              {
                "system": {
                  "value": "urn:oid:2.16.724.4.9.20.91-INVENTAT"
                },
                "value": {
                  "value": "04374"
                }
              },
              {
                "system": {
                  "value": "urn:oid:2.16.724.4.9.20.2-INVENTAT"
                },
                "value": {
                  "value": "INFP3"
                }
              },
              {
                "system": {
                  "value": "urn:oid:INVENTAT"
                },
                "value": {
                  "value": "CBOU035"
                }
              }
            ]
          },
          {
            "id": "0f22e5ff-70bc-457f-bdaf-7afe86d478de",
            "identifier": [
              {
                "system": {
                  "value": "urn:oid:2.16.724.4.9.20.91-INVENTAT"
                },
                "value": {
                  "value": "04376"
                }
              },
              {
                "system": {
                  "value": "urn:oid:2.16.724.4.9.20.2-INVENTAT"
                },
                "value": {
                  "value": "INF07"
                }
              },
              {
                "system": {
                  "value": "urn:oid:INVENTAT"
                },
                "value": {
                  "value": "S527918"
                }
              }
            ]
          },
          {
            "id": "a1ea574c-438b-443c-ad87-d31d09d581f0",
            "identifier": [
              {
                "system": {
                  "value": "urn:oid:2.16.724.4.9.20.91-INVENTAT"
                },
                "value": {
                  "value": "08096"
                }
              },
              {
                "system": {
                  "value": "urn:oid:2.16.724.4.9.20.2-INVENTAT"
                },
                "value": {
                  "value": "INF04"
                }
              },
              {
                "system": {
                  "value": "urn:oid:INVENTAT"
                },
                "value": {
                  "value": "5635132"
                }
              }
            ]
          }
        ],
        "output": [
          {
            "id": "3e67b455-8cdb-4bc0-a5e1-f90253870fc9",
            "oid1": "04374",
            "oid2": "INFP3"
          },
          {
            "id": "0f22e5ff-70bc-457f-bdaf-7afe86d478de",
            "oid1": "04376",
            "oid2": "INF07"
          },
          {
            "id": "a1ea574c-438b-443c-ad87-d31d09d581f0",
            "oid1": "08096",
            "oid2": "INF04"
          }
        ]
      }
    ],
    "identifier": 71021632
  }
]