[
  {
    "context": [
      "I still can use the expression on the CLI on `jq` version 1.6: \n\n```\n# jq '.|[leaf_paths as $path|{\"key\": $path | join(\"^\"), \"value\": getpath($path)}]' /tmp/a.json",
      "When I upgrade `jq` to 1.7 ... I'm getting the following:\n```\njq: error: leaf_paths/0 is not defined at <top-level>, line 1:\n. | [leaf_paths as $path | {\"key\": $path | join(\"^\"), \"value\": getpath($path)}]\njq: 1 compile error",
      "Anything I can do to fix it or get the same results using 1.7 (flatten my json into single key value structure)",
      "`leaf_paths` was deprecated in favor of the (more universal) `paths(scalars)`. With jq 1.7 use:\n```sh\njq '[paths(scalars) as $path | {key: $path | join(\"^\"), value: getpath($path)}]'"
    ],
    "utterance": "Flatten the data so that each leaf value is paired with its path as a ^-separated key.",
    "expressions": [
      "[paths(scalars) as $path | {key: $path | join(\"^\"), value: getpath($path)}]"
    ],
    "identifier": 77511091
  },
  {
    "context": [
      "I would like to find `weight` in `rules.primaryRefs` whose `name` is `b`",
      "In this example, it should return `20`",
      "However it returns an error if `primaryRefs` doesn\u2019t exist",
      "I would like to not error out or return null when `primaryRefs` or `b` doesn't exist.",
      "Either explicitly [check for the existence of the field using `has`](https://jqlang.github.io/jq/manual/#has):",
      ".rules[] | select(has(\"primaryRefs\"))\n| .primaryRefs[] | select(.name == \"b\").weight",
      "Or use the [error suppression operator `?`](https://jqlang.github.io/jq/manual/#error-suppression-optional-operator):",
      ".rules[].primaryRefs[]? | select(.name == \"b\").weight"
    ],
    "utterance": "Get the weight value from all primaryRefs objects under rules where the name is b, ignoring errors or missing fields if primaryRefs or b do not exist.",
    "expressions": [
      ".rules[] | select(has(\"primaryRefs\")) | .primaryRefs[] | select(.name == \"b\").weight",
      ".rules[].primaryRefs[]? | select(.name == \"b\").weight"
    ],
    "data": [
      {
        "input": {
          "rules": [
            {
              "primaryRefs": [
                {
                  "name": "a"
                },
                {
                  "name": "b",
                  "weight": 20
                }
              ],
              "siblingRefs": [
                {
                  "name": "d"
                },
                {
                  "name": "e",
                  "weight": 90
                }
              ]
            },
            {
              "siblingRefs": [
                {
                  "name": "d"
                },
                {
                  "name": "e",
                  "weight": 90
                }
              ]
            }
          ]
        },
        "output": 20
      }
    ],
    "identifier": 77512617
  },
  {
    "context": [
      "dependencies=$(echo \"$body\" | grep -oE \"#[0-9]+\" | sed 's/#//g' || true)",
      "status=$(curl -s -H \"Authorization: Bearer $GITHUB_TOKEN\" \\\n  -H \"Accept: application/vnd.github.v3+json\" \\\n  \"https://api.github.com/repos/${{ github.repository }}/issues/$issue\" | jq -r .state)",
      "for issue in $dependencies; do\n  status=$(...) # as above\n  if [ \"$status\" != \"closed\" ]; then\n    ...\n  fi\n done"
    ],
    "utterance": "Extract the issue state from an API response and determine if the issue is not closed.",
    "expressions": [
      ".state",
      "jq -r .state"
    ],
    "data": [
      {
        "input": {
          "number": 123,
          "state": "open"
        },
        "output": "open"
      }
    ],
    "identifier": 77529334
  },
  {
    "context": [
      "I am trying to output TSV where each line contains the \"Key\" and the first \"url\" value in the \"Image\" array that contains the string \"fanart\". So for instance with the above JSON, the output I'm looking for is:",
      "5d77682c151a60001f24bbe8 http://assets.fanart.tv/fanart/movies/2639/hdmovielogo/deconstructing-harry-60f13837ee6aa.png",
      "Here we use `first` to obtain the first url that meets the condition, on the assumption that there is at least one:",
      ".MediaContainer.Metadata[]\n| [.Key, first(.Image[].url | select(test(\"fanart\") ) ) ]\n| @tsv"
    ],
    "utterance": "Output a tab-separated line for each Metadata item containing the Key and the first url from the Image array whose url contains 'fanart'.",
    "expressions": [
      ".MediaContainer.Metadata[] | [.Key, first(.Image[].url | select(test(\"fanart\")))] | @tsv"
    ],
    "data": [
      {
        "input": {
          "MediaContainer": {
            "Metadata": [
              {
                "Key": "5d77682c151a60001f24bbe8",
                "Image": [
                  {
                    "alt": "image",
                    "type": "background",
                    "url": "https://image.tmdb.org/t/p/original/f8Q3Sug5Sa42psw2b3Gdd1aT8t.jpg"
                  },
                  {
                    "alt": "image",
                    "type": "clearLogoWide",
                    "url": "http://assets.fanart.tv/fanart/movies/2639/hdmovielogo/deconstructing-harry-60f13837ee6aa.png"
                  },
                  {
                    "alt": "image",
                    "type": "coverArt",
                    "url": "https://metadata-static.imdb.com/4/gracenote/44a1852151a726d730c214b97986c27e.jpg"
                  },
                  {
                    "alt": "image",
                    "type": "coverPoster",
                    "url": "https://image.tmdb.org/t/p/original/i7Z5DdznqANJUjqWISEFu9bw6J7.jpg"
                  },
                  {
                    "alt": "image",
                    "type": "coverSquare",
                    "url": "https://metadata-static.imdb.com/c/gracenote/c8c351b348baf43a909e4a3b1c60a443.jpg"
                  },
                  {
                    "alt": "image",
                    "type": "snapshot",
                    "url": "https://metadata-static.imdb.com/a/gracenote/ab5a905958de8d43c763d74153242690.jpg"
                  }
                ]
              }
            ]
          }
        },
        "output": "5d77682c151a60001f24bbe8\thttp://assets.fanart.tv/fanart/movies/2639/hdmovielogo/deconstructing-harry-60f13837ee6aa.png"
      }
    ],
    "identifier": 77509326
  },
  {
    "context": [
      "I want to now delete the lines where the \"id\" matches any of the id on the banned list text file.",
      "You could read the banned ids using `--rawfile`, split it at newline characters, and compare each JSON line read if its `.id` is contained:",
      "jq -c --rawfile b banned_list.txt 'select(IN(.id; $b | (. / \"\\n\")[]) | not)' source.jsonl",
      "it'd be better to prepare it beforehand into a proper JSON array using another call to jq, and `--slurpfile` to read the JSON strings into an array:",
      "jq -c --slurpfile b <(jq -R . banned_list.txt) 'select(IN(.id; $b[]) | not)' source.jsonl",
      "You can create a simple json-list : (Note: the awk ensures no '\\r' chars ):",
      "Blacklist implementation:",
      "$ jq --argfile black list.json 'select(.id|IN($black[])|not) ' source.jsonl -c",
      "{ \"id\":\"y88979\",\"content\":\"content goes here\" }",
      "{ \"id\":\"h93794\",\"content\":\"content goes here\" }",
      "{ \"id\":\"i8408\",\"content\":\"content goes here\" }"
    ],
    "utterance": "Remove all lines where the id field matches any value from a given banned list stored in a text file.",
    "expressions": [
      "jq -c --rawfile b banned_list.txt 'select(IN(.id; $b | (. / \"\\n\")[]) | not)' source.jsonl",
      "jq -c --slurpfile b <(jq -R . banned_list.txt) 'select(IN(.id; $b[]) | not)' source.jsonl",
      "jq --argfile black list.json 'select(.id|IN($black[])|not)' source.jsonl -c"
    ],
    "data": [
      {
        "input": [
          {
            "id": "y88979",
            "content": "content goes here"
          },
          {
            "id": "h93794",
            "content": "content goes here"
          },
          {
            "id": "k9489",
            "content": "content goes here"
          },
          {
            "id": "p48947",
            "content": "content goes here"
          },
          {
            "id": "i8408",
            "content": "content goes here"
          }
        ],
        "output": [
          {
            "id": "y88979",
            "content": "content goes here"
          },
          {
            "id": "h93794",
            "content": "content goes here"
          },
          {
            "id": "i8408",
            "content": "content goes here"
          }
        ]
      },
      {
        "input": "banned_list.txt:\nk9489\np48947\n"
      }
    ],
    "identifier": 77531885
  },
  {
    "context": [
      "Here is what I'd ultimately like to have as an output from JQ.",
      "group_by(.muleVersion)\n| map({ muleVersion: first.muleVersion, s2iVersions: (map(.s2iVersion)|unique) })",
      "group_by(.muleVersion) | \n  map({\"muleVersion\": .[0].muleVersion, s2iVersions: (map(.s2iVersion) | unique)})"
    ],
    "utterance": "Group objects by muleVersion and create an array for each group containing unique s2iVersion values as s2iVersions.",
    "expressions": [
      "group_by(.muleVersion) | map({ muleVersion: first.muleVersion, s2iVersions: (map(.s2iVersion)|unique) })",
      "group_by(.muleVersion) | map({\"muleVersion\": .[0].muleVersion, s2iVersions: (map(.s2iVersion) | unique)})"
    ],
    "data": [
      {
        "input": [
          {
            "name": "pcmp-ingestion-master",
            "s2iVersion": "4.5.0-05",
            "muleVersion": "4.5.0",
            "imageSha": "sha256:c1b618c6fbec2e2832824578a47893707ebea8a681bab1ce97b73b1a1e2fccb5"
          },
          {
            "name": "pcmp-ingestion-syst",
            "s2iVersion": "4.4.0-87",
            "muleVersion": "4.4.0",
            "imageSha": "sha256:c1b618c6fbec2e2832824578a47893707ebea8a681bab1ce97b73b1a1e2fccb5"
          },
          {
            "name": "pcmp-ingestion-uat",
            "s2iVersion": "4.4.0-87",
            "muleVersion": "4.4.0",
            "imageSha": "sha256:c1b618c6fbec2e2832824578a47893707ebea8a681bab1ce97b73b1a1e2fccb5"
          },
          {
            "name": "qualityofhire-uat",
            "s2iVersion": "4.4.0-85",
            "muleVersion": "4.4.0",
            "imageSha": "sha256:baabd127862667b17bda7ff278144314469205c12d1445295dc3cf0001ac79db"
          },
          {
            "name": "virtual-assist-uat",
            "s2iVersion": "4.4.0-85",
            "muleVersion": "4.4.0",
            "imageSha": "sha256:b82d58aa174fe668061e41453d11212e9162381f8b20a2db3b9a525e6b981140"
          }
        ],
        "output": [
          {
            "muleVersion": "4.4.0",
            "s2iVersions": [
              "4.4.0-85",
              "4.4.0-87"
            ]
          },
          {
            "muleVersion": "4.5.0",
            "s2iVersions": [
              "4.5.0-05"
            ]
          }
        ]
      }
    ],
    "identifier": 77529089
  },
  {
    "context": [
      "Here's the code in my MAKE file",
      "echo \"$${json}\" | jq -r '.assets[] | .name, .browser_download_url' | while read -r name ; do \\",
      "cat /tmp/realm.txt | jq -r '.assets[] | .name, .browser_download_url' | while read -r name ; do \\",
      "The above code works correctly but I would rather pipe the cURL output directly into jq instead of having to first save it into a file..."
    ],
    "utterance": "Extract, for each asset in the releases, the name and browser_download_url using a query.",
    "expressions": [
      ".assets[] | .name, .browser_download_url"
    ],
    "identifier": 77533956
  },
  {
    "context": [
      "I would like to pass to `contains` many words. So I made a file named input.txt that contains these words and I am trying to pass this file to `contains` expression but with no luck:",
      "assuming input.txt is a simple text file using \"newline\" as a delimiter of the relevant strings, then you'd want to gather those into a suitable JSON structure, such as an array:",
      "($foo / \"\\n\" | map(select(length>0))) as $ok",
      "If you really want to use `contains`, then presumably you'd want something like:",
      "select(.metadata.name as $name | any($ok[]; . as $s | $name | contains($s)) )"
    ],
    "utterance": "Delete all items whose metadata.name contains any of the strings listed in input.txt, where each string is on a separate line.",
    "expressions": [
      "($foo / \"\\n\" | map(select(length>0))) as $ok | del(.items[] | select(.metadata.name as $name | any($ok[]; . as $s | $name | contains($s))))"
    ],
    "identifier": 77533126
  },
  {
    "context": [
      "I need to change values rec_9M.rec_E[].id but I need to use a universal bash function for that, which can be using for changing values on different levels (rec_9M.id or rec_9M.rec_E[].files[].id)",
      "VAR=rec_9M.rec_E[]",
      "echo $(cat config.json) | jq --arg VAR_I $VAR --arg NUM_I $NUM '.[$VAR_I].id = $NUM_I' > config_t.json",
      "If key was hardcoded - everything works correctly.:",
      "One way uses [`getpath()`][1] to extract the paths of the input JSON based on a variable (Or other string):",
      "$ jq --arg path \"rec_9M.rec_E\" --arg i 555 'getpath($path | split(\".\"))[] += {id: $i}' config.json",
      "Another, more flexible but also more fragile approach involves putting the path held in the shell variable directly in the `jq` program:",
      "$ path_var=\".rec_9M.rec_E[].id\"",
      "$ jq --arg i 555 \"$path_var\"' |= $i' config.json"
    ],
    "utterance": "Update the id field of all objects within rec_9M.rec_E[] to 555, using a path specified by a shell variable.",
    "expressions": [
      "jq --arg path \"rec_9M.rec_E\" --arg i 555 'getpath($path | split(\".\"))[] += {id: $i}' config.json",
      "jq --arg i 555 '.rec_9M.rec_E[].id |= $i' config.json"
    ],
    "data": [
      {
        "input": {
          "rec_9M": {
            "id": "000",
            "rec_E": [
              {
                "id": "111"
              },
              {
                "id": "222"
              }
            ]
          }
        },
        "output": {
          "rec_9M": {
            "id": "000",
            "rec_E": [
              {
                "id": "555"
              },
              {
                "id": "555"
              }
            ]
          }
        }
      }
    ],
    "identifier": 77533031
  },
  {
    "context": [
      "I am having problems parsing a JSON file using jq from a .sh script. When the object contains a space, shell splits it into two. Can i escape the space somehow?",
      "echo $(jq '.[]' ../ext/js/language/languages.json)",
      "entries=($(jq -c '.[]' ../ext/js/language/languages.json))",
      "Because unquoted command substitution $(...) is split a space \"t\":\"don't read\"} into two elements.",
      "You could convert each item into a JSON-encoded string using @json, and escape that for shell using @sh.",
      "jq -r '.[] | @json | @sh' ../ext/js/language/languages.json"
    ],
    "utterance": "Output each item in the array as a shell-escaped string suitable for use as a Bash array element, including items that may contain spaces.",
    "expressions": [
      ".[] | @json | @sh"
    ],
    "data": [
      {
        "input": [
          {
            "iso": "en",
            "language": "English",
            "flag": "\ud83c\uddfa\ud83c\uddf8\ud83c\udde8\ud83c\udde6",
            "exampleText": "don't read"
          },
          {
            "iso": "fr",
            "language": "French",
            "flag": "\ud83c\uddeb\ud83c\uddf7",
            "exampleText": "lisez-moi"
          }
        ],
        "output": [
          "'{\"iso\":\"en\",\"language\":\"English\",\"flag\":\"\ud83c\uddfa\ud83c\uddf8\ud83c\udde8\ud83c\udde6\",\"exampleText\":\"don'\\''t read\"}'",
          "'{\"iso\":\"fr\",\"language\":\"French\",\"flag\":\"\ud83c\uddeb\ud83c\uddf7\",\"exampleText\":\"lisez-moi\"}'"
        ]
      }
    ],
    "identifier": 77536544
  },
  {
    "context": [
      "I have the following json:",
      "\"Environment\": \"$ENV_DEFINITION\"",
      "And I have exported the `$ENV_DEFINITION` with the value `dev`.",
      "I need to obtain the following output:",
      "'AmiId=/my/image/id/latest' 'InstanceType=t3.medium' 'Environment=dev'",
      "But then I needed to add a few more parameters to json:",
      "\"MinSize\": 0,",
      "\"MaxSize\": 0,",
      "\"DesiredCapacity\": 0,",
      "And `jq` started to fail with the following message:",
      "jq: error (at myfile:10): Cannot index number with object",
      "To only trigger the lookup if the value is a string, you can use `select(type == \"string\")`, which also has the `strings` shortcut. So, in your first attempt, just replace `.[1:]` with `strings[1:]`, and you should be good to go.",
      "jq -r '[ .Parameters | to_entries[] | .value |= (env[strings[1:]] // .) | [.key, .value] | join(\"=\") ] | @sh' < myfile.json"
    ],
    "utterance": "Output all key-value pairs from an object where string values starting with $ are replaced by their environment variable value if set, otherwise left unchanged, and other values remain unchanged; output the pairs as strings in the format key=value and shell-quoted.",
    "expressions": [
      "[ .Parameters | to_entries[] | .value |= (env[strings[1:]] // .) | [.key, .value] | join(\"=\") ] | @sh"
    ],
    "data": [
      {
        "input": {
          "Parameters": {
            "AmiId": "/my/image/id/latest",
            "InstanceType": "t3.medium",
            "Environment": "$ENV_DEFINITION",
            "MinSize": 0,
            "MaxSize": 0,
            "DesiredCapacity": 0
          }
        },
        "output": "'AmiId=/my/image/id/latest' 'InstanceType=t3.medium' 'Environment=dev' 'MinSize=0' 'MaxSize=0' 'DesiredCapacity=0'"
      }
    ],
    "identifier": 77537504
  },
  {
    "identifier": 77562545
  },
  {
    "context": [
      "\"this shows the list like this below, in this case three lines, but it can change.\"",
      "\"task id such as `408879277ab24490b1b911b119c81414` is set as environment variable\"",
      "\"However I want to do this for every row.\"",
      "\"You can alter your JQ command by looping over the items (`[]`), then use `split()` and `[-1]` to select the task id's:\"",
      "jq -r '.taskArns[] | split(\"/\")[-1]'",
      "\"This gives us a list of the task id's:\"",
      "1f3761101efd439f9d8959901e8f6095",
      "2bfb7cdfb9e64362b4df6b7f7e829236",
      "408879277ab24490b1b911b119c81414"
    ],
    "utterance": "Extract all ECS task IDs from a list of ARNs by taking the last segment after the slash for each ARN in the array.",
    "expressions": [
      ".taskArns[] | split(\"/\")[-1]",
      "-r '.taskArns[] | split(\"/\")[-1]'"
    ],
    "data": [
      {
        "input": {
          "taskArns": [
            "arn:aws:ecs:ap-northeast-1:678100222222:task/dev-ec2-cls/1f3761101efd439f9d8959901e8f6095",
            "arn:aws:ecs:ap-northeast-1:678100222222:task/dev-ec2-cls/2bfb7cdfb9e64362b4df6b7f7e829236",
            "arn:aws:ecs:ap-northeast-1:678100222222:task/dev-ec2-cls/408879277ab24490b1b911b119c81414"
          ]
        },
        "output": [
          "1f3761101efd439f9d8959901e8f6095",
          "2bfb7cdfb9e64362b4df6b7f7e829236",
          "408879277ab24490b1b911b119c81414"
        ]
      }
    ],
    "identifier": 77556057
  },
  {
    "context": [
      "I\u2019d like to have a list of named jq arguments in a file, e.g so that using a file like\n\n```\n{ \"foo\" : \"bar\", \"baz\": 123 }\n```\n\nWould be equivalent to invoking `jq --argjson foo '\"bar\"' --argjson baz 123`",
      "In the end I want to run a jq program with several different sets of arguments. E.g.\n\n```\njq -n --argjson foo '\"bar\"' --argjson baz 123 '\"\\($foo) is \\($baz)\"'\njq -n --argjson foo '\"RAB\"' --argjson baz 321 '\"\\($foo) is \\($baz)\"'\n```\n\nbut each set of arguments taken from separate file instead of specifying them on the command line.",
      "prefix your jq filters with a static set of bindings off of the imported arguments object. For example, statically prepend your unchanged jq code once with $args as {$foo, $baz} |, and use --argjson args \u2026 to import the set at once:\n\n```sh\njq -n --argjson args '{\"foo\": \"bar\", \"baz\": 123}' '$args as {$foo, $baz} |'\n  \"\\($foo) is \\($baz)\"\n```\n```\n\"bar is 123\"\n```\n",
      "Assuming your list of named jq arguments is in arguments.json,\n\nyou can define a shell function as follows :\n\n```\n#!/usr/bin/env bash\n\njq2(){\n    local arguments=$1 args; shift\n    mapfile -t args < <(jq -r 'to_entries[] | \"--argjson\", .key, (.value|@json)' $arguments)\n    jq \"${args[@]}\" \"$@\"\n}\n\njq2 arguments.json -n '\"\\($foo) is \\($baz)\"'\n```\n\nOutput :\n```\n\"bar is 123\"\n```\n"
    ],
    "utterance": "Run a program with argument values loaded from a file so that each key-value pair becomes an argument variable, allowing the same query to be run with different argument files.",
    "expressions": [
      "jq -n --argjson args '{\"foo\": \"bar\", \"baz\": 123}' '$args as {$foo, $baz} | \"\\($foo) is \\($baz)\"'",
      "jq2 arguments.json -n '\"\\($foo) is \\($baz)\"'"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "baz": 123
        },
        "output": "\"bar is 123\""
      }
    ],
    "identifier": 77559130
  },
  {
    "context": [
      "So the first query would be: [\"data\", \"*\", \"things\", \"*\"]",
      "The following filter can then be used to pose queries:",
      "def query($query):\n  . as $in\n  | ($query|length) as $ql\n  | paths\n  | select(length == $ql and matchesQuery($query)) as $path\n  | ($in | getpath($path)) as $value\n  | {$path, $value} ;",
      "For example, executing query( [\"data\", \"*\", \"things\", \"*\"] ) against\nthe first file produces the desired output.",
      "We can next adapt the above for use with jq's streaming parser by wrapping query/1 as follows:",
      "def streamQuery($query):\n  fromstream(inputs\n    | . as $in\n    | if ( length == 2 )\n      then select( .[0] | matchesQuery($query))\n      else . \n      end )\n  | query($query);",
      "jq -n --stream --argjson query '[\"data\", \"*\", \"things\", \"*\"]' -c -f streamQuery.jq  file1.json"
    ],
    "utterance": "List each object matching the path pattern [\"data\", \"*\", \"things\", \"*\"] along with its full path and value.",
    "expressions": [
      "def matchesQuery($array):\n  . as $in\n  | type == \"array\"\n    and length >= ($array|length)\n    and all(range(0; $array|length); . as $i | $array[$i] | IN(\"*\", $in[$i]));",
      "def query($query):\n  . as $in\n  | ($query|length) as $ql\n  | paths\n  | select(length == $ql and matchesQuery($query)) as $path\n  | ($in | getpath($path)) as $value\n  | {$path, $value} ;",
      "def streamQuery($query):\n  fromstream(inputs\n    | . as $in\n    | if ( length == 2 )\n      then select( .[0] | matchesQuery($query))\n      else . \n      end )\n  | query($query);",
      "streamQuery( $query )"
    ],
    "data": [
      {
        "input": {
          "data": {
            "<userId1>": {
              "things": {
                "<thingId1>": {
                  "subfield1": "blah1",
                  "subfield3": "foobar"
                },
                "<thingId2>": {
                  "subfield2": "blah2"
                }
              }
            },
            "<userId2>": {
              "things": {
                "<thingId1>": {
                  "subfield4": "blah3"
                },
                "<thingId2>": {
                  "subfield3": "blah4"
                }
              }
            }
          },
          "users": {
            "<userId1>": {
              "name": "user1",
              "email": "foo@bar.com"
            },
            "<userId2>": {
              "name": "user2"
            },
            "<userId3>": {
              "email": "hello@world.com"
            }
          }
        },
        "output": [
          {
            "path": [
              "data",
              "<userId1>",
              "things",
              "<thingId1>"
            ],
            "value": {
              "subfield1": "blah1",
              "subfield3": "foobar"
            }
          },
          {
            "path": [
              "data",
              "<userId1>",
              "things",
              "<thingId2>"
            ],
            "value": {
              "subfield2": "blah2"
            }
          },
          {
            "path": [
              "data",
              "<userId2>",
              "things",
              "<thingId1>"
            ],
            "value": {
              "subfield4": "blah3"
            }
          },
          {
            "path": [
              "data",
              "<userId2>",
              "things",
              "<thingId2>"
            ],
            "value": {
              "subfield3": "blah4"
            }
          }
        ]
      }
    ],
    "identifier": 77528680
  },
  {
    "context": [
      "Specifically I'm looking for a count of various HTTP status codes in the output json.",
      "$ jq 'def counter(stream):\nreduce stream as $s ({}; .[$s|tostring] += 1);\ncounter(.[].status)' test.json",
      "This works:\n\n    reduce .[] as $row ({}; .[$row.status | tostring] += 1)",
      "$ jq -r 'group_by(.status)[] | \"\\(.[0].status)\\t\\(length)\"' test.json",
      "$ jq '[group_by(.status)[] | {key:\"\\(.[0].status)\", value:length}] | from_entries' test.json"
    ],
    "utterance": "Count the occurrences of each status code and return an object with status codes as keys and their counts as values.",
    "expressions": [
      "reduce .[] as $row ({}; .[$row.status | tostring] += 1)",
      "def counter(stream): reduce stream as $s ({}; .[$s|tostring] += 1); counter(.[].status)",
      "[group_by(.status)[] | {key:\"\\(.[0].status)\", value:length}] | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "content-length": 45,
            "path": "/foo",
            "redirect": null,
            "status": 200
          },
          {
            "content-length": 40,
            "path": "/bar",
            "redirect": null,
            "status": 301
          },
          {
            "content-length": 1150,
            "path": "/baz",
            "redirect": null,
            "status": 403
          }
        ],
        "output": {
          "200": 1,
          "301": 1,
          "403": 1
        }
      }
    ],
    "identifier": 77566633
  },
  {
    "context": [
      "For each item into `env`, I'd like to transform the `configMapKeyRef` into `secretKeyRef` if name contains (SECRET|PASSWORD|KEY) pattern and then replace the secretKeyRef name by the key name into lowcase.",
      "would be transformed into\n```json\n                \"name\": \"APP_JWTSECRET\",\n                \"valueFrom\": {\n                  \"secretKeyRef\": {\n                    \"key\": \"APP_JWTSECRET\",\n                    \"name\": \"app-jwtsecret\"\n                  }\n                }\n              }\n```",
      ".spec.template.spec.containers[].env[] |= {name} + \nif .name | test(\"SECRET|PASSWORD|KEY\") then \n    .valueFrom |= ( \n        with_entries(\n            if .key == \"configMapKeyRef\" then .key = \"secretKeyRef\" end | \n                .value |= {key} + {name: .key|ascii_downcase}\n        )\n    )\nend",
      "(.spec.template.spec.containers[].env[]?\n    | select(.name | test(\"SECRET|PASSWORD|KEY\"))\n)\n\n.valueFrom |= with_entries(select(.key == \"configMapKeyRef\") |= {\n    key: \"secretKeyRef\", value: (.value | .name = (.key | ascii_downcase))\n})",
      ".spec.template.spec.containers\n|= map(\n    (.env\n     |= map(\n          if (.name|test(\"SECRET|PASSWORD|KEY\"))\n          then .valueFrom\n            |= with_entries(.key=\"secretKeyRef\"\n                 |.value.name=(.value.key|ascii_downcase|gsub(\"_\";\"-\"))\n               )\n          else .\n          end\n        )\n    )? // .\n)\n"
    ],
    "utterance": "Transform all env entries where the name contains SECRET, PASSWORD, or KEY, replacing configMapKeyRef with secretKeyRef, and set the secretKeyRef name to the key in lowercase with underscores replaced by dashes.",
    "expressions": [
      ".spec.template.spec.containers |= map((.env |= map(if (.name|test(\"SECRET|PASSWORD|KEY\")) then .valueFrom |= with_entries(.key=\"secretKeyRef\" | .value.name=(.value.key|ascii_downcase|gsub(\"_\";\"-\"))) else . end))? // .)",
      ".spec.template.spec.containers[].env[] |= {name} + if .name | test(\"SECRET|PASSWORD|KEY\") then .valueFrom |= ( with_entries( if .key == \"configMapKeyRef\" then .key = \"secretKeyRef\" end | .value |= {key} + {name: .key|ascii_downcase} ) ) end",
      "(.spec.template.spec.containers[].env[]? | select(.name | test(\"SECRET|PASSWORD|KEY\")))\n.valueFrom |= with_entries(select(.key == \"configMapKeyRef\") |= {key: \"secretKeyRef\", value: (.value | .name = (.key | ascii_downcase))})"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "apps/v1",
          "kind": "Deployment",
          "spec": {
            "replicas": 1,
            "selector": {
              "matchLabels": {
                "io.kompose.service": "item-api"
              }
            },
            "strategy": {
              "type": "Recreate"
            },
            "template": {
              "spec": {
                "containers": [
                  {
                    "env": [
                      {
                        "name": "APP_JWTSECRET",
                        "valueFrom": {
                          "configMapKeyRef": {
                            "key": "APP_JWTSECRET",
                            "name": "item-api-env"
                          }
                        }
                      },
                      {
                        "name": "SPRING_DATASOURCE_BASEXML_JDBCURL",
                        "valueFrom": {
                          "configMapKeyRef": {
                            "key": "SPRING_DATASOURCE_BASEXML_JDBCURL",
                            "name": "item-api-env"
                          }
                        }
                      }
                    ]
                  }
                ]
              }
            }
          }
        },
        "output": {
          "apiVersion": "apps/v1",
          "kind": "Deployment",
          "spec": {
            "replicas": 1,
            "selector": {
              "matchLabels": {
                "io.kompose.service": "item-api"
              }
            },
            "strategy": {
              "type": "Recreate"
            },
            "template": {
              "spec": {
                "containers": [
                  {
                    "env": [
                      {
                        "name": "APP_JWTSECRET",
                        "valueFrom": {
                          "secretKeyRef": {
                            "key": "APP_JWTSECRET",
                            "name": "app-jwtsecret"
                          }
                        }
                      },
                      {
                        "name": "SPRING_DATASOURCE_BASEXML_JDBCURL",
                        "valueFrom": {
                          "configMapKeyRef": {
                            "key": "SPRING_DATASOURCE_BASEXML_JDBCURL",
                            "name": "item-api-env"
                          }
                        }
                      }
                    ]
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 77544622
  },
  {
    "context": [
      "Is there a way to substitute the `.resource_name` field with the strings in a text file and execute a `jq` for each line of substitution from the text file?",
      "I have `list.txt` file with the below contents:\napple\nmango\ngrapes",
      "I want the `jq` command to be substituted as below:\n\njq '.backups[] | select(.resource_name == \"**apple**\") | {BackupTime: .updated_at, DiskName: .resource_name}' js.json | head -4",
      "while read -r resource; do\n    jq --arg resource \"$resource\" '.backups[] |\n        select(.resource_name == $rname) |\n        {BackupTime: .updated_at, DiskName: .resource_name}' js.json |\n    head -4\ndone <list.txt"
    ],
    "utterance": "For each value in a text file, select all backups where the resource_name matches that value and output updated_at and resource_name for each match.",
    "expressions": [
      "while read -r resource; do jq --arg rname \"$resource\" '.backups[] | select(.resource_name == $rname) | {BackupTime: .updated_at, DiskName: .resource_name}' js.json | head -4; done <list.txt",
      "parallel -k jq '.backups[] | select(.resource_name == \"{}\") | {BackupTime: .updated_at, DiskName: .resource_name}' js.json :::: list.txt"
    ],
    "identifier": 77570671
  },
  {
    "context": [
      "Is it possible with using jq to have a more specific return, for example i'd like to display only the device_id of the devices that have the 13.3.1 version.",
      "jq '.[] | select(.os_version == \"13.3.1\") | .device_id' input_file",
      "... will print a sequence of JSON strings containing the `device_id` values of the array elements having `os_version` of \"13.3.1\"."
    ],
    "utterance": "Return the device_id values where os_version equals 13.3.1.",
    "expressions": [
      ".[] | select(.os_version == \"13.3.1\") | .device_id"
    ],
    "data": [
      {
        "input": [
          {
            "agent_installed": true,
            "agent_version": "",
            "asset_tag": "",
            "blueprint_id": "",
            "blueprint_name": "",
            "device_id": "d35feff4-7867-268a-zet1-82caa4bcf5a0",
            "device_name": "Spare's MacBook Air",
            "model": "MacBook Air",
            "os_version": "13.3.1",
            "platform": "Mac",
            "serial_number": "FK1VXASVRFS2E"
          },
          {
            "agent_installed": true,
            "agent_version": "",
            "asset_tag": "",
            "blueprint_id": "",
            "blueprint_name": "",
            "device_id": "abc124",
            "device_name": "Other MacBook",
            "model": "MacBook Pro",
            "os_version": "13.2.1",
            "platform": "Mac",
            "serial_number": "SOMESERIAL"
          }
        ],
        "output": [
          "d35feff4-7867-268a-zet1-82caa4bcf5a0"
        ]
      }
    ],
    "identifier": 77572717
  },
  {
    "context": [
      "I have an Array of Employees like this one",
      "the output should look as follows for each Employee",
      "Here's one approach using `to_entries` to access keys and values. The `.key` is split at dots using `/`, the parts looking like numbers converted to numbers representing array indices, and used as path to set the `.value` with `setpath`. Using a `reduce` iteration successively builds up the result objects, for each item in the `.Employees` array.",
      "Here's another approach using [streaming](https://jqlang.github.io/jq/manual/#streaming).  Streaming produces an array for each leaf-value. The path (also an array) is the first element in the array and the leaf-value is the second element in the array.  Splitting the _dotted_ path elements to produce more path elements creates the structure you are looking for.  After processing the paths, `fromstream` reconstructs the desired JSON output."
    ],
    "utterance": "Restructure objects with dotted keys and array indices into nested objects and arrays, as shown in the target structure for Employees, converting flat keys like 'address.street' or 'contactDetails.1.phone' into their respective nested positions.",
    "expressions": [
      ".Employees[] |= ( reduce to_entries[] as $e (null; setpath($e.key / \".\" | map(tonumber? // .); $e.value) ) )",
      "fromstream( tostream |[(.[0] | map((splits(\"\\\\.\")? // .) | (tonumber? // .))), (.[1] // empty)] )"
    ],
    "data": [
      {
        "input": {
          "Employees": [
            {
              "firstName": "First",
              "lastName": "Last",
              "birthday": "1990-01-01",
              "account": "true",
              "address.street": "Street",
              "address.addition": "1",
              "address.zipCode": "1000",
              "address.city": "Vienna",
              "address.region": "AT",
              "contactDetails.1.phone": "+431234567",
              "contactDetails.1.mail": "first.last@mail.com",
              "organisations.0.id": 1,
              "departments.0.id": 1,
              "roles.0.id": 1
            }
          ]
        },
        "output": {
          "Employees": [
            {
              "firstName": "First",
              "lastName": "Last",
              "birthday": "1990-01-01",
              "account": "true",
              "address": {
                "street": "Street",
                "addition": "1",
                "zipCode": "1000",
                "city": "Vienna",
                "region": "AT"
              },
              "contactDetails": [
                null,
                {
                  "phone": "+431234567",
                  "mail": "first.last@mail.com"
                }
              ],
              "organisations": [
                {
                  "id": 1
                }
              ],
              "departments": [
                {
                  "id": 1
                }
              ],
              "roles": [
                {
                  "id": 1
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 77543097
  },
  {
    "context": [
      "If you want to merge these results into a single array, you need to wrap the entire expression with brackets [].",
      "One way to avoid having to do so would be to avoid using `[]` after the call to `group_by`, so your filter would end with:",
      "group_by(.school) | map({k:.[0].school, len:length})",
      "For the record, it might be worth mentioning that if you're working at the command prompt and find yourself in the situation described, you can always simply pipe the stream into `jq -s`.",
      "If you are working in a POSIX shell, you can pipe the output to another jq invocation:",
      "jq '..... your long jq program producing a stream of object .....' | jq -s",
      "-s is \"slurp\", which will put all objects from the input stream into a single array."
    ],
    "utterance": "Aggregate objects produced by grouping items by the 'school' key and counting them into a single array without manually adding top-level brackets.",
    "expressions": [
      "group_by(.school) | map({k:.[0].school, len:length})",
      "[map(select(.sno|startswith(\"20\")))|group_by(.school)[]|{k:.[0].school,len:length}]",
      "map(select(.sno|startswith(\"20\")))|group_by(.school)[]|{k:.[0].school,len:length} | jq -s"
    ],
    "data": [
      {
        "input": [
          {
            "school": "xxx",
            "sno": "20123"
          },
          {
            "school": "xxx",
            "sno": "20011"
          },
          {
            "school": "aaa",
            "sno": "20199"
          },
          {
            "school": "xxx",
            "sno": "19101"
          },
          {
            "school": "aaa",
            "sno": "20333"
          }
        ],
        "output": [
          {
            "k": "aaa",
            "len": 2
          },
          {
            "k": "xxx",
            "len": 2
          }
        ]
      }
    ],
    "identifier": 77583037
  },
  {
    "context": [
      "I want to get all the paths of keys whose values are either empty string or string with only spaces",
      "how to extend the above to regex like \"^\\s*&\"  which can check all values with empty string or string with only spaces.",
      "You can use `strings` to filter for strings, and `test` to have regex test return a boolean.",
      "jq -c 'paths(strings | test(\"^\\\\s*$\"))' input.json"
    ],
    "utterance": "Find all paths where the value is an empty string or consists only of whitespace.",
    "expressions": [
      "paths(strings | test(\"^\\\\s*$\"))"
    ],
    "data": [
      {
        "input": {
          "key0": null,
          "key": 1010,
          "key1": "",
          "key2": "  ",
          "key3": {
            "key4": "   ",
            "key5": "test"
          }
        },
        "output": [
          [
            "key1"
          ],
          [
            "key2"
          ],
          [
            "key3",
            "key4"
          ]
        ]
      }
    ],
    "identifier": 77590943
  },
  {
    "context": [
      "I am trying to capture the topic name - `TEST2` from the following `topic-json` file",
      "so far I wrote the following in order to get the first elements but not succeeded to print only the `TEST2` name",
      "Expected output\n\n    TEST2",
      "you could go with:\n\n    jq -r '.partitions[0].topic' topic-json",
      "consider alternatives such as:\n\n    jq -r 'first(.partitions[].topic)' topic-json"
    ],
    "utterance": "Extract the first topic name from the partitions array where the expected value is TEST2.",
    "expressions": [
      ".partitions[0].topic",
      "first(.partitions[].topic)"
    ],
    "data": [
      {
        "input": {
          "version": 1,
          "partitions": [
            {
              "topic": "TEST2",
              "partition": 0,
              "replicas": [
                1003,
                1002,
                1001
              ]
            },
            {
              "topic": "TEST2",
              "partition": 1,
              "replicas": [
                1001,
                1003,
                1002
              ]
            },
            {
              "topic": "TEST2",
              "partition": 2,
              "replicas": [
                1002,
                1001,
                1003
              ]
            },
            {
              "topic": "TEST2",
              "partition": 3,
              "replicas": [
                1003,
                1001,
                1002
              ]
            },
            {
              "topic": "TEST2",
              "partition": 4,
              "replicas": [
                1001,
                1002,
                1003
              ]
            },
            {
              "topic": "TEST2",
              "partition": 5,
              "replicas": [
                1002,
                1003,
                1001
              ]
            }
          ]
        },
        "output": "TEST2"
      }
    ],
    "identifier": 77600597
  },
  {
    "context": [
      "I want engine.type to become engineType.  So I'm trying to add a new field, then delete the old one:",
      "echo $json|jq '(.details[].engineType = .details[].engine.type)|del(.details[].engine.type)'",
      "But this is giving me a cartesian product:",
      "Each time you use `.details[]`, another iteration is performed (in the context of the previous one). Factor it out, and perform your operations in a subcontext. Here's an example using the update operator |=:",
      ".details[] |= (.enginetype = .engine.type | del(.engine.type))"
    ],
    "utterance": "For each object in the 'details' array, move 'engine.type' to a new field named 'engineType' and remove the original 'engine.type' field.",
    "expressions": [
      ".details[] |= (.engineType = .engine.type | del(.engine.type))"
    ],
    "data": [
      {
        "input": {
          "name": "vehicles",
          "details": [
            {
              "type": "passenger",
              "engine": {
                "type": "electric"
              }
            },
            {
              "type": "commercial",
              "engine": {
                "type": "diesel"
              }
            }
          ]
        },
        "output": {
          "name": "vehicles",
          "details": [
            {
              "type": "passenger",
              "engine": {},
              "engineType": "electric"
            },
            {
              "type": "commercial",
              "engine": {},
              "engineType": "diesel"
            }
          ]
        }
      }
    ],
    "identifier": 77610317
  },
  {
    "context": [
      "I need to add the below section in my json under ressummary",
      "So basically we just merge `insert.json` to the `ressummary`.",
      "cat input.json insert.json | jq -s \".[0] * (.[0].ressummary * .[1] | {ressummary:.})\"",
      "use `.ressummary.Check = [\u2026]` to set the `Check` field to an array as defined (or `.ressummary.Check += [\u2026]` to append to that array)",
      "jq --arg code \"$code\" '.ressummary.Check = [{Check: $ARGS.positional, $code}]' \\ \n   key.json --args \"${ccheck[@]}\""
    ],
    "utterance": "Add or update the 'Check' array containing specified objects with 'Check' and 'code' fields under the 'ressummary' object, merging new values without overwriting existing fields.",
    "expressions": [
      ".[0] * (.[0].ressummary * .[1] | {ressummary:.})",
      ".[0].ressummary += .[1] | .[0]",
      ".ressummary.Check = [{Check: $ARGS.positional, $code}]"
    ],
    "data": [
      {
        "input": {
          "resstart": 1700839261,
          "resend": 1700839965,
          "resop": "SUCCESS",
          "resurl": "http://xxxx/",
          "ressummary": {
            "value": 1,
            "expect": 0,
            "tool": "abc"
          }
        },
        "output": {
          "resstart": 1700839261,
          "resend": 1700839965,
          "resop": "SUCCESS",
          "resurl": "http://xxxx/",
          "ressummary": {
            "value": 1,
            "expect": 0,
            "tool": "abc",
            "Check": [
              {
                "Check": [
                  "A_DOG",
                  "A_CAT",
                  "A_HORSE"
                ],
                "code": "C/C++"
              }
            ]
          }
        }
      }
    ],
    "identifier": 77583221
  },
  {
    "context": [
      "I\u2019d like to update this file so that each `volumes` of each `service` to be sorted by the '.type':",
      "or what I initially did with regular ''jq''",
      "jq '.services|=with_entries(.value|=(select(has(\"volumes\")).volumes |= sort_by((.type)) ))'"
    ],
    "utterance": "For each service, sort the volumes array by the 'type' field.",
    "expressions": [
      ".services |= with_entries(.value |= (select(has(\"volumes\")).volumes |= sort_by(.type)))"
    ],
    "data": [
      {
        "input": {
          "name": "movies-docker-test",
          "services": {
            "movies-rp": {
              "volumes": [
                {
                  "type": "volume",
                  "source": "certs",
                  "target": "/etc/nginx/certs"
                },
                {
                  "type": "bind",
                  "source": "/home/nblanchet/jeudi_infra/kubernetes/okd/movies-docker-test/reverse-proxy/wikibase.conf.template",
                  "target": "/etc/nginx/templates/wikibase.conf.template"
                }
              ]
            }
          }
        },
        "output": {
          "name": "movies-docker-test",
          "services": {
            "movies-rp": {
              "volumes": [
                {
                  "type": "bind",
                  "source": "/home/nblanchet/jeudi_infra/kubernetes/okd/movies-docker-test/reverse-proxy/wikibase.conf.template",
                  "target": "/etc/nginx/templates/wikibase.conf.template"
                },
                {
                  "type": "volume",
                  "source": "certs",
                  "target": "/etc/nginx/certs"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 77629210
  },
  {
    "context": [
      "Here\u0019s a snippet of example WebVTT.",
      "\"... the desired output is produced for my example files.\"",
      "Filter requires an extra newline at the end of the file to emit the last cue.",
      "have a look at the following rewrite:",
      "You could read the entire input into one string using `jq --raw-input --slurp`, then remove all carriage return characters using `gsub(\"\\r\"; \"\")`, so from then on you only have to deal with newline characters.",
      "To partition the long string into empty-line-delimited blocks, it can be split into an array at any occurrence of at least two consecutive newline characters (i.e. at least one empty line) using the regex `\\n\\n+`. That way, it doesn't matter if there is no newline at the end. Combine it with the regex `\\n$` to also catch (and eliminate) a single newline ending: `splits(\"\\n(\\n+|$)\")`",
      "Use map to transform each item by first splitting them again into lines using /, then drop any items that had no lines using select(has(0)), and distribute the first (.[0]), second (.[1]) and all remaining lines (.[2:]) to .uid, .timeline, and .subtitles, respectively.",
      "# jq -Rs",
      "gsub(\"\\r\"; \"\") | [splits(\"\\n(\\n+|$)\")] | {\n  filename: input_filename, filetype: first,\n  cues: .[1:] | map(. / \"\\n\" | select(has(0)) | {\n    uid: .[0], timeline: .[1], subtitles: .[2:]\n  })\n}",
      "Below is a much improved filter (compared to the one in the question), that uses a small FIFO to collect each cue, and then emit it when there's a line break.",
      "Improved filter (using `--null-input --raw-input`):",
      "input | rtrimstr(\"\\r\") |\n{\n  filename: input_filename,\n  filetype: .,\n  cues: [\n    foreach inputs as $i\n      ( {fifo:[], emit: false};\n        if .emit then .emit=false|.fifo=[] else . end |\n        if ($i|test(\"^\\\\s*$\")) and (.fifo|length > 0)\n        then .emit=true\n        else\n          if ($i|test(\"^\\\\s*$\")|not)\n          then .fifo+=[$i|rtrimstr(\"\\r\")]\n          else .\n          end\n        end;\n        if .emit then {uid:.fifo[0], timeline:.fifo[1], subtitles:.fifo[2:] } else empty end\n      )\n  ]\n}\n"
    ],
    "utterance": "Parse WebVTT subtitle input where each cue consists of an ID, a timeline line, and one or more subtitle lines separated by blank lines, and produce a structured object with filename, filetype, and an array of cues with uid, timeline, and subtitles.",
    "expressions": [
      "gsub(\"\\r\"; \"\") | [splits(\"\\n(\\n+|$)\")] | {\n  filename: input_filename, filetype: first,\n  cues: .[1:] | map(. / \"\\n\" | select(has(0)) | {\n    uid: .[0], timeline: .[1], subtitles: .[2:]\n  })\n}",
      "input | rtrimstr(\"\\r\") |\n{\n  filename: input_filename,\n  filetype: .,\n  cues: [\n    foreach inputs as $i\n      ( {fifo:[], emit: false};\n        if .emit then .emit=false|.fifo=[] else . end |\n        if ($i|test(\"^\\\\s*$\")) and (.fifo|length > 0)\n        then .emit=true\n        else\n          if ($i|test(\"^\\\\s*$\")|not)\n          then .fifo+=[$i|rtrimstr(\"\\r\")]\n          else .\n          end\n        end;\n        if .emit then {uid:.fifo[0], timeline:.fifo[1], subtitles:.fifo[2:] } else empty end\n      )\n  ]\n}\n"
    ],
    "data": [
      {
        "input": "WEBVTT\r\n\r\ndc9af9e8-8909-11ee-80b1-44850052397e\r\n00:00:08.280 --> 00:00:08.880\r\nGood morning Mr. Phelps.\r\n\r\nddf6092c-8909-11ee-bc4f-44850052397e\r\n00:00:09.720 --> 00:00:12.840\r\nYour mission, should you choose to\r\naccept it,\r\n\r\ne03b2da2-8909-11ee-a212-44850052397e\r\n00:17:52.052 --> 00:17:55.586\r\nThis tape will self-destruct in 5\r\nseconds.\r\n",
        "output": {
          "filename": "<stdin>",
          "filetype": "WEBVTT",
          "cues": [
            {
              "uid": "dc9af9e8-8909-11ee-80b1-44850052397e",
              "timeline": "00:00:08.280 --> 00:00:08.880",
              "subtitles": [
                "Good morning Mr. Phelps."
              ]
            },
            {
              "uid": "ddf6092c-8909-11ee-bc4f-44850052397e",
              "timeline": "00:00:09.720 --> 00:00:12.840",
              "subtitles": [
                "Your mission, should you choose to",
                "accept it,"
              ]
            },
            {
              "uid": "e03b2da2-8909-11ee-a212-44850052397e",
              "timeline": "00:17:52.052 --> 00:17:55.586",
              "subtitles": [
                "This tape will self-destruct in 5",
                "seconds."
              ]
            }
          ]
        }
      }
    ],
    "identifier": 77529561
  },
  {
    "context": [
      "I tried to pass shell variable in cli, didn't work as below:",
      "cat /home/azure/fourkeys/deploy.json |jq  '.value[]|  \"$ENV.name, \\(.id), \\(.startTime), \\(.finishTime)\"'",
      "\"$ENV.name, 7765709, 2023-12-05T09:19:44.8090261Z, 2023-12-05T09:23:11.4171119Z\"",
      "The issue you are seeing is because of using $ENV or env inside double-quotes, which is interpolated as a string in jq and its value is emitted out literally. You need to use them inside single quotes or use the syntax for expression evaluation i.e. \\(..)",
      "jq '.value[] | \"\\($ENV.name), \\(.id), \\(.startTime), \\(.finishTime)\"'",
      "jq '$ENV.name as $v | .value[] | \"\\($v), \\(.id), \\(.startTime), \\(.finishTime)\"'"
    ],
    "utterance": "Print each item's id, startTime, and finishTime, prefixing each line with the value of the shell environment variable 'name'.",
    "expressions": [
      ".value[] | \"\\($ENV.name), \\(.id), \\(.startTime), \\(.finishTime)\"",
      "$ENV.name as $v | .value[] | \"\\($v), \\(.id), \\(.startTime), \\(.finishTime)\""
    ],
    "data": [
      {
        "input": {
          "count": 1,
          "value": [
            {
              "id": 7765709,
              "buildNumber": "20231205.2",
              "status": "completed",
              "result": "succeeded",
              "queueTime": "2023-12-05T09:19:39.1877578Z",
              "startTime": "2023-12-05T09:19:44.8090261Z",
              "finishTime": "2023-12-05T09:23:11.4171119Z",
              "url": "https://dev.azure.com/slb1-swt/68bde508-a9d3-43ca-ae50-1ad38b747a65/_apis/build/Builds/7765709"
            }
          ]
        },
        "output": "\"build, 7765709, 2023-12-05T09:19:44.8090261Z, 2023-12-05T09:23:11.4171119Z\""
      }
    ],
    "identifier": 77644442
  },
  {
    "context": [
      "Now I would like to read every `macAddress` pass it to a hash function (e.g. `md5sum`) and write the result back to the JSON document.",
      "**Desired output**\n\n```\n{\n  \"key\": \"value\",\n  \"ips\": [\n    {\n      \"ip\": \"1.2.3.4\",\n      \"macAddress\": \"45ee585278a0717c642ff2cb25a8e441\"\n    },\n    {\n      \"ip\": \"5.6.7.8\",\n      \"macAddress\": \"ab47bf90cb9f385127977569e676ce70\"\n    },\n    {\n      \"ip\": \"9.10.11.12\",\n      \"macAddress\": \"a5e9785db428e3956a47776dbd00fc91\"\n    },\n    {\n      \"ip\": \"13.14.15.16\",\n      \"macAddress\": \"f75d61937f70252ff139adee241daab4\"\n    }\n  ]\n}\n```",
      "jq -r '.ips[].macAddress' input.json |\nwhile read -r line ; do printf '%s' \"$line\" | md5 ; done |\njq -s -R --slurpfile json input.json 'split(\"\\n\")\n  | map(select(length>0))\n  | . as $in\n  | reduce range(0;length) as $i ($json; .[].ips[$i].macAddress = $in[$i])'",
      "jq -c . --stream input.json | awk '\n  BEGIN { FS = OFS = \"\\\"\" }\n  $2 == \"ips\" && $4 == \"macAddress\" && $6 {\n    \"printf %s \" $6 \" | md5sum | cut -d \\\\  -f1\" | getline $6\n  }\n  1\n' | jq -n 'fromstream(inputs)'"
    ],
    "utterance": "Replace each macAddress value in all objects of the ips array with its MD5 hash.",
    "expressions": [
      ".ips[].macAddress",
      "reduce range(0;length) as $i ($json; .[].ips[$i].macAddress = $in[$i])",
      "fromstream(inputs)",
      ".ips[] |= (.macAddress |= (external_md5_function))",
      ".ips |= map(.macAddress |= (external_md5_function))"
    ],
    "data": [
      {
        "input": {
          "key": "value",
          "ips": [
            {
              "ip": "1.2.3.4",
              "macAddress": "ac:5f:3e:87:d7:1a"
            },
            {
              "ip": "5.6.7.8",
              "macAddress": "ac:5f:3e:87:d7:2a"
            },
            {
              "ip": "9.10.11.12",
              "macAddress": "ac:5f:3e:87:d7:3a"
            },
            {
              "ip": "13.14.15.16",
              "macAddress": "42:12:20:2e:2b:ca"
            }
          ]
        },
        "output": {
          "key": "value",
          "ips": [
            {
              "ip": "1.2.3.4",
              "macAddress": "45ee585278a0717c642ff2cb25a8e441"
            },
            {
              "ip": "5.6.7.8",
              "macAddress": "ab47bf90cb9f385127977569e676ce70"
            },
            {
              "ip": "9.10.11.12",
              "macAddress": "a5e9785db428e3956a47776dbd00fc91"
            },
            {
              "ip": "13.14.15.16",
              "macAddress": "f75d61937f70252ff139adee241daab4"
            }
          ]
        }
      }
    ],
    "identifier": 77570196
  },
  {
    "context": [
      "My goal is to use `jq` to kind of iterate over key `\"data\"` and select important info about particular `\"id\"` and then some additional information related to this very `\"id\"` is also stored in this other main key `\"included\"` and it is `id`'ed via `\"ww-212121\"`.",
      "I cannot find a way how to enrich this jq so I will have the info about a branch and sender-username taken from keyword \"included\"",
      "cat example.json| jq -r '(.included | map({(.id): .}) | add)  as $inc | .data[] | {\"run-id\": .id , message: .message, \"created-by\": .\"created-by\", cv: .relationships.\"configuration-version\".data.id, branch: $inc[.relationships.\"configuration-version\".data.id].attributes.branch, \"commit-message\":$inc[.relationships.\"configuration-version\".data.id].attributes.\"commit-message\", \"sender-username\": $inc[.relationships.\"configuration-version\".data.id].attributes.\"sender-username\"  }'",
      "{\n  \"run-id\": \"run-12345\",\n  \"message\": \"some message\",\n  \"created-by\": \"me\",\n  \"cv\": \"cv-23198\",\n  \"branch\": \"prod\",\n  \"commit-message\": \"Commit message 1\",\n  \"sender-username\": \"Name Surname\"\n}",
      "{\n  \"run-id\": \"run-67891\",\n  \"message\": \"some message\",\n  \"created-by\": \"me\",\n  \"cv\": \"cv-12198\",\n  \"branch\": \"dev\",\n  \"commit-message\": \"Commit message 3\",\n  \"sender-username\": \"Joe Sur\"\n}"
    ],
    "utterance": "For each run, retrieve its id, message, created-by, the related configuration-version's id, and that version's branch, commit-message, and sender-username from included.",
    "expressions": [
      "(.included | map({(.id): .}) | add) as $inc | .data[] | {\"run-id\": .id , message: .message, \"created-by\": .\"created-by\", cv: .relationships.\"configuration-version\".data.id, branch: $inc[.relationships.\"configuration-version\".data.id].attributes.branch, \"commit-message\":$inc[.relationships.\"configuration-version\".data.id].attributes.\"commit-message\", \"sender-username\": $inc[.relationships.\"configuration-version\".data.id].attributes.\"sender-username\"  }"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "run-12345",
              "message": "some message",
              "created-by": "me",
              "attributes": {
                "is-cancelable": false,
                "is-confirmable": false,
                "is-discardable": false,
                "is-force-cancelable": false
              },
              "relationships": {
                "configuration-version": {
                  "data": {
                    "id": "cv-23198",
                    "type": "configuration-version"
                  }
                }
              }
            },
            {
              "id": "run-67891",
              "message": "some message",
              "created-by": "me",
              "attributes": {
                "is-cancelable": false,
                "is-confirmable": false,
                "is-discardable": false,
                "is-force-cancelable": false
              },
              "relationships": {
                "configuration-version": {
                  "data": {
                    "id": "cv-12198",
                    "type": "configuration-version"
                  }
                }
              }
            }
          ],
          "included": [
            {
              "id": "cv-23198",
              "type": "ingress-attributes",
              "attributes": {
                "branch": "prod",
                "clone-url": "ssh://git@github/project/repo-awesome.git",
                "commit-message": "Commit message 1",
                "commit-sha": "4444444444444444444444f601bb4bcd5e07f02a",
                "sender-username": "Name Surname"
              }
            },
            {
              "id": "cv-12198",
              "type": "ingress-attributes",
              "attributes": {
                "branch": "dev",
                "clone-url": "ssh://git@github/project/less-awesome.git",
                "commit-message": "Commit message 3",
                "commit-sha": "eeeeeeeeeeeeeeeeeeee44f601bb4bcd5e07f02a",
                "sender-username": "Joe Sur"
              }
            }
          ]
        },
        "output": [
          {
            "run-id": "run-12345",
            "message": "some message",
            "created-by": "me",
            "cv": "cv-23198",
            "branch": "prod",
            "commit-message": "Commit message 1",
            "sender-username": "Name Surname"
          },
          {
            "run-id": "run-67891",
            "message": "some message",
            "created-by": "me",
            "cv": "cv-12198",
            "branch": "dev",
            "commit-message": "Commit message 3",
            "sender-username": "Joe Sur"
          }
        ]
      }
    ],
    "identifier": 77544567
  },
  {
    "context": [
      "I need to get all the objects where the version is \"1.2.0\".",
      "if instead of 1.2.0 maybe in a short time in the future lets say I want the objects with version greater than 1.2.7 for instance?",
      "jq --arg target 1.2.0 '    map(select(.version == $target))' input.json",
      "jq --arg target 1.2.7 '    def triple($i): $i | [splits(\"[.-]\") | tonumber? // .];    map(select(triple(.version) > triple($target)))' input.json",
      "def semver:   sub(\"\\\\+.*\";\"\") | [scan(\"[^-.]+\") | tonumber? // .];",
      "(\"1.2.7\" | semver) as $v | map(select( (.version|semver) > $v))"
    ],
    "utterance": "Select all objects whose version is greater than 1.2.7.",
    "expressions": [
      "jq --arg target 1.2.7 'def triple($i): $i | [splits(\"[.-]\") | tonumber? // .]; map(select(triple(.version) > triple($target)))' input.json",
      "(\"1.2.7\" | semver) as $v | map(select( (.version|semver) > $v))",
      "map(select(.version | cmp_semver(\"1.2.7\") > 0))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "version": "2.3.4"
          },
          {
            "id": 2,
            "version": "1.4.4"
          },
          {
            "id": 3,
            "version": "0.0.4"
          },
          {
            "id": 4,
            "version": "1.3.4"
          }
        ],
        "output": [
          {
            "id": 1,
            "version": "2.3.4"
          },
          {
            "id": 2,
            "version": "1.4.4"
          },
          {
            "id": 4,
            "version": "1.3.4"
          }
        ]
      }
    ],
    "identifier": 77607580
  },
  {
    "context": [
      "So, if it's an array with at least 1 object with value's name which not start from \".\" or equal to \"README.md\".",
      "Basically, I would like to check if a repo exist and it has some content apart from the dot files and the README.",
      "This will evaluate to `false` given your first two inputs, and `true` given the third one.",
      "any(arrays[]; .name | . == \"README.md\" or startswith(\".\") | not)"
    ],
    "utterance": "Determine if there is at least one object in the array whose name does not start with a dot and is not equal to README.md.",
    "expressions": [
      "any(arrays[]; .name | . == \"README.md\" or startswith(\".\") | not)"
    ],
    "data": [
      {
        "input": {
          "message": "The repo doesn't exist"
        },
        "output": false
      },
      {
        "input": [
          {
            "name": ".dotfile"
          },
          {
            "name": ".anotherdotfile"
          },
          {
            "name": "README.md"
          }
        ],
        "output": false
      },
      {
        "input": [
          {
            "name": ".dotfile"
          },
          {
            "name": ".anotherdotfile"
          },
          {
            "name": "README.md"
          },
          {
            "name": "myscript.sh"
          },
          {
            "name": "anotherscript.sh"
          },
          {
            "name": "anotherfile.sh"
          }
        ],
        "output": true
      }
    ],
    "identifier": 77672423
  },
  {
    "identifier": 77714718
  },
  {
    "context": [
      "What I want is to add to the properties part a new key-value pair.",
      "Expected result should look like this:",
      "\"properties\": {\n  \"neighbourhood\": \"Bijlmer-Oost\",\n  \"neighbourhood_group\": null,\n  \"date_added\": \"2022-01-01\"\n}",
      "You can use:",
      "$ jq --arg dd \"$d\" '.features[].properties += {date_added: $dd}' file"
    ],
    "utterance": "Add a new key 'date_added' with a given value to every object's 'properties' field in each element of the 'features' array.",
    "expressions": [
      ".features[].properties += {date_added: $dd}"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": [
                  [
                    [
                      [
                        4.991669,
                        52.324436,
                        0
                      ]
                    ]
                  ]
                ]
              },
              "properties": {
                "neighbourhood": "Bijlmer-Oost",
                "neighbourhood_group": null
              }
            },
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": [
                  [
                    [
                      [
                        5.079162,
                        52.388654,
                        0
                      ]
                    ]
                  ]
                ]
              },
              "properties": {
                "neighbourhood": null,
                "neighbourhood_group": null
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": [
                  [
                    [
                      [
                        4.991669,
                        52.324436,
                        0
                      ]
                    ]
                  ]
                ]
              },
              "properties": {
                "neighbourhood": "Bijlmer-Oost",
                "neighbourhood_group": null,
                "date_added": "2022-01-01"
              }
            },
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": [
                  [
                    [
                      [
                        5.079162,
                        52.388654,
                        0
                      ]
                    ]
                  ]
                ]
              },
              "properties": {
                "neighbourhood": null,
                "neighbourhood_group": null,
                "date_added": "2022-01-01"
              }
            }
          ]
        }
      }
    ],
    "identifier": 77660782
  },
  {
    "context": [
      "I need to reproduce the same structure, but only for pupils 10 or older, so the output should look like this: ...",
      ".data |= map(select(.age >= 10))",
      ".data | { data: map(select(.age >= 10)) }",
      "{ data: (.data | map(select(.age >= 10))) }"
    ],
    "utterance": "Filter the array under 'data' so it only contains objects with age greater than or equal to 10, and keep the same overall structure.",
    "expressions": [
      ".data |= map(select(.age >= 10))",
      ".data | { data: map(select(.age >= 10)) }",
      "{ data: (.data | map(select(.age >= 10))) }"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "name": "Rich",
              "age": 10
            },
            {
              "name": "Michael",
              "age": 11
            },
            {
              "name": "Victoria",
              "age": 8
            },
            {
              "name": "Philip",
              "age": 9
            }
          ]
        },
        "output": {
          "data": [
            {
              "name": "Rich",
              "age": 10
            },
            {
              "name": "Michael",
              "age": 11
            }
          ]
        }
      }
    ],
    "identifier": 77699072
  },
  {
    "context": [
      "I am trying to find the right way to take the results and merge them so that there are no duplicate repo names, and their lists are concatenated.",
      "You can even collect all into one object using `reduce` instead of a mapping:\n```sh\ngh \u2026 | jq 'reduce .items[] as $i ({}; .[$i.repository.full_name] += [$i.path])'\n```",
      "If you want to have an array of separate, single-field objects, append `to_entries | map([.] | from_entries)` to sort them out."
    ],
    "utterance": "Merge search results so that each repo name appears once, with a list of all corresponding file paths.",
    "expressions": [
      "reduce .items[] as $i ({}; .[$i.repository.full_name] += [$i.path])",
      "reduce .items[] as $i ({}; .[$i.repository.full_name] += [$i.path]) | to_entries | map([.] | from_entries)"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "repository": {
                "full_name": "org-name/helm-charts"
              },
              "path": "README.md"
            },
            {
              "repository": {
                "full_name": "org-name/repo-name"
              },
              "path": "file-name-1.py"
            },
            {
              "repository": {
                "full_name": "org-name/repo-name"
              },
              "path": "file-name-2.py"
            }
          ]
        },
        "output": {
          "org-name/helm-charts": [
            "README.md"
          ],
          "org-name/repo-name": [
            "file-name-1.py",
            "file-name-2.py"
          ]
        }
      },
      {
        "input": {
          "items": [
            {
              "repository": {
                "full_name": "org-name/helm-charts"
              },
              "path": "README.md"
            },
            {
              "repository": {
                "full_name": "org-name/repo-name"
              },
              "path": "file-name-1.py"
            },
            {
              "repository": {
                "full_name": "org-name/repo-name"
              },
              "path": "file-name-2.py"
            }
          ]
        },
        "output": [
          {
            "org-name/helm-charts": [
              "README.md"
            ]
          },
          {
            "org-name/repo-name": [
              "file-name-1.py",
              "file-name-2.py"
            ]
          }
        ]
      }
    ],
    "identifier": 77679117
  },
  {
    "context": [
      "I have a following array",
      "I am trying to get the following output of it:",
      "2.16.1.0-2.16.1.255",
      "2.16.3.0-2.16.3.255",
      "2.16.6.0-2.16.7.255",
      "You could select the first 2 items in the array (`.[0:2]`) and then [`join()`][1] that with a `-`.",
      ".data[] | .[0:2] | join(\"-\")",
      ".data[] | .[:-1] | join(\"-\")",
      "jq -r '.data[] | \"\\(.[0])-\\(.[1])\"'",
      "jq -r '.data[] | .[0] + \"-\" + .[1]'"
    ],
    "utterance": "For each element of the 'data' array, join the first two values with a dash.",
    "expressions": [
      ".data[] | .[0:2] | join(\"-\")",
      ".data[] | .[:-1] | join(\"-\")",
      ".data[] | \"\\(.[0])-\\(.[1])\"",
      ".data[] | .[0] + \"-\" + .[1]"
    ],
    "data": [
      {
        "input": {
          "data": [
            [
              "2.16.1.0",
              "2.16.1.255",
              "256"
            ],
            [
              "2.16.3.0",
              "2.16.3.255",
              "256"
            ],
            [
              "2.16.6.0",
              "2.16.7.255",
              "512"
            ]
          ]
        },
        "output": [
          "2.16.1.0-2.16.1.255",
          "2.16.3.0-2.16.3.255",
          "2.16.6.0-2.16.7.255"
        ]
      }
    ],
    "identifier": 77680411
  },
  {
    "context": [
      "But unfortunately it isnt producing a valid jq path if there is an object key is a number.",
      "The path to the object key needs to be quoted to be correctly handled, but I cant seem to get the syntax correct.",
      "The correct filter should be:\n.\":00\"",
      "This is how I would create the desired output:",
      "`tostream` produces a stream of path-only items and path-value pairs; filter for those having a value (using `select(has(1))`) to get the scalars (alternatively, use `paths(scalars)` and `getpath`)",
      "in the path array, strings represent object fields, numbers represent array indices; convert them separately using `strings` and `numbers`, respectively, then prepend the dot (since jq 1.7, a dot preceding array indices in brackets is valid syntax even in concatenated expressions)",
      "```sh\n tostream | select(has(1))  # or: paths(scalars) as $p | [$p, getpath($p)]\n| \"\\(first | map(\".\\(\"[\\(numbers)]\" // strings|=@json)\") | add) = \\(last|@json)\"\n```"
    ],
    "utterance": "List all paths and their scalar values, ensuring object keys that are numeric strings are quoted in the path.",
    "expressions": [
      "tostream | select(has(1)) | \"\\(first | map(\".\\(\"[\\(numbers)]\" // strings|=@json)\") | add) = \\(last|@json)\""
    ],
    "data": [
      {
        "input": {
          "00": "a"
        },
        "output": ".\"00\" = \"a\""
      },
      {
        "input": {
          "00": {
            "02": "a",
            "banana": "foo"
          }
        },
        "output": [
          ".\"00\".\"02\" = \"a\"",
          ".\"00\".banana = \"foo\""
        ]
      }
    ],
    "identifier": 77672251
  },
  {
    "context": [
      "I want ``jq`` command to print the \"count\" field.",
      "jq '.\"solr.jetty\".\"org.eclipse.jetty.server.handler.DefaultHandler.requests\".count'",
      "If you want to minimize typing, consider:",
      "..|.count? // empty"
    ],
    "utterance": "Extract the value of the count field located under solr.jetty -> org.eclipse.jetty.server.handler.DefaultHandler.requests.",
    "expressions": [
      ".\"solr.jetty\".\"org.eclipse.jetty.server.handler.DefaultHandler.requests\".count",
      "..|.count? // empty"
    ],
    "data": [
      {
        "input": {
          "solr.jetty": {
            "org.eclipse.jetty.server.handler.DefaultHandler.requests": {
              "count": 432742,
              "meanRate": 0.1393530774422645,
              "1minRate": 0.1582358234691172,
              "5minRate": 0.24472281886082692,
              "15minRate": 0.32856666658514566,
              "min_ms": 0,
              "max_ms": 124,
              "mean_ms": 19.05039312538189,
              "median_ms": 1,
              "stddev_ms": 27.68447649619781,
              "p75_ms": 61,
              "p95_ms": 63,
              "p99_ms": 64,
              "p999_ms": 67
            }
          }
        },
        "output": 432742
      }
    ],
    "identifier": 77727557
  },
  {
    "context": [
      "I want to use \"jq\" to get the docker image name and version from \"RepoTags\":",
      "jq -r '[0].RepoTags[0]' manifest.json",
      "Or more robustly:\n\n    ..|.RepoTags? // empty | .[]"
    ],
    "utterance": "Extract all image names and versions listed in all RepoTags fields within the file.",
    "expressions": [
      ".[0].RepoTags[0]",
      "..|.RepoTags?[]",
      "..|.RepoTags? // empty | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "Config": "a5a29aeb4d6a28cb5a0b759572ae5696f0a99a4be39aa4de08d8a897e6d12b95.json",
            "RepoTags": [
              "hello/world:latest"
            ],
            "Layers": [
              "b0e93b0b2e63771ea0cd34f350681b4397c804e5ed5ba01aec23cfaf6c49bc51/layer.tar",
              "f9b7caaf240b159e636f77a9571073f6e4d5a0541d864ec64e4e2808b282e302/layer.tar",
              "1355029c32eee25981e17b0e89e946d9346cffdff29ff53858104ebfe6728d80/layer.tar",
              "362092bb6a9ed18c0e88a9b1635e7c16914661935ce64f1b581d19fd5226463a/layer.tar",
              "fe2bde379de2f44bb47d5d75a25294485f70d8b4c7a99a08b0fcef8f4076914d/layer.tar",
              "4acfd2b9473bf5c17f50ad2ff04c148b1be79d1174509e0fb10d27ba8cff9294/layer.tar",
              "e5131e82e66e45e002a88618254c1cde43a497d8a94fcb5d9b20171f19b15b96/layer.tar"
            ]
          }
        ],
        "output": [
          "hello/world:latest"
        ]
      }
    ],
    "identifier": 77726749
  },
  {
    "context": [
      "I would like to take an existing JSON object and use `jq` to add/update two additional values to it.",
      "I can set either `a` or `b` with two back to back commands like so `echo {} | jq '.a=1' | jq '.b=2'`. But I was wondering if there is a way to make only a single `jq` call to do both operations?",
      "you can separate multiple field assignments with commas in a single expression ",
      "`echo {} | jq '.a = 1, .b = 2'`",
      "no matter the input, jq will overwrite these values if present.",
      "# Output: {\"a\":1,\"b\":2}"
    ],
    "utterance": "Set both fields a and b to 1 and 2, respectively, on any input, overwriting existing values.",
    "expressions": [
      ".a = 1 | .b = 2",
      ".a = 1 | .b = 2",
      "{a: 1, b: 2}"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "a": 1,
          "b": 2
        }
      },
      {
        "input": {
          "a": 42
        },
        "output": {
          "a": 1,
          "b": 2
        }
      },
      {
        "input": {
          "a": "hello"
        },
        "output": {
          "a": 1,
          "b": 2
        }
      },
      {
        "input": {
          "b": "qwerty"
        },
        "output": {
          "a": 1,
          "b": 2
        }
      }
    ],
    "identifier": 77789650
  },
  {
    "context": [
      "aws iam list-users | jq.Reservations[].functions[].UserId",
      "jq: error (at <stdin>:18): Cannot iterate over null (null)",
      "You could sprinkle postfix \"?\"s in your query, though exactly how will of course depend on your requirements.",
      "Here's an example:",
      "jq '.Reservations[]?.functions[]?.UserId'",
      "To understand this, note that if E is some jq expression, then `(E)?` is like `try E catch empty`."
    ],
    "utterance": "Extract all UserId fields from functions inside Reservations, safely handling cases where Reservations or functions may be null or missing.",
    "expressions": [
      ".Reservations[]?.functions[]?.UserId"
    ],
    "identifier": 77799635
  },
  {
    "context": [
      "try to get all parents who have the \"linux-image-amd64\"",
      "I tried jq -r 'keys[] as $k | \"\\($k) \\(.[$k].\\\"linux-image-amd64\\\")\"' but I just got one entry instead of two",
      "You should check if the context has that key. Also, to prevent the string from failing when trying to apply has on it, either filter for objects, or suppress the error with ?. In either case, use this condition to filter the results using select.",
      "keys[] as $k | .[$k] | select(has(\"linux-image-amd64\")?) | $k",
      "lmrelaunch.example.de\nweb-prode-04.example.de"
    ],
    "utterance": "List all top-level keys whose value contains the key \"linux-image-amd64\".",
    "expressions": [
      "keys[] as $k | .[$k] | select(has(\"linux-image-amd64\")?) | $k"
    ],
    "data": [
      {
        "input": {
          "web-prode-01.example.de": "ERROR: Problem encountered installing package(s). Additional info follows:\n\nchanges:\n    ----------\n    linux-image-amd64:\n        ----------\n        new:\n        old:\n            6.1.55-1\nerrors:\n    - Running scope as unit: run-rad31bddd35ec452b9d67fef004ce3daf.scope\n      E: Sub-process /usr/bin/dpkg returned an error code (1)",
          "web-prode-04.example.de": {
            "linux-image-amd64": {
              "old": "5.10.197-1",
              "new": "5.10.205-2"
            },
            "linux-image-5.10.0-27-amd64": {
              "old": "",
              "new": "5.10.205-2"
            }
          },
          "lmrelaunch.example.de": {
            "linux-image-6.1.0-0.deb11.13-amd64": {
              "old": "",
              "new": "6.1.55-1~bpo11+1"
            },
            "linux-image-amd64": {
              "old": "6.1.38-4~bpo11+1",
              "new": "6.1.55-1~bpo11+1"
            }
          }
        },
        "output": [
          "web-prode-04.example.de",
          "lmrelaunch.example.de"
        ]
      }
    ],
    "identifier": 77786240
  },
  {
    "context": [
      "I want a transformed json like this using jq commands",
      "{\n\"innerList\": [\n        {\"id\": 1, \"rootElement\": \"root\", \"value\": \"A\"\n        },\n        {\"id\": 2, \"rootElement\": \"root\", \"value\": \"B\"\n        },\n        {\"id\": 3, \"rootElement\": \"root\", \"value\": \"C\"\n        }\n    ],\n \"rootElement\": \"root\"\n}",
      ".parent | .innerList[] += {rootElement}",
      ".parent\n| .rootElement as $rootElement\n| .innerList[] += {$rootElement}",
      "| .innerList[] |= {$rootElement} + ."
    ],
    "utterance": "For each object in innerList, add a rootElement field with the value \"root\" and output an object containing both innerList (with augmented objects) and rootElement at the top level.",
    "expressions": [
      ".parent | .innerList[] += {rootElement}",
      ".parent | .rootElement as $rootElement | .innerList[] += {$rootElement}",
      ".parent | .rootElement as $rootElement | .innerList[] |= {$rootElement} + ."
    ],
    "data": [
      {
        "input": {
          "parent": {
            "rootElement": "root",
            "innerList": [
              {
                "id": 1,
                "value": "A"
              },
              {
                "id": 2,
                "value": "B"
              },
              {
                "id": 3,
                "value": "C"
              }
            ]
          }
        },
        "output": {
          "rootElement": "root",
          "innerList": [
            {
              "id": 1,
              "value": "A",
              "rootElement": "root"
            },
            {
              "id": 2,
              "value": "B",
              "rootElement": "root"
            },
            {
              "id": 3,
              "value": "C",
              "rootElement": "root"
            }
          ]
        }
      }
    ],
    "identifier": 77799300
  },
  {
    "context": [
      "I want to be able to create dynamicc partitioning using uuid.",
      "But perhaps this is what you want.",
      "jq '{ id, \"users\": .users[] }'"
    ],
    "utterance": "Output each record so that for every user, the result contains the id and a single-element users array with that user.",
    "expressions": [
      "{ id, \"users\": [ .users[] ] }",
      "{ id, users: [ .users[] ] }",
      "{ id, users: [ .users[] ] }"
    ],
    "data": [
      {
        "input": [
          {
            "id": 20,
            "users": [
              {
                "uuid": 2330,
                "first": "Stevie",
                "last": "Wonder"
              },
              {
                "uuid": 9033131,
                "first": "Michael",
                "last": "Jackson"
              }
            ]
          },
          {
            "id": 30,
            "users": [
              {
                "uuid": 984209302,
                "first": "lower",
                "last": "harvest"
              },
              {
                "uuid": 8980323932,
                "first": "Duncan",
                "last": "mighty"
              }
            ]
          }
        ],
        "output": [
          {
            "id": 20,
            "users": [
              {
                "uuid": 2330,
                "first": "Stevie",
                "last": "Wonder"
              }
            ]
          },
          {
            "id": 20,
            "users": [
              {
                "uuid": 9033131,
                "first": "Michael",
                "last": "Jackson"
              }
            ]
          },
          {
            "id": 30,
            "users": [
              {
                "uuid": 984209302,
                "first": "lower",
                "last": "harvest"
              }
            ]
          },
          {
            "id": 30,
            "users": [
              {
                "uuid": 8980323932,
                "first": "Duncan",
                "last": "mighty"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 77809442
  },
  {
    "context": [
      "An example is to return objects that have both \"value-1\" and \"value-2\" in the \"field\" property, using jq.",
      ".[] | select(.field as $field | [\"value-1\", \"value-3\"] | all(IN($field[])))",
      "Here is a reformatted version of it:\n.[] | select(. as {$field} | all(\"value-1\", \"value-3\"; IN($field[])))",
      ".[] | select([\"value-1\", \"value-3\"] - .field == [])"
    ],
    "utterance": "Select objects whose field contains all of the values 'value-1' and 'value-3'.",
    "expressions": [
      ".[] | select(.field as $field | [\"value-1\", \"value-3\"] | all(IN($field[])))",
      ".[] | select(. as {$field} | all(\"value-1\", \"value-3\"; IN($field[])))",
      ".[] | select([\"value-1\", \"value-3\"] - .field == [])"
    ],
    "data": [
      {
        "input": [
          {
            "field": [
              "value-1",
              "value-2",
              "value-3"
            ]
          },
          {
            "field": [
              "value-1",
              "value-2",
              "value-34"
            ]
          },
          {
            "field": [
              "value-3",
              "value-1",
              "value-4",
              "value-5"
            ]
          }
        ],
        "output": [
          {
            "field": [
              "value-1",
              "value-2",
              "value-3"
            ]
          },
          {
            "field": [
              "value-3",
              "value-1",
              "value-4",
              "value-5"
            ]
          }
        ]
      }
    ],
    "identifier": 77812664
  },
  {
    "context": [
      "I have a JSON which looks like this",
      "And I want something like this",
      "And I want something like this\n\n```json\n[\n  {\n    \"name\": \"test_name\",\n    \"cpu\": \"1\",\n    \"ip\": [\n\t\t\"192.168.0.1\",\n\t\t\"192.168.0.2\"\n\t],\n\t\"key_value\": [\n\t\t{\n\t\t\t\"test1_key\": \"test1_value\",\n\t\t\t\"test2_key\": \"test2_value\",\n\t\t\t\"test3_key\": \"test3_value\"\n\t\t}\n\t],\n    \"location\": \"here\"\n  }\n]\n```",
      "You can try:\n\n```bash\n$ jq 'group_by(.name) \n| map(first + {ip: map(.ip) | unique} \n            + {key: map(.kv_key) | unique}\n            + {value: map(.kv_value) | unique}) \n| map(. + {key_value: [.key,.value] | transpose | map({(.[0]):.[1]}) | add}) \n| map(del(.key,.value,.kv_key,.kv_value))' file\n\n[\n  {\n    \"name\": \"test_name\",\n    \"cpu\": \"1\",\n    \"ip\": [\n      \"192.168.0.1\",\n      \"192.168.0.2\"\n    ],\n    \"location\": \"here\",\n    \"key_value\": {\n      \"test1_key\": \"test1_value\",\n      \"test2_key\": \"test2_value\",\n      \"test3_key\": \"test3_value\"\n    }\n  }\n]\n```",
      "map(del(.kv_key, .kv_value) + {key_value: {(.kv_key): .kv_value}})\n| group_by(.name) | map(map(to_entries) | transpose | map(first + {value: (\n    map(.value) | unique | select(all(type == \"object\")) |= [add]\n    | select(has(1)) // first\n  )}) | from_entries)",
      "group_by(.name)\n| map(\n    reduce .[] as $e(\n        first | del(.ip, .kv_key, .kv_value);\n        .ip += [ $e.ip ]\n        | .key_value[$e.kv_key] = $e.kv_value\n    )\n    | .ip |= unique\n)"
    ],
    "utterance": "Merge all objects with the same name into one, collect their unique ip addresses into an array, and group their kv_key/kv_value pairs into a key_value object mapping kv_key to kv_value.",
    "expressions": [
      "group_by(.name) \n| map(first + {ip: map(.ip) | unique} \n            + {key: map(.kv_key) | unique}\n            + {value: map(.kv_value) | unique}) \n| map(. + {key_value: [.key,.value] | transpose | map({(.[0]):.[1]}) | add}) \n| map(del(.key,.value,.kv_key,.kv_value))",
      "map(del(.kv_key, .kv_value) + {key_value: {(.kv_key): .kv_value}})\n| group_by(.name) | map(map(to_entries) | transpose | map(first + {value: (\n    map(.value) | unique | select(all(type == \"object\")) |= [add]\n    | select(has(1)) // first\n  )}) | from_entries)",
      "group_by(.name)\n| map(\n    reduce .[] as $e(\n        first | del(.ip, .kv_key, .kv_value);\n        .ip += [ $e.ip ]\n        | .key_value[$e.kv_key] = $e.kv_value\n    )\n    | .ip |= unique\n)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "test_name",
            "cpu": "1",
            "ip": "192.168.0.1",
            "kv_key": "test2_key",
            "kv_value": "test2_value",
            "location": "here"
          },
          {
            "name": "test_name",
            "cpu": "1",
            "ip": "192.168.0.2",
            "kv_key": "test1_key",
            "kv_value": "test1_value",
            "location": "here"
          },
          {
            "name": "test_name",
            "cpu": "1",
            "ip": "192.168.0.1",
            "kv_key": "test2_key",
            "kv_value": "test2_value",
            "location": "here"
          },
          {
            "name": "test_name",
            "cpu": "1",
            "ip": "192.168.0.1",
            "kv_key": "test3_key",
            "kv_value": "test3_value",
            "location": "here"
          }
        ],
        "output": [
          {
            "name": "test_name",
            "cpu": "1",
            "ip": [
              "192.168.0.1",
              "192.168.0.2"
            ],
            "location": "here",
            "key_value": {
              "test1_key": "test1_value",
              "test2_key": "test2_value",
              "test3_key": "test3_value"
            }
          }
        ]
      }
    ],
    "identifier": 77652021
  },
  {
    "context": [
      "Input:\r\n\r\n    {\r\n      \"level1\": {\r\n        \"id\": \"a\"\r\n      },\r\n      \"level2\": [\r\n        {\r\n          \"id\": \"1\"\r\n        },\r\n        {\r\n          \"id\": \"2\"\r\n        }\r\n      ]\r\n    }\r\n    {\r\n      \"level1\": {\r\n        \"id\": \"b\"\r\n      },\r\n      \"level2\": [\r\n        {\r\n          \"id\": \"3\"\r\n        },\r\n        {\r\n          \"id\": \"4\"\r\n        }\r\n      ]\r\n    }\r\n",
      "Expected output:\r\n\r\n    a  1 \r\n    a  2 \r\n    b  3 \r\n    b  4 \r\n",
      "where .level1.id repeats for every object in the .level2 array",
      "Separate them to iterate outside another array, make both parts create (sub)arrays themselves, then add them together:\r\n```sh\r\n[.level1.id] + (.level2[] | [.id]) | @tsv\r\n```",
      "Alternatively, use variables which you can reference from inside the array constructor:\r\n```sh\r\n.level2[] as {$id} | [.level1.id, $id] | @tsv\r\n```",
      "Output:\r\n```\r\na\t1\r\na\t2\r\nb\t3\r\nb\t4\r\n```"
    ],
    "utterance": "For each top-level object, output every combination of that object's level1.id and each level2[].id as tab-separated values, repeating the level1.id for every level2 entry.",
    "expressions": [
      "[.level1.id] + (.level2[] | [.id]) | @tsv",
      ".level2[] as $x | [.level1.id, $x.id] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "level1": {
              "id": "a"
            },
            "level2": [
              {
                "id": "1"
              },
              {
                "id": "2"
              }
            ]
          },
          {
            "level1": {
              "id": "b"
            },
            "level2": [
              {
                "id": "3"
              },
              {
                "id": "4"
              }
            ]
          }
        ],
        "output": "a\t1\na\t2\nb\t3\nb\t4"
      }
    ],
    "identifier": 77848300
  },
  {
    "context": [
      "I am trying to write a JMSEpath query to return a list of Instances that's 90days old returning instances ID number, Launch Tine and the Instance Tag name if not null.",
      "The following works for me:\n\n```\n$ aws ec2 describe-instances --query \"Reservations[].Instances[?LaunchTime<='$(date --date='-90 days' '+%Y-%m-%d')']\" | jq -r '.[] | .[] | (.InstanceId + \",\" + .LaunchTime) + \",\" + (.Tags[] | .Key + \"=\" + .Value)'\ni-08e56acf,2020-04-12T11:37:18+00:00,RemoveNote=DoNotDelete\ni-08e56acf,2020-04-12T11:37:18+00:00,AlwaysOn=True\ni-08e56acf,2020-04-12T11:37:18+00:00,Name=AD-US\n```\nNote that I put a comma (\",\") between the fields, and an equal (\"=\") between the key and its value."
    ],
    "utterance": "List all instances older than 90 days, showing their instance ID, launch time, and all tags as key=value pairs.",
    "expressions": [
      ".[] | .[] | (.InstanceId + \",\" + .LaunchTime) + \",\" + (.Tags[] | .Key + \"=\" + .Value)"
    ],
    "identifier": 77848822
  },
  {
    "context": [
      "In the new json is an array with one entry, which needs to remain the first entry in the array. With jq generate additional entries to this arrays.",
      "My desired result would be the following:\n\n{\n  \"sections\": [\n    {\n      \"first\": \"element\",\n      \"that\": \"is needed at pos 0 in this array\"\n    },\n    {\n      \"markdown\": true,\n      \"facts\": [\n        {\n          \"name\": \"MyFoo\",\n          \"value\": \" bar\"\n        }\n      ]\n    },\n    {\n      \"markdown\": true,\n      \"facts\": [\n        {\n          \"name\": \"MyFoo\",\n          \"value\": \"bing\"\n        }\n      ]\n    }\n  ]\n}",
      "Something like this?\n\n$ echo '{\"Results\": [{\"Input\": [{\"foo\":\" bar\", \"this\": \"that\"}, {\"foo\": \"bing\"}]}]}' | \\\n  jq '{sections: ([{first: \"element\", that: \"is needed at pos 0 in this array\"}] + [.Results[].Input[] | { markdown: true, facts: [ { name: \"MyFoo\", value: .foo }]}])}'",
      "The solution is simple: wrap the pipeline that processes the input in parentheses and it will work.",
      "{\n  sections: [\n    { first: \"element\", that: \"is needed at pos 0 in this array\" },\n    (.Results[] | .Input[]? | { markdown: true, facts: [{ name: \"MyFoo\", value: .foo }]})\n  ]\n}"
    ],
    "utterance": "Create an object with a sections array where the first element is a fixed object and the remaining items are generated from each .Results[].Input[] entry as objects with markdown: true and facts containing name as MyFoo and the value from .foo.",
    "expressions": [
      "{sections: ([{first: \"element\", that: \"is needed at pos 0 in this array\"}] + [.Results[].Input[] | { markdown: true, facts: [ { name: \"MyFoo\", value: .foo }]}])}",
      "{\n  sections: [\n    { first: \"element\", that: \"is needed at pos 0 in this array\" },\n    (.Results[] | .Input[]? | { markdown: true, facts: [{ name: \"MyFoo\", value: .foo }]})\n  ]\n}"
    ],
    "data": [
      {
        "input": {
          "Results": [
            {
              "Input": [
                {
                  "foo": " bar",
                  "this": "that"
                },
                {
                  "foo": "bing"
                }
              ]
            }
          ]
        },
        "output": {
          "sections": [
            {
              "first": "element",
              "that": "is needed at pos 0 in this array"
            },
            {
              "markdown": true,
              "facts": [
                {
                  "name": "MyFoo",
                  "value": " bar"
                }
              ]
            },
            {
              "markdown": true,
              "facts": [
                {
                  "name": "MyFoo",
                  "value": "bing"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 77794243
  },
  {
    "context": [
      "However introducing a single whitespace character causes an error",
      "BAD_JSON='{\"key\": $VALUE}';",
      "echo $(jq -n --arg VALUE \"$VALUE\" $BAD_JSON)",
      "jq: error: syntax error, unexpected end of file (Unix shell quoting issues?)"
    ],
    "utterance": "Parse a parameterized object using a variable for the value of key, where the variable is referenced in the jq program and passed with --arg.",
    "expressions": [
      "jq -n --arg VALUE \"$VALUE\" '{\"key\":$VALUE}'"
    ],
    "data": [
      {
        "input": {
          "VALUE": "1234"
        },
        "output": {
          "key": "1234"
        }
      }
    ],
    "identifier": 77852580
  },
  {
    "context": [
      "I\u2019m looking for the display-name, id, memory-in-gbs.",
      "I can gain the display-name and id with relative ease.",
      "I can collect the memory-in-gbs as well with the following.",
      "I\u2019m unable to get them together. The output from above will contain multiple iterations of the above data for each vm.",
      "The end goal should look like this:\ndisplay-name\nid\nmemory",
      "Into an array, for example, using the array constructor []:\n.data[] | [\n  .\"display-name\",\n  .\"id\",\n  .\"shape-config\".\"memory-in-gbs\"\n]",
      "Or into an object, using the object constructor {}:\n.data[]| {\n  \"display-name\": .\"display-name\",\n  \"id\": .\"id\",\n  \"memory\": .\"shape-config\".\"memory-in-gbs\"\n}",
      "If you want to collect them into an array, either wrap this in an outer array just as we did before:\n[ .data[] | [ \u2026 ] ]\n# or\n[ .data[] | { \u2026 } ]",
      "Or use the equivalent map shortcut, which performs the iteration automatically (so you can strip [] from .data):\n.data | map( [ \u2026 ] )\n# or\n.data | map( { \u2026 } )"
    ],
    "utterance": "Select display-name, id, and shape-config.memory-in-gbs together for each item, outputting each as an object or array.",
    "expressions": [
      ".data[] | [ .\"display-name\", .\"id\", .\"shape-config\".\"memory-in-gbs\" ]",
      ".data[] | { \"display-name\": .\"display-name\", \"id\": .\"id\", \"memory\": .\"shape-config\".\"memory-in-gbs\" }",
      "[ .data[] | [ .\"display-name\", .\"id\", .\"shape-config\".\"memory-in-gbs\" ] ]",
      "[ .data[] | { \"display-name\": .\"display-name\", \"id\": .\"id\", \"memory\": .\"shape-config\".\"memory-in-gbs\" } ]",
      ".data | map( [ .\"display-name\", .\"id\", .\"shape-config\".\"memory-in-gbs\" ] )",
      ".data | map( { \"display-name\": .\"display-name\", \"id\": .\"id\", \"memory\": .\"shape-config\".\"memory-in-gbs\" } )"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "agent-config": null,
              "availability-config": {
                "is-live-migration-preferred": null,
                "recovery-action": "RESTORE_INSTANCE"
              },
              "availability-domain": "AD",
              "capacity-reservation-id": null,
              "compartment-id": "ocid1.compartment.",
              "dedicated-vm-host-id": null,
              "defined-tags": {},
              "display-name": "TEST-VM",
              "extended-metadata": null,
              "fault-domain": "FAULT-DOMAIN",
              "freeform-tags": {},
              "id": "ocid1.instance.",
              "image-id": "ocid1.image.",
              "instance-options": {
                "are-legacy-imds-endpoints-disabled": false
              },
              "ipxe-script": null,
              "launch-mode": "PARAVIRTUALIZED",
              "launch-options": {
                "boot-volume-type": "PARAVIRTUALIZED",
                "firmware": "BIOS",
                "is-consistent-volume-naming-enabled": false,
                "is-pv-encryption-in-transit-enabled": false,
                "network-type": "PARAVIRTUALIZED",
                "remote-data-volume-type": "PARAVIRTUALIZED"
              },
              "lifecycle-state": "STOPPED",
              "metadata": {
                "ssh_authorized_keys": "lots_of_random"
              },
              "platform-config": null,
              "preemptible-instance-config": null,
              "region": "2nd-reg",
              "shape": "Standard1.1",
              "shape-config": {
                "baseline-ocpu-utilization": null,
                "gpu-description": null,
                "gpus": null,
                "local-disk-description": null,
                "local-disks": null,
                "local-disks-total-size-in-gbs": null,
                "max-vnic-attachments": 2,
                "memory-in-gbs": 16.0,
                "networking-bandwidth-in-gbps": 24.6,
                "ocpus": 1.0,
                "processor-description": null
              },
              "source-details": {
                "boot-volume-size-in-gbs": null,
                "boot-volume-vpus-per-gb": null,
                "image-id": "ocid1.image.",
                "kms-key-id": null,
                "source-type": "image"
              },
              "system-tags": null,
              "time-created": "2022-10-27T19:43:33.651460+00:00",
              "time-maintenance-reboot-due": null
            }
          ]
        },
        "output": [
          {
            "display-name": "TEST-VM",
            "id": "ocid1.instance.",
            "memory": 16.0
          }
        ]
      }
    ],
    "identifier": 77821502
  },
  {
    "context": [
      "Whenever a key/value gets repeated, rather than removing it, would want to add an additional key/value into that particular element as shown below",
      "The desired output would be:",
      "  {\r\n    \"foo\": \"bar\",\r\n    \"id\": \"noot\",\r\n    \"desc\": \"1st duplicate found\r\n  },",
      "reduce .[] as $kv ({ ans: [], count: {}};\r\n  ($kv|del(.id)|tostring) as $pair\r\n  | .count[$pair] += 1\r\n  | .count[$pair] as $count\r\n  | if $count == 1 then .ans += [$kv]\r\n    else .ans += [$kv + {desc: \"duplicate #\\($count) of \\($pair)\"} ]\r\n    end)\r\n  | .ans",
      "Sample output:",
      "{\r\n    \"foo\": \"bar\",\r\n    \"id\": \"noot\",\r\n    \"desc\": \"duplicate #2 of {\\\"foo\\\":\\\"bar\\\"}\"\r\n  },"
    ],
    "utterance": "For each object where the non-id fields have key/value pairs seen previously, add a desc key indicating it is a duplicate and its count in the sequence.",
    "expressions": [
      "reduce .[] as $kv ({ ans: [], count: {}};\n  ($kv|del(.id)|tostring) as $pair\n  | .count[$pair] += 1\n  | .count[$pair] as $count\n  | if $count == 1 then .ans += [$kv]\n    else .ans += [$kv + {desc: \"duplicate #\\($count) of \\($pair)\"} ]\n    end)\n  | .ans"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "bar",
            "id": "baz"
          },
          {
            "thud": "grunt",
            "id": "fum"
          },
          {
            "foo": "bar",
            "id": "noot"
          },
          {
            "zot": "toto",
            "id": "pluto"
          },
          {
            "foo": "bar",
            "id": "toto"
          }
        ],
        "output": [
          {
            "foo": "bar",
            "id": "baz"
          },
          {
            "thud": "grunt",
            "id": "fum"
          },
          {
            "foo": "bar",
            "id": "noot",
            "desc": "duplicate #2 of {\"foo\":\"bar\"}"
          },
          {
            "zot": "toto",
            "id": "pluto"
          },
          {
            "foo": "bar",
            "id": "toto",
            "desc": "duplicate #3 of {\"foo\":\"bar\"}"
          }
        ]
      }
    ],
    "identifier": 77848480
  },
  {
    "identifier": 77864613
  },
  {
    "context": [
      "How do I convert this into an array and sort it by `Tag`.  In the end I want something like this.",
      "Just iterate over the (outer) object's items using `.[]`, and collect them into a new array by surrounding with `[\u2026]`; or use `map(.)` with the same effect. The sorting can then be achieved using `sort_by(.Tag)`.",
      "jq '[.[]] | sort_by(.Tag)' input.json",
      "jq 'map(.) | sort_by(.Tag)' input.json"
    ],
    "utterance": "Convert an object to an array of its values and sort the array by the Tag field.",
    "expressions": [
      "[.[]] | sort_by(.Tag)",
      "map(.) | sort_by(.Tag)",
      "to_entries | map(.value) | sort_by(.Tag)"
    ],
    "data": [
      {
        "input": {
          "1eba648810a9": {
            "ID": "1eba648810a9",
            "Tag": "1.0.237"
          },
          "2df272728204": {
            "ID": "2df272728204",
            "Tag": "1.0.243"
          },
          "2f5a63db6634": {
            "ID": "2f5a63db6634",
            "Tag": "1.0.179"
          },
          "91a86fec59b1": {
            "ID": "91a86fec59b1",
            "Tag": "1.0.202"
          },
          "9aa95de44891": {
            "ID": "9aa95de44891",
            "Tag": "1.0.189"
          },
          "a1caaccdba45": {
            "ID": "a1caaccdba45",
            "Tag": "1.0.183"
          },
          "a35ad9d93e62": {
            "ID": "a35ad9d93e62",
            "Tag": "1.0.42"
          },
          "a4e57f2db7eb": {
            "ID": "a4e57f2db7eb",
            "Tag": "1.0.181"
          },
          "d0254d6406e0": {
            "ID": "d0254d6406e0",
            "Tag": "1.0.253"
          },
          "ddeeb3d41a4c": {
            "ID": "ddeeb3d41a4c",
            "Tag": "1.0.177"
          },
          "f92356a49d78": {
            "ID": "f92356a49d78",
            "Tag": "1.0.178"
          }
        },
        "output": [
          {
            "ID": "ddeeb3d41a4c",
            "Tag": "1.0.177"
          },
          {
            "ID": "f92356a49d78",
            "Tag": "1.0.178"
          },
          {
            "ID": "2f5a63db6634",
            "Tag": "1.0.179"
          },
          {
            "ID": "a4e57f2db7eb",
            "Tag": "1.0.181"
          },
          {
            "ID": "a1caaccdba45",
            "Tag": "1.0.183"
          },
          {
            "ID": "9aa95de44891",
            "Tag": "1.0.189"
          },
          {
            "ID": "91a86fec59b1",
            "Tag": "1.0.202"
          },
          {
            "ID": "1eba648810a9",
            "Tag": "1.0.237"
          },
          {
            "ID": "2df272728204",
            "Tag": "1.0.243"
          },
          {
            "ID": "d0254d6406e0",
            "Tag": "1.0.253"
          },
          {
            "ID": "a35ad9d93e62",
            "Tag": "1.0.42"
          }
        ]
      }
    ],
    "identifier": 77764999
  },
  {
    "context": [
      "I\u2019d like to transform any mountpath ending with an extension into a mountPath pointing to a  corresponding 'configMaps' object that itself replaces the pre-existing associated 'persistentVolumeClaim'.",
      "With this result:",
      "\"mountPath\": \"/var/www/html/LocalSettings.d/LocalSettings.override.php\", \"name\": \"movies-wikibase-localsettings-override-php\", \"subPath\": \"LocalSettings.override.php\"",
      "{\"configMap\": {\"defaultMode\": 420, \"name\": \"movies-wikibase-localsettings-override-php\"}, \"name\": \"movies-wikibase-localsettings-override-php\"}",
      "As you want to modify array items in two distinct places and in two distinct ways, but all based on the same values that come from transforming the same source, I\u2019d recommend setting up a lookup table (e.g. using INDEX), and then querying it in both cases (instead of recurring to the same source and repeating the same transformations over and over):",
      ".spec.template.spec |= ( ... | .containers[].volumeMounts[] |= last(., {mountPath} + ( $lookup[.name] | values | {name, subPath} )) | .volumes[] |= last(., ( $lookup[.name] | values | {configMap: {defaultMode: 420, name}, name} )) )"
    ],
    "utterance": "Replace volumes and volumeMounts for any mountPath ending with a file extension so that the volume becomes a configMap with defaultMode 420 and the volumeMount has a generated name and subPath set to the filename.",
    "expressions": [
      ".spec.template.spec |= (\n  INDEX(.containers[].volumeMounts[]\n    | {id: .name, subPath: (.mountPath / \"/\")[-1]}\n    | .name = (.id | .[:index(\"claim\")])\n            + (.subPath | gsub(\"[_.]\";\"-\") | ascii_downcase);\n    select(.subPath | test(\"[.][^.]+$\"))).id\n  ) as $lookup\n  | .containers[].volumeMounts[] |= last(., {mountPath} + ($lookup[.name] | values | {name, subPath}))\n  | .volumes[] |= last(., ($lookup[.name] | values | {configMap: {defaultMode: 420, name}, name}))\n)"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "apps/v1",
          "kind": "Deployment",
          "spec": {
            "template": {
              "spec": {
                "containers": [
                  {
                    "volumeMounts": [
                      {
                        "mountPath": "/var/www/html",
                        "name": "shared"
                      },
                      {
                        "mountPath": "/var/www/html/LocalSettings.d/LocalSettings.override.php",
                        "name": "movies-wikibase-claim1"
                      },
                      {
                        "mountPath": "/var/www/html/img/wikibase_logo.png",
                        "name": "movies-wikibase-claim2"
                      }
                    ]
                  }
                ],
                "volumes": [
                  {
                    "name": "shared",
                    "persistentVolumeClaim": {
                      "claimName": "shared"
                    }
                  },
                  {
                    "name": "movies-wikibase-claim1",
                    "persistentVolumeClaim": {
                      "claimName": "movies-wikibase-claim1"
                    }
                  },
                  {
                    "name": "movies-wikibase-claim2",
                    "persistentVolumeClaim": {
                      "claimName": "movies-wikibase-claim2"
                    }
                  }
                ]
              }
            }
          }
        },
        "output": {
          "apiVersion": "apps/v1",
          "kind": "Deployment",
          "spec": {
            "template": {
              "spec": {
                "containers": [
                  {
                    "volumeMounts": [
                      {
                        "mountPath": "/var/www/html",
                        "name": "shared"
                      },
                      {
                        "mountPath": "/var/www/html/LocalSettings.d/LocalSettings.override.php",
                        "name": "movies-wikibase-localsettings-override-php",
                        "subPath": "LocalSettings.override.php"
                      },
                      {
                        "mountPath": "/var/www/html/img/wikibase_logo.png",
                        "name": "movies-wikibase-wikibase-logo-png",
                        "subPath": "wikibase_logo.png"
                      }
                    ]
                  }
                ],
                "volumes": [
                  {
                    "name": "shared",
                    "persistentVolumeClaim": {
                      "claimName": "shared"
                    }
                  },
                  {
                    "configMap": {
                      "defaultMode": 420,
                      "name": "movies-wikibase-localsettings-override-php"
                    },
                    "name": "movies-wikibase-localsettings-override-php"
                  },
                  {
                    "configMap": {
                      "defaultMode": 420,
                      "name": "movies-wikibase-wikibase-logo-png"
                    },
                    "name": "movies-wikibase-wikibase-logo-png"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 77695140
  },
  {
    "context": [
      "seq 3 | jq -nR 'reduce inputs as $_ (0; . + ($_|tonumber))'",
      "seq 3 | jq -R 'reduce splits(\"\\n\") as $_ (0; . + ($_|tonumber))'",
      "seq 3 | jq -Rs 'reduce splits(\"\\n\") as $_ (0; . + ($_|tonumber? // 0))'",
      "seq 3 | jq -nR '[inputs]'",
      "seq 3 | jq -R '[splits(\"\\n\")]'"
    ],
    "utterance": "Sum the numbers from standard input, each number appearing on its own line.",
    "expressions": [
      "reduce inputs as $_ (0; . + ($_|tonumber))",
      "reduce splits(\"\\n\") as $_ (0; . + ($_|tonumber? // 0))"
    ],
    "data": [
      {
        "input": "1\n2\n3\n",
        "output": 6
      }
    ],
    "identifier": 77881699
  },
  {
    "context": [
      "I tried to use random and rand function to generate random strings, but JQ is giving error saying random or rand is not defined. I am using 1.7 version of JQ but these functions are not supported in this version.",
      "JQ doesn&#39;t have built-ins for generating random data but it&#39;s easy to roll your own.",
      "def random_words:\n  def LCG($seed):\n    (105*$seed + 1) % pow(26; 5) | ., LCG(.);\n  LCG(now) | [97 + (. / pow(26; range(5)))%26] | implode;",
      "[[limit(length; random_words)], .]\n| transpose | map({id: .[0]} + .[1])",
      "pseudo-random five-character-long `id` field to each object",
      "def random_word($width):\n  [limit($width; repeat(26|prn)) + 97] | implode;",
      "reduce $input[][] as $in ([]; . +  [$in | .id = random_word(5)] )"
    ],
    "utterance": "Generate a random string of length 5 consisting of lowercase letters a to z.",
    "expressions": [
      "def random_words:\n  def LCG($seed):\n    (105*$seed + 1) % pow(26; 5) | ., LCG(.);\n  LCG(now) | [97 + (. / pow(26; range(5)))%26] | implode;\nrandom_words",
      "def random_word($width): [limit($width; repeat(26|prn)) + 97] | implode; random_word(5)"
    ],
    "identifier": 77879588
  },
  {
    "context": [
      "I want to filter from the file the \"name\" attributes for which the associated \"key1\" attribute, seen as an array, hold all the values (order of elements doesn't matter) of \"str\" seen as an array [foo]",
      "You could split the list at commas into an array, then use `all` with `IN` to test the containedness for all items.",
      "jq --arg str \"$str\" '($str / \",\") as $arr\n  | map(select(. as $dot | $arr | all(IN(($dot.key1 / \",\")[]))).name)\n'",
      "jq -r --arg v \"val1,val2,val3\" '\n   ($v / \",\") as $values\n   | .[]\n   | select( (.key1 / \",\") as $kv\n             | all( $values[]; IN($kv[]) ))\n   | .name"
    ],
    "utterance": "Filter and return the name values for objects whose key1 values (as split array) contain all members from the provided string split by commas.",
    "expressions": [
      "jq --arg str \"$str\" '($str / \",\") as $arr | map(select(. as $dot | $arr | all(IN(($dot.key1 / \",\")[]))).name)'",
      "jq -r --arg v \"val1,val2,val3\" '($v / \",\") as $values | .[] | select((.key1 / \",\") as $kv | all($values[]; IN($kv[]))) | .name'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "key1": "val3,val2,val1",
            "category": "thefoocategory"
          },
          {
            "name": "bar",
            "key1": "val2",
            "category": "thebarcategory"
          }
        ],
        "output": [
          "foo"
        ]
      }
    ],
    "identifier": 77874726
  },
  {
    "context": [
      "Here is my json file:",
      "\"facet_fields\":{\r\n      \"title\":[\r\n        \"primary\",5981,\r\n        \"database\",5965,\r\n        \"source\",5963,\r\n        \"eecm\",5949,\r\n        \"the\",5066,\r\n        \"research\",4888]},",
      "I want to print the output like: -\r\n\"primary\",5981,\r\n\"database\",5965,\r\n\"source\",5963,\r\n\"eecm\",5949,\r\n\"the\",5066,\r\n\"research\",4888",
      "So far, I've been trying jq -c '.facet_counts.facet_fields.title[]', but members of the tuplet are being output on different lines (i.e. effectively decoupled): -",
      "You can split the array into chunks with `_nwise`, then `join()` those with a char of your liking:\r\n.facet_counts.facet_fields.title | _nwise(2) | join(\": \")",
      "primary: 5981\ndatabase: 5965\nsource: 5963\neecm: 5949\nthe: 5066\nresearch: 4888"
    ],
    "utterance": "Print all elements of the title array as alternating pairs on a single line, preserving their original order.",
    "expressions": [
      ".facet_counts.facet_fields.title | @csv",
      ".facet_counts.facet_fields.title | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "facet_counts": {
            "facet_queries": {},
            "facet_fields": {
              "title": [
                "primary",
                5981,
                "database",
                5965,
                "source",
                5963,
                "eecm",
                5949,
                "the",
                5066,
                "research",
                4888
              ]
            },
            "facet_ranges": {}
          }
        },
        "output": [
          "\"primary\",5981,\"database\",5965,\"source\",5963,\"eecm\",5949,\"the\",5066,\"research\",4888"
        ]
      }
    ],
    "identifier": 77872962
  },
  {
    "context": [
      "- OLD_ENVIRONMENTS=$(curl --header \"PRIVATE-TOKEN:${ENVIRONMENT_DELETER}\" \"https://gitlab.mycompany.net/api/v4/projects/${CI_PROJECT_ID}/environments?states=stopped\" | jq '[.[] | select(.updated_at | .[0:19] +\"Z\" | fromdateiso8601 < $FILTER_DATE)]')",
      "jq: error: $FILTER_DATE is not defined at <top-level>, line 1:",
      "I've tried all kinds of quoting schemas around `$FILTER_DATE`, but I just can't seem to get the syntax right."
    ],
    "utterance": "Filter environments whose updated_at timestamp is earlier than a variable cutoff date provided as an external argument.",
    "expressions": [
      "[.[] | select(.updated_at | .[0:19] + \"Z\" | fromdateiso8601 < $FILTER_DATE)]"
    ],
    "identifier": 77889755
  },
  {
    "context": [
      "1) from this json I need to create a csv file",
      "2) `passCount` and `failCount` in the top of the file including the values (only displayed once)",
      "3) only testcases \"cases\" that have `\"status\": \"FAILED\"`",
      "4) generally only the key/value pairs of: `className, name, errorDetail, status`",
      "jq -r '\n  [.passCount, .failCount] + (\n    .suites[].cases[] | select(.status == \"FAILED\")\n    | [.className, .name, .errorDetails, .status]\n  ) | @csv\n'"
    ],
    "utterance": "Output a CSV containing top-level passCount and failCount, followed by each test case with status FAILED, including className, name, errorDetails, and status.",
    "expressions": [
      "[.passCount, .failCount] + ( .suites[].cases[] | select(.status == \"FAILED\") | [.className, .name, .errorDetails, .status] ) | @csv"
    ],
    "data": [
      {
        "input": {
          "_class": "hudson.tasks.junit.TestResult",
          "testActions": [],
          "duration": 9408.876,
          "empty": false,
          "failCount": 4,
          "passCount": 147,
          "skipCount": 1040,
          "suites": [
            {
              "cases": [
                {
                  "testActions": [],
                  "age": 0,
                  "className": "Main testsuite 1",
                  "duration": 17.281,
                  "errorDetails": null,
                  "errorStackTrace": null,
                  "failedSince": 0,
                  "name": "testcase 1.1",
                  "properties": {},
                  "skipped": false,
                  "skippedMessage": null,
                  "status": "PASSED",
                  "stderr": null,
                  "stdout": null
                },
                {
                  "testActions": [],
                  "age": 0,
                  "className": "Main testsuite 1",
                  "duration": 40.538,
                  "errorDetails": null,
                  "errorStackTrace": null,
                  "failedSince": 0,
                  "name": "testcase 1.2",
                  "properties": {},
                  "skipped": false,
                  "skippedMessage": null,
                  "status": "PASSED",
                  "stderr": null,
                  "stdout": null
                }
              ],
              "duration": 170.714,
              "enclosingBlockNames": [
                "Blockname 1",
                "Blockname 2"
              ],
              "enclosingBlocks": [
                "52",
                "25"
              ],
              "id": null,
              "name": "Main testsuite 1",
              "nodeId": "67",
              "properties": {},
              "stderr": null,
              "stdout": null,
              "timestamp": null
            },
            {
              "cases": [
                {
                  "testActions": [],
                  "age": 0,
                  "className": "Main testsuite 2",
                  "duration": 17.781,
                  "errorDetails": null,
                  "errorStackTrace": null,
                  "failedSince": 0,
                  "name": "testcase 2.1",
                  "properties": {},
                  "skipped": false,
                  "skippedMessage": null,
                  "status": "FIXED",
                  "stderr": null,
                  "stdout": null
                },
                {
                  "testActions": [],
                  "age": 1,
                  "className": "Main testsuite 2",
                  "duration": 184.508,
                  "errorDetails": "short error message",
                  "errorStackTrace": "longer error message",
                  "failedSince": 2410,
                  "name": "testcase 2.2",
                  "properties": {},
                  "skipped": false,
                  "skippedMessage": null,
                  "status": "FAILED",
                  "stderr": null,
                  "stdout": "Random pretty long error message"
                }
              ],
              "duration": 215.862,
              "enclosingBlockNames": [
                "Others",
                "Blockname 2"
              ],
              "enclosingBlocks": [
                "98",
                "25"
              ],
              "id": null,
              "name": "Main testsuite 2",
              "nodeId": "113",
              "properties": {},
              "stderr": null,
              "stdout": null,
              "timestamp": null
            }
          ]
        },
        "output": "147,4,\"Main testsuite 2\",\"testcase 2.2\",\"short error message\",\"FAILED\"\n"
      }
    ],
    "identifier": 77872831
  },
  {
    "context": [
      "I am iterating over `kubectl` output that looks similar to this:",
      "I am trying to learn `jq`, but my command to get a value out of the first dictionary is really long:\n\nkubectl get pods -o json -A | jq '.items | .[] | select(.metadata.name == \"ubuntu1\")  | .metadata.namespace'",
      "As [@pmf][1] said in a comment, you can select the value of a key nested in that array using this:\n\njq '.items[] | select(.metadata.name == \"ubuntu1\").metadata.namespace'"
    ],
    "utterance": "Extract the namespace value for the pod with name equal to \"ubuntu1\" from the items array in the data.",
    "expressions": [
      ".items[] | select(.metadata.name == \"ubuntu1\").metadata.namespace"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "items": [
            {
              "kind": "Pod",
              "metadata": {
                "name": "ubuntu1",
                "namespace": "development-namespace1"
              }
            },
            {
              "kind": "Pod",
              "metadata": {
                "name": "ubuntu2",
                "namespace": "development-namespace2"
              }
            }
          ]
        },
        "output": "development-namespace1"
      }
    ],
    "identifier": 77886305
  },
  {
    "context": [
      "I aim to retrieve a distinct object from a set of identical objects, as illustrated below:",
      "to get the uniques values just run `.sc | unique`",
      "By the way if \"unique\" constraint is based on some field, then you can run `.sc | unique_by(.pn)`.",
      "Concatenate your lists and then you can use `unique` as explained above.",
      ".[0] + .[1] | unique"
    ],
    "utterance": "Get all unique objects from the array under the 'sc' key, removing duplicates.",
    "expressions": [
      ".sc | unique",
      ".sc | unique_by(.pn)"
    ],
    "data": [
      {
        "input": {
          "sn": "fdd",
          "sc": [
            {
              "pn": "di",
              "pv": {
                "val": "26",
                "com": "="
              },
              "fix": "Hello",
              "tp": "String"
            },
            {
              "pn": "di2",
              "pv": {
                "val": "28",
                "com": "="
              },
              "fix": "Hello2",
              "tp": "String"
            }
          ]
        },
        "output": [
          {
            "pn": "di",
            "pv": {
              "val": "26",
              "com": "="
            },
            "fix": "Hello",
            "tp": "String"
          },
          {
            "pn": "di2",
            "pv": {
              "val": "28",
              "com": "="
            },
            "fix": "Hello2",
            "tp": "String"
          }
        ]
      }
    ],
    "identifier": 77906806
  },
  {
    "context": [
      "def.args-pod no and send answer",
      "jq: error: pod/0 is not defined at <top-level>, line 1:",
      "`jq \".${param}\" \"$file\"` would become `jq '.def.args-pod' '/path/to/file'` which is obviously incorrect. For the program to be correct, this needs to be `.\"def.args-pod\"` or `.[\"def.args-pod\"]`.",
      "instead pass variables and use those:",
      "jq --arg prop \"$param\" '.[$prop]' \"$file\""
    ],
    "utterance": "Extract the value whose property key, possibly containing dots or dashes such as def.args-pod, is provided as a variable.",
    "expressions": [
      "jq --arg prop \"$param\" '.[$prop]' \"$file\""
    ],
    "data": [
      {
        "input": {
          "args1": "/my-api/",
          "def": {
            "args-pod": "^0.7.9",
            "car": "^0.8.8"
          },
          "args2": "^0.9.5"
        }
      }
    ],
    "identifier": 77907894
  },
  {
    "context": [
      "I would like to compress the space for a json file by printing in compact mode (`-c`) but I want to add a new line after each root-level object.",
      "I would like to print it as {\n\"a\":{\"a1\":1,\"a2\":[null]},\n\"b\":{\"b1\":\"test\"},\n\"c\":[1,2,3]\n} i.e., one root-level object per line (adding the start/end brackets)",
      "You have very limited options how jq does pretty-printing.",
      "Here's a very manual approach using `to_entries` and `@json`",
      "jq -r '\n  \"{\", ([to_entries[] | @json \"\\(.key):\\(.value)\" ] | .[:-1][] += \",\")[], \"}\"\n'"
    ],
    "utterance": "Print each root-level key-value pair of an object on its own line in compact form, enclosed within braces.",
    "expressions": [
      "\"{\", ([to_entries[] | @json \"\\(.key):\\(.value)\" ] | .[:-1][] += \",\")[], \"}\""
    ],
    "data": [
      {
        "input": {
          "a": {
            "a1": 1,
            "a2": [
              null
            ]
          },
          "b": {
            "b1": "test"
          },
          "c": [
            1,
            2,
            3
          ]
        },
        "output": "{\n\"a\":{\"a1\":1,\"a2\":[null]},\n\"b\":{\"b1\":\"test\"},\n\"c\":[1,2,3]\n}"
      }
    ],
    "identifier": 77908875
  },
  {
    "context": [
      "I would like to filter the stream such that only records of \"type\" `process_exit` remain.",
      "your input is a already stream of objects which you want to filter by the presence of a key. This can simply be done using `select` and `has` as follows:",
      "jq 'select(has(\"process_exit\"))'",
      "If for some reason you need to generate the input with `--stream`, use `inputs` with the `-n` flag to capture and process the broken-down parts:",
      "jq --stream -n 'fromstream(inputs) | select(has(\"process_exit\"))'"
    ],
    "utterance": "Filter a stream of objects to only include those that have the key 'process_exit'.",
    "expressions": [
      "select(has(\"process_exit\"))",
      "fromstream(inputs) | select(has(\"process_exit\"))"
    ],
    "data": [
      {
        "input": [
          {
            "process_exec": {
              "process": {
                "pid": 1234,
                "uid": 42,
                "binary": "/usr/bin/foo"
              }
            },
            "time": "2024-06-03T10:00:00Z"
          },
          {
            "process_exit": {
              "process": {
                "pid": 1234,
                "uid": 42,
                "binary": "/usr/bin/foo"
              }
            },
            "time": "2024-06-03T10:01:00Z"
          }
        ],
        "output": [
          {
            "process_exit": {
              "process": {
                "pid": 1234,
                "uid": 42,
                "binary": "/usr/bin/foo"
              }
            },
            "time": "2024-06-03T10:01:00Z"
          }
        ]
      }
    ],
    "identifier": 77907536
  },
  {
    "context": [
      "my goal is to create the following tab-separated lines (\\t below means tab `\\x09`)\n```\n\"a1\"\\t{\"b1\":1,\"c1\":{\"c1\":\"test\",\"c2\":null}}\n\"a2\"\\t{\"b2\":1,\"c\":{\"c2\":null}}\n```",
      "if I use join(\"\\t\"), it complains that it can not join a string with an object\n```\necho '[{\"a1\":{\"b1\":1,\"c1\":{\"c1\":\"test\",\"c2\":null}}},{\"a2\":{\"b2\":1,\"c\":{\"c2\":\"test\",\"c2\":null}}}]' | jq -c '.[] | to_entries | .[] | [.key, .value] | join(\"\\t\")'\njq: error (at <stdin>:1): string (\"a1\\t\") and object ({\"b1\":1,\"c1...) cannot be added\n```",
      "To get your desired output, use @json to [JSON-encode] any input as strings. Then, use the --raw-output (or -r) flag to print the string values as is.",
      "The simplest way would be to use [string interpolation]:\n```sh\n\u2026 | jq -r '.[] | to_entries[] | @json \"\\(.key)\\t\\(.value)\"'\n```",
      "But you can also use join(\"\\t\") from your attempt on a prepared array. In this case, using the tojson converter is also possible:\n```sh\n\u2026 | jq -r '.[] | to_entries[] | [.key, .value | @json] | join(\"\\t\")'\n# or\n\u2026 | jq -r '.[] | to_entries[] | [.key, .value | tojson] | join(\"\\t\")'\n```",
      "Output:\n```json\n\"a1\"\t{\"b1\":1,\"c1\":{\"c1\":\"test\",\"c2\":null}}\n\"a2\"\t{\"b2\":1,\"c\":{\"c2\":null}}\n```"
    ],
    "utterance": "Print each object's key and value from an array as a line with the key and value separated by a tab character, where the value remains in its JSON form.",
    "expressions": [
      ".[] | to_entries[] | @json \"\\(.key)\\t\\(.value)\"",
      ".[] | to_entries[] | [.key, .value | @json] | join(\"\\t\")",
      ".[] | to_entries[] | [.key, .value | tojson] | join(\"\\t\")"
    ],
    "data": [
      {
        "input": [
          {
            "a1": {
              "b1": 1,
              "c1": {
                "c1": "test",
                "c2": null
              }
            }
          },
          {
            "a2": {
              "b2": 1,
              "c": {
                "c2": null
              }
            }
          }
        ],
        "output": "\"a1\"\t{\"b1\":1,\"c1\":{\"c1\":\"test\",\"c2\":null}}\n\"a2\"\t{\"b2\":1,\"c\":{\"c2\":null}}"
      }
    ],
    "identifier": 77895726
  },
  {
    "context": [
      "The real question I am asking is how to extract the value of `color` keys in the order provided by the integers in `componentIndex`.",
      "For that, you really just need to convert the object into a regular (you don't need the keys) array of objects using `map(.)` or `[.[]]`, then sort it using `sort_by(.componentIndex)` (note that `.componentIndex` is already a number, so `.componentIndex|tonumber` won't make a difference here), and extract from its items the fields you're interested in:",
      "jq -r 'map(.) | sort_by(.componentIndex)[].color'",
      "#BB2DD4",
      "#E6009B",
      "#ED2024",
      "#8CC63F",
      "#DDE223",
      "#2E97BC"
    ],
    "utterance": "Extract the color values, ordered by ascending componentIndex.",
    "expressions": [
      "map(.) | sort_by(.componentIndex)[].color",
      "[.[]] | sort_by(.componentIndex)[].color"
    ],
    "data": [
      {
        "input": {
          "lungCancerCellLines": {
            "componentIndex": 11,
            "active": true,
            "longName": "Lung cancer cell lines",
            "filenameKey": "lungCancerCellLines",
            "color": "#8CC63F"
          },
          "naturalKillerCells": {
            "componentIndex": 1,
            "active": true,
            "longName": "Natural killer cells",
            "filenameKey": "naturalKillerCells",
            "color": "#BB2DD4"
          },
          "respiratoryMuscular": {
            "componentIndex": 12,
            "active": true,
            "longName": "Respiratory / muscular",
            "filenameKey": "respiratoryMuscular",
            "color": "#DDE223"
          },
          "cerebellarHemisphere": {
            "componentIndex": 14,
            "active": true,
            "longName": "Cerebellar hemisphere",
            "filenameKey": "cerebellarHemisphere",
            "color": "#2E97BC"
          },
          "bCells": {
            "componentIndex": 2,
            "active": true,
            "longName": "B cells",
            "filenameKey": "bCells",
            "color": "#E6009B"
          },
          "cd34PlusProgenitor": {
            "componentIndex": 8,
            "active": true,
            "longName": "CD34+ progenitor",
            "filenameKey": "cd34PlusProgenitor",
            "color": "#ED2024"
          }
        },
        "output": [
          "#BB2DD4",
          "#E6009B",
          "#ED2024",
          "#8CC63F",
          "#DDE223",
          "#2E97BC"
        ]
      }
    ],
    "identifier": 77862400
  },
  {
    "context": [
      "result = subprocess.run([\"jq -r '.accountdata[] | [id, name, number, date] | @csv'\"], stdout=open(file_name, 'a'))",
      "subprocess.run([\"jq\", \"-r\", \"'.accountdata[] | [id, name, number, date] | @csv'\"])",
      "subprocess.run(\"jq -r '.accountdata[] | [id, name, number, date] | @csv'\", shell=True)"
    ],
    "utterance": "Extract the fields id, name, number, and date from each object in accountdata and output each as a CSV-formatted line.",
    "expressions": [
      ".accountdata[] | [id, name, number, date] | @csv"
    ],
    "identifier": 77922966
  },
  {
    "context": [
      "This gives me an error:",
      "jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Unix shell quoting issues?) at <top-level>, line 1:",
      "Your `filter.jq` contains DOS line endings. Strip them using the `dos2unix` utility or run your script using the Windows build; `jq-win64.exe` from the [releases page](https://github.com/jqlang/jq/releases) works fine on both Cygwin and WSL2."
    ],
    "utterance": "Write a filter file with multiple filter lines and comments, and run it successfully without syntax errors.",
    "expressions": [
      ".signal[] | .name\n# .signal[] | select(.name | contains(\"signal\")) as $matches"
    ],
    "data": [
      {
        "input": {
          "signal": [
            {
              "name": "alpha"
            },
            {
              "name": "beta"
            }
          ]
        },
        "output": [
          "alpha",
          "beta"
        ]
      }
    ],
    "identifier": 77924502
  },
  {
    "context": [
      "The expected output should be a JSON array of objects with multiple objects in it but I'm only seeing the last object.",
      "I would also like to give the array a key and the output should look something like the following:\n{\n  \"secrets\":[\n    {\n      \"name\": \"name1\",\n      \"newValue\": \"****\"\n    },\n    {\n      \"name\": \"name2\",\n      \"newValue\": \"****\"\n    },\n    {\n      \"name\": \"name3\",\n      \"newValue\": \"****\"\n    }\n  ]\n}",
      "jq --arg name \"$secretName\" -n '{$name, newValue: \"****\"}'",
      "done < \"$input\" | jq -s '{secrets:.}' > jsonOutput.json",
      "jq -R '{name: ., newValue: \"****\"}' \"$input\" | jq -s \"{secrets:.}\"",
      "jq -Rn '[{name: inputs, newValue: \"****\"}]|{secrets:.}' \"$input\""
    ],
    "utterance": "Collect all lines from a file as objects with keys name and newValue (set to \"****\"), then wrap the resulting array as the value of the secrets key.",
    "expressions": [
      "jq --arg name \"$secretName\" -n '{name: $name, newValue: \"****\"}'",
      "jq -R '{name: ., newValue: \"****\"}' \"$input\" | jq -s '{secrets:.}'",
      "jq -Rn '[{name: inputs, newValue: \"****\"}]|{secrets:.}' \"$input\""
    ],
    "data": [
      {
        "input": [
          "name1",
          "name2",
          "name3"
        ],
        "output": {
          "secrets": [
            {
              "name": "name1",
              "newValue": "****"
            },
            {
              "name": "name2",
              "newValue": "****"
            },
            {
              "name": "name3",
              "newValue": "****"
            }
          ]
        }
      }
    ],
    "identifier": 77918614
  },
  {
    "context": [
      "Then I try to select only the nodes with `statusId == 10270`.  this would give me, as expected result, just the last node.",
      "What I am trying to get is just the element itself or at least the \"key\"",
      "Assuming you want a stream of objects having a key with the string value `\"10270\"`:\n\n```\n.issuesData.issues[] | select(.statusId == \"10270\")\n```",
      "Assuming you want an _array_ containing all matching objects:\n\n```\n.issuesData.issues | map(select(.statusId == \"10270\"))\n```"
    ],
    "utterance": "Select all objects in the 'issues' array where the value of 'statusId' is \"10270\".",
    "expressions": [
      ".issuesData.issues[] | select(.statusId == \"10270\")",
      ".issuesData.issues | map(select(.statusId == \"10270\"))"
    ],
    "data": [
      {
        "input": {
          "issuesData": {
            "issues": [
              {
                "id": 3619364,
                "key": "AIG-1992",
                "hidden": false,
                "typeId": "1",
                "summary": "XXXXXX",
                "priorityId": "2",
                "done": false,
                "assignee": "XXXX",
                "assigneeName": "XXXX",
                "hasCustomUserAvatar": false,
                "autoUserAvatar": {
                  "letter": "B",
                  "color": "#d39c3f"
                },
                "color": "#ff0000",
                "epicId": "3557134",
                "epic": "AIG-1",
                "estimateStatisticRequired": false,
                "statusId": "10370",
                "fixVersions": [
                  120044
                ],
                "projectId": 49202
              },
              {
                "id": 3617950,
                "key": "AIG-1938",
                "hidden": false,
                "typeId": "1",
                "summary": "YYYYYY",
                "priorityId": "2",
                "done": false,
                "assignee": "YYYY",
                "assigneeName": "YYY",
                "hasCustomUserAvatar": false,
                "autoUserAvatar": {
                  "letter": "F",
                  "color": "#7bc1a1"
                },
                "color": "#ff0000",
                "epicId": "3658470",
                "epic": "AIG-574",
                "estimateStatisticRequired": false,
                "statusId": "10270",
                "fixVersions": [],
                "projectId": 49202
              }
            ]
          }
        },
        "output": [
          {
            "id": 3617950,
            "key": "AIG-1938",
            "hidden": false,
            "typeId": "1",
            "summary": "YYYYYY",
            "priorityId": "2",
            "done": false,
            "assignee": "YYYY",
            "assigneeName": "YYY",
            "hasCustomUserAvatar": false,
            "autoUserAvatar": {
              "letter": "F",
              "color": "#7bc1a1"
            },
            "color": "#ff0000",
            "epicId": "3658470",
            "epic": "AIG-574",
            "estimateStatisticRequired": false,
            "statusId": "10270",
            "fixVersions": [],
            "projectId": 49202
          }
        ]
      }
    ],
    "identifier": 77915548
  },
  {
    "context": [
      "I want to get only the below output side by side,O/P\n\n    \"username\": \"admin\",\"eventTime\": \"2023-12-01T23:50:02.554+0000\"",
      "$ cat filename | jq -r '\"\\\"username\\\" : \\\"\" + .requestData.username + \"\\\" , \\\"eventTime\\\" : \\\"\" + .eventTime + \"\\\"\"'",
      "$ cat filename | jq -r '\"\\\"username\\\" : \\\"\\(.requestData.username)\\\" , \\\"eventTime\\\" : \\\"\\(.eventTime)\\\"\"'",
      "jq -r '\n[[\"username\", .requestData.username], [\"eventTime\", .eventTime]]\n| map(map(tojson)|join(\":\"))\n| join(\",\")\n'"
    ],
    "utterance": "Produce output with \"username\": \"admin\", \"eventTime\": \"2023-12-01T23:50:02.554+0000\" side by side as a single string.",
    "expressions": [
      "\"\\\"username\\\" : \\\"\" + .requestData.username + \"\\\" , \\\"eventTime\\\" : \\\"\" + .eventTime + \"\\\"\"",
      "\"\\\"username\\\" : \\\"\\(.requestData.username)\\\" , \\\"eventTime\\\" : \\\"\\(.eventTime)\\\"\"",
      "[[\"username\", .requestData.username], [\"eventTime\", .eventTime]] | map(map(tojson)|join(\":\")) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "requestData": {
            "username": "admin"
          },
          "eventTime": "2023-12-01T23:50:02.554+0000",
          "observer": {
            "id": "target"
          }
        },
        "output": "\"username\":\"admin\",\"eventTime\":\"2023-12-01T23:50:02.554+0000\""
      }
    ],
    "identifier": 77910541
  },
  {
    "context": [
      "I have a JSON object that contains a JWT token. I would like to extract the claims from the token and put them into the JSON object, replacing the token.",
      "How can I pull out the claims and put them into the JSON in place of the JWT token using jq?",
      "Split the value of `.token` at the dot into an array, take the second item, and use `@base64d` to decode base64, and `fromjson` to interpret the output as JSON:\r\njq '.token |= ((./\".\")[1] | @base64d | fromjson)'",
      "Use [string division](https://jqlang.github.io/jq/manual/#multiplication-division-modulo) to split the token on dots, the `@base64d` filter to base64 decode the data, and the `fromjson` filter to turn the string into JSON.\r\n\r\nThe `|=` update operator can be used to assign the result back to the `.token` field.\r\n\r\n    jq '.token |= ((. / \".\")[1] | @base64d | fromjson)' file.json",
      "You can also use the `splits` function to split the token on dots:\r\n\r\n    jq '.token |= ([splits(\"\\.\")][1] | @base64d | fromjson)' file.json"
    ],
    "utterance": "Replace the value of the 'token' field with the claims extracted from the JWT's payload segment (base64-decoded second part after splitting on dots).",
    "expressions": [
      ".token |= ((./\".\")[1] | @base64d | fromjson)",
      ".token |= ((. / \".\")[1] | @base64d | fromjson)",
      ".token |= ([splits(\"\\.\")][1] | @base64d | fromjson)"
    ],
    "data": [
      {
        "input": {
          "id": 7,
          "time": "now",
          "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJuYW1lIjoiYm9iYnkiLCJjb2xvciI6ImJsdWUiLCJ0cmVlIjoiZWxtIn0K.9JCVXpkI6ICc5RnIsIiN1IzUIJiOicGbhJye"
        },
        "output": {
          "id": 7,
          "time": "now",
          "token": {
            "name": "bobby",
            "color": "blue",
            "tree": "elm"
          }
        }
      }
    ],
    "identifier": 77917165
  },
  {
    "context": [
      "filter this JSON down to only the first occurrence of the `user.login` for each item, with the highest `submitted_at` key.",
      "The result should be the following JSON with only the most recent duplicate of `user.login` that I can then loop over",
      "`jq '. |= sort_by(.submitted_at) | reverse | unique_by(.user.login)'`",
      "group_by(.user.login) you can group together into subarrays all objects with the same `.user.login` value. Then, from each subarray, pick the one item with the highest `.submitted_at` value using `max_by(.submitted_at)`.",
      "[group_by(.user.login)[] | max_by(.submitted_at)]",
      "group_by(.user.login) | map(max_by(.submitted_at))"
    ],
    "utterance": "Get the item with the highest submitted_at for each unique user.login.",
    "expressions": [
      ". |= sort_by(.submitted_at) | reverse | unique_by(.user.login)",
      "[group_by(.user.login)[] | max_by(.submitted_at)]",
      "group_by(.user.login) | map(max_by(.submitted_at))"
    ],
    "data": [
      {
        "input": [
          {
            "user": {
              "login": "user1"
            },
            "state": "CHANGE_REQUESTED",
            "submitted_at": "2024-01-23T19:18:31Z"
          },
          {
            "user": {
              "login": "user1"
            },
            "state": "DISMISSED",
            "submitted_at": "2024-02-05T16:49:58Z"
          },
          {
            "user": {
              "login": "user1"
            },
            "state": "APPROVED",
            "submitted_at": "2024-02-06T19:18:31Z"
          },
          {
            "user": {
              "login": "user2"
            },
            "state": "APPROVED",
            "submitted_at": "2024-01-23T19:18:31Z"
          },
          {
            "user": {
              "login": "user2"
            },
            "state": "DISMISSED",
            "submitted_at": "2024-01-21T19:18:31Z"
          }
        ],
        "output": [
          {
            "user": {
              "login": "user1"
            },
            "state": "APPROVED",
            "submitted_at": "2024-02-06T19:18:31Z"
          },
          {
            "user": {
              "login": "user2"
            },
            "state": "APPROVED",
            "submitted_at": "2024-01-23T19:18:31Z"
          }
        ]
      }
    ],
    "identifier": 77950999
  },
  {
    "context": [
      "The value is:\r\n\r\n    HOUSE|CAR",
      "read doc doc2 < <(echo $(callapi server:id| jq '[].Documentation'))",
      "but it gives me:\r\n\r\n    echo $doc\r\n    \"HOUSE|CAR\"\r\n    echo $doc2\r\n    <empty>",
      "How could I get these:\r\n\r\n    echo $doc\r\n    HOUSE\r\n    eccho $doc2\r\n    CAR",
      "IFS='|' read -r doc doc2 < <(callapi server:id | jq -r '[].Documentation')",
      "Passing the `-r` argument to `jq` tells it not to escape content as JSON (preventing `\"`s at the beginning and end of the output, and possibly other escaping of characters within)."
    ],
    "utterance": "Extract the 'Documentation' fields from each array element, returning the values as unescaped strings separated by a pipe.",
    "expressions": [
      ".[].Documentation",
      ".[].Documentation | @text",
      ".[].Documentation | @csv",
      ".[].Documentation | @tsv",
      ".[].Documentation | .[0], .[1]",
      ".[].Documentation | split(\"|\") | .[]"
    ],
    "identifier": 77958241
  },
  {
    "context": [
      "If name is `architecture-design-detailed`, \r\n\r\n* change name to `new_name_here`\r\n\r\n* replace last part of rootPath (which is architecture-design-detailed, after the last /) with new_name_here.",
      "But not understanding how to replace last part of rootPath. I think we have to use `sub` or `gsub`. But not understanding how.",
      "You can use `split(\"/\")` to convert `rootPath` to an array, then set the last index (`.[-1]`) to `new_name` and then `join(\"/\")` them back together.",
      "Here\u2019s another approach that updates at once the two fields `.name, .rootPath` for selected items matching `.name == $from` by right-trimming by the old name using `rtrimstr($from)`, and then adding the new one with `+ $to`"
    ],
    "utterance": "For objects where name equals architecture-design-detailed, change the name to new_name_here and update rootPath so that its last segment is also new_name_here.",
    "expressions": [
      "map(select(.name == \"architecture-design-detailed\") \n    |= ( \n        .name = \"new_name_here\",\n        .rootPath = (.rootPath | split(\"/\") | .[-1] = \"new_name_here\" | join(\"/\"))\n    ) \n)",
      "map((select(.name == $from) | .name, .rootPath) |= rtrimstr($from) + $to)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "architecture-design-detailed",
            "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed",
            "paths": [],
            "group": "",
            "enabled": true
          },
          {
            "name": "architecture-design-detailed-engineering",
            "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering",
            "paths": [],
            "group": "",
            "enabled": true
          }
        ],
        "output": [
          {
            "name": "new_name_here",
            "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/new_name_here",
            "paths": [],
            "group": "",
            "enabled": true
          },
          {
            "name": "architecture-design-detailed-engineering",
            "rootPath": "/media/ismail/architecture-design-detailed/_Working/_NotesFiltered/_software/architecture-design-detailed-engineering",
            "paths": [],
            "group": "",
            "enabled": true
          }
        ]
      }
    ],
    "identifier": 77956650
  },
  {
    "context": [
      "basically I am trying to return the name value of the visible workspaces.",
      "Currently I have this line doing most of the heavy lifting,\n```bash\n  local currentWorkspaces=$(i3-msg -t get_workspaces | jq -r 'map(select(.visible == true)).name')\n```",
      "X=($(i3-msg -t get_workspaces | jq -r '.[] | select(.visible == true).name' ))",
      "For an indexed array, use `declare -a`:\n```sh\n$ declare -a cw=\"($(i3-msg \u2026 | jq -r '.[]  | select(.visible).name | @sh'))\"\n```",
      "For an associative array, use `declare -A`, and output each keys before its value:\n```sh\n$ declare -A cw=\"($(i3-msg \u2026 | jq -r '.[]  | select(.visible) | .output, .name | @sh'))\"\n```"
    ],
    "utterance": "Extract the name fields of all workspace objects where visible is true.",
    "expressions": [
      ".[] | select(.visible == true).name",
      ".[] | select(.visible).name",
      "map(select(.visible == true)).name"
    ],
    "data": [
      {
        "input": [
          {
            "id": 94475011596992,
            "num": 6,
            "name": "6:NoteTaking",
            "visible": false,
            "focused": false,
            "rect": {
              "x": 40,
              "y": 65,
              "width": 1840,
              "height": 975
            },
            "output": "DisplayPort-2",
            "urgent": false
          },
          {
            "id": 94475011603104,
            "num": 7,
            "name": "7:Entertainment",
            "visible": false,
            "focused": false,
            "rect": {
              "x": 40,
              "y": 65,
              "width": 1840,
              "height": 975
            },
            "output": "DisplayPort-2",
            "urgent": false
          },
          {
            "id": 94475011612464,
            "num": 9,
            "name": "9",
            "visible": true,
            "focused": true,
            "rect": {
              "x": 40,
              "y": 65,
              "width": 1840,
              "height": 975
            },
            "output": "DisplayPort-2",
            "urgent": false
          },
          {
            "id": 94475011631328,
            "num": 1,
            "name": "1:Browsing",
            "visible": true,
            "focused": false,
            "rect": {
              "x": 40,
              "y": 1145,
              "width": 1840,
              "height": 975
            },
            "output": "DisplayPort-1",
            "urgent": false
          },
          {
            "id": 94475011637712,
            "num": 2,
            "name": "2:Messaging",
            "visible": false,
            "focused": false,
            "rect": {
              "x": 40,
              "y": 1145,
              "width": 1840,
              "height": 975
            },
            "output": "DisplayPort-1",
            "urgent": false
          },
          {
            "id": 94475011644096,
            "num": 3,
            "name": "3",
            "visible": false,
            "focused": false,
            "rect": {
              "x": 40,
              "y": 1145,
              "width": 1840,
              "height": 975
            },
            "output": "DisplayPort-1",
            "urgent": false
          }
        ],
        "output": [
          "9",
          "1:Browsing"
        ]
      }
    ],
    "identifier": 77934601
  },
  {
    "context": [
      "jq --arg cat \"$1\" --arg key \"$2\" --arg val \"$3\" \\\n  'getpath($cat / \".\")[] | select(.[$key] == $val)' ./silly-sample.json",
      "$ retrieve_from_array2 \"fruits_with_a\" \"fruitName\" \"Apricot\";\n{\n  \"fruitName\": \"Apricot\",\n  \"value\": \"...\"\n}",
      "$ retrieve_from_array2 \"vegetables.with_a\" \"n\" \"asparagus\";\n{\n  \"n\": \"asparagus\",\n  \"value\": \"...\"\n}"
    ],
    "utterance": "Given three parameters\u2014the array path (possibly dot-separated), the field name, and the search value\u2014return all items in the specified array whose given field matches the value.",
    "expressions": [
      "getpath($cat / \".\")[] | select(.[$key] == $val)"
    ],
    "data": [
      {
        "input": {
          "fruits_with_a": [
            {
              "fruitName": "Apple",
              "value": "..."
            },
            {
              "fruitName": "Apricot",
              "value": "..."
            },
            {
              "fruitName": "Aratiles",
              "value": "..."
            },
            {
              "fruitName": "Araza",
              "value": "..."
            },
            {
              "fruitName": "Avocado",
              "value": "..."
            }
          ],
          "fruits_with_b": [
            {
              "name": "Banana",
              "value": "..."
            },
            {
              "name": "Blackberry",
              "value": "..."
            },
            {
              "name": "Black sapote",
              "value": "..."
            },
            {
              "name": "Blueberry",
              "value": "..."
            },
            {
              "name": "Breadfruit",
              "value": "..."
            }
          ],
          "fruits_with_c": [
            {
              "id": "Cherry",
              "value": "..."
            },
            {
              "id": "Coconut",
              "value": "..."
            },
            {
              "id": "Cranberry",
              "value": "..."
            }
          ],
          "fruits_with_d": [
            {
              "sku": "Dragonfruit",
              "value": "..."
            },
            {
              "sku": "Durian",
              "value": "..."
            }
          ],
          "vegetables": {
            "with_a": [
              {
                "n": "artichoke",
                "value": "..."
              },
              {
                "n": "aubergine",
                "value": "..."
              },
              {
                "n": "asparagus",
                "value": "..."
              }
            ],
            "with_b": [
              {
                "n": "broccoflower",
                "value": "..."
              },
              {
                "n": "broccoli",
                "value": "..."
              },
              {
                "n": "brussels sprouts",
                "value": "..."
              }
            ],
            "with_c": [
              {
                "n": "cabbage",
                "value": "..."
              },
              {
                "n": "cauliflower",
                "value": "..."
              },
              {
                "n": "celery",
                "value": "..."
              },
              {
                "n": "cichory",
                "value": "..."
              }
            ]
          }
        },
        "output": {
          "fruitName": "Apricot",
          "value": "..."
        }
      },
      {
        "input": {
          "fruits_with_a": [
            {
              "fruitName": "Apple",
              "value": "..."
            },
            {
              "fruitName": "Apricot",
              "value": "..."
            },
            {
              "fruitName": "Aratiles",
              "value": "..."
            },
            {
              "fruitName": "Araza",
              "value": "..."
            },
            {
              "fruitName": "Avocado",
              "value": "..."
            }
          ],
          "fruits_with_b": [
            {
              "name": "Banana",
              "value": "..."
            },
            {
              "name": "Blackberry",
              "value": "..."
            },
            {
              "name": "Black sapote",
              "value": "..."
            },
            {
              "name": "Blueberry",
              "value": "..."
            },
            {
              "name": "Breadfruit",
              "value": "..."
            }
          ],
          "fruits_with_c": [
            {
              "id": "Cherry",
              "value": "..."
            },
            {
              "id": "Coconut",
              "value": "..."
            },
            {
              "id": "Cranberry",
              "value": "..."
            }
          ],
          "fruits_with_d": [
            {
              "sku": "Dragonfruit",
              "value": "..."
            },
            {
              "sku": "Durian",
              "value": "..."
            }
          ],
          "vegetables": {
            "with_a": [
              {
                "n": "artichoke",
                "value": "..."
              },
              {
                "n": "aubergine",
                "value": "..."
              },
              {
                "n": "asparagus",
                "value": "..."
              }
            ],
            "with_b": [
              {
                "n": "broccoflower",
                "value": "..."
              },
              {
                "n": "broccoli",
                "value": "..."
              },
              {
                "n": "brussels sprouts",
                "value": "..."
              }
            ],
            "with_c": [
              {
                "n": "cabbage",
                "value": "..."
              },
              {
                "n": "cauliflower",
                "value": "..."
              },
              {
                "n": "celery",
                "value": "..."
              },
              {
                "n": "cichory",
                "value": "..."
              }
            ]
          }
        },
        "output": {
          "n": "asparagus",
          "value": "..."
        }
      }
    ],
    "identifier": 77974838
  },
  {
    "context": [
      "I have a text file, I want to make it into a single JSON string with quotes and \\n, ideally from the command line. I don&#39;t want multiple strings, or dictionaries.",
      "cat ./my-input-file | jq -R --slurp . > ./my-output.json"
    ],
    "utterance": "Convert the entire contents of a text file into a single quoted string, preserving newlines.",
    "expressions": [
      "jq -R --slurp ."
    ],
    "identifier": 77991126
  },
  {
    "context": [
      "here is original json example:\r\n\r\n    {\r\n      \"item1\": {\r\n        \"foo1\": 1,\r\n        \"foo2\": 2\r\n    },\r\n      \"item2\": {\r\n        \"foo1\": 11,\r\n        \"foo2\": 22\r\n      }\r\n    }",
      "how can i convert it into json array with new attribute using jq:\r\n\r\n    [\r\n      {\r\n        \"name\": \"item1\",\r\n        \"foo1\": 1,\r\n        \"foo2\": 2\r\n      },\r\n      {\r\n        \"name\": \"item2\",\r\n        \"foo1\": 11,\r\n        \"foo2\": 22\r\n      }\r\n    ]",
      "Instead of `keys` I would start with `to_entries`:\r\n\r\n    to_entries | map({name: .key} + .value)\r\n\r\n<sup>([online demo](https://jqplay.org/s/98DMHXY56WS))</sup>"
    ],
    "utterance": "Transform an object with items as keys into an array of objects, each with a 'name' field set to the original key and the rest of the item's fields preserved.",
    "expressions": [
      "to_entries | map({name: .key} + .value)"
    ],
    "data": [
      {
        "input": {
          "item1": {
            "foo1": 1,
            "foo2": 2
          },
          "item2": {
            "foo1": 11,
            "foo2": 22
          }
        },
        "output": [
          {
            "name": "item1",
            "foo1": 1,
            "foo2": 2
          },
          {
            "name": "item2",
            "foo1": 11,
            "foo2": 22
          }
        ]
      }
    ],
    "identifier": 77975793
  },
  {
    "context": [
      "I have a JSON array with a bunch of objects, all the same keys, but some of the keys contain serialized JSON instead of actual JSON.",
      "I'd like to replace the contents of all the `b`s with their parsed form.",
      "Use `fromjson`, and update the fields in question using `.[].b |=`.\n```sh\n.[].b |= fromjson\n```",
      "If you want to decode all JSON-encoded strings, unknowing which ones are, you could `try` using `fromjson`, and in case of a failure resort to the original input `.`. `try` can be abbreviated to `?`:\n```sh\n.[][] |= (fromjson? // .)\n```"
    ],
    "utterance": "Replace the value of each object's key 'b' with its parsed form as an object if it contains a serialized object string.",
    "expressions": [
      ".[].b |= fromjson",
      ".[][] |= (fromjson? // .)"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": "{\"c\":2}"
          }
        ],
        "output": [
          {
            "a": 1,
            "b": {
              "c": 2
            }
          }
        ]
      }
    ],
    "identifier": 77988392
  },
  {
    "context": [
      "Here\u0019s the change in words: `.signal[]` objects with a `.name` that contains \"signal\" should set their `.nested.prop` value to `\"CHANGED-\"` plus the aforementioned `.name`'s last digit. The result should be the original json with this modification.",
      ".signal[] |= if .name | contains(\"signal\") then\n  .nested.prop = \"CHANGED-\\(.name | scan(\"\\\\d$\")\")\nend",
      ".signal[] |= (select(.name | contains(\"signal\")) .nested.prop = (.name | gsub(\".*-(?<namedigit>[0-9])\"; \"CHANGED-\\(.namedigit)\")))"
    ],
    "utterance": "Modify the 'signal' array so that for each object whose 'name' contains 'signal', set 'nested.prop' to 'CHANGED-' followed by the last digit of its 'name', preserving the original structure.",
    "expressions": [
      ".signal[] |= (select(.name | contains(\"signal\")) .nested.prop = (.name | gsub(\".*-(?<namedigit>[0-9])\"; \"CHANGED-\\(.namedigit)\")))",
      ".signal[] |= if .name | contains(\"signal\") then\n  .nested.prop = \"CHANGED-\\(.name | scan(\"\\\\d$\")\")\nend"
    ],
    "data": [
      {
        "input": {
          "noise1": 5,
          "signal": [
            {
              "name": "child-signal-1",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-noise-2",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-signal-3",
              "nested": {
                "prop": "child-prop-3"
              }
            }
          ],
          "noise2": [
            {
              "name": "child-signal-1",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-noise-2",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-signal-3",
              "nested": {
                "prop": "child-prop-3"
              }
            }
          ]
        },
        "output": {
          "noise1": 5,
          "signal": [
            {
              "name": "child-signal-1",
              "nested": {
                "prop": "CHANGED-1"
              }
            },
            {
              "name": "child-noise-2",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-signal-3",
              "nested": {
                "prop": "CHANGED-3"
              }
            }
          ],
          "noise2": [
            {
              "name": "child-signal-1",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-noise-2",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-signal-3",
              "nested": {
                "prop": "child-prop-3"
              }
            }
          ]
        }
      }
    ],
    "identifier": 77925097
  },
  {
    "context": [
      "This is working great for \"smaller\" geojson (< 1.4 GB):",
      "jq '.features | map(.geometry.coordinates) | map(.[]) | map(first) | .[] | {\"long\": first, \"lat\": last} | [.long, .lat] | @csv' small.geojson",
      "But I got a \"Killed\" message (I am assuming I am running out of memory)",
      "So, this can be translated to a --stream version as follows:",
      "fromstream(5|truncate_stream(inputs))[0] | @csv"
    ],
    "utterance": "Extract the first coordinate pair from each Polygon feature as a CSV list of longitude and latitude, streaming over large input to avoid memory issues.",
    "expressions": [
      ".features[].geometry.coordinates[][0] | @csv",
      "fromstream(5|truncate_stream(inputs))[0] | @csv"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      -84.959634,
                      32.421887
                    ],
                    [
                      -84.95982,
                      32.421889
                    ],
                    [
                      -84.959822,
                      32.421797
                    ],
                    [
                      -84.959767,
                      32.421796
                    ],
                    [
                      -84.959767,
                      32.421771
                    ],
                    [
                      -84.959636,
                      32.421769
                    ],
                    [
                      -84.959634,
                      32.421887
                    ]
                  ]
                ]
              },
              "properties": {
                "release": 2,
                "capture_dates_range": "3/26/2020-7/22/2020"
              }
            },
            {
              "type": "Feature",
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      -84.959636,
                      32.42095
                    ],
                    [
                      -84.959715,
                      32.42095
                    ],
                    [
                      -84.959714,
                      32.420984
                    ],
                    [
                      -84.959816,
                      32.420985
                    ],
                    [
                      -84.959818,
                      32.420849
                    ],
                    [
                      -84.959637,
                      32.420848
                    ],
                    [
                      -84.959636,
                      32.42095
                    ]
                  ]
                ]
              },
              "properties": {
                "release": 2,
                "capture_dates_range": "3/26/2020-7/22/2020"
              }
            }
          ]
        },
        "output": [
          "-84.959634,32.421887",
          "-84.959636,32.42095"
        ]
      }
    ],
    "identifier": 77962098
  },
  {
    "context": [
      "I tried this:\n```lang-bash\njq -r --arg quote \"\\\"\" (\"alicreate \" + $quote + .\"alias-name\" + $quote + \",\" + $quote + .\"member-entry\".\"alias-entry-name\"[] + $quote)'\n```\nbut it gives a one by one line instead of a sequential.",
      "Iterating over an array produces its items. To instead join the items into a single string, use the [`join` filter](https://jqlang.github.io/jq/manual/#join). Also, inside strings you can use `\\\"` to generate quotes, and [string interpolation `\\(\u2026)`](https://jqlang.github.io/jq/manual/#string-interpolation) to inject values.",
      "jq -r '\"alicreate \\\"\\(.\"alias-name\")\\\",\\\"\\(\n  .\"member-entry\".\"alias-entry-name\" | join(\";\")\n)\\\"\"'",
      "We can use the `@csv` filter to handle quoting for us:",
      "jq -r '\n  [.\"alias-name\", (.\"member-entry\".\"alias-entry-name\" | join(\";\"))]\n  | @csv\n  | \"alicreate \" + .\n'"
    ],
    "utterance": "For each object, create a line starting with alicreate, then the alias-name in double quotes, a comma, and the semicolon-separated list of alias-entry-name values in double quotes, all on one line per object.",
    "expressions": [
      "\"alicreate \\\"\\(.\"alias-name\")\\\",\\\"\\(.\"member-entry\".\"alias-entry-name\" | join(\";\"))\\\"\"",
      "[.\"alias-name\", (.\"member-entry\".\"alias-entry-name\" | join(\";\"))] | @csv | \"alicreate \" + ."
    ],
    "data": [
      {
        "input": [
          {
            "alias-name": "soufriere",
            "member-entry": {
              "alias-entry-name": [
                "21:00:f4:e9:d4:50:56:7e",
                "21:00:f4:e9:d4:50:56:7f"
              ]
            }
          },
          {
            "alias-name": "stromboli",
            "member-entry": {
              "alias-entry-name": [
                "21:00:f4:e9:d4:50:56:8e",
                "21:00:f4:e9:d4:50:56:9e"
              ]
            }
          }
        ],
        "output": [
          "alicreate \"soufriere\",\"21:00:f4:e9:d4:50:56:7e;21:00:f4:e9:d4:50:56:7f\"",
          "alicreate \"stromboli\",\"21:00:f4:e9:d4:50:56:8e;21:00:f4:e9:d4:50:56:9e\""
        ]
      }
    ],
    "identifier": 77981950
  },
  {
    "context": [
      "I want to get next output:\n\n```\n0, 1, 2, 3, 4, ... etc\n40 41 42 43 44 ... etc\n```\n\nIs it possible to get such a list using `jq`? Perhaps with subsequent `awk/sed` processing.",
      "Here's an approach that sorts each `.thread_siblings` array, and then the array of all sibling arrays, transposes it to get all first numbers in one array, and all last ones in another, and joins both with a glue string:\n```sh\njq -r '\n  [.numa_topology.cpus[] | select(.numa_node == 0).thread_siblings | sort]\n  | sort | transpose[] | join(\", \")\n'\n```",
      "Example output:\n```\n0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19\n40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59\n```"
    ],
    "utterance": "Print lines listing the thread_siblings values for all CPUs with numa_node equal to 0, grouped by sibling position, each line containing comma-separated values.",
    "expressions": [
      "[.numa_topology.cpus[] | select(.numa_node == 0).thread_siblings | sort]\n| sort | transpose[] | join(\", \")",
      ".numa_topology.cpus | map(\n  select(.numa_node == 0) .thread_siblings | sort\n) | sort | transpose[] | @csv",
      ".numa_topology.cpus\n| map(select(.numa_node == 0).thread_siblings)\n| sort_by(min)\n| map(sort)\n| transpose | .[] | @csv"
    ],
    "identifier": 78003589
  },
  {
    "context": [
      "Here's the data:\n[\n{\"field1\":\"1\", \"field2\":\"x\", \"Tags\":[{\"Key\": \"Name\", \"Value\": \"Name1\"}, {\"Key\": \"tag1\", \"Value\": \"tag1valuea\"}]},\n{\"field1\":\"2\", \"field2\":\"y\", \"Tags\":[{\"Key\": \"Name\", \"Value\": \"Name2\"}]},\n{\"field1\":\"3\", \"field2\":\"z\", \"Tags\":[{\"Key\": \"tag2\", \"Value\": \"tag2valueb\"}]}\n]",
      "The output I want is:\n1 x name1\n2 y name2\n3 z",
      "jq -r '.[] | .field1 + \" \" + .field2 + \" \" + (.Tags[] | select(.Key == \"Name\") .Value)'",
      "jq -r '.[] | .field1 + \" \" + .field2 + \" \" + (.Tags[] | if(.Key == \"Name\") then .Value else null end)'",
      ".[]\n| [.field1, .field2, (.Tags[]|select(.Key == \"Name\").Value)]\n| join(\" \")",
      ".[] | (.Tags | map(select(.Key == \"Name\").Value)) as $m\n| \"\\(.field1) \\(.field2) \\($m | join(\" \"))\""
    ],
    "utterance": "List field1, field2, and the Value of a tag where Key is Name if present, leaving the field blank if not, for each object in the array.",
    "expressions": [
      ".[] | [.field1, .field2, (.Tags[] | select(.Key == \"Name\").Value)] | join(\" \")",
      ".[] | (.Tags | map(select(.Key == \"Name\").Value)) as $m | \"\\(.field1) \\(.field2) \\($m | join(\" \"))\""
    ],
    "data": [
      {
        "input": [
          {
            "field1": "1",
            "field2": "x",
            "Tags": [
              {
                "Key": "Name",
                "Value": "Name1"
              },
              {
                "Key": "tag1",
                "Value": "tag1valuea"
              }
            ]
          },
          {
            "field1": "2",
            "field2": "y",
            "Tags": [
              {
                "Key": "Name",
                "Value": "Name2"
              }
            ]
          },
          {
            "field1": "3",
            "field2": "z",
            "Tags": [
              {
                "Key": "tag2",
                "Value": "tag2valueb"
              }
            ]
          }
        ],
        "output": "1 x Name1\n2 y Name2\n3 z"
      }
    ],
    "identifier": 77991602
  },
  {
    "context": [
      "jq -c '.[]' ./data.json | while read i; do    \n    curl --location 'http://localhost:8080/endpoint' \\\n    --header 'Authorization: Bearer xxx' \\\n    --json $i\ndone",
      "data.json\n[\n  {\n    \"orderId\": \"abc111\",\n    \"amount\": 2,\n    \"name\": \"item 1\"\n  },\n  {\n    \"orderId\": \"abc222\",\n    \"amount\": 5,\n    \"name\": \"item 2\"\n  }\n]",
      "jq -c '.[]' ./data.json"
    ],
    "utterance": "Extract each object as a compact string from an array in a file for use as a POST payload in a shell loop.",
    "expressions": [
      "jq -c '.[]' ./data.json"
    ],
    "data": [
      {
        "input": [
          {
            "orderId": "abc111",
            "amount": 2,
            "name": "item 1"
          },
          {
            "orderId": "abc222",
            "amount": 5,
            "name": "item 2"
          }
        ],
        "output": [
          "{\"orderId\":\"abc111\",\"amount\":2,\"name\":\"item 1\"}",
          "{\"orderId\":\"abc222\",\"amount\":5,\"name\":\"item 2\"}"
        ]
      }
    ],
    "identifier": 78021543
  },
  {
    "context": [
      "I want to check that each top level key ie. `id1, id2` is present only once in a file and if not produce an error.",
      "You can use jq's stream representation, which can be called either via the `--stream` flag or via the `tostream` function. The difference is that for the function, the input has already been parsed (and duplicate keys collapsed), whereas using the flag would start streaming while reading the input, thus before any collapsing could occur.",
      "The following (shell-free) approach tries to mitigate this by instead collecting all paths provided by the flag variant into an array, and then comparing its `sort`ed version with its `unique`d version (which is also automatically sorted), rendering irrelevant a potential sorting performed by the employed processor's implementation.",
      "$ jq --stream -n '[inputs[-2] | arrays] | sort == unique' nodupkeys.json",
      "$ jq --stream -n '[inputs[-2] | arrays] | sort == unique' withdupkeys.json"
    ],
    "utterance": "Determine if any top-level key is present more than once in an object and output true if all keys are unique, otherwise false.",
    "expressions": [
      "[inputs[-2] | arrays] | sort == unique"
    ],
    "data": [
      {
        "input": {
          "id1": {
            "key": "value"
          },
          "id2": {
            "key": "value"
          }
        },
        "output": true
      },
      {
        "input": {
          "id1": {
            "key": "value"
          }
        },
        "output": false
      }
    ],
    "identifier": 78021300
  },
  {
    "context": [
      "My expected output is -\r\n\r\n    {\"book_id\"},{\"edition_id\"}\r\n\r\n\r\nHere if there are more primary keys, they should also get appended in expected output.\r\n\r\nPlease help me with correct JQ that will work in jqplay.org",
      "jq -r '.body.primarykey | map(\"{\\\"\\(.)\\\"}\") | join(\",\")'",
      "This will output a single line, each key quoted and enclosed in curly braces; and multiple keys separated by a comma:\r\n\r\n    {\"book_id\"},{\"edition_id\"}\r\n"
    ],
    "utterance": "Output all primary keys as a single comma-separated line, each surrounded by curly braces and double quotes, such as {\"book_id\"},{\"edition_id\"}.",
    "expressions": [
      ".body.primarykey | map(\"{\\\"\\(.)\\\"}\") | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "body": {
            "primarykey": [
              "book_id",
              "edition_id"
            ],
            "members": [
              {
                "name": "book_id",
                "type": "NUMBER"
              },
              {
                "name": "edition_id",
                "type": "NUMBER"
              },
              {
                "name": "title",
                "type": "VARCHAR2"
              }
            ],
            "links": [
              {
                "rel": "collection",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/",
                "mediaType": "application/json"
              },
              {
                "rel": "canonical",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/books/",
                "mediaType": "application/json"
              },
              {
                "rel": "alternate",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/open-api-catalog/books/",
                "mediaType": "application/openapi+json"
              },
              {
                "rel": "describes",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/books/"
              }
            ]
          }
        },
        "output": "{\"book_id\"},{\"edition_id\"}"
      }
    ],
    "identifier": 78027649
  },
  {
    "context": [
      "\"curl -u \\\"$user:$password\\\" \\\"https://mylink.dot\\\" \\\n    | tee >(jq -r '.dataSummaries[] | .dataId' >> my_data_file.txt ) \\\n    >(jq -r '.nextToken'>next_token_file.txt) > /dev/null\"",
      "\"curl -u \\\"$user:$password\\\" \\\"https://mylink.dot\\\" | tee >(jq -r '.dataSummaries[] | .dataId' | read my_array[index] ) >(jq -r '.nextToken'>next_token_file.txt) > /dev/null\"",
      "\"tee >(jq -r '.dataSummaries[] | .dataId' >> my_data_file.txt ) ... >(jq -r '.nextToken'>next_token_file.txt)\"",
      "\"tee >(jq -r '.dataSummaries[] | .dataId' | read my_array[index] ) ... >(jq -r '.nextToken'>next_token_file.txt)\"",
      "\"jq -r '.dataSummaries[] | .dataId'\"",
      "\"jq -r '.nextToken'\""
    ],
    "utterance": "Extract each value in the dataSummaries[].dataId array and the nextToken value from the API response.",
    "expressions": [
      ".dataSummaries[] | .dataId",
      ".nextToken"
    ],
    "identifier": 78028685
  },
  {
    "context": [
      "Here's my example ([playground link][2]):\r\n\r\nFilter: `(.signal[] | select(.name | contains(\"signal\"))) as $matches | .`",
      "Output:\r\n\r\n{\r\n  \"noise1\": 5,\r\n  \"signal\": [...],\r\n  \"noise2\": [...] \r\n} \r\n{\r\n  ... \r\n}",
      "I'd also like to understand why my output prints the input twice, thereby making it invalid json. I think that relates to `(.signal[] | select(.name | contains(\"signal\")))` returning 2 results, but I don't understand how that's relevant if I'm not referencing the variable on the RHS.",
      "What you're really actually asking about is why the expression that follows the `|` is evaluated multiple times. This results from the use of `.[]`.",
      "When something produces multiple values, the rest of the pipeline is evaluated for each of those values.",
      "The expression `exp as $x | ...` means: for each value of expression `exp`, run the rest of the pipeline with the entire original input, and with `$x` set to that value.",
      "Let\u2019s look at a slightly more elaborate version of my original version:\r\n\r\n```sh\r\nprintf '%s\\n' '[ \"abc\", \"def\" ]' | jq -c '.[] as $x | [ ., $x ]'\r\n```\r\n\r\n```json\r\n[[\"abc\",\"def\"],\"abc\"]\r\n[[\"abc\",\"def\"],\"def\"]\r\n```",
      "The documentation I\u2019ve quoted says this should be equivalent to the following:\r\n\r\n```sh\r\nprintf '%s\\n' '[ \"abc\", \"def\" ]' | jq -c '\r\n   . as $orig |  # Save original input.\r\n   .[] |         # Produces multiple values.\r\n   .  as $x |    # This is evaluated for each of those values.\r\n   $orig |       # Set `.` to the original input.\r\n   [ ., $x ]\r\n'\r\n```\r\n\r\n```json\r\n[[\"abc\",\"def\"],\"abc\"]\r\n[[\"abc\",\"def\"],\"def\"]\r\n```"
    ],
    "utterance": "Show the original input once for each value in .signal[] whose name contains \"signal\", and explain why the output is repeated.",
    "expressions": [
      "(.signal[] | select(.name | contains(\"signal\"))) as $matches | .",
      ". as $orig | .signal[] | select(.name | contains(\"signal\")) | $orig"
    ],
    "data": [
      {
        "input": {
          "noise1": 5,
          "signal": [
            {
              "name": "child-signal-1",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-noise-2",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-signal-3",
              "nested": {
                "prop": "child-prop-3"
              }
            }
          ],
          "noise2": [
            {
              "name": "child-signal-1",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-noise-2",
              "nested": {
                "prop": "child-prop-3"
              }
            },
            {
              "name": "child-signal-3",
              "nested": {
                "prop": "child-prop-3"
              }
            }
          ]
        },
        "output": [
          {
            "noise1": 5,
            "signal": [
              {
                "name": "child-signal-1",
                "nested": {
                  "prop": "child-prop-3"
                }
              },
              {
                "name": "child-noise-2",
                "nested": {
                  "prop": "child-prop-3"
                }
              },
              {
                "name": "child-signal-3",
                "nested": {
                  "prop": "child-prop-3"
                }
              }
            ],
            "noise2": [
              {
                "name": "child-signal-1",
                "nested": {
                  "prop": "child-prop-3"
                }
              },
              {
                "name": "child-noise-2",
                "nested": {
                  "prop": "child-prop-3"
                }
              },
              {
                "name": "child-signal-3",
                "nested": {
                  "prop": "child-prop-3"
                }
              }
            ]
          },
          {
            "noise1": 5,
            "signal": [
              {
                "name": "child-signal-1",
                "nested": {
                  "prop": "child-prop-3"
                }
              },
              {
                "name": "child-noise-2",
                "nested": {
                  "prop": "child-prop-3"
                }
              },
              {
                "name": "child-signal-3",
                "nested": {
                  "prop": "child-prop-3"
                }
              }
            ],
            "noise2": [
              {
                "name": "child-signal-1",
                "nested": {
                  "prop": "child-prop-3"
                }
              },
              {
                "name": "child-noise-2",
                "nested": {
                  "prop": "child-prop-3"
                }
              },
              {
                "name": "child-signal-3",
                "nested": {
                  "prop": "child-prop-3"
                }
              }
            ]
          }
        ]
      }
    ],
    "identifier": 77924756
  },
  {
    "context": [
      "I try to [use][1] `map(select(.key == \"WEIGHT_BODYFAT_BROAD\"))` to filter this type of records, but got error message.",
      "In your case the JSON consists of multiple objects, so you have to wrap them in an array. Try to insert `[` at the beginning of the file and `]` at the very end, don\u2019t change anything else.",
      "Then try your call to jq again."
    ],
    "utterance": "Filter samplePoints arrays to return only those objects where key equals \"WEIGHT_BODYFAT_BROAD\".",
    "expressions": [
      ".[].samplePoints[] | select(.key == \"WEIGHT_BODYFAT_BROAD\")"
    ],
    "data": [
      {
        "input": [
          {
            "timeZone": "+0200",
            "deviceCode": 202590286,
            "type": 8,
            "version": 1622385523034,
            "recordId": "TkgTDAAAAAAIAAAArF62vXkBAAA=",
            "dataId": 0,
            "healthDataSource": 0,
            "appType": 1,
            "startTime": 1622385516204,
            "endTime": 1622385516204,
            "samplePoints": [
              {
                "mergedFlag": 0,
                "unit": "0",
                "startTime": 1622385516204,
                "endTime": 1622385516204,
                "value": "{\"age\":29,\"basalMetabolism\":2266.0,\"bmi\":34.0,\"bodyAge\":38,\"bodyFatRate\":33.20000076293945,\"bodyScore\":67.0,\"bodySize\":5,\"bodyWeight\":115.19999694824219,\"boneSalt\":3.989405632019043,\"extendAttribute\":\"0\",\"gender\":1,\"heartRate\":84,\"height\":184,\"moisture\":51.61684036254883,\"moistureRate\":44.8062858581543,\"muscleMass\":72.9608154296875,\"pole\":1,\"proteinRate\":21.34735107421875,\"skeletalMusclelMass\":42.30829620361328,\"visceralFatLevel\":20.0}",
                "key": "WEIGHT_BODYFAT_BROAD"
              }
            ]
          },
          {
            "timeZone": "+0200",
            "deviceCode": 202576998,
            "type": 7,
            "version": 1622408526036,
            "recordId": "ZhQTDAAAAAAHAAAAIAvJvXkBAAA=",
            "dataId": 0,
            "healthDataSource": 0,
            "appType": 1,
            "startTime": 1622386740000,
            "endTime": 1622386800000,
            "samplePoints": [
              {
                "mergedFlag": 0,
                "unit": "0",
                "startTime": 1622386740000,
                "endTime": 1622386800000,
                "value": "78.0",
                "key": "DATA_POINT_DYNAMIC_HEARTRATE"
              }
            ]
          },
          {
            "timeZone": "+0800",
            "deviceCode": 202590286,
            "type": 8,
            "version": 1622615424878,
            "recordId": "TkgTDAAAAAAIAAAAAHxqy3kBAAA=",
            "dataId": 0,
            "healthDataSource": 0,
            "appType": 1,
            "startTime": 1622615424000,
            "endTime": 1622615424000,
            "samplePoints": [
              {
                "mergedFlag": 0,
                "startTime": 1622615424000,
                "endTime": 1622615424000,
                "value": "{\"age\":29,\"bodyWeight\":114.3,\"extendAttribute\":\"0\",\"gender\":1,\"height\":184,\"pole\":1,\"weightDivision\":2}",
                "key": "WEIGHT_BODYFAT_BROAD"
              }
            ]
          }
        ],
        "output": [
          {
            "mergedFlag": 0,
            "unit": "0",
            "startTime": 1622385516204,
            "endTime": 1622385516204,
            "value": "{\"age\":29,\"basalMetabolism\":2266.0,\"bmi\":34.0,\"bodyAge\":38,\"bodyFatRate\":33.20000076293945,\"bodyScore\":67.0,\"bodySize\":5,\"bodyWeight\":115.19999694824219,\"boneSalt\":3.989405632019043,\"extendAttribute\":\"0\",\"gender\":1,\"heartRate\":84,\"height\":184,\"moisture\":51.61684036254883,\"moistureRate\":44.8062858581543,\"muscleMass\":72.9608154296875,\"pole\":1,\"proteinRate\":21.34735107421875,\"skeletalMusclelMass\":42.30829620361328,\"visceralFatLevel\":20.0}",
            "key": "WEIGHT_BODYFAT_BROAD"
          },
          {
            "mergedFlag": 0,
            "startTime": 1622615424000,
            "endTime": 1622615424000,
            "value": "{\"age\":29,\"bodyWeight\":114.3,\"extendAttribute\":\"0\",\"gender\":1,\"height\":184,\"pole\":1,\"weightDivision\":2}",
            "key": "WEIGHT_BODYFAT_BROAD"
          }
        ]
      }
    ],
    "identifier": 78026070
  },
  {
    "context": [
      "I use curl to have this answer :",
      "curl -sX https://xx.com | jq -r '.res.out[].server // empty | {host: .host, description: .description}'",
      "And I use a second curl to get the state of serveur if it is running or not. on second curl I need the name of host to get the state of server which I get on first curl, and I want to add also the description of server.",
      "So, I would like to store the list of host and description on a map, to use on second curl",
      "for host in ${array_host[@]}; do \n  echo \"HOST: $host\";\n  echo \"Description: $description\"\n  curl -sX https://xx.com/servers/$host | jq -r '.specInfo.resul.out[].server.operationalStatus //empty';\ndone",
      "I expect somethink like that\n\n    HOST: Server1\n    Description: Server 1\n    RUNNING\n    HOST: Server2\n    Description: Server 2\n    RUNNING\n    HOST: Server3\n    Description: Server 3\n    NOT RUNNING",
      "Without more sample data, it's hard to test, but something like this should fit your needs:",
      "curl \u2026 | jq -r '.res.out[].server | .host, .description' |\nwhile read -r host; read -r desc; do\n  printf 'HOST: %s\\nDescription: %s\\n' \"$host\" \"$desc\"\n  curl \u2026 | jq \u2026\ndone"
    ],
    "utterance": "Extract each server's host and description, then for each host, fetch and print its operational status together with its description.",
    "expressions": [
      ".res.out[].server | .host, .description",
      ".specInfo.resul.out[].server.operationalStatus //empty"
    ],
    "data": [
      {
        "input": {
          "res": {
            "out": [
              {
                "server": {
                  "host": "server1",
                  "description": "server 1"
                }
              },
              {
                "server": {
                  "host": "server2",
                  "description": "server 2"
                }
              },
              {
                "server": {
                  "host": "server3",
                  "description": "server 3"
                }
              }
            ]
          }
        },
        "output": [
          {
            "host": "server1",
            "description": "server 1"
          },
          {
            "host": "server2",
            "description": "server 2"
          },
          {
            "host": "server3",
            "description": "server 3"
          }
        ]
      },
      {
        "input": {
          "specInfo": {
            "resul": {
              "out": [
                {
                  "server": {
                    "operationalStatus": "RUNNING"
                  }
                }
              ]
            }
          }
        },
        "output": "RUNNING"
      }
    ],
    "identifier": 78031134
  },
  {
    "context": [
      "And i need the output like\n\n    {\n    \"zoo\": [\n       { \"x\": { \"guesst\": \"zebra\" } },\n       { \"y\": { \"guesst\": \"zebra\" } }\n      ]\n    }\n",
      "But, what if i do not know the order of the objects in the array?",
      "Iterate over all items using [.[]](https://jqlang.github.io/jq/manual/#array-object-value-iterator), and use [select](https://jqlang.github.io/jq/manual/#select) and [has](https://jqlang.github.io/jq/manual/#has) to filter for the right ones:",
      "jq '(.zoo[] | select(has(\"x\"))).x.guesst = (.zoo[] | select(has(\"y\"))).y.guesst'"
    ],
    "utterance": "Set the value of the x.guesst property in the zoo array to the value of the y.guesst property, regardless of their positions in the array.",
    "expressions": [
      "(.zoo[] | select(has(\"x\"))).x.guesst = (.zoo[] | select(has(\"y\"))).y.guesst"
    ],
    "data": [
      {
        "input": {
          "zoo": [
            {
              "x": {
                "guesst": ""
              }
            },
            {
              "y": {
                "guesst": "zebra"
              }
            }
          ]
        },
        "output": {
          "zoo": [
            {
              "x": {
                "guesst": "zebra"
              }
            },
            {
              "y": {
                "guesst": "zebra"
              }
            }
          ]
        }
      }
    ],
    "identifier": 78035762
  },
  {
    "context": [
      "I need to copy from zebra's sum into fish's sum.",
      "Actually, I need to do it be the field \"name\".",
      "(.zoo[] | select(.room.name == \"x\").gpu.sum) =\n(.zoo[] | select(.room.name == \"y\").gpu.sum)",
      "(.zoo|first(.[]|select(.room.name==\"y\").gpu.sum)//null) as $sum\n| if $sum\n  then .zoo |= map(if .room.name==\"x\" then .gpu.sum=$sum else . end)\n  else .\n  end"
    ],
    "utterance": "Set the value of the 'sum' field in the 'gpu' object of the array element whose 'room.name' is 'x' to the value of 'sum' from the element whose 'room.name' is 'y'.",
    "expressions": [
      "(.zoo[] | select(.room.name == \"x\").gpu.sum) =\n(.zoo[] | select(.room.name == \"y\").gpu.sum)",
      "(.zoo|first(.[]|select(.room.name==\"y\").gpu.sum)//null) as $sum\n| if $sum\n  then .zoo |= map(if .room.name==\"x\" then .gpu.sum=$sum else . end)\n  else .\n  end"
    ],
    "data": [
      {
        "input": {
          "zoo": [
            {
              "room": {
                "name": "x"
              },
              "gpu": {
                "id": "fish",
                "sum": 0
              }
            },
            {
              "room": {
                "name": "y"
              },
              "gpu": {
                "id": "zebra",
                "sum": 797
              }
            }
          ]
        },
        "output": {
          "zoo": [
            {
              "room": {
                "name": "x"
              },
              "gpu": {
                "id": "fish",
                "sum": 797
              }
            },
            {
              "room": {
                "name": "y"
              },
              "gpu": {
                "id": "zebra",
                "sum": 797
              }
            }
          ]
        }
      }
    ],
    "identifier": 78039985
  },
  {
    "context": [
      "Here, my requirement is - I want to remove record / field from output `body:{}` which is having same name as `primarykey`.",
      "The key is to reuse the variable `$k` once for forming the key name and then later to exclude it from the members.",
      ".body.primarykey[] as $k | \n{ \n  parameters: {($k): \"\" }, \n  body: (.body.members | map(select(.name != $k) | {(.name): .type | ascii_downcase}) | add)\n}"
    ],
    "utterance": "Return an object with a parameters key mapping each primarykey name to an empty string, and a body key mapping all member names (except those matching the primarykey) to their type values in lowercase.",
    "expressions": [
      ".body.primarykey[] as $k | { parameters: {($k): \"\" }, body: (.body.members | map(select(.name != $k) | {(.name): .type | ascii_downcase}) | add) }"
    ],
    "data": [
      {
        "input": {
          "body": {
            "name": "DATATYPES",
            "primarykey": [
              "db_number"
            ],
            "members": [
              {
                "name": "db_number",
                "type": "NUMBER"
              },
              {
                "name": "db_date",
                "type": "DATE"
              },
              {
                "name": "db_timestamp",
                "type": "TIMESTAMP(6)"
              },
              {
                "name": "db_timestamp_with_local_time_zone",
                "type": "TIMESTAMP(6) WITH LOCAL TIME ZONE"
              },
              {
                "name": "db_char",
                "type": "CHAR"
              },
              {
                "name": "db_float",
                "type": "FLOAT"
              },
              {
                "name": "db_nchar",
                "type": "NCHAR"
              },
              {
                "name": "db_nvarchar2",
                "type": "NVARCHAR2"
              },
              {
                "name": "db_varchar2",
                "type": "VARCHAR2"
              },
              {
                "name": "db_binary_float",
                "type": "BINARY_FLOAT"
              },
              {
                "name": "db_binary_double",
                "type": "BINARY_DOUBLE"
              },
              {
                "name": "db_timestamp_with_time_zone",
                "type": "TIMESTAMP(6) WITH TIME ZONE"
              },
              {
                "name": "db_interval_year_to_month",
                "type": "INTERVAL YEAR(2) TO MONTH"
              },
              {
                "name": "db_interval_day_to_second",
                "type": "INTERVAL DAY(2) TO SECOND(6)"
              },
              {
                "name": "db_long",
                "type": "LONG"
              },
              {
                "name": "db_blob",
                "type": "BLOB"
              },
              {
                "name": "db_clob",
                "type": "CLOB"
              },
              {
                "name": "db_boolean",
                "type": "CHAR"
              }
            ],
            "links": [
              {
                "rel": "collection",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/",
                "mediaType": "application/json"
              },
              {
                "rel": "canonical",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/datatypes/",
                "mediaType": "application/json"
              },
              {
                "rel": "alternate",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/open-api-catalog/datatypes/",
                "mediaType": "application/openapi+json"
              },
              {
                "rel": "describes",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/datatypes/"
              }
            ]
          }
        },
        "output": {
          "parameters": {
            "db_number": ""
          },
          "body": {
            "db_date": "date",
            "db_timestamp": "timestamp(6)",
            "db_timestamp_with_local_time_zone": "timestamp(6) with local time zone",
            "db_char": "char",
            "db_float": "float",
            "db_nchar": "nchar",
            "db_nvarchar2": "nvarchar2",
            "db_varchar2": "varchar2",
            "db_binary_float": "binary_float",
            "db_binary_double": "binary_double",
            "db_timestamp_with_time_zone": "timestamp(6) with time zone",
            "db_interval_year_to_month": "interval year(2) to month",
            "db_interval_day_to_second": "interval day(2) to second(6)",
            "db_long": "long",
            "db_blob": "blob",
            "db_clob": "clob",
            "db_boolean": "char"
          }
        }
      }
    ],
    "identifier": 78000879
  },
  {
    "context": [
      "I want to merge the `.environments.default` and `.environments.dev` objects together, so that `dev` values override any `default` values and `default` values fill in anything not defined in the `dev` object. If I use `.environments.default * .environments.dev` most of the objects are merged correctly, except for the array lists under the `env` and `secrets` objects. The entire `dev` object is used, but I want the array lists to be merged with unique values.",
      "The env list should be unique by name and the secrets list should be unique by secretID. [\u2026] I was wondering if it could be unique by the first object key in the array? [\u2026] name always comes before value and secretID always comes before mountPath",
      "This captures and iterates over all items of non-empty arrays from the `.default` branch (saving the array path with `paths(arrays | select(has(0)))`, each item's value with `getpath(\u2026)[]`, and the first item's key and value using `to_entries[0]`). The iteration's base document is the merge you already performed, but with these arrays removed from the `.default` branch, so the saved items can be individually tested and appended to it if they pass the condition that no other first key's value matches theirs: `IN(.[][$v0.key]; $v0.value) | not`.",
      "```\n.environments | [.default | paths(arrays | select(has(0))) as $p\n  | getpath($p)[] as $v | {$p,$v,v0:($v | to_entries[0])}\n] as $a | reduce $a[] as {$p,$v,$v0} ((.default | delpaths([$a[].p])) * .dev;\n  setpath($p; getpath($p) | . + [select(IN(.[][$v0.key]; $v0.value) | not) | $v])\n)\n```"
    ],
    "utterance": "Merge the environments.default and environments.dev objects so dev values override defaults, but for child arrays, merge items uniquely by the key of the first field in each array object.",
    "expressions": [
      ".environments | [.default | paths(arrays | select(has(0))) as $p\n  | getpath($p)[] as $v | {$p,$v,v0:($v | to_entries[0])}\n] as $a | reduce $a[] as {$p,$v,$v0} ((.default | delpaths([$a[].p])) * .dev;\n  setpath($p; getpath($p) | . + [select(IN(.[][$v0.key]; $v0.value) | not) | $v])\n)"
    ],
    "data": [
      {
        "input": {
          "environments": {
            "default": {
              "config": {
                "security": {
                  "user": 0,
                  "group": 0
                },
                "resources": {
                  "limits": {
                    "memory": "256Mi",
                    "cpu": "500m"
                  }
                },
                "env": [
                  {
                    "name": "DEFAULT_ENV",
                    "value": "DEFAULT_ENV_VALUE"
                  },
                  {
                    "name": "BASE_URL",
                    "value": "DEFAULT_BASE_URL"
                  }
                ],
                "secrets": [
                  {
                    "secretID": "567",
                    "mountPath": "/default/dir/to/567/path"
                  },
                  {
                    "secretID": "123",
                    "mountPath": "/default/dir/to/123/path"
                  },
                  {
                    "secretUUID": "789",
                    "mountPath": "/default/dir/to/789/path"
                  }
                ]
              }
            },
            "dev": {
              "config": {
                "replicas": 1,
                "resources": {
                  "limits": {
                    "cpu": "5000m"
                  }
                },
                "env": [
                  {
                    "name": "BASE_URL",
                    "value": "DEV_BASE_URL"
                  },
                  {
                    "name": "DEV_ENV_1",
                    "value": "DEV_ENV_1"
                  }
                ],
                "secrets": [
                  {
                    "secretID": "456",
                    "mountPath": "/dev/dir/to/456/path"
                  },
                  {
                    "secretID": "123",
                    "mountPath": "/dev/dir/to/456/path"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "config": {
            "security": {
              "user": 0,
              "group": 0
            },
            "resources": {
              "limits": {
                "memory": "256Mi",
                "cpu": "5000m"
              }
            },
            "env": [
              {
                "name": "BASE_URL",
                "value": "DEV_BASE_URL"
              },
              {
                "name": "DEV_ENV_1",
                "value": "DEV_ENV_1"
              },
              {
                "name": "DEFAULT_ENV",
                "value": "DEFAULT_ENV_VALUE"
              }
            ],
            "secrets": [
              {
                "secretID": "456",
                "mountPath": "/dev/dir/to/456/path"
              },
              {
                "secretID": "123",
                "mountPath": "/dev/dir/to/456/path"
              },
              {
                "secretID": "567",
                "mountPath": "/default/dir/to/567/path"
              },
              {
                "secretUUID": "789",
                "mountPath": "/default/dir/to/789/path"
              }
            ],
            "replicas": 1
          }
        }
      }
    ],
    "identifier": 77998185
  },
  {
    "context": [
      "Here, my requirement is - I want type of primary also in parameters in output by comparing it with matching record from members.",
      "My expected output is -\n{\n\"parameters\": {\n\"db_number\": \"number\"\n}\n}",
      "Here, my requirement is - I want same parameters as above with type of primarykey along with body which eliminates matching primarykey from body.",
      "My expected output is -\n{\n\"parameters\": {\n\"db_number\": \"number\"\n},\n\"body\": {\n\"db_date\": \"date\",\n\"db_timestamp\": \"timestamp(6)\",\n\"db_timestamp_with_local_time_zone\": \"timestamp(6) with local time zone\",\n\"db_char\": \"char\",\n\"db_float\": \"float\",\n\"db_nchar\": \"nchar\",\n\"db_nvarchar2\": \"nvarchar2\",\n\"db_varchar2\": \"varchar2\",\n\"db_binary_float\": \"binary_float\",\n\"db_binary_double\": \"binary_double\",\n\"db_timestamp_with_time_zone\": \"timestamp(6) with time zone\",\n\"db_interval_year_to_month\": \"interval year(2) to month\",\n\"db_interval_day_to_second\": \"interval day(2) to second(6)\",\n\"db_long\": \"long\",\n\"db_blob\": \"blob\",\n\"db_clob\": \"clob\",\n\"db_boolean\": \"char\"\n}\n}",
      ".body | . as {$primarykey} | .members\n| map(.value = (.type | ascii_downcase))\n| group_by(IN(.name; $primarykey[])) | map(from_entries)\n| {parameters: last, body: first}",
      "jq '.body\n   |( .members | map(.value=(.type|ascii_downcase)) | from_entries ) as $mapping\n   |{parameters:(.primarykey | map({key:., value:$mapping[.]}) | from_entries)\n}' input.json",
      "jq '.body\n   |( .members | map(.value=(.type|ascii_downcase)) | from_entries ) as $mapping\n   |{parameters:(.primarykey | map({key:., value:$mapping[.]}) | from_entries),\n     body:$mapping\n}' input.json"
    ],
    "utterance": "Return an object with a parameters field mapping primarykey names to their type (lowercased) and a body field mapping all non-primarykey members names to their type (lowercased).",
    "expressions": [
      ".body | . as {$primarykey} | .members\n| map(.value = (.type | ascii_downcase))\n| group_by(IN(.name; $primarykey[])) | map(from_entries)\n| {parameters: last, body: first}",
      ".body\n   |( .members | map(.value=(.type|ascii_downcase)) | from_entries ) as $mapping\n   |{parameters:(.primarykey | map({key:., value:$mapping[.]}) | from_entries),\n     body:$mapping\n}"
    ],
    "data": [
      {
        "input": {
          "body": {
            "name": "DATATYPES",
            "primarykey": [
              "db_number"
            ],
            "members": [
              {
                "name": "db_number",
                "type": "NUMBER"
              },
              {
                "name": "db_date",
                "type": "DATE"
              },
              {
                "name": "db_timestamp",
                "type": "TIMESTAMP(6)"
              },
              {
                "name": "db_timestamp_with_local_time_zone",
                "type": "TIMESTAMP(6) WITH LOCAL TIME ZONE"
              },
              {
                "name": "db_char",
                "type": "CHAR"
              },
              {
                "name": "db_float",
                "type": "FLOAT"
              },
              {
                "name": "db_nchar",
                "type": "NCHAR"
              },
              {
                "name": "db_nvarchar2",
                "type": "NVARCHAR2"
              },
              {
                "name": "db_varchar2",
                "type": "VARCHAR2"
              },
              {
                "name": "db_binary_float",
                "type": "BINARY_FLOAT"
              },
              {
                "name": "db_binary_double",
                "type": "BINARY_DOUBLE"
              },
              {
                "name": "db_timestamp_with_time_zone",
                "type": "TIMESTAMP(6) WITH TIME ZONE"
              },
              {
                "name": "db_interval_year_to_month",
                "type": "INTERVAL YEAR(2) TO MONTH"
              },
              {
                "name": "db_interval_day_to_second",
                "type": "INTERVAL DAY(2) TO SECOND(6)"
              },
              {
                "name": "db_long",
                "type": "LONG"
              },
              {
                "name": "db_blob",
                "type": "BLOB"
              },
              {
                "name": "db_clob",
                "type": "CLOB"
              },
              {
                "name": "db_boolean",
                "type": "CHAR"
              }
            ],
            "links": [
              {
                "rel": "collection",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/",
                "mediaType": "application/json"
              },
              {
                "rel": "canonical",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/metadata-catalog/datatypes/",
                "mediaType": "application/json"
              },
              {
                "rel": "alternate",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/open-api-catalog/datatypes/",
                "mediaType": "application/openapi+json"
              },
              {
                "rel": "describes",
                "href": "https://tdcvm28s16.bcone.com:7002/ords/testords/datatypes/"
              }
            ]
          }
        },
        "output": {
          "parameters": {
            "db_number": "number"
          },
          "body": {
            "db_date": "date",
            "db_timestamp": "timestamp(6)",
            "db_timestamp_with_local_time_zone": "timestamp(6) with local time zone",
            "db_char": "char",
            "db_float": "float",
            "db_nchar": "nchar",
            "db_nvarchar2": "nvarchar2",
            "db_varchar2": "varchar2",
            "db_binary_float": "binary_float",
            "db_binary_double": "binary_double",
            "db_timestamp_with_time_zone": "timestamp(6) with time zone",
            "db_interval_year_to_month": "interval year(2) to month",
            "db_interval_day_to_second": "interval day(2) to second(6)",
            "db_long": "long",
            "db_blob": "blob",
            "db_clob": "clob",
            "db_boolean": "char"
          }
        }
      }
    ],
    "identifier": 78005777
  }
]