[
  {
    "identifier": 74618227
  },
  {
    "context": [
      "how can I check if json being inside the file is empty, ie. looks like this `{}`? Can it be done with `jq`?"
    ],
    "utterance": "Check if the content of a file is an empty object, i.e., exactly '{}'.",
    "expressions": [
      "jq 'if . == {} then true else false end' file.json",
      "jq 'select(. == {})' file.json"
    ],
    "identifier": 74618012
  },
  {
    "context": [
      "jq -f config/jest.jq -s reports/jest/*.json",
      "If I try to run the same thing within a node script like so however:\n\n      const jq = await cp.spawnSync('jq', ['-f', configPath, '-s', folderPath]);\n\nIt fails - jq.stderr tells me he can't finds \"/reports/jest/*.json\".",
      "That's not a regular expression, but a shell glob (or shell wildcard pattern). It is evaluated by your shell (sh, bash, zsh, \u2026). spawnSync is not running a shell, but executing the binary directly, passing all arguments verbatim.",
      "If you need a shell's behavior, you must execute a shell or resolve the wildcard somehow else.",
      "const jq = await cp.spawnSync(\n  'sh',\n  [\n    '-c',\n    'jq -f ' + configPath + ' -s ' + folderPath\n  ]);\n",
      "const jq = await cp.spawnSync(\n  'sh',\n  [\n    '-c',\n    ['jq -f', configPath, '-s', folderPath].join(' ')\n  ]);\n"
    ],
    "utterance": "Apply filters defined in a file to all files matching a wildcard pattern in a directory using -s and -f options.",
    "expressions": [
      "jq -f config/jest.jq -s reports/jest/*.json"
    ],
    "identifier": 74643445
  },
  {
    "context": [
      "Your \"template\" is just a filter that requires no input, but you forgot to tell `jq` that the filter won't need any input. As a result, `jq` is waiting to read from standard input.",
      "Use the `-n` option to tell `jq` it doesn't need to read from standard input.",
      "jq --arg SUMMARY \"Summary\" --arg BUILD_ID \"BUILD_ID\" --arg BUILD_URL \"BUILD_URL\" --arg DURATION \"DURATION\" --arg USER_EMAIL \"EMAIL\" --arg USER_NAME \"USER\" --arg TEST_CASES 3 --arg PX_VERSION \"VERSION\" --arg PX_BACKUP_VERSION \"PX_VERSION\" --arg STORK_IMAGE \"IMAGE_STORK\" --arg K8S_VERSION \"1.23.0\" --arg GITHUB_BRANCH \"branch\" --arg GITHUB_REPO \"repo\" --arg KIBANA_URL \"url\" -f template.jq",
      "jq -n <lots of --args> -f template.jq"
    ],
    "utterance": "Generate output from a template filter using provided arguments without reading data from standard input.",
    "expressions": [
      "jq -n --arg SUMMARY \"Summary\" --arg BUILD_ID \"BUILD_ID\" --arg BUILD_URL \"BUILD_URL\" --arg DURATION \"DURATION\" --arg USER_EMAIL \"EMAIL\" --arg USER_NAME \"USER\" --arg TEST_CASES 3 --arg PX_VERSION \"VERSION\" --arg PX_BACKUP_VERSION \"PX_VERSION\" --arg STORK_IMAGE \"IMAGE_STORK\" --arg K8S_VERSION \"1.23.0\" --arg GITHUB_BRANCH \"branch\" --arg GITHUB_REPO \"repo\" --arg KIBANA_URL \"url\" -f template.jq"
    ],
    "identifier": 74645042
  },
  {
    "context": [
      "s3_buckets_with_cache | jq '.buckets[].bucket'",
      "{\n  \"buckets\": [\n    {\n      \"bucket\": \"abc.logs.test\",\n      \"tags\": [\n        {\n          \"expiration_date\": \"12-06-2022\"\n        },\n        {\n          \"mark_for_delete\": \"true\"\n        }\n      ]\n    },\n    {\n      \"bucket\": \"bcd.logs.test\",\n      \"tags\": [\n        {\n          \"mark_for_delete\": \"true\"\n        },\n        {\n          \"expiration_date\": \"08-15-2022\"\n        }\n      ]\n    }\n  ]\n}\n",
      "What am i doing wrong here?"
    ],
    "utterance": "Extract all bucket names from the buckets array.",
    "expressions": [
      ".buckets[].bucket"
    ],
    "data": [
      {
        "input": {
          "buckets": [
            {
              "bucket": "abc.logs.test",
              "tags": [
                {
                  "expiration_date": "12-06-2022"
                },
                {
                  "mark_for_delete": "true"
                }
              ]
            },
            {
              "bucket": "bcd.logs.test",
              "tags": [
                {
                  "mark_for_delete": "true"
                },
                {
                  "expiration_date": "08-15-2022"
                }
              ]
            }
          ]
        },
        "output": [
          "abc.logs.test",
          "bcd.logs.test"
        ]
      }
    ],
    "identifier": 74646174
  },
  {
    "context": [
      "So basically, I have this command that runs in Gitlab CI to update a field in YAML configuration before packaging and pushing a Helm chart.",
      "I keep getting this error.\n    jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?)",
      "Use jq's `--arg` option to introduce values from shell:\n~~~sh\nyq -i -y --arg tag \"${CI_COMMIT_SHORT_SHA}\" '.pod.image.imageTag=$tag' deployment/values.yaml\n~~~",
      "gojq --yaml-input --yaml-output --arg tag \"${CI_COMMIT_SHORT_SHA}\" '\n  .pod.image.imageTag=$tag\n' values.yaml"
    ],
    "utterance": "Set the value of .pod.image.imageTag to the value of the CI_COMMIT_SHORT_SHA environment variable in a YAML file.",
    "expressions": [
      ".pod.image.imageTag = $tag"
    ],
    "data": [
      {
        "input": {
          "pod": {
            "image": {
              "repository": "my.private.repo/my-project",
              "imageTag": "latest"
            },
            "nodegroupName": "nessie-nodegroup"
          }
        },
        "output": {
          "pod": {
            "image": {
              "repository": "my.private.repo/my-project",
              "imageTag": "foo"
            },
            "nodegroupName": "nessie-nodegroup"
          }
        }
      }
    ],
    "identifier": 74648235
  },
  {
    "context": [
      "I would like to extract just the id and name from each object and print it.",
      "jq -r '.users[] | [.id , .name] | @csv' sample.json",
      "$ jq -r '.users[] | [.id, .name] | \"\\(.[0]) \\(.[1])\"' sample.json",
      "jq -r -c '.users[] | .id, .name' /tmp/input3 | while read -r id && read -r name; do\n    echo -e \"ID: ${id}\\t Name: ${name}\"\ndone"
    ],
    "utterance": "Extract and print the id and name fields from each user object.",
    "expressions": [
      ".users[] | [.id , .name] | @csv",
      ".users[] | [.id, .name] | \"\\(.[0]) \\(.[1])\""
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "id": "1",
              "name": "John Wick",
              "location": "USA"
            },
            {
              "id": "2",
              "name": "Walter White",
              "location": "USA"
            }
          ]
        },
        "output": [
          "\"1\",\"John Wick\"",
          "\"2\",\"Walter White\""
        ]
      },
      {
        "input": {
          "users": [
            {
              "id": "1",
              "name": "John Wick",
              "location": "USA"
            },
            {
              "id": "2",
              "name": "Walter White",
              "location": "USA"
            }
          ]
        },
        "output": [
          "1 John Wick",
          "2 Walter White"
        ]
      }
    ],
    "identifier": 74637498
  },
  {
    "context": [
      "And I want the id of the object whose path is a substring of a given pattern, so if I provide `/home/user/data` I want to get 1.",
      ".[] as {$id, $path} | $id | select(\"/home/user/data\" | startswith($path))",
      "The real substring checker `contains` already has a flipped version built in, called `inside`. With this, you don't need the variables for flipping, but it also returns `1` and `2` as both are actually contained within the given pattern:",
      ".[] | select(.path | inside(\"/home/user/data\")).id"
    ],
    "utterance": "Get the ids of objects whose path is a substring of '/home/user/data'.",
    "expressions": [
      ".[] as {$id, $path} | $id | select(\"/home/user/data\" | startswith($path))",
      ".[] | select(.path | inside(\"/home/user/data\")).id"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "path": "/home/user"
          },
          {
            "id": 2,
            "path": "/user"
          },
          {
            "id": 3,
            "path": "/var"
          }
        ],
        "output": [
          1,
          2
        ]
      }
    ],
    "identifier": 74653009
  },
  {
    "context": [
      "The problem is `None` and `True`, is there a possible way to tell jq to threat these as strings?",
      "I don&#39;t think [jq](https://stedolan.github.io/jq/) can help you."
    ],
    "utterance": "Interpret unquoted values like None and True as strings instead of special keywords.",
    "expressions": [],
    "data": [
      {
        "input": {
          "acquired": "None",
          "avail": true,
          "cls": "NetworkService",
          "params": {
            "address": "192.168.7.193",
            "password": "root",
            "username": "root"
          }
        }
      }
    ],
    "identifier": 74656148
  },
  {
    "context": [
      "But this is only half a journey. I watned to get an output, where each path also shows what type it is.",
      "That does give me paths to all the properties in the JSON.",
      "[",
      "  { \"_links.self.href\": \"string\" },",
      "  ...",
      "  { \"items.[]._maintainer.value\": \"boolean\" },",
      "  { \"totalCount\": \"number\" }",
      "]",
      "What way should I structure the query, for this to be able to achieve?",
      "#### Using `paths`",
      "[",
      "  paths(scalars) as $p",
      "  | {($p | map(numbers = \"[]\") | join(\".\")): getpath($p) | type}",
      "]",
      "| unique",
      "#### Using `tostream`",
      "reduce (tostream | select(has(1))) as [$p, $v] ([]; . + [{",
      "  ($p | map(numbers = \"[]\") | join(\".\")): ($v | type)",
      "}])",
      "| unique",
      "#### Output:",
      "[",
      "  {\"_links.self.href\":\"string\"},",
      "  {\"_links.self.type\":\"string\"},",
      "  {\"items.[]._links.parent.href\":\"string\"},",
      "  {\"items.[]._links.parent.type\":\"string\"},",
      "  {\"items.[]._links.self.href\":\"string\"},",
      "  {\"items.[]._links.self.type\":\"string\"},",
      "  {\"items.[]._maintainer._id\":\"number\"},",
      "  {\"items.[]._maintainer.email\":\"string\"},",
      "  {\"items.[]._maintainer.value\":\"boolean\"},",
      "  {\"totalCount\":\"number\"}",
      "]"
    ],
    "utterance": "List all property paths matched by paths(scalars), along with their value type at that location.",
    "expressions": [
      "[paths(scalars) as $p | {($p | map(numbers = \"[]\") | join(\".\")): getpath($p) | type}] | unique",
      "reduce (tostream | select(has(1))) as [$p, $v] ([]; . + [{($p | map(numbers = \"[]\") | join(\".\")): ($v | type)}]) | unique"
    ],
    "data": [
      {
        "input": {
          "_links": {
            "self": {
              "href": "HTTPS",
              "type": "application/json"
            }
          },
          "items": [
            {
              "_links": {
                "parent": {
                  "href": "LINK",
                  "type": "application/json"
                },
                "self": {
                  "href": "LINK",
                  "type": "application/json"
                }
              },
              "_maintainer": {
                "_id": 1,
                "email": "EMAIL",
                "value": true
              }
            }
          ],
          "totalCount": 1
        },
        "output": [
          {
            "_links.self.href": "string"
          },
          {
            "_links.self.type": "string"
          },
          {
            "items.[]._links.parent.href": "string"
          },
          {
            "items.[]._links.parent.type": "string"
          },
          {
            "items.[]._links.self.href": "string"
          },
          {
            "items.[]._links.self.type": "string"
          },
          {
            "items.[]._maintainer._id": "number"
          },
          {
            "items.[]._maintainer.email": "string"
          },
          {
            "items.[]._maintainer.value": "boolean"
          },
          {
            "totalCount": "number"
          }
        ]
      }
    ],
    "identifier": 74640842
  },
  {
    "context": [
      "that should convert the ARR and print it as a JSON array.",
      "What I want is:",
      "> some command {\r\n>  \"arr\": [\r\n>    \"a\", \"b\"\r\n>  ]\r\n>}",
      "collection_init_msg=$( jq -nc '{arr: $ARGS.positional}'  --args \"${ARR[@]}\"  )"
    ],
    "utterance": "Convert an array of bash variables a and b into a field named arr with both values in an array.",
    "expressions": [
      "jq -nc '{arr: $ARGS.positional}' --args \"${ARR[@]}\""
    ],
    "data": [
      {
        "input": [
          "a",
          "b"
        ],
        "output": {
          "arr": [
            "a",
            "b"
          ]
        }
      }
    ],
    "identifier": 74662395
  },
  {
    "context": [
      "but extending this to exclude more than one value eludes me",
      "So the negation is the issue. the jq pipe changes from strings to boolean so its important where to write the negation with not.",
      "this is working",
      "'select( .Image | contains(\"rancher\") or contains(\"jenkins\") or contains(\"google\") |not)'",
      "this is a much cooler way to do it by removing the entries directly from the list:",
      "echo $JSONTABLE|jq -C 'del (.[]|select( .Image | contains(\"rancher\") or contains(\"jenkins\")))' > table.json"
    ],
    "utterance": "Exclude all records where the Image field contains any of the values 'rancher', 'jenkins', or 'google'.",
    "expressions": [
      "select(.Image | contains(\"rancher\") or contains(\"jenkins\") or contains(\"google\") | not)",
      "del(.[] | select(.Image | contains(\"rancher\") or contains(\"jenkins\")))"
    ],
    "identifier": 74655735
  },
  {
    "context": [
      "I've filtered values in a json file that I obtained from Google Maps API with the following command:",
      "jq '.[] | select(.vicinity|contains(\"Bern\"))' Bern.json > Bern_test.json",
      "I only want to have places in Bern",
      "Your current filter produces a *stream* of JSON objects rather than a single JSON value. To fix that, wrap your filter in `[...]`:",
      "jq '[.[] | select(.vicinity|contains(\"Bern\"))]' Bern.json > Bern_test.json",
      "or use the predefined `map` function to achieve the same result.",
      "jq 'map(select(.vicinity|contains(\"Bern\")))' Bern.json > Bern_test.json"
    ],
    "utterance": "Extract all elements whose 'vicinity' field contains 'Bern', ensuring the output is properly formatted as an array.",
    "expressions": [
      "[.[] | select(.vicinity|contains(\"Bern\"))]",
      "map(select(.vicinity|contains(\"Bern\")))"
    ],
    "identifier": 74657818
  },
  {
    "context": [
      "What I need, however, is this:",
      "1. one a (0)",
      "2. two a (3)",
      "",
      "3. three a (2)",
      "",
      "4. one b (1)",
      "5. two b (3)",
      "6. three b (2)",
      "Using `foreach` to count would be one way:",
      "foreach .[] as {$index, $value} (0;\n  if $value != \"\" then . + 1 else . end;\n  if $value != \"\" then \"\\(.). \\($value) (\\($index))\" else \"\" end\n)"
    ],
    "utterance": "Output each non-empty entry in the array as a numbered line, grouping entries separated by those with an empty value, and skip numbering and output for empty-value entries.",
    "expressions": [
      "foreach .[] as {$index, $value} (0;\n  if $value != \"\" then . + 1 else . end;\n  if $value != \"\" then \"\\(.). \\($value) (\\($index))\" else \"\" end\n)"
    ],
    "data": [
      {
        "input": [
          {
            "index": 0,
            "value": "one a"
          },
          {
            "index": 3,
            "value": "two a"
          },
          {
            "value": ""
          },
          {
            "index": 2,
            "value": "three a"
          },
          {
            "value": ""
          },
          {
            "index": 1,
            "value": "one b"
          },
          {
            "index": 3,
            "value": "two b"
          },
          {
            "index": 2,
            "value": "three b"
          }
        ],
        "output": "1. one a (0)\n2. two a (3)\n\n3. three a (2)\n\n4. one b (1)\n5. two b (3)\n6. three b (2)"
      }
    ],
    "identifier": 74655111
  },
  {
    "context": [
      "say that I'm debugging bigger script, and just want to see first few rows, from first statement. How to do that effectively in rather huge file?",
      "jq --stream -cn 'limit(5; fromstream(2|truncate_stream(inputs)))' dump.json"
    ],
    "utterance": "Show the first five rows from the first statement of a large file without knowing the field names and without loading unnecessary data.",
    "expressions": [
      "jq --stream -cn 'limit(5; fromstream(2|truncate_stream(inputs)))' dump.json"
    ],
    "identifier": 74665921
  },
  {
    "context": [
      "The data looks like this when it arrives:\r\n{ [ 48.2725225, 12.6538725, 595.2270812 ], [ 48.2725226, 12.6654544 ] }\r\n\r\nI need it to be formatted like this without the elevations:\r\n{ [ 48.2725225, 12.6538725 ], [ 48.2725226, 12.6654544 ] }",
      "If instead you had an array of arrays (both enclosed within square brackets `[]`) like this:\r\n~~~sh\r\n[ [ 48.2725225, 12.6538725, 595.2270812 ], [ 48.2725226, 12.6654544 ] ]\r\n~~~\r\nyou could use `map` on the outer array to individually process each inner array. That processing could then be to slice the array, reducing it to its first two elements `.[:2]`:\r\n~~~\r\nmap(.[:2])\r\n~~~\r\n~~~json\r\n[ [48.2725225,12.6538725], [48.2725226,12.6654544] ]\r\n~~~",
      "If, however, you only have a stream of arrays like this (notice the lack of braces **and** commas compared to the outer array from above):\r\n~~~sh\r\n[ 48.2725225, 12.6538725, 595.2270812 ] [ 48.2725226, 12.6654544 ]\r\n~~~\r\nyou can directly proceed with the slicing, no outer mapping is needed:\r\n~~~sh\r\n.[:2]\r\n~~~\r\n~~~json\r\n[48.2725225,12.6538725] [48.2725226,12.6654544]\r\n~~~"
    ],
    "utterance": "Remove the third value from each coordinate array, keeping only the first two elements (longitude and latitude), for all arrays in the input.",
    "expressions": [
      "map(.[:2])",
      ".[:2]"
    ],
    "data": [
      {
        "input": [
          [
            48.2725225,
            12.6538725,
            595.2270812
          ],
          [
            48.2725226,
            12.6654544
          ]
        ],
        "output": [
          [
            48.2725225,
            12.6538725
          ],
          [
            48.2725226,
            12.6654544
          ]
        ]
      }
    ],
    "identifier": 74657564
  },
  {
    "context": [
      "I would like the output to be exactly the same, with the exception of an incrementing integer in place of the \"id\" : \"guid\" - something like:",
      ".stage.objects |= (to_entries | map(.value.id = .key + 1 | .value))",
      ".stage.objects |= (to_entries | map(.value += {id: (.key + 1)} | .value))",
      ".stage.objects |= reduce keys[] as $i (.; .[$i].id = $i + 1)"
    ],
    "utterance": "Replace each object's id property within stage.objects with a sequential integer starting from 1, keeping all other data unchanged.",
    "expressions": [
      ".stage.objects |= (to_entries | map(.value.id = .key + 1 | .value))",
      ".stage.objects |= (to_entries | map(.value += {id: (.key + 1)} | .value))",
      ".stage.objects |= reduce keys[] as $i (.; .[$i].id = $i + 1)"
    ],
    "data": [
      {
        "input": {
          "version": "2.0",
          "stage": {
            "objects": [
              {
                "foo": 1100,
                "bar": false,
                "id": "56a983f1-8111-4abc-a1eb-263d41cfb098"
              },
              {
                "foo": 1100,
                "bar": false,
                "id": "6369df4b-90c4-4695-8a9c-6bb2b8da5976"
              }
            ],
            "bish": "#FFFFFF"
          },
          "more": "abcd"
        },
        "output": {
          "version": "2.0",
          "stage": {
            "objects": [
              {
                "foo": 1100,
                "bar": false,
                "id": 1
              },
              {
                "foo": 1100,
                "bar": false,
                "id": 2
              }
            ],
            "bish": "#FFFFFF"
          },
          "more": "abcd"
        }
      }
    ],
    "identifier": 74664554
  },
  {
    "context": [
      "Having (simplified for learning) input file:\r\n\r\n    {\"type\":\"a\",\"id\":\"1\"}\r\n    {\"type\":\"a\",\"id\":\"2\"}\r\n    {\"type\":\"b\",\"id\":\"1\"}\r\n    {\"type\":\"c\",\"id\":\"3\"}\r\n\r\nI'd like to turn it into:\r\n\r\n    {\r\n        \"a\": [1,2],\r\n        \"b\": [1],\r\n        \"c\": [3]\r\n    }\r\n\r\nvia **using --stream** option, not needed here, just for learning.",
      "With the `--stream` option set, just re-create the streamed items using `fromstream`:\r\n~~~sh\r\njq --stream -n 'reduce fromstream(inputs) as $i ({}; .[$i.type] += [$i.id | tonumber])'\r\n~~~",
      "{\r\n  \"a\": [1,2],\r\n  \"b\": [1],\r\n  \"c\": [3]\r\n}"
    ],
    "utterance": "Group all id values under their respective type as arrays, using the streaming option, and parse id as numbers.",
    "expressions": [
      "reduce fromstream(inputs) as $i ({}; .[$i.type] += [$i.id | tonumber])"
    ],
    "data": [
      {
        "input": [
          {
            "type": "a",
            "id": "1"
          },
          {
            "type": "a",
            "id": "2"
          },
          {
            "type": "b",
            "id": "1"
          },
          {
            "type": "c",
            "id": "3"
          }
        ],
        "output": {
          "a": [
            1,
            2
          ],
          "b": [
            1
          ],
          "c": [
            3
          ]
        }
      }
    ],
    "identifier": 74667045
  },
  {
    "context": [
      "Json file format in directory:\n{\n  \"language\":\"JSON\",\n    \"input\": {\n    \"time\": \"2022-04-07T12:53:39.302+0300\",\n    \"user\": \"Basic PGxvZ2luPg==\"\n  },\n\n  \"jq_solution\": \".user |= if startswith(\\\"Basic\\\") then .[6:] | @base64d else . end\",\n\n  \"desired_output\": { \"time\": \"2022-04-07T12:53:39.302+0300\", \"user\": \"<login>\" },\n\n  \"task\": \"Using jq, get all the characters after 'Basic', base64 decode them and replace in input.\"\n  \n}",
      "\"jq_solution\": \".user |= if startswith(\\\"Basic\\\") then .[6:] | @base64d else . end\"",
      "\"desired_output\": { \"time\": \"2022-04-07T12:53:39.302+0300\", \"user\": \"<login>\" }"
    ],
    "utterance": "Extract all characters after 'Basic' from the 'user' field, base64 decode them, and replace the field value with the result.",
    "expressions": [
      ".user |= if startswith(\"Basic\") then .[6:] | @base64d else . end"
    ],
    "data": [
      {
        "input": {
          "time": "2022-04-07T12:53:39.302+0300",
          "user": "Basic PGxvZ2luPg=="
        },
        "output": {
          "time": "2022-04-07T12:53:39.302+0300",
          "user": "<login>"
        }
      }
    ],
    "identifier": 74667418
  },
  {
    "context": [
      "I\u2019m trying to remove all the entries with the city \"Ostermundigen\" in it.",
      "del(.[] | select(.vicinity|contains(\"Ostermundigen\")))"
    ],
    "utterance": "Remove all array elements whose 'vicinity' field contains the string 'Ostermundigen'.",
    "expressions": [
      "del(.[] | select(.vicinity|contains(\"Ostermundigen\")))"
    ],
    "data": [
      {
        "input": [
          {
            "geometry": {
              "location": {
                "lat": 46.93629499999999,
                "lng": 7.503256800000001
              }
            },
            "name": "La Tana Del Lupo",
            "price_level": 1,
            "rating": 4.4,
            "types": [
              "restaurant",
              "point_of_interest",
              "food",
              "establishment"
            ],
            "user_ratings_total": 84,
            "vicinity": "Dorfstrasse 11, Muri bei Bern"
          },
          {
            "geometry": {
              "location": {
                "lat": 46.93406969999999,
                "lng": 7.503247199999999
              }
            },
            "name": "Rung Reuang",
            "rating": 4.8,
            "types": [
              "restaurant",
              "point_of_interest",
              "food",
              "establishment"
            ],
            "user_ratings_total": 131,
            "vicinity": "Worbstrasse 198, Muri bei Bern"
          },
          {
            "name": "Test Restaurant",
            "vicinity": "Schulweg 12, Ostermundigen"
          }
        ],
        "output": [
          {
            "geometry": {
              "location": {
                "lat": 46.93629499999999,
                "lng": 7.503256800000001
              }
            },
            "name": "La Tana Del Lupo",
            "price_level": 1,
            "rating": 4.4,
            "types": [
              "restaurant",
              "point_of_interest",
              "food",
              "establishment"
            ],
            "user_ratings_total": 84,
            "vicinity": "Dorfstrasse 11, Muri bei Bern"
          },
          {
            "geometry": {
              "location": {
                "lat": 46.93406969999999,
                "lng": 7.503247199999999
              }
            },
            "name": "Rung Reuang",
            "rating": 4.8,
            "types": [
              "restaurant",
              "point_of_interest",
              "food",
              "establishment"
            ],
            "user_ratings_total": 131,
            "vicinity": "Worbstrasse 198, Muri bei Bern"
          }
        ]
      }
    ],
    "identifier": 74666194
  },
  {
    "identifier": 74688905
  },
  {
    "context": [
      "How would I also get the `Alias Items, so that I have:\n\n```\n\"EG3MOA,a***.cloudfront.net,'a.domain.tld,b.domain.tld'\"\n\"EG3MOB,b***.cloudfront.net,'c.domain.tld,d.domain.tld'\"\n```",
      "you can use the codepoint notation instead: `\\u0027`\n~~~sh\njq '\u2026 | \"\\(.Id),\\(.DomainName),\\u0027\\(.Aliases.Items | join(\",\"))\\u0027\"'\n~~~"
    ],
    "utterance": "Output Id, DomainName, and the Aliases.Items list (joined by commas and enclosed in single quotes) as a comma-separated string for each distribution.",
    "expressions": [
      ".DistributionList.Items[] | \"\\(.Id),\\(.DomainName),\\u0027\\(.Aliases.Items | join(\",\"))\\u0027\""
    ],
    "data": [
      {
        "input": {
          "DistributionList": {
            "Items": [
              {
                "Id": "EG3MOA",
                "Status": "Deployed",
                "LastModifiedTime": "2022-12-03T19:32:35.007000+00:00",
                "DomainName": "a***.cloudfront.net",
                "Aliases": {
                  "Quantity": 1,
                  "Items": [
                    "a.domain.tld",
                    "b.domain.tld"
                  ]
                }
              },
              {
                "Id": "EG3MOB",
                "Status": "Deployed",
                "LastModifiedTime": "2022-12-03T19:32:35.007000+00:00",
                "DomainName": "b***.cloudfront.net",
                "Aliases": {
                  "Quantity": 1,
                  "Items": [
                    "c.domain.tld",
                    "d.domain.tld"
                  ]
                }
              }
            ]
          }
        },
        "output": [
          "EG3MOA,a***.cloudfront.net,'a.domain.tld,b.domain.tld'",
          "EG3MOB,b***.cloudfront.net,'c.domain.tld,d.domain.tld'"
        ]
      }
    ],
    "identifier": 74671244
  },
  {
    "context": [
      "I want to remove the duplicates from each array in this JSON:",
      "I tried `map`, `uniq`, `group_by` with `jq` but nothing helped",
      "Here is a sort-free alternative for obtaining the distinct items in an array (or stream) while retaining the order of first occurrence.",
      "Now it's just a matter of applying this filter to your JSON.  One possibility would be:\n\n     map_values([uniques(.[])])",
      "Or circumvent any sorting behaviour by writing your own straightforward de-duplication function:\n~~~sh\njq '.[] |= reduce .[] as $i ([]; . + if index($i) then [] else [$i] end)'",
      "In my tests, the latter performed best, with both producing\n~~~json\n{\n  \"abc\": [\n    \"five\"\n  ],\n  \"pqr\": [\n    \"one\",\n    \"two\",\n    \"three\",\n    \"four\"\n  ],\n  \"xyz\": [\n    \"one\",\n    \"two\",\n    \"four\"\n  ]\n}\n~~~"
    ],
    "utterance": "Remove duplicates from each array, preserving the first occurrence order.",
    "expressions": [
      ".[] |= reduce .[] as $i ([]; . + if index($i) then [] else [$i] end)",
      "map_values([uniques(.[])])"
    ],
    "data": [
      {
        "input": {
          "abc": [
            "five"
          ],
          "pqr": [
            "one",
            "one",
            "two",
            "two",
            "three",
            "three",
            "four",
            "four"
          ],
          "xyz": [
            "one",
            "one",
            "two",
            "two",
            "four"
          ]
        },
        "output": {
          "abc": [
            "five"
          ],
          "pqr": [
            "one",
            "two",
            "three",
            "four"
          ],
          "xyz": [
            "one",
            "two",
            "four"
          ]
        }
      }
    ],
    "identifier": 74678678
  },
  {
    "context": [
      "I want to filter and get the results of each index that\r\n\r\n it's name starts with `\"abc\"` and the state is `\"DISABLED\"`.",
      "And it's giving me whatever starts with `\"abc\"` which is good but I want it to be also\r\n `.State == \"DISABLED\"` and I want the output to be regular and not JSON.\r\n (I need to get the names of whatever starts with `abc` and it's state is `DISABLED` into a file)",
      "cat test.json | jq -r '.[] | .[] |  select((.Name | startswith(\"abc\")) and .State == \"DISABLED\") | .Name'",
      ".Rules[] | select(.State == \"DISABLED\" and (.Name | startswith(\"abc\"))) | .Name",
      ".Rules[] | select(.State == \"DISABLED\") | .Name | select(startswith(\"abc\"))"
    ],
    "utterance": "Get the names of all entries where the name starts with 'abc' and the state is 'DISABLED'.",
    "expressions": [
      ".[] | .[] | select((.Name | startswith(\"abc\")) and .State == \"DISABLED\") | .Name",
      ".Rules[] | select(.State == \"DISABLED\" and (.Name | startswith(\"abc\"))) | .Name",
      ".Rules[] | select(.State == \"DISABLED\") | .Name | select(startswith(\"abc\"))"
    ],
    "data": [
      {
        "input": {
          "Rules": [
            {
              "Name": "abcd",
              "Arn": "arn:aws:events:eu-west-2:XXXXXX:rule/abcd",
              "State": "ENABLED",
              "ScheduleExpression": "rate(6 hours)",
              "EventBusName": "default"
            },
            {
              "Name": "abcxxx",
              "Arn": "arn:aws:events:eu-west-2:XXXXXX:rule/abcxxx",
              "State": "DISABLED",
              "ScheduleExpression": "rate(12 hours)",
              "EventBusName": "default"
            }
          ]
        },
        "output": [
          "abcxxx"
        ]
      }
    ],
    "identifier": 74674700
  },
  {
    "context": [
      "I can reduce produced lines like:\r\n\r\n    seq 5 | jq --slurp ' reduce .[] as $i (0;.+($i|tonumber))'\r\n\r\nto get\r\n\r\n    15\r\n\r\nbut this put whole input into memory, I don\u2019t want that.",
      "What is correct syntax?",
      "Use [`inputs`](https://stedolan.github.io/jq/manual/#inputs) instead of the context `.`, along with the `--null-input` (or `-n`) [option](https://stedolan.github.io/jq/manual/#Invokingjq) so the context wouldn't eat up the first item:\r\n~~~sh\r\nseq 5 | jq -n 'reduce inputs as $i (0;.+($i|tonumber))'\r\n~~~\r\n~~~\r\n15\r\n~~~"
    ],
    "utterance": "Sum all incoming streamed lines numerically without loading the entire input into memory.",
    "expressions": [
      "reduce inputs as $i (0; . + ($i|tonumber))"
    ],
    "data": [
      {
        "input": [
          "1",
          "2",
          "3",
          "4",
          "5"
        ],
        "output": 15
      }
    ],
    "identifier": 74686998
  },
  {
    "context": [
      "newjson=$(echo $test | jq '.\"two.two\".version = \"$newvalue\" ')",
      "none of the escapes i tried `\\\"` `\\'` around $newvalue seems to work",
      "to use a variable, it can't be in quotes. Replace\n\n```jq\n\"$newvalue\"\n```\n\nwith\n\n```jq\n$newvalue\n```\n",
      "you never set `$newvalue` in the jq program. To achieve that, you can use the following:\n\n```sh\n--arg newvalue \"$newvalue\"\n```"
    ],
    "utterance": "Update the value of the key 'version' inside the object with key 'two.two' to a shell variable's value, where the key contains a dot.",
    "expressions": [
      ".\"two.two\".version = $newvalue"
    ],
    "data": [
      {
        "input": {
          "one.one": {
            "version": "0.0.1"
          },
          "two.two": {
            "version": "0.0.2"
          }
        },
        "output": {
          "one.one": {
            "version": "0.0.1"
          },
          "two.two": {
            "version": "3.3.3"
          }
        }
      }
    ],
    "identifier": 74684386
  },
  {
    "context": [
      "I would like to get the following result:",
      "[ { \"propertyA\": 11, \"propertyB\": 12 }, { \"propertyA\": 21, \"propertyB\": null } ]",
      "You can use the [alternative operator](https://stedolan.github.io/jq/manual/#Alternativeoperator%3A%2F%2F) `//` to set a default value:",
      "map({propertyA, propertyB: (.nestedPropertyB[]? // null)})"
    ],
    "utterance": "For each item, return an object with propertyA unchanged and propertyB set to the first value in nestedPropertyB or null if not present.",
    "expressions": [
      "map({propertyA, propertyB: (.nestedPropertyB[]? // null)})"
    ],
    "data": [
      {
        "input": [
          {
            "propertyA": 11,
            "nestedPropertyB": [
              12
            ]
          },
          {
            "propertyA": 21
          }
        ],
        "output": [
          {
            "propertyA": 11,
            "propertyB": 12
          },
          {
            "propertyA": 21,
            "propertyB": null
          }
        ]
      }
    ],
    "identifier": 74706927
  },
  {
    "context": [
      "Is there a way for jq to give a reference to _where_ in code an error occurred?",
      "jq: error (at <stdin>:43913): Cannot index object with null",
      "Wrapping code snippets in try/catch blocks with $__loc__ have proven unhelpful too",
      "you will probably find that some combination of `debug` statements, `$__loc__`, and debugging functions defined using `debug` to be most helpful.",
      "def debug(msg): (msg|debug) as $debug | . ;",
      "In a pinch, the command-line option `--debug-trace` can be useful."
    ],
    "utterance": "Identify the location in script code where an error occurs during execution to facilitate debugging.",
    "expressions": [
      "def debug(msg): (msg|debug) as $debug | . ;"
    ],
    "identifier": 74710084
  },
  {
    "context": [
      "I am trying to dynamically assign the key name as its value in my json",
      "This is the json i am using:\n{\n    \"test1\": \"\",\n    \"test2\": \"\",\n    \"test3\": \"\"\n}",
      "the result i would like to obtain looks like this:\n{\n    \"test1\": \"test1\",\n    \"test2\": \"test2\",\n    \"test3\": \"test3\"\n}",
      "with_entries(.value = .key)",
      "[keys[] as $key | {($key): $key}] | add",
      "[keys[] | {\"\\(.)\": .}] | add",
      "keys | map({\"\\(.)\": .}) | add",
      "reduce keys_unsorted[] as $key (.; .[$key] = $key)"
    ],
    "utterance": "Transform all string-valued fields so that each field's value becomes its key name.",
    "expressions": [
      "with_entries(.value = .key)",
      "[keys[] as $key | {($key): $key}] | add",
      "[keys[] | {\"\\(.)\": .}] | add",
      "keys | map({\"\\(.)\": .}) | add",
      "reduce keys_unsorted[] as $key (.; .[$key] = $key)"
    ],
    "data": [
      {
        "input": {
          "test1": "",
          "test2": "",
          "test3": ""
        },
        "output": {
          "test1": "test1",
          "test2": "test2",
          "test3": "test3"
        }
      }
    ],
    "identifier": 74691995
  },
  {
    "context": [
      "I want to rename nested json key and keep under same schema.",
      "Expected Output should be :\r\n\r\n    \"properties\":\r\n     {\r\n      \"name\": \"Ram\",\r\n      \"age\": \"17\",\r\n      \"company\": \"Sony\"  \r\n     }",
      ".properties |= (.company = .department | del(.department))",
      ".properties |= { name, age, company: .department }",
      ".properties |=  del(.department) + { company: .department }",
      ".properties |= with_entries(.key |= if . == \"department\" then \"company\" else . end)",
      ".properties |= with_entries(.key |= (select(. != \"department\") // \"company\"))"
    ],
    "utterance": "Rename the 'department' key inside 'properties' to 'company', leaving all other properties unchanged.",
    "expressions": [
      ".properties |= (.company = .department | del(.department))",
      ".properties |= { name, age, company: .department }",
      ".properties |= del(.department) + { company: .department }",
      ".properties |= with_entries(.key |= if . == \"department\" then \"company\" else . end)",
      ".properties |= with_entries(.key |= (select(. != \"department\") // \"company\"))"
    ],
    "data": [
      {
        "input": {
          "properties": {
            "name": "Ram",
            "age": "17",
            "department": "Sony"
          }
        },
        "output": {
          "properties": {
            "name": "Ram",
            "age": "17",
            "company": "Sony"
          }
        }
      }
    ],
    "identifier": 74709583
  },
  {
    "context": [
      "I would like to get a result:\r\n[\r\n  {\r\n    \"root-property-a\": 11,\r\n    \"root-property-b\": 22,\r\n    \"root-property-c\": 33\r\n  },\r\n  {\r\n    \"root-property-a\": 12,\r\n    \"root-property-b\": 22,\r\n    \"root-property-c\": 33\r\n  },\r\n  {\r\n    \"root-property-a\": 13,\r\n    \"root-property-b\": 22,\r\n    \"root-property-c\": 33\r\n  },\r\n]",
      "jq 'map({\"root-property-a\": .\"root-array-a\"[]} + . | del(.\"root-array-a\"))'",
      "map({\n    \"root-property-a\": .\"root-array-a\"[],\n    \"root-property-b\": .\"root-property-b\",\n    \"root-property-c\": .\"root-property-c\"\n})"
    ],
    "utterance": "For each element in the root array, output separate objects with 'root-property-a' set to each value from 'root-array-a' and all other properties copied, omitting 'root-array-a'.",
    "expressions": [
      "map({\"root-property-a\": .\"root-array-a\"[]} + . | del(.\"root-array-a\"))",
      "map({\"root-property-a\": .\"root-array-a\"[], \"root-property-b\": .\"root-property-b\", \"root-property-c\": .\"root-property-c\"})"
    ],
    "data": [
      {
        "input": [
          {
            "root-array-a": [
              11,
              12,
              13
            ],
            "root-property-b": 22,
            "root-property-c": 33
          }
        ],
        "output": [
          {
            "root-property-a": 11,
            "root-property-b": 22,
            "root-property-c": 33
          },
          {
            "root-property-a": 12,
            "root-property-b": 22,
            "root-property-c": 33
          },
          {
            "root-property-a": 13,
            "root-property-b": 22,
            "root-property-c": 33
          }
        ]
      }
    ],
    "identifier": 74691377
  },
  {
    "context": [
      "I am trying to insert new key/value in json using jq.",
      "my value comes from a variable but I am not able to set it properly.",
      "jq '.properties += { \"short_name\": \"$SHORT_NAME\" }' filepath",
      "it shows \"short_name\" = \"SHORT_NAME\" instead of actual value"
    ],
    "utterance": "Insert a new key 'short_name' under 'properties' and set its value from a shell variable SHORT_NAME.",
    "expressions": [
      "jq --arg short_name \"$SHORT_NAME\" '.properties += { short_name: $short_name }' filepath"
    ],
    "identifier": 74724945
  },
  {
    "context": [
      "I have this input.",
      "{\r\n  \"ver\" : \"2.4\",\r\n  \"startDate\"  : \"2022-12-07T10:38:10+07:00\",\r\n  \"disk\" : {},\r\n  \"network\" : {\r\n    \"ipv4\" : {},\r\n    \"ipv6\" : {}\r\n  },\r\n  \"test\" : {}\r\n}",
      "I want to add empty object `/dev/sda` for example into `disk`. Below is ideal output.",
      "{\r\n\t\"ver\": \"2.4\",\r\n\t\"startDate\": \"2022-12-07T10:38:10+07:00\",\r\n\t\"disk\": {\r\n\t\t\"/dev/sda\": {}\r\n\t},\r\n\t\"network\": {\r\n\t\t\"ipv4\": {},\r\n\t\t\"ipv6\": {}\r\n\t},\r\n\t\"test\": {}\r\n}",
      "I search the net but only found how to add element, not how to add empty object."
    ],
    "utterance": "Add a key named /dev/sda with an empty object as its value to the disk object, preserving the rest of the structure.",
    "expressions": [
      ".disk[\"/dev/sda\"] = {}"
    ],
    "data": [
      {
        "input": {
          "ver": "2.4",
          "startDate": "2022-12-07T10:38:10+07:00",
          "disk": {},
          "network": {
            "ipv4": {},
            "ipv6": {}
          },
          "test": {}
        },
        "output": {
          "ver": "2.4",
          "startDate": "2022-12-07T10:38:10+07:00",
          "disk": {
            "/dev/sda": {}
          },
          "network": {
            "ipv4": {},
            "ipv6": {}
          },
          "test": {}
        }
      }
    ],
    "identifier": 74711543
  },
  {
    "context": [
      "I have below string json in a file as file.json:",
      "I am trying to convert this to something like this:",
      "trying to do with",
      "jq -rc file.json",
      "Use `fromjson`.",
      "jq fromjson file.json"
    ],
    "utterance": "Convert a JSON string containing an escaped JSON object stored in a file to its unescaped JSON object representation.",
    "expressions": [
      "jq fromjson file.json"
    ],
    "data": [
      {
        "input": "\"{\\n  \\\"devices\\\" : [ {\\n    \\\"type\\\" : \\\"eks\\\",\\n    \\\"kubeconfig_path\\\" : \\\"/home/centos/workspace/rt-argus-eks-parallel-dynamic-infra/ansible/utils/dynamic-infra-v2/./kubeconfig-jenkins-rt-argus-eks-parallel-dynamic-infra-70_0\\\"\\n  }, {\\n    \\\"type\\\" : \\\"eks\\\",\\n    \\\"kubeconfig_path\\\" : \\\"/home/centos/workspace/rt-argus-eks-parallel-dynamic-infra/ansible/utils/dynamic-infra-v2/./kubeconfig-jenkins-rt-argus-eks-parallel-dynamic-infra-70_1\\\"\\n  } ]\\n}\"",
        "output": {
          "devices": [
            {
              "type": "eks",
              "kubeconfig_path": "/home/centos/workspace/rt-argus-eks-parallel-dynamic-infra/ansible/utils/dynamic-infra-v2/./kubeconfig-jenkins-rt-argus-eks-parallel-dynamic-infra-70_0"
            },
            {
              "type": "eks",
              "kubeconfig_path": "/home/centos/workspace/rt-argus-eks-parallel-dynamic-infra/ansible/utils/dynamic-infra-v2/./kubeconfig-jenkins-rt-argus-eks-parallel-dynamic-infra-70_1"
            }
          ]
        }
      }
    ],
    "identifier": 74720338
  },
  {
    "identifier": 74739698
  },
  {
    "context": [
      "I have a set of JSON objects that each contain one unique key:value pair (that is, there are no duplicate keys). I want to combine all of these into a single object using `jq`.",
      "to become this:",
      "    {\n      \"Key1\": \"Value1\",\n      \"Key2\": \"Value2\",\n      \"Key3\": \"Value3\",\n      ...\n    }",
      "Since this is a single file, use slurp and simply add the objects:",
      "jq -s 'add' yourfile",
      "slurp reads all entities in the input file as one big array, which will then be reduced with `add`. Adding two objects simply merges their key-value pairs, with conflicting keys being overwritten by the last value.",
      "If your input is really really large, you might not want to load all entities into memory at once and you might want to reduce on inputs instead:",
      "jq -n 'reduce inputs as $obj ({}; . + $obj)' yourfile"
    ],
    "utterance": "Combine multiple single-key objects, each with a unique key, into one object containing all key-value pairs.",
    "expressions": [
      "jq -s 'add'",
      "jq -n 'reduce inputs as $obj ({}; . + $obj)'"
    ],
    "data": [
      {
        "input": [
          {
            "Key1": "Value1"
          },
          {
            "Key2": "Value2"
          },
          {
            "Key3": "Value3"
          }
        ],
        "output": {
          "Key1": "Value1",
          "Key2": "Value2",
          "Key3": "Value3"
        }
      }
    ],
    "identifier": 74736351
  },
  {
    "context": [
      "how can I transform an input to a JSON object which maps the first level keys to the value of the `latest` nested value?",
      "Map all field values to their `.latest` field, either by using `map_values`",
      "map_values(.latest)",
      "Or by updating `|=` each field `.[]` with that filter",
      ".[] |= .latest"
    ],
    "utterance": "Transform the input so that each top-level key maps to its corresponding nested 'latest' value.",
    "expressions": [
      "map_values(.latest)",
      ".[] |= .latest"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "current": "0.15.14",
            "wanted": "0.15.14",
            "latest": "0.16.4"
          },
          "bar": {
            "current": "8.27.0",
            "wanted": "8.27.0",
            "latest": "8.29.0"
          },
          "baz": {
            "current": "27.1.5",
            "wanted": "27.1.5",
            "latest": "27.1.6"
          }
        },
        "output": {
          "foo": "0.16.4",
          "bar": "8.29.0",
          "baz": "27.1.6"
        }
      }
    ],
    "identifier": 74759088
  },
  {
    "context": [
      "I am trying to grab the `in_network` object where `billing_code` is equal to 99285.",
      "If the objects from the `.in_network` array alone do fit into your memory, truncate at the array items (two levels deep):",
      "jq --stream -n '\n  fromstream(2|truncate_stream(inputs | select(.[0][0] == \"in_network\")))\n  | select(.billing_code == \"99285\")\n' example.json"
    ],
    "utterance": "Extract objects from the in_network array where billing_code equals \"99285\" using streaming mode to avoid loading the entire document into memory.",
    "expressions": [
      "jq --stream -n '\n  fromstream(2|truncate_stream(inputs | select(.[0][0] == \"in_network\")))\n  | select(.billing_code == \"99285\")\n' example.json"
    ],
    "data": [
      {
        "input": {
          "reporting_entity_name": "INSURANCE COMPANY",
          "reporting_entity_type": "INSURER",
          "last_updated_on": "2022-12-01",
          "version": "1.0.0",
          "in_network": [
            {
              "negotiation_arrangement": "ffs",
              "name": "ER VISIT",
              "billing_code_type": "CPT",
              "billing_code_type_version": "2022",
              "billing_code": "99285",
              "description": "HIGHEST LEVEL ER VISIT",
              "negotiated_rates": [
                {
                  "provider_groups": [
                    {
                      "npi": [
                        111111111,
                        222222222
                      ],
                      "tin": {
                        "type": "ein",
                        "value": "99-9999999"
                      }
                    }
                  ],
                  "negotiated_prices": [
                    {
                      "negotiated_type": "negotiated",
                      "negotiated_rate": 550.5,
                      "expiration_date": "9999-12-31",
                      "service_code": [
                        "23"
                      ],
                      "billing_class": "institutional"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "negotiation_arrangement": "ffs",
          "name": "ER VISIT",
          "billing_code_type": "CPT",
          "billing_code_type_version": "2022",
          "billing_code": "99285",
          "description": "HIGHEST LEVEL ER VISIT",
          "negotiated_rates": [
            {
              "provider_groups": [
                {
                  "npi": [
                    111111111,
                    222222222
                  ],
                  "tin": {
                    "type": "ein",
                    "value": "99-9999999"
                  }
                }
              ],
              "negotiated_prices": [
                {
                  "negotiated_type": "negotiated",
                  "negotiated_rate": 550.5,
                  "expiration_date": "9999-12-31",
                  "service_code": [
                    "23"
                  ],
                  "billing_class": "institutional"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 74745000
  },
  {
    "context": [
      "jq '.outputs | {\"kubeconfig-file\"}' terraform.tfstate;",
      "jq '.outputs | {\\\"kubeconfig-file\\\"}' terraform.tfstate;",
      "I want the jq to be executed over ssh session.",
      "{\n\"outputs\": {\n    \"kubeconfig-file\": {\n      \"value\": \"/home/chi/jenkins-terraform/config\",\n      \"type\": \"string\"\n    },\n    \"master-node-ip\": {\n      \"value\": \"x.x.x.x\",\n      \"type\": \"string\"\n    },\n    \"master-node-vm-name\": {\n      \"value\": \"v1\",\n      \"type\": \"string\"\n    },\n    \"worker-node-ip\": {\n      \"value\": \"x.x.x.x, x.x.x.x, x.x.x.x\",\n      \"type\": \"string\"\n    },\n    \"worker-node-vm-names\": {\n      \"value\": \"v2, v3, v4\",\n      \"type\": \"string\"\n    }\n  }\n}"
    ],
    "utterance": "Extract the value of the 'outputs.kubeconfig-file' key including its nested fields.",
    "expressions": [
      ".outputs[\"kubeconfig-file\"]",
      ".outputs | {\"kubeconfig-file\"}"
    ],
    "data": [
      {
        "input": {
          "outputs": {
            "kubeconfig-file": {
              "value": "/home/chi/jenkins-terraform/config",
              "type": "string"
            },
            "master-node-ip": {
              "value": "x.x.x.x",
              "type": "string"
            },
            "master-node-vm-name": {
              "value": "v1",
              "type": "string"
            },
            "worker-node-ip": {
              "value": "x.x.x.x, x.x.x.x, x.x.x.x",
              "type": "string"
            },
            "worker-node-vm-names": {
              "value": "v2, v3, v4",
              "type": "string"
            }
          }
        },
        "output": {
          "kubeconfig-file": {
            "value": "/home/chi/jenkins-terraform/config",
            "type": "string"
          }
        }
      }
    ],
    "identifier": 74762518
  },
  {
    "context": [
      "I want to get only cpuUtilization and memory.",
      "And the form is:",
      "cpuUtilization\\guest = 0",
      "Here is one solution, first updating your inner keys, then streaming all entries:",
      "{ cpuUtilization, memory } | to_entries[] | .key as $key | .value | to_entries[] | \"\\($key)\\\\\\(.key) = \\(.value)\"",
      "Here's a simple nested loop using `keys_unsorted`:",
      "keys_unsorted[] as $lev1 | .[$lev1] | keys_unsorted[] as $lev2 | .[$lev2] | $lev1 + \"\\\\\" + $lev2 + \" = \\(.)\""
    ],
    "utterance": "Output each field of cpuUtilization and memory as group\\key = value pairs.",
    "expressions": [
      "{ cpuUtilization, memory } | to_entries[] | .key as $key | .value | to_entries[] | \"\\($key)\\\\\\(.key) = \\(.value)\"",
      "{ cpuUtilization, memory } | to_entries[] | { group: .key } + (.value | to_entries[]) | \"\\(.group)\\\\\\(.key) = \\(.value)\"",
      "{ cpuUtilization, memory } | keys_unsorted[] as $lev1 | .[$lev1] | keys_unsorted[] as $lev2 | .[$lev2] | $lev1 + \"\\\\\" + $lev2 + \" = \\(.)\"",
      "{ cpuUtilization, memory } | keys[] as $lev1 | .[$lev1] | keys[] as $lev2 | .[$lev2] | $lev1 + \"\\\\\" + $lev2 + \" = \\(.)\""
    ],
    "data": [
      {
        "input": {
          "cpuUtilization": {
            "guest": 0,
            "irq": 0,
            "system": 1.7,
            "wait": 0.1,
            "idle": 86.6,
            "user": 4.2,
            "total": 13.4,
            "steal": 5,
            "nice": 2.4
          },
          "loadAverageMinute": {
            "one": 0.65,
            "five": 0.63,
            "fifteen": 0.5
          },
          "memory": {
            "writeback": 0,
            "hugePagesFree": 1,
            "hugePagesRsvd": 0,
            "hugePagesSurp": 0,
            "cached": 216624,
            "hugePagesSize": 2048,
            "free": 116764,
            "hugePagesTotal": 325,
            "inactive": 478084,
            "pageTables": 6508,
            "dirty": 620,
            "mapped": 57336,
            "active": 649440,
            "total": 2014212,
            "slab": 48984,
            "buffers": 67976
          }
        },
        "output": [
          "cpuUtilization\\guest = 0",
          "cpuUtilization\\irq = 0",
          "cpuUtilization\\system = 1.7",
          "cpuUtilization\\wait = 0.1",
          "cpuUtilization\\idle = 86.6",
          "cpuUtilization\\user = 4.2",
          "cpuUtilization\\total = 13.4",
          "cpuUtilization\\steal = 5",
          "cpuUtilization\\nice = 2.4",
          "memory\\writeback = 0",
          "memory\\hugePagesFree = 1",
          "memory\\hugePagesRsvd = 0",
          "memory\\hugePagesSurp = 0",
          "memory\\cached = 216624",
          "memory\\hugePagesSize = 2048",
          "memory\\free = 116764",
          "memory\\hugePagesTotal = 325",
          "memory\\inactive = 478084",
          "memory\\pageTables = 6508",
          "memory\\dirty = 620",
          "memory\\mapped = 57336",
          "memory\\active = 649440",
          "memory\\total = 2014212",
          "memory\\slab = 48984",
          "memory\\buffers = 67976"
        ]
      }
    ],
    "identifier": 74739215
  },
  {
    "context": [
      "When i try to do `jq -s '.[0] * .[1]' kube-apiserver.json patch.json > patched-apiserver.json` items that are in patch.json overrides items from kube-apiserver.json so it looks like this:",
      "and i would like my file to look like this: ... I have added `unique` to ensure that `commands`, `volumeMounts` and `volumes` only appear once. This has the side effect of sorting the arrays.",
      "jq --slurpfile patch patch.json '\n  (.spec.containers |= map(.command      |= (. + $patch[].spec.containers[0].command      | unique) |\n                           .volumeMounts |= (. + $patch[].spec.containers[0].volumeMounts | unique))) |\n  (.spec.volumes    |= (. + $patch[].spec.volumes | unique))\n' kube-apiserver.json"
    ],
    "utterance": "Combine two files so that elements from patch are appended to the corresponding arrays in the original, avoiding duplicates in 'command', 'volumeMounts', and 'volumes'.",
    "expressions": [
      "jq --slurpfile patch patch.json '\n  (.spec.containers |= map(.command      |= (. + $patch[].spec.containers[0].command      | unique) |\n                           .volumeMounts |= (. + $patch[].spec.containers[0].volumeMounts | unique))) |\n  (.spec.volumes    |= (. + $patch[].spec.volumes | unique))\n' kube-apiserver.json"
    ],
    "data": [
      {
        "input": {
          "kube-apiserver.json": {
            "apiVersion": "v1",
            "kind": "Pod",
            "metadata": {},
            "spec": {
              "containers": [
                {
                  "command": [
                    "kube-apiserver",
                    "--advertise-address=192.168.49.2"
                  ],
                  "volumeMounts": [
                    {
                      "mountPath": "/etc/ssl/certs",
                      "name": "ca-certs",
                      "readOnly": true
                    }
                  ]
                }
              ],
              "volumes": [
                {
                  "hostPath": {
                    "path": "/etc/ssl/certs",
                    "type": "DirectoryOrCreate"
                  },
                  "name": "ca-certs"
                }
              ]
            },
            "status": {}
          },
          "patch.json": {
            "apiVersion": "v1",
            "kind": "Pod",
            "metadata": {},
            "spec": {
              "containers": [
                {
                  "command": [
                    "--audit-policy-file=/etc/kubernetes/audit-policy.yaml",
                    "--audit-log-path=/var/log/kubernetes/audit/audit.log"
                  ],
                  "volumeMounts": [
                    {
                      "mountPath": "/etc/kubernetes/audit-policy.yaml",
                      "name": "audit",
                      "readOnly": true
                    }
                  ]
                }
              ],
              "volumes": [
                {
                  "hostPath": {
                    "path": "/etc/kubernetes/audit-policy.yaml",
                    "type": "FileOrCreate"
                  },
                  "name": "audit"
                }
              ]
            },
            "status": {}
          }
        },
        "output": {
          "apiVersion": "v1",
          "kind": "Pod",
          "metadata": {},
          "spec": {
            "containers": [
              {
                "command": [
                  "kube-apiserver",
                  "--advertise-address=192.168.49.2",
                  "--audit-policy-file=/etc/kubernetes/audit-policy.yaml",
                  "--audit-log-path=/var/log/kubernetes/audit/audit.log"
                ],
                "volumeMounts": [
                  {
                    "mountPath": "/etc/ssl/certs",
                    "name": "ca-certs",
                    "readOnly": true
                  },
                  {
                    "mountPath": "/etc/kubernetes/audit-policy.yaml",
                    "name": "audit",
                    "readOnly": true
                  }
                ]
              }
            ],
            "volumes": [
              {
                "hostPath": {
                  "path": "/etc/ssl/certs",
                  "type": "DirectoryOrCreate"
                },
                "name": "ca-certs"
              },
              {
                "hostPath": {
                  "path": "/etc/kubernetes/audit-policy.yaml",
                  "type": "FileOrCreate"
                },
                "name": "audit"
              }
            ]
          },
          "status": {}
        }
      }
    ],
    "identifier": 74646311
  },
  {
    "context": [
      "The goal is to, within a JSON file and using jq, assign portions of `hrefFull` to `hrefSimple` and `hrefSubsite`.",
      "- `hrefSimple` is everything after and including `articles`. If `articles` is not in the string, `hrefSimple` is the string after the final `/`. See example object 7.",
      "- `hrefSubsite` is the string between `https://docs.mysite.com/` and `/articles...`.",
      "`hrefFull` does not change. Strings extracted from `hrefFull` are applied to `hrefSimple` and `hrefSubsite`.",
      "I\u2019d use `capture` with a regex:",
      ". + (.hrefFull | capture(\n  \"^https://docs.mysite.com/(?<hrefSubsite>.*?)/(?<hrefSimple>articles.*|[^/]*)$\"\n))"
    ],
    "utterance": "From the key 'hrefFull', extract 'hrefSimple' as everything after and including 'articles' (or the last path segment if 'articles' is missing) and 'hrefSubsite' as the portion between 'https://docs.mysite.com/' and '/articles...'.",
    "expressions": [
      ". + (.hrefFull | capture(\"^https://docs.mysite.com/(?<hrefSubsite>.*?)/(?<hrefSimple>articles.*|[^/]*)$\"))"
    ],
    "data": [
      {
        "input": {
          "hrefFull": "https://docs.mysite.com/product-a/articles/page-a.html"
        },
        "output": {
          "hrefFull": "https://docs.mysite.com/product-a/articles/page-a.html",
          "hrefSubsite": "product-a",
          "hrefSimple": "articles/page-a.html"
        }
      },
      {
        "input": {
          "hrefFull": "https://docs.mysite.com/product-d/sub-product-d/articles/page-d.html"
        },
        "output": {
          "hrefFull": "https://docs.mysite.com/product-d/sub-product-d/articles/page-d.html",
          "hrefSubsite": "product-d/sub-product-d",
          "hrefSimple": "articles/page-d.html"
        }
      },
      {
        "input": {
          "hrefFull": "https://docs.mysite.com/product-g/index.html"
        },
        "output": {
          "hrefFull": "https://docs.mysite.com/product-g/index.html",
          "hrefSubsite": "product-g",
          "hrefSimple": "index.html"
        }
      }
    ],
    "identifier": 74724025
  },
  {
    "context": [
      "\"Your shell pipeline can easily be merged into a single jq invocation:\\n\\n... | jq '.workflow_runs[] | first(select(.status==\\\"in_progress\\\")) | .pull_requests[0] | .number'\"",
      "\"prId=\\\"$(echo '${{ steps.get_in_progress_workflow_run.outputs.data }}' | jq '.workflow_runs[] | first(select(.status==\\\"in_progress\\\")) | .pull_requests[0] | .number')\\\";\\necho \\\"$prId\\\";\\necho \\\"prId=$prId\\\" >> \\\"$GITHUB_OUTPUT\\\"\""
    ],
    "utterance": "Extract the number of the first pull request from a workflow run that has status equal to 'in_progress'.",
    "expressions": [
      ".workflow_runs[] | first(select(.status==\"in_progress\")) | .pull_requests[0] | .number"
    ],
    "identifier": 74777243
  },
  {
    "context": [
      "I am trying to transform this JSON object:",
      "into that one:",
      "There are also empty objects in the outer object that should be remained. Only the key `details` should be transformed, others should be kept.",
      "Here is one way:",
      "map_values(\n  select(has(\"details\")) .details |=\n    map(.detail | select(. != \" \"))\n)",
      "Try this :",
      "jq 'map_values(.details? |= map(select(.detail != \" \"))' file.json",
      "You can also use `values` to empty objects not having a `.details` field (or having one with `null` as its value).",
      ".[].details |= (values | map(.detail | select(. != \" \")))"
    ],
    "utterance": "For each top-level object with a details array, replace details with an array of its detail values excluding elements where detail is a single space; keep empty objects unchanged.",
    "expressions": [
      "map_values(select(has(\"details\")) .details |= map(.detail | select(. != \" \")))",
      "map_values(.details? |= map(select(.detail != \" \")))",
      ".[].details |= (values | map(.detail | select(. != \" \")))"
    ],
    "data": [
      {
        "input": {
          "id_1": {},
          "id_2": {
            "sys": "S",
            "details": [
              {
                "detail": "S1",
                "index": 0
              },
              {
                "detail": " ",
                "index": 1
              },
              {
                "detail": " ",
                "index": 2
              },
              {
                "detail": " ",
                "index": 3
              },
              {
                "detail": " ",
                "index": 4
              }
            ],
            "color": "Grey"
          },
          "id_3": {
            "sys": "A",
            "details": [
              {
                "detail": "240",
                "index": 0
              },
              {
                "detail": "63",
                "index": 1
              },
              {
                "detail": "70",
                "index": 2
              },
              {
                "detail": " ",
                "index": 3
              },
              {
                "detail": " ",
                "index": 4
              }
            ],
            "color": "White"
          },
          "id_4": {},
          "id_5": {
            "sys": "G",
            "details": [
              {
                "detail": "266",
                "index": 0
              },
              {
                "detail": "G",
                "index": 1
              },
              {
                "detail": "1",
                "index": 2
              },
              {
                "detail": " ",
                "index": 3
              },
              {
                "detail": " ",
                "index": 4
              }
            ],
            "color": "Red"
          }
        },
        "output": {
          "id_1": {},
          "id_2": {
            "sys": "S",
            "details": [
              "S1"
            ],
            "color": "Grey"
          },
          "id_3": {
            "sys": "A",
            "details": [
              "240",
              "63",
              "70"
            ],
            "color": "White"
          },
          "id_4": {},
          "id_5": {
            "sys": "G",
            "details": [
              "266",
              "G",
              "1"
            ],
            "color": "Red"
          }
        }
      }
    ],
    "identifier": 74770252
  },
  {
    "context": [
      "I would like to right-align the amounts in a text using [jq](https://stedolan.github.io/jq/).",
      "\"\\d+\\.?\\d*\\s+EUR\" as $searchPattern | (match($searchPattern) as $m\n  | .[:$m.offset] + ($alignToColumn - $m.offset - $m.length) * \" \" + .[$m.offset:]\n) // .",
      "You can avoid `if \u2026 then \u2026 else \u2026 end` by using the alternative operator `//`."
    ],
    "utterance": "Right-align all amounts ending in 'EUR' at column 40 within the text, without using if-then-else.",
    "expressions": [
      "\"\\d+\\.?\\d*\\s+EUR\" as $searchPattern | (match($searchPattern) as $m | .[:$m.offset] + ($alignToColumn - $m.offset - $m.length) * \" \" + .[$m.offset:]) // ."
    ],
    "data": [
      {
        "input": "# comment\nlorem ipsum\n\n* Header\n2022-01-01 Internet\n    provider       30.00 EUR\n    router          5.00 EUR\n2022-01-01 House\n    rent       321.00 EUR\n    carports    20.00 EUR, 20.00 EUR\n",
        "output": "# comment\nlorem ipsum\n\n* Header\n2022-01-01 Internet\n    provider                   30.00 EUR\n    router                      5.00 EUR\n2022-01-01 House\n    rent                      321.00 EUR\n    carports                   20.00 EUR, 20.00 EUR\n"
      }
    ],
    "identifier": 74772672
  },
  {
    "context": [
      "I need to merge file1.json file2.json (could be more) into onefile.json.",
      "version is always the same value in all files. however vulnerabilities array and dependency_files array values different but there might be duplicate/which I want to remove if any after the merge",
      "You could have a `reduce` on all files, initialized with the first, hence no need for the `-n` option:",
      "jq '\n  reduce inputs as {$vulnerabilities, $dependency_files} (.;\n    .vulnerabilities = (.vulnerabilities + $vulnerabilities | unique_by(.id))\n    | .dependency_files = (.dependency_files + $dependency_files | unique_by(.name))\n  )\n' file*.json"
    ],
    "utterance": "Merge multiple files with the same structure, combining 'vulnerabilities' and 'dependency_files' arrays while removing duplicates based on 'id' and 'name', resulting in a single object.",
    "expressions": [
      "reduce inputs as {$vulnerabilities, $dependency_files} (.;\n  .vulnerabilities = (.vulnerabilities + $vulnerabilities | unique_by(.id))\n  | .dependency_files = (.dependency_files + $dependency_files | unique_by(.name))\n)"
    ],
    "data": [
      {
        "input": [
          {
            "version": "x.x.x",
            "vulnerabilities": [
              {
                "id": "0000"
              },
              {
                "id": "11111"
              },
              {
                "id": "2222"
              }
            ],
            "dependency_files": [
              {
                "name": "name0000"
              },
              {
                "name": "name1111"
              },
              {
                "name": "name2222"
              }
            ]
          },
          {
            "version": "x.x.x",
            "vulnerabilities": [
              {
                "id": "2222"
              },
              {
                "id": "3333"
              }
            ],
            "dependency_files": [
              {
                "name": "name2222"
              },
              {
                "name": "name3333"
              }
            ]
          }
        ],
        "output": {
          "version": "x.x.x",
          "vulnerabilities": [
            {
              "id": "0000"
            },
            {
              "id": "11111"
            },
            {
              "id": "2222"
            },
            {
              "id": "3333"
            }
          ],
          "dependency_files": [
            {
              "name": "name0000"
            },
            {
              "name": "name1111"
            },
            {
              "name": "name2222"
            },
            {
              "name": "name3333"
            }
          ]
        }
      }
    ],
    "identifier": 74738798
  },
  {
    "context": [
      "I'm trying to clean it by removing unwanted fields, like \"remove\", \"nokeep1\" and \"nokeep2\".",
      "However objects in the \"data2\" and \"data3\" arrays might contain more fields than the example \"nokeepX\", but will always contain \"keep1\" and \"keep2\" which I want to keep.",
      "Just provide all the concrete paths to `del`:",
      "Or generalize by e.g. traversing all array items (not just the first) using `[]` without indices:",
      "Or go arbitrarily deep using `..`, and just provide the deepest field names:",
      "For the other way round, you could list all the leaf paths using `paths(scalars)`, filter out those where the deepest level `.[-1]` does `not` match your criteria, and use `delpaths` to remove the remaining leafs:",
      "If you have only a limited set of properties, it could be easier not to remove unwanted fields, but create the output from the required fields only:"
    ],
    "utterance": "Remove all fields except 'keep1' and 'keep2' from each object in both 'data2' and 'data3' arrays inside 'detail', and remove the top-level 'drop' field.",
    "expressions": [
      "del(\n  .detail.data2[].nokeep1,\n  .detail.data3[].nokeep2,\n  .drop\n)",
      "del(.. | objects | .nokeep1, .nokeep2, .drop)",
      "delpaths([paths(scalars) | select(\n  .[-1] | IN(\"keep\", \"keep1\", \"keep2\") | not\n)])",
      "{\n    meta,\n    detail: .detail | {\n        data2: .data2 | map({ keep1, keep2 }),\n        data3: .data3 | map({ keep1, keep2 })\n    }\n}"
    ],
    "data": [
      {
        "input": {
          "meta": {
            "data1": {
              "keep": {
                "key": "value"
              }
            }
          },
          "detail": {
            "data2": [
              {
                "keep1": "keep1value",
                "keep2": "keep2value",
                "nokeep1": "abc"
              }
            ],
            "data3": [
              {
                "keep1": "keep1value",
                "keep2": "keep2value",
                "nokeep2": {
                  "abc": "def"
                }
              }
            ]
          },
          "drop": "this"
        },
        "output": {
          "meta": {
            "data1": {
              "keep": {
                "key": "value"
              }
            }
          },
          "detail": {
            "data2": [
              {
                "keep1": "keep1value",
                "keep2": "keep2value"
              }
            ],
            "data3": [
              {
                "keep1": "keep1value",
                "keep2": "keep2value"
              }
            ]
          }
        }
      }
    ],
    "identifier": 74783585
  },
  {
    "context": [
      "Now i want to add more logic to the query, and do something like that: If the number of bla lines is bigger than 3, then print the oldest bla lines (according to the date field). In my case, the output should be:\r\n\r\n    bla-233",
      "sort_by(.CreateTime) sorts _ascending_ by the CreateTime property.",
      "map(.LaunchTemplateName|select(startswith(\"bla\")))",
      "[:-3] slices the input array to drop the last 3 elements (i.e. dropping the 3 newest elements.",
      "reverse[] reverses the array and streams its elements."
    ],
    "utterance": "If there are more than three LaunchTemplates whose name starts with 'bla', print the oldest one(s) based on CreateTime.",
    "expressions": [
      ".LaunchTemplates\n| map(select(.LaunchTemplateName | startswith(\"bla\")))\n| sort_by(.CreateTime)\n| if length > 3 then .[:length-3][] .LaunchTemplateName else empty end"
    ],
    "data": [
      {
        "input": {
          "LaunchTemplates": [
            {
              "LaunchTemplateName": "bla-99",
              "CreateTime": "2022-12-13T13:40:33+00:00"
            },
            {
              "LaunchTemplateName": "abcabc",
              "CreateTime": "2022-12-13T09:58:14+00:00"
            },
            {
              "LaunchTemplateName": "bla-34",
              "CreateTime": "2022-12-13T13:58:56+00:00"
            },
            {
              "LaunchTemplateName": "bla-222",
              "CreateTime": "2022-12-11T13:58:56+00:00"
            },
            {
              "LaunchTemplateName": "bla-233",
              "CreateTime": "2022-12-10T13:58:56+00:00"
            }
          ]
        },
        "output": "bla-233"
      }
    ],
    "identifier": 74790314
  },
  {
    "context": [
      "I would like to create a custom CSV from this data to see all connections by process id (pid), but I don't get it.",
      "jq -r '{pid: .process.pid} + .connections[] | to_entries | map(.value) | @csv' input.json"
    ],
    "utterance": "Output a CSV where each row contains the process pid and all fields from each connection.",
    "expressions": [
      "{pid: .process.pid} + .connections[] | to_entries | map(.value) | @csv"
    ],
    "data": [
      {
        "input": {
          "process": {
            "pid": "1462",
            "path": "/Applications/Google Chrome.app/Contents/Frameworks/Google Chrome Framework.framework/Versions/108.0.5359.98/Helpers/Google Chrome Helper.app/Contents/MacOS/Google Chrome Helper",
            "signature(s)": {
              "signatureIdentifier": "com.google.Chrome.helper",
              "signatureStatus": 0,
              "signatureSigner": 3,
              "signatureAuthorities": [
                "Developer ID Application: Google LLC (EQHXZ8M8AV)",
                "Developer ID Certification Authority",
                "Apple Root CA"
              ]
            }
          },
          "connections": [
            {
              "remoteHostName": "n/a",
              "protocol": "UDP",
              "interface": "",
              "localAddress": "::",
              "state": "n/a",
              "remotePort": "0",
              "localPort": "5353",
              "remoteAddress": "::"
            },
            {
              "remoteHostName": "n/a",
              "protocol": "TCP",
              "interface": "en0",
              "localAddress": "2a02:560:5424:b200:359c:f801:abab:cd28",
              "state": "Established",
              "remotePort": "443",
              "localPort": "50190",
              "remoteAddress": "2600:1f18:60d5:4e03:ffe8:813e:6d1a:d379"
            }
          ]
        },
        "output": [
          "\"1462\",\"n/a\",\"UDP\",\"\",\"::\",\"n/a\",\"0\",\"5353\",\"::\"",
          "\"1462\",\"n/a\",\"TCP\",\"en0\",\"2a02:560:5424:b200:359c:f801:abab:cd28\",\"Established\",\"443\",\"50190\",\"2600:1f18:60d5:4e03:ffe8:813e:6d1a:d379\""
        ]
      }
    ],
    "identifier": 74795560
  },
  {
    "context": [
      "Current API output (which needs to be converted into HCL):",
      "Required format:",
      "If I recall correctly, the filter would be something like",
      "[\n  inputs |\n     split(\",\") |\n     map(ltrimstr(\"\\\"\")) |\n     map(rtrimstr(\"\\\"\") ) |\n     {\n        cluster_name: .[0],\n        cluster_region: .[1],\n        instance_db_size: .[2],\n        instance_size: .[3]\n     }\n] | {variable: {cluster_configuration: {default: .}}}",
      "jq -srR '\n  split(\"\\n\") |        # split lines\n  map(split(\" \") |     # split fields\n      select(any) |    # remove emty lines\n      map(.[1:-1]) |   # remove enclosing quotes\n      {\n        cluster_name: .[0],\n        cluster_region: .[1],\n        instance_db_size: .[2],\n        instance_size: .[3]\n      }) |\n  \"variable \\\"cluster_configuration\\\" {\",\n  \"    default = \",\n  .,\n  \"}\"\n' <<< \"$INPUT\""
    ],
    "utterance": "Convert input lines containing quoted cluster attributes into a variable block with a default array of objects, each containing cluster_name, cluster_region, instance_db_size, and instance_size, matching the values from each input line.",
    "expressions": [
      "[inputs | split(\",\") | map(ltrimstr(\"\\\"\") ) | map(rtrimstr(\"\\\"\") ) | {cluster_name: .[0], cluster_region: .[1], instance_db_size: .[2], instance_size: .[3]}] | {variable: {cluster_configuration: {default: .}}}",
      "split(\"\\n\") | map(split(\" \") | select(any) | map(.[1:-1]) | {cluster_name: .[0], cluster_region: .[1], instance_db_size: .[2], instance_size: .[3]}) | \"variable \\\"cluster_configuration\\\" {\", \"    default = \", ., \"}\""
    ],
    "data": [
      {
        "input": [
          "'cluster_name1' 'REGION1' 'Volume_Size1' 'Instance_Size1'",
          "'cluster_name2' 'REGION2' 'Volume_Size2' 'Instance_Size2'",
          "'cluster_name3' 'REGION3' 'Volume_Size3' 'Instance_Size3'"
        ],
        "output": [
          {
            "cluster_name": "cluster_name1",
            "cluster_region": "REGION1",
            "instance_db_size": "Volume_Size1",
            "instance_size": "Instance_Size1"
          },
          {
            "cluster_name": "cluster_name2",
            "cluster_region": "REGION2",
            "instance_db_size": "Volume_Size2",
            "instance_size": "Instance_Size2"
          },
          {
            "cluster_name": "cluster_name3",
            "cluster_region": "REGION3",
            "instance_db_size": "Volume_Size3",
            "instance_size": "Instance_Size3"
          }
        ]
      }
    ],
    "identifier": 74748192
  },
  {
    "context": [
      "I would like to select the `SerialNumber` of the device containing the string `cli`. But in case there is only one device in the list (regardless of the presence or absence of the string `cli`), I'd like to get its `SerialNumber`.",
      ".MFADevices | map(.SerialNumber) | first((.[] | select(contains(\"cli\"))), first)",
      "[.MFADevices[].SerialNumber] | map(select(contains(\"cli\"))) + .[:1] | first",
      "(MFADevices[?contains(SerialNumber, `cli`)] | [0]).SerialNumber \n  || MFADevices[0].SerialNumber"
    ],
    "utterance": "Return the SerialNumber containing 'cli' if present; otherwise, if there is only one device, return its SerialNumber; if multiple devices and none contains 'cli', return the first SerialNumber.",
    "expressions": [
      ".MFADevices | map(.SerialNumber) | first((.[] | select(contains(\"cli\"))), first)",
      "[.MFADevices[].SerialNumber] | map(select(contains(\"cli\"))) + .[:1] | first",
      "(MFADevices[?contains(SerialNumber, `cli`)] | [0]).SerialNumber || MFADevices[0].SerialNumber"
    ],
    "data": [
      {
        "input": {
          "MFADevices": [
            {
              "UserName": "foobar@example.com",
              "SerialNumber": "arn:aws:iam::000000000000:mfa/foo",
              "EnableDate": "2022-12-06T16:23:41+00:00"
            },
            {
              "UserName": "barfoo@example.com",
              "SerialNumber": "arn:aws:iam::111111111111:mfa/bar_cli",
              "EnableDate": "2022-12-12T09:13:10+00:00"
            }
          ]
        },
        "output": "arn:aws:iam::111111111111:mfa/bar_cli"
      },
      {
        "input": {
          "MFADevices": [
            {
              "UserName": "foobar@example.com",
              "SerialNumber": "arn:aws:iam::000000000000:mfa/foo",
              "EnableDate": "2022-12-06T16:23:41+00:00"
            }
          ]
        },
        "output": "arn:aws:iam::000000000000:mfa/foo"
      }
    ],
    "identifier": 74800790
  },
  {
    "context": [
      "In the output file, name3 is listed only with the second product, I want all the products to be listed separately. If more than a product is available under a nameX, the result lists only the last product.",
      "You can use the multiplication operator for recursive merges.",
      "reduce .[] as $obj ({}; . * $obj)"
    ],
    "utterance": "Merge an array of objects, recursively combining all sub-objects so that for each key, all values are preserved and not overwritten by later objects.",
    "expressions": [
      "reduce .[] as $obj ({}; . * $obj)"
    ],
    "data": [
      {
        "input": [
          {
            "Action": {
              "name1": {
                "product": {
                  "summary": "Summary Product"
                }
              }
            }
          },
          {
            "Action": {
              "name2": {
                "gproduct": {
                  "summary": "Summary Product"
                }
              }
            }
          },
          {
            "Action": {
              "name3": {
                "product1": {
                  "summary": "Summary Product1"
                }
              }
            }
          },
          {
            "Action": {
              "name3": {
                "product2": {
                  "summary": "Summary Product2"
                }
              }
            }
          }
        ],
        "output": {
          "Action": {
            "name1": {
              "product": {
                "summary": "Summary Product"
              }
            },
            "name2": {
              "gproduct": {
                "summary": "Summary Product"
              }
            },
            "name3": {
              "product1": {
                "summary": "Summary Product1"
              },
              "product2": {
                "summary": "Summary Product2"
              }
            }
          }
        }
      }
    ],
    "identifier": 74811009
  },
  {
    "context": [
      "I need to restructure some JSON files to clean up the data representation. Part of this restructuring includes grouping similar objects in a parent object rather than relying on a particular property of the object.",
      "We will have five \"sections\" in the files: `attributes`, `associatedObjects`, `inheritedObjects`, `enumerations`, which will be used to represent \"active\" objects, and then a `deprecated` section that has those same four subgroups to denote, well, \"deprecated\" objects.",
      "Given a structure such as:\n\n``` {\n    \"attributes\": {\n        \"alpha\": {\n            \"deprecated\": true,\n            \"description\": \"A description of alpha.\",\n            \"dataType\": \"string\"\n        },\n        \"beta\": {\n            \"deprecated\": false,\n            \"description\": \"A description of beta.\",\n            \"dataType\": \"associated object\",\n            \"associatedObject\": \"gamma\"\n        },\n        \"kappa\": {\n            \"deprecated\": false,\n            \"description\": \"A description of kappa.\",\n            \"dataType\": \"string\"\n        }\n    }\n}\n```",
      "How might I reorganize the file using `jq` to appear more like the following?\n\n```{\n    \"deprecations\": {\n        \"attributes\": {\n            \"alpha\": {\n                \"description\": \"A description of alpha.\",\n                \"dataType\": \"string\"\n            }\n        },\n        \"enumerations\": {},\n        \"associatedObjects\": {},\n        \"inheritedObjects\": {}\n    },\n    \"attributes\": {\n        \"kappa\": {\n            \"description\": \"A description of kappa.\",\n            \"dataType\": \"string\"\n        }\n    },\n    \"enumerations\": {},\n    \"associatedObjects\": {\n        \"beta\": {\n            \"description\": \"A description of beta.\",\n            \"dataType\": \"gamma\"\n        }\n    },\n    \"inheritedObjects\": {}\n}\n```",
      "This should generate the expected output :\n\n```\njq '(.attributes | map_values(select(.deprecated))) as $dep\n    | .depreciations.attributes = ($dep | map_values(del(.deprecated)))\n    | (.attributes | map_values(select(has(\"associatedObject\")))) as $assoc\n    | .associatedObjects = ($assoc\n                           | map_values(.dataType = .associatedObject)\n                           | map_values(del(.deprecated, .associatedObject))\n                           )\n    | .attributes |= del(.[]|select(.deprecated))\n    | .attributes |= del(.[]|select(has(\"associatedObject\")))\n    | .attributes[] |= del(.deprecated)\n    | .depreciations += { \"enumerations\": {}, \"associatedObjects\": {}, \"inheritedObjects\": {} }\n    | . + { \"enumerations\": {}, \"inheritedObjects\": {} }\n' input.json\n```"
    ],
    "utterance": "Restructure the data so non-deprecated items with dataType string are under attributes, items with has(\"associatedObject\") are under associatedObjects with dataType set to the associatedObject's value, deprecated items are grouped under deprecations.attributes with deprecated and associatedObject properties removed, and all sections (enumerations, inheritedObjects) present and empty where needed.",
    "expressions": [
      "(.attributes | map_values(select(.deprecated))) as $dep\n    | .depreciations.attributes = ($dep | map_values(del(.deprecated)))\n    | (.attributes | map_values(select(has(\"associatedObject\")))) as $assoc\n    | .associatedObjects = ($assoc\n                           | map_values(.dataType = .associatedObject)\n                           | map_values(del(.deprecated, .associatedObject))\n                           )\n    | .attributes |= del(.[]|select(.deprecated))\n    | .attributes |= del(.[]|select(has(\"associatedObject\")))\n    | .attributes[] |= del(.deprecated)\n    | .depreciations += { \"enumerations\": {}, \"associatedObjects\": {}, \"inheritedObjects\": {} }\n    | . + { \"enumerations\": {}, \"inheritedObjects\": {} }"
    ],
    "data": [
      {
        "input": {
          "attributes": {
            "alpha": {
              "deprecated": true,
              "description": "A description of alpha.",
              "dataType": "string"
            },
            "beta": {
              "deprecated": false,
              "description": "A description of beta.",
              "dataType": "associated object",
              "associatedObject": "gamma"
            },
            "kappa": {
              "deprecated": false,
              "description": "A description of kappa.",
              "dataType": "string"
            }
          }
        },
        "output": {
          "attributes": {
            "kappa": {
              "description": "A description of kappa.",
              "dataType": "string"
            }
          },
          "depreciations": {
            "attributes": {
              "alpha": {
                "description": "A description of alpha.",
                "dataType": "string"
              }
            },
            "enumerations": {},
            "associatedObjects": {},
            "inheritedObjects": {}
          },
          "associatedObjects": {
            "beta": {
              "description": "A description of beta.",
              "dataType": "gamma"
            }
          },
          "enumerations": {},
          "inheritedObjects": {}
        }
      }
    ],
    "identifier": 74775708
  },
  {
    "context": [
      "I'm trying to combine two json files with arrays in common using jq (example below):",
      "Desired output:",
      "{\n  \"veg\": {\n    \"trolley\": [\n      \"potato\",\n      \"lettuce\",\n      \"tomato\"\n    ],\n    \"total_items\": [\n      1,\n      2\n    ]\n  }\n}",
      "jq -s '{ \n    veg: {\n        trolley: ([ .[].veg.trolley ] | add),\n        total_items: ([ .[].veg.total_items ] | add),\n    }\n}' input1 input2",
      "reduce (input.veg | to_entries)[] as $e (.; .veg[$e.key] += $e.value)"
    ],
    "utterance": "Combine the 'trolley' and 'total_items' arrays from two input files under 'veg', concatenating values without overwriting.",
    "expressions": [
      "jq -s '{ veg: { trolley: ([ .[].veg.trolley ] | add), total_items: ([ .[].veg.total_items ] | add) } }' input1 input2",
      "jq 'reduce (input.veg | to_entries)[] as $e (.; .veg[$e.key] += $e.value)' file1.json file2.json"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "veg": {
              "trolley": [
                "potato"
              ],
              "total_items": [
                1
              ]
            }
          },
          "file2.json": {
            "veg": {
              "trolley": [
                "lettuce",
                "tomato"
              ],
              "total_items": [
                2
              ]
            }
          }
        },
        "output": {
          "veg": {
            "trolley": [
              "potato",
              "lettuce",
              "tomato"
            ],
            "total_items": [
              1,
              2
            ]
          }
        }
      }
    ],
    "identifier": 74810329
  },
  {
    "context": [
      "for i in $(cat \"$FILENAME\" | jq -r .[].personnelNumber); do \n  echo $i\n  echo\n  jq '.[] | select(.personnelNumber==\"'$i'\")' \"$FILENAME\"\n  echo\n   done",
      "it partly seems to run fine but sadly the output is.",
      "if there is only 1 person in the json everything works as expected.\nbut when there are more, the code only runs properly on the last person in the \"For i in $cat\" list.",
      "I am first making making a loop based upon the personnelNumber.\nThan for each personnelNumber I want to print the full array (which doesn't have an array ID)",
      "The Comment of Gordon Davisson was exacly what was going on.\n\n> That weirdly-formatted error message makes me suspect you've got DOS/Windows line endings somewhere",
      "So conclusion, if you are running GITBASH or any Cygwin BASH make sure the Carriage Return in line endings are correct."
    ],
    "utterance": "For each personnelNumber in the input, print the entire object with that personnelNumber.",
    "expressions": [
      ".[] | select(.personnelNumber==\"$i\")"
    ],
    "data": [
      {
        "input": [
          {
            "personnelNumber": "3633014",
            "name": "Alice"
          },
          {
            "personnelNumber": "3634594",
            "name": "Bob"
          },
          {
            "personnelNumber": "3634708",
            "name": "Carol"
          }
        ],
        "output": [
          {
            "personnelNumber": "3633014",
            "name": "Alice"
          },
          {
            "personnelNumber": "3634594",
            "name": "Bob"
          },
          {
            "personnelNumber": "3634708",
            "name": "Carol"
          }
        ]
      }
    ],
    "identifier": 74863850
  },
  {
    "context": [
      "I would like to make a small `jq`-like function that does get-or-default-if-not-present similar to Python's `dict.get(key, default)`.",
      "% my-jq nested.key \\\"default\\\" file.json\n\"value\"\n% my-jq nested.tricky \\\"default\\\" file.json\nnull\n% my-jq nested.dne \\\"default\\\" file.json\n\"default\"",
      "`$key | ltrimstr(\".\") | split(\".\")` first gets rid of the leading `.`, then splits the remaining string on the remaining `.` to produce a list of separate keys. `getpath` produces a filter using that list of keys; `getpath([\"nested\", \"key\"])` is equivalent (AFAIK) to `.nested.key`.",
      "jq  'getpath($key | ltrimstr(\".\") | split(\".\")) // $default' file.json --arg key .nested.key --arg default foobar",
      "function my-jq() { jq \"if any(path($1) == paths; .) then ($1) else ($2) end\" \"$3\"; }",
      "% my-jq .nested.key \\\"default\\\" file.json\n\"value\"\nmy-jq .nested.tricky \\\"default\\\" file.json\nnull\n% my-jq .nested.dne \\\"default\\\" file.json\n\"default\""
    ],
    "utterance": "Return the value at a given nested key path, or a specified default if the key does not exist; return null if the key exists with null value.",
    "expressions": [
      "getpath($key | ltrimstr(\".\") | split(\".\")) // $default",
      "if any(path($1) == paths; .) then ($1) else ($2) end",
      "($1) // if any(path($1) == paths; .) then ($1) else ($2) end"
    ],
    "data": [
      {
        "input": {
          "nested": {
            "key": "value",
            "tricky": null
          }
        },
        "output": "\"value\""
      },
      {
        "input": {
          "nested": {
            "key": "value",
            "tricky": null
          }
        },
        "output": "null"
      },
      {
        "input": {
          "nested": {
            "key": "value",
            "tricky": null
          }
        },
        "output": "\"default\""
      }
    ],
    "identifier": 74816550
  },
  {
    "context": [
      "There can be anywhere any deep `..body.raw` strings, on these I want to do a simple search and replace (Or better: Parse the string as JSon and do some jq on that?).",
      "And any deep objects with `.key` and .`value` (strings), in this I just want to replace the `.value=\"{{\"+.key+\"}}\"`",
      "One way to process the .body.raw values would be to start with:\n\n    (.. | try .body.raw // empty) |= fromjson",
      "One way to update the .value values would be to include the following in your jq pipeline:\n\n    walk(if type == \"object\" and has(\"key\") and has(\"value\") \n         then .value = \"{{\\(.key)}}\" else . end)"
    ],
    "utterance": "Parse all nested .body.raw string values as data and update all objects with both .key and .value properties so that .value becomes \"{{<key>}}\" where <key> is the value of .key",
    "expressions": [
      "(.. | try .body.raw // empty) |= fromjson | walk(if type == \"object\" and has(\"key\") and has(\"value\") then .value = \"{{\\(.key)}}\" else . end)"
    ],
    "data": [
      {
        "input": {
          "bla": {
            "body": {
              "mode": "raw",
              "raw": "{\n  \"accountId\": \"1111\",\n  \"monetaryAmount\": {\n    \"amount\": 111,\n    \"exponent\": 2,\n    \"currency\": \"aaa\"\n  },\n  \"remarks\": \"consequat quis\"\n}",
              "options": {
                "raw": {
                  "language": "json"
                }
              }
            }
          },
          "auth": {
            "type": "bearer",
            "bearer": [
              {
                "key": "token",
                "value": "{{token}}",
                "type": "string"
              }
            ]
          },
          "segg": {
            "key": "txn_id",
            "value": "{{token}}",
            "type": "string"
          },
          "slugg": {
            "key": "companyId",
            "value": "{{token}}",
            "type": "string"
          },
          "blu": [
            {
              "key": "teamMemberId",
              "value": "{{token}}",
              "type": "string"
            }
          ]
        }
      }
    ],
    "identifier": 74821551
  },
  {
    "context": [
      "aws iam list-roles | jq -c '.Roles[].RoleName | select(startswith (\"blabla\"))'",
      "jq: error: AD_/0 is not defined at <top-level>, line 1:\n.Roles[].RoleName | select(startswith (AD_))\njq: 1 compile error",
      "It looks like you might be missing a string after the `startswith` function. Try adding a string in quotes after `startswith:`",
      "aws iam list-roles | jq -c '.Roles[].RoleName | select(startswith(\"blabla\"))'",
      "AFAIK Powershell does not support single quotes. Use double quotes and escaped double quotes instead:",
      "aws iam list-roles | jq -c \".Roles[].RoleName | select(startswith (\\\"blabla\\\"))\""
    ],
    "utterance": "Return all RoleName values where the role name starts with 'blabla'.",
    "expressions": [
      ".Roles[].RoleName | select(startswith(\"blabla\"))"
    ],
    "data": [
      {
        "input": {
          "Roles": [
            {
              "RoleName": "blabla_rolename_1"
            },
            {
              "RoleName": "foo_bar"
            },
            {
              "RoleName": "blabla_secondrole"
            }
          ]
        },
        "output": [
          "blabla_rolename_1",
          "blabla_secondrole"
        ]
      }
    ],
    "identifier": 74864461
  },
  {
    "context": [
      "jq --arg NAME \"John\" '.[] | select(.group | contains ($NAME))",
      "this should return only the name John, but it is displaying all values where John is included..",
      "Eg: displays Johnny, Johnie",
      "It's giving these values also as output.",
      "Use `==` for exact matches, i.e. comparing with the entire string only:",
      "jq --arg NAME \"John\" '.[] | select(.group == $NAME)'"
    ],
    "utterance": "Select objects where the group field matches John exactly and not just as a substring.",
    "expressions": [
      ".[] | select(.group == $NAME)"
    ],
    "identifier": 74887953
  },
  {
    "context": [
      "The final output should produce the following json when I `echo \"${json_query_data}\"`:\n\n    {\n        devices: {\n                   sda: {\"disk_id\": 111, \"volume_id\": null },\n                   sdb: {\"disk_id\": null, \"volume_id\": 444 },\n                   sdc: {\"disk_id\": 222, \"volume_id\": null },\n                   sdd: {\"disk_id\": 333, \"volume_id\": null },\n    }}",
      "for i in ${!disk_ids[@]}\ndo\n  json=\"$(\n    jq --argjson disk_id \"${disk_ids[$i]}\" --argjson volume_id \"${volume_ids[$i]}\" '\n      .devices |= . + {\"sd([length + 97] | implode)\": {$disk_id, $volume_id}}\n    ' <<< \"$json\"\n  )\"\ndone\necho \"$json\""
    ],
    "utterance": "Build an object with key 'devices' containing properties 'sda', 'sdb', 'sdc', and 'sdd', each with values pairing disk_ids and volume_ids in order",
    "expressions": [
      "jq -n --arg disk_ids \"${disk_ids[*]}\" --arg volume_ids \"${volume_ids[*]}\" '\n  [$disk_ids, $volume_ids | . / \" \" | map(fromjson)]\n  | transpose | {devices: with_entries(\n      .key |= \"sd([. + 97] | implode)\"\n      | .value |= {disk_id: first, volume_id: last}\n    )}\n'",
      "jq -n --arg disk_ids \"${disk_ids[*]}\" --arg volume_ids \"${volume_ids[*]}\" --arg letters \"${letters[*]}\" '\n  [$disk_ids, $letters, $volume_ids | . / \" \" ] | .[0,2] |= map(fromjson)\n  | transpose | {devices: with_entries(\n      .key = \"sd(.value[1])\"\n      | .value |= {disk_id: first, volume_id: last}\n    )}\n'",
      "jq --argjson disk_id \"${disk_ids[$i]}\" --argjson volume_id \"${volume_ids[$i]}\" '\n  .devices |= . + {\"sd([length + 97] | implode)\": {$disk_id, $volume_id}}\n'",
      "jq --argjson disk_id \"${disk_ids[$i]}\" --argjson volume_id \"${volume_ids[$i]}\" --arg letter \"${letters[$i]}\" '\n  .devices[\"sd($letter)\"] += {$disk_id, $volume_id}\n'"
    ],
    "data": [
      {
        "input": {
          "disk_ids": [
            111,
            null,
            222,
            333
          ],
          "volume_ids": [
            null,
            444,
            null,
            null
          ]
        },
        "output": {
          "devices": {
            "sda": {
              "disk_id": 111,
              "volume_id": null
            },
            "sdb": {
              "disk_id": null,
              "volume_id": 444
            },
            "sdc": {
              "disk_id": 222,
              "volume_id": null
            },
            "sdd": {
              "disk_id": 333,
              "volume_id": null
            }
          }
        }
      }
    ],
    "identifier": 74832052
  },
  {
    "context": [
      "jq -n --argjson r1 \"$DETAILS\" --argjson r2 \"$LATEST_SNAP_ID\" '\n{\n    \"cluster_configuration\": {\n      ($r1[0]): {\n        \"db_size\": $r1[2],\n        \"size\": $r1[3],\n        \"id\": $r2[0],\n        \"created_at\": $r2[1]\n      }\n   }\n}\n'",
      "This produces:\n{\n  \"cluster_configuration\": {\n    \"cluster_name\": {\n      \"db_size\": 100,\n      \"size\": \"R50\",\n      \"id\": \"1234567890987654321\",\n      \"created_at\": \"2022-12-20T23:01:56Z\"\n    }\n  }\n}"
    ],
    "utterance": "Construct an object with a key named cluster_configuration whose value is an object keyed by the cluster's name, containing db_size, size, id, and created_at, using lists of values from previous queries.",
    "expressions": [
      "jq -n --argjson r1 \"$DETAILS\" --argjson r2 \"$LATEST_SNAP_ID\" '{\n    \"cluster_configuration\": {\n      ($r1[0]): {\n        \"db_size\": $r1[2],\n        \"size\": $r1[3],\n        \"id\": $r2[0],\n        \"created_at\": $r2[1]\n      }\n   }\n}'"
    ],
    "data": [
      {
        "input": {
          "DETAILS": [
            "cluster_name",
            "region",
            100,
            "R50"
          ],
          "LATEST_SNAP_ID": [
            "1234567890987654321",
            "2022-12-20T23:01:56Z"
          ]
        },
        "output": {
          "cluster_configuration": {
            "cluster_name": {
              "db_size": 100,
              "size": "R50",
              "id": "1234567890987654321",
              "created_at": "2022-12-20T23:01:56Z"
            }
          }
        }
      }
    ],
    "identifier": 74881238
  },
  {
    "context": [
      "How can I instruct jq to stop once it sees the first object with \"/Type\".N being \"/Catalog\"?",
      "first(.[] | select(.[1] | objects.\"/Type\".N == \"/Catalog\") | .[1].\"/Dests\")"
    ],
    "utterance": "Return the '/Dests' field from the first object where '[1]' contains an object whose '/Type'.N is '/Catalog'.",
    "expressions": [
      "first(.[] | select(.[1] | objects.\"/Type\".N == \"/Catalog\") | .[1].\"/Dests\")"
    ],
    "identifier": 74904685
  },
  {
    "context": [
      "I would like to get the following result:",
      "{\n    \"item\": \"arrayItem1\",\n    \"outer\": \"outerDescription1\",\n    \"inner\": \"innerDescription1\",\n    \"otherProperties\": 1\n}",
      "Assumption: there are many `outerDescription` and `innerDescription` keys and they are not known upfront.",
      "But right now, without knowing the next nested key name exactly, I am not able to unroll for a second time in the same way as `outer` would be swallowed.",
      "path(.[][].items[]) as $p\n| {item: getpath($p), outer: $p[0], inner: $p[1]}\n+ (getpath($p[:-2]) | del(.items))",
      "If you know the name of your `items` property, the following equivalent programs are quite readable:",
      "to_entries[]\n| { outer: .key, nested: (.value | to_entries[]) }\n| { item: .nested.value.items[] }\n+ { outer, inner: .nested.key }\n+ (.nested.value | del(.items))"
    ],
    "utterance": "Produce a stream of objects for each item in any nested 'items' arrays, including the item, the outermost and innermost dynamic key names, and the remaining properties at the innermost level, regardless of what the key names are.",
    "expressions": [
      "path(.[][].items[]) as $p | {item: getpath($p), outer: $p[0], inner: $p[1]} + (getpath($p[:-2]) | del(.items))",
      "to_entries[]\n| { outer: .key, nested: (.value | to_entries[]) }\n| { item: .nested.value.items[] }\n+ { outer, inner: .nested.key }\n+ (.nested.value | del(.items))",
      "to_entries[] | .key as $outer | .value | to_entries[] | .key as $inner | .value | .otherProperties as $otherProperties | .items[] | {item: ., $outer, $inner, $otherProperties}",
      "to_entries[] | {outer: .key} + ( .value | to_entries[] | {inner: .key} + ( .value | {otherProperties} + ( .items[] | {item: .} )))"
    ],
    "data": [
      {
        "input": {
          "outerDescription1": {
            "innerDescription1": {
              "otherProperties": 1,
              "items": [
                "arrayItem1",
                "arrayItem2"
              ]
            }
          },
          "outerDescription2": {
            "innerDescription2": {
              "otherProperties": 2,
              "items": [
                "arrayItem3",
                "arrayItem4"
              ]
            }
          }
        },
        "output": [
          {
            "item": "arrayItem1",
            "outer": "outerDescription1",
            "inner": "innerDescription1",
            "otherProperties": 1
          },
          {
            "item": "arrayItem2",
            "outer": "outerDescription1",
            "inner": "innerDescription1",
            "otherProperties": 1
          },
          {
            "item": "arrayItem3",
            "outer": "outerDescription2",
            "inner": "innerDescription2",
            "otherProperties": 2
          },
          {
            "item": "arrayItem4",
            "outer": "outerDescription2",
            "inner": "innerDescription2",
            "otherProperties": 2
          }
        ]
      }
    ],
    "identifier": 74789072
  },
  {
    "context": [
      "I want to extract the nodes with /Type /Pages. and show /Parent and /Kids along with the first number of each node. In the above example, the output should be something like this, where <TAB> is a tab character.",
      "jq -r '\n  .[] | select(.[1] | objects.\"/Type\".N == \"/Pages\")\n  | [.[0], .[1].\"/Parent\", (.[1].\"/Kids\" | join(\",\"))]\n  | @tsv\n'"
    ],
    "utterance": "For all entries where the second element has /Type.N equal to /Pages, output the first number, the value of /Parent, and a comma-separated list of /Kids, each row separated by tabs.",
    "expressions": [
      ".[] | select(.[1] | objects.\"/Type\".N == \"/Pages\") | [.[0], .[1].\"/Parent\", (.[1].\"/Kids\" | join(\",\"))] | @tsv"
    ],
    "data": [
      {
        "input": [
          [
            16876,
            {
              "/Type": {
                "N": "/Pages"
              },
              "/Count": {
                "I": 68
              },
              "/Kids": [
                16872,
                16847
              ],
              "/Parent": 16877
            }
          ],
          [
            16877,
            {
              "/Type": {
                "N": "/Pages"
              },
              "/Count": {
                "I": 1604
              },
              "/Kids": [
                16873,
                16874,
                16875,
                16876
              ]
            }
          ],
          [
            168,
            []
          ]
        ],
        "output": "16876\t16877\t16872,16847\n16877\t\t16873,16874,16875,16876"
      }
    ],
    "identifier": 74894477
  },
  {
    "context": [
      "I have an object that looks like this ... I'd like to get all of the image properties from each of the objects, and from each object in `my_list` and other lists that have objects that include an `image` property. So in this example I'd like to get ...\n\"an_image.com\"\n\"another_image.com\"\n\"foobar.io\"\n\"bar_image.io\" ... We don't know the keys of any of these objects at runtime, so we can't reference `my_list`, `foo`, or `bar` in this example.",
      "If you don't mind the terseness, you could perhaps go with:\n    jq '..|select(.image?).image'",
      "You could select by `objects` and items of `arrays`:\n~~~sh\njq '.[] | ., arrays[] | objects.image'\n~~~",
      "Using _recursive descent_ `..` is more elegant:\n    jq '.. | .image? // empty'",
      "$ jq --stream -r 'select(.[0][-1] == \"image\")[1] // empty' input.json"
    ],
    "utterance": "Extract all values of properties named \"image\" from all objects, regardless of their nesting or key names, including objects within arrays.",
    "expressions": [
      "..|select(.image?).image",
      ".. | .image? // empty",
      ".[] | ., arrays[] | objects.image",
      "--stream -r 'select(.[0][-1] == \"image\")[1] // empty'"
    ],
    "data": [
      {
        "input": {
          "my_list": [
            {
              "name": "an_image",
              "image": "an_image.com"
            },
            {
              "name": "another_image",
              "image": "another_image.com"
            }
          ],
          "foo": {
            "image": "foobar.io"
          },
          "bar": {
            "image": "bar_image.io"
          }
        },
        "output": [
          "an_image.com",
          "another_image.com",
          "foobar.io",
          "bar_image.io"
        ]
      }
    ],
    "identifier": 74894635
  },
  {
    "context": [
      "What I am looking for using the above example is to output only the following:\n\n\"PI6MJXZ\"\n\nSo it should go team ---> id",
      "My question is, how can I go about filtering one specific key within this nested json key?",
      "jq '.team |= .id'",
      "{\n  \"team\": \"PI6MJXZ\"\n}"
    ],
    "utterance": "Select the value of the id field inside the team object.",
    "expressions": [
      ".team.id"
    ],
    "data": [
      {
        "input": {
          "team": {
            "id": "PI6MJXZ",
            "name": "my_team",
            "description": null,
            "type": "team",
            "summary": "my_team",
            "self": "https://someurl.com/my_teams/ID",
            "html_url": "https://someurl.com/my_teams/ID",
            "default_role": "manager",
            "parent": null
          }
        },
        "output": "PI6MJXZ"
      }
    ],
    "identifier": 74911183
  },
  {
    "context": [
      "I use the following command to extract data from a json file. Suppose that I just keep the first match if there is a match. (If there is no match, an error should be printed.)",
      ".[] | select(.[1] | objects.\"/Type\".N == \"/Catalog\") | .[1].\"/Dests\"",
      ".[] | select(.[0] == 16876) | .[1] | to_entries[] | [.key, .value[0], .value[2].F, .value[3].F] | @tsv",
      "Can the two jq commands be combined into one, so that one pass of the input json data is sufficient?",
      "(.[] | select(.[1] | objects.\"/Type\".N == \"/Catalog\") | .[1].\"/Dests\") as $dests\n| .[] | select(.[0] == $dests) | .[1] | to_entries[] | [.key, .value[0], .value[2].F, .value[3].F] | @tsv"
    ],
    "utterance": "Combine two queries to first find the '/Dests' field of the first object with '/Type' equal to '/Catalog', then use its value to select and process a second matching object, all in a single pass.",
    "expressions": [
      "(.[] | select(.[1] | objects.\"/Type\".N == \"/Catalog\") | .[1].\"/Dests\") as $dests | .[] | select(.[0] == $dests) | .[1] | to_entries[] | [.key, .value[0], .value[2].F, .value[3].F] | @tsv"
    ],
    "identifier": 74905435
  },
  {
    "context": [
      "I use the code to find in three steps: 1) find the objects of an array, 2) then see if the object contain the name \"/Root\", 3) if so print the first value of \"/Root\" then exit.",
      "`first(.[][1] | objects | select(.\">/Root\" != null) | .\"/Root\")`",
      "The following streaming solution should work:",
      "`<input.json jq --stream 'select(.[0][1:] == [1, \"/Root\"])[1] | values' | head -1`",
      "More streaming goodness:",
      "`<input.json jq --stream -n 'limit(1; fromstream(2 | truncate_stream(inputs)).\"/Root\" | values)'`"
    ],
    "utterance": "Extract the first \"/Root\" value found in any object within an array and stop processing further.",
    "expressions": [
      "first(.[][1] | objects | select(./\"/Root\" != null) | .\"/Root\")",
      "select(.[0][1:] == [1, \"/Root\"])[1] | values",
      "limit(1; fromstream(2 | truncate_stream(inputs)).\"/Root\" | values)",
      "first(fromstream(2 | truncate_stream(inputs)).\"/Root\" | values)"
    ],
    "identifier": 74905755
  },
  {
    "context": [
      "What if I am not sure which level it is, like in `{..., {\"x\": \"abc\"}, ...}`? How can I extract the value in this case (suppose there is one such match, or I only care about the first match)?",
      "first(..|select(has(\"x\")).x)",
      "[..|select(has(\"x\")).x][0]"
    ],
    "utterance": "Extract the value associated with a key named 'x', regardless of its nesting depth, returning at most the first match found.",
    "expressions": [
      "first(..|select(has(\"x\")).x)",
      "[..|select(has(\"x\")).x][0]"
    ],
    "identifier": 74916740
  },
  {
    "context": [
      ".yml_catalog.shop.offers[][] | \"~~~\\(.[\\\"@id\\\"])~~~\\(.[\\\"@available\\\"])~~~\\(.url)\"",
      "CODE_SPLIT_OFFERS='\n  .yml_catalog.shop.offers.offer |\n  _nwise((length - (length % $partitions)) / $partitions)\n'",
      "CODE_PROCESSING='.[] | \"~~~\\(.[\\\"@id\\\"])~~~\\(.[\\\"@available\\\"])~~~\\(.url)\"'",
      "parallel --keep jq '-cr {1} <<< {2}' \\\n  ::: \"$CODE_PROCESSING\" \\\n  :::: <(xq -c --argjson partitions $PARTITIONS \"$CODE_SPLIT_OFFERS\" <<< \"$INPUT\")"
    ],
    "utterance": "Extract fields id, available, and url from each offer, outputting them as lines in the format '~~~id~~~available~~~url'.",
    "expressions": [
      ".yml_catalog.shop.offers[][] | \"~~~\\(.[\"@id\"])~~~\\(.[\"@available\"])~~~\\(.url)\"",
      ".[] | \"~~~\\(.[\"@id\"])~~~\\(.[\"@available\"])~~~\\(.url)\""
    ],
    "data": [
      {
        "input": {
          "yml_catalog": {
            "shop": {
              "offers": {
                "offer": [
                  {
                    "@id": "177484701",
                    "@available": "true",
                    "url": "http:/site.com/offer1"
                  },
                  {
                    "@id": "177485702",
                    "@available": "false",
                    "url": "http:/site.com/offer2"
                  },
                  {
                    "@id": "177484403",
                    "@available": "true",
                    "url": "http:/site.com/offer3"
                  },
                  {
                    "@id": "177484404",
                    "@available": "true",
                    "url": "http:/site.com/offer4"
                  }
                ]
              }
            }
          }
        },
        "output": "~~~177484701~~~true~~~http:/site.com/offer1\n~~~177485702~~~false~~~http:/site.com/offer2\n~~~177484403~~~true~~~http:/site.com/offer3\n~~~177484404~~~true~~~http:/site.com/offer4"
      }
    ],
    "identifier": 74882763
  },
  {
    "context": [
      "I would like to get roles which have Pricipal as AWS mentioned in AssumeRolePolicyDocument. I would like to omit all roles which have Principal as service in AssumeRolePolicyDocument.",
      "below will give you expected answer, use `select` query from jq to filter.",
      "This will give you list of iam roles with principal as \"AWS\"",
      "my_data2 = pyjq.all('map(select(.AssumeRolePolicyDocument.Statement[].Principal.AWS != null ) )',role_list_new)"
    ],
    "utterance": "Select all roles where any AssumeRolePolicyDocument statement has Principal.AWS defined.",
    "expressions": [
      "map(select(.AssumeRolePolicyDocument.Statement[].Principal.AWS != null))"
    ],
    "identifier": 74941201
  },
  {
    "context": [
      "I need to get the keys and the values of the \"filterFeatureGroup\" object with JQ.",
      "My desired output is:\n[\n  \"Hauttyp: Normal\",\n  \"Deckkraft: Mittlere Deckkraft\",\n  \"Grundfarbe: Grau\",\n  \"Produkteigenschaften: Vegan\",\n  \"Textur / Konsistenz / Applikation: Stift\"\n]",
      "Use `to_entries` for that",
      ".filterFeatureGroup | to_entries | map(\"\\(.key): \\(.value[0])\")"
    ],
    "utterance": "Produce an array where each element consists of a key from the filterFeatureGroup object joined with its first value, separated by a colon and space.",
    "expressions": [
      ".filterFeatureGroup | to_entries | map(\"\\(.key): \\(.value[0])\")"
    ],
    "data": [
      {
        "input": {
          "filterFeatureGroup": {
            "Hauttyp": [
              "Normal"
            ],
            "Deckkraft": [
              "Mittlere Deckkraft"
            ],
            "Grundfarbe": [
              "Grau"
            ],
            "Produkteigenschaften": [
              "Vegan"
            ],
            "Textur / Konsistenz / Applikation": [
              "Stift"
            ]
          }
        },
        "output": [
          "Hauttyp: Normal",
          "Deckkraft: Mittlere Deckkraft",
          "Grundfarbe: Grau",
          "Produkteigenschaften: Vegan",
          "Textur / Konsistenz / Applikation: Stift"
        ]
      }
    ],
    "identifier": 74937237
  },
  {
    "identifier": 74960053
  },
  {
    "context": [
      "I want the `mmsi` value combined with the key from each object to become the index to the associative array.",
      "Make `jq` construct a `declare` statement using brackets around the key and escaping with `@sh`:",
      "jq -r '\n  .ships[] | .mmsi as $mmsi\n  | to_entries[] | @sh \"[\\($mmsi):\\(.key)]=\\(.value)\"\n' ships_full.json",
      "jq -r '.ships[] | .mmsi as $mmsi | to_entries[] | @sh \"VESSELS[\\($mmsi):\\(.key)]=\\(.value)\"'"
    ],
    "utterance": "Produce key-value pairs where each key is the combination of a ship's mmsi and each property name, in the form mmsi:key, and the value is the corresponding property value.",
    "expressions": [
      ".ships[] | .mmsi as $mmsi | to_entries[] | @sh \"[\\($mmsi):\\(.key)]=\\(.value)\"",
      ".ships[] | .mmsi as $mmsi | to_entries[] | @sh \"VESSELS[\\($mmsi):\\(.key)]=\\(.value)\""
    ],
    "data": [
      {
        "input": {
          "count": 2,
          "ships": [
            {
              "mmsi": 367513050,
              "lat": 42.380329,
              "lon": -71.042946,
              "distance": 0.317654,
              "mmsi_type": 1,
              "level": -28.161266,
              "count": 6895,
              "ppm": 4.918982,
              "heading": null,
              "cog": null,
              "speed": 0,
              "to_bow": 10,
              "to_stern": 17,
              "to_starboard": 3,
              "to_port": 5,
              "shiptype": 52,
              "msg_type": 0,
              "country": "US",
              "status": 0,
              "callsign": "WDG2188",
              "shipname": "VINCENT D. TIBBETTS",
              "destination": "BOSTON",
              "last_signal": 0
            },
            {
              "mmsi": 367447520,
              "lat": 42.324032,
              "lon": -70.994347,
              "distance": 3.777312,
              "mmsi_type": 1,
              "level": -37.657475,
              "count": 1103,
              "ppm": -1.157407,
              "heading": 156,
              "cog": 155.5,
              "speed": 28.4,
              "to_bow": 24,
              "to_stern": 20,
              "to_starboard": 9,
              "to_port": 4,
              "shiptype": 40,
              "msg_type": 0,
              "country": "US",
              "status": 0,
              "callsign": "WDF4062",
              "shipname": "SALACIA",
              "destination": "XX XXX>?? ???",
              "last_signal": 0
            }
          ],
          "error": false
        }
      }
    ],
    "identifier": 74924784
  },
  {
    "context": [
      "So I will have the key name in a variable",
      "`export KEY_NAME=bar.xml`",
      "Trying to use this variable in jq command and haven't been able to figure out the right way.",
      "$ jq --arg a $KEY_NAME -r  '.data.\"$a\"' myfile.json ",
      "Could you please help me with a right command?"
    ],
    "utterance": "Retrieve the value for the key whose name is stored in a shell variable within the 'data' object, using the variable in the query.",
    "expressions": [
      ".data[$a]"
    ],
    "data": [
      {
        "input": {
          "kind": "Configuration",
          "data": {
            "foo.xml": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<conf>\n </conf>\n",
            "bar.xml": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Configuration>\n </Configuration>\n",
            "abc.properties": "transaction=true"
          }
        },
        "output": "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n<Configuration>\n </Configuration>\n"
      }
    ],
    "identifier": 74946376
  },
  {
    "context": [
      "I do not want to each key with if but would like to have the output like this below",
      "app_custom,app_wblb_status=UP wlb_status_code=1",
      "You can use `to_entries` to split up the items into an array of key-value pairs, then [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29) to piece together the output strings:",
      "curl -s http://example:8080/Cluster | jq -r '\n  to_entries[] | select(.value | type == \"object\")\n  | [.key, .value.status] as [$id, $status]\n  | \"app_custom,\\($id | ascii_downcase)_status=\\($status) wlb_status_code=\\([\"DOWN\",\"UP\"] | index($status))\"\n'",
      "We can read values using the `read` shell function:",
      "jq -r 'to_entries[]|select(.key != \"status\")|[.key, .value.status]|@tsv' data.json |"
    ],
    "utterance": "List all top-level keys (except 'status' itself) with their status in the format app_custom,<key>_status=<status> wlb_status_code=1 if status is UP, or 0 if status is DOWN.",
    "expressions": [
      "to_entries[] | select(.value | type == \"object\") | [.key, .value.status] as [$id, $status] | \"app_custom,\\($id | ascii_downcase)_status=\\($status) wlb_status_code=\\([\"DOWN\",\"UP\"] | index($status))\"",
      "to_entries[] | select(.key != \"status\") | [.key, .value.status] | @tsv"
    ],
    "data": [
      {
        "input": {
          "status": "UP",
          "WBAD": {
            "status": "UP",
            "count": "0",
            "minDateTime": "",
            "description": "Workbasket Admin"
          },
          "WBCA": {
            "status": "UP",
            "count": "0",
            "minDateTime": "",
            "description": "Workbasket CreateAppWait"
          },
          "JS01": {
            "status": "UP",
            "description": "Job Scheduler UpdateReferenceData (Any one associated node:BackgroundProcessing)"
          }
        },
        "output": [
          "app_custom,wbad_status=UP wlb_status_code=1",
          "app_custom,wbca_status=UP wlb_status_code=1",
          "app_custom,js01_status=UP wlb_status_code=1"
        ]
      }
    ],
    "identifier": 74902324
  },
  {
    "context": [
      "How can I filter all devices which have (or don't have) a \"jira.assetid\"?",
      "My goal is to get 2 outputs:\n\nNo jira.assetid present:  id, jira.assetid\n\nYes jira.assetid present:  only id",
      ".data.items[]\n| {\n    id,\n    assetId: (.customProperties[] | select(.name == \"jira.assetid\").value)\n}",
      ".data.items[]\n| {\n    id,\n    assetId: (.customProperties | from_entries.\"jira.assetid\")\n}\n| select(.assetId)",
      ".data.items[]\n| {\n    id,\n    assetId: (.customProperties | from_entries.\"jira.assetid\" // empty)\n}",
      ".data.items[]\n| select(any(.customProperties[]; .name == \"jira.assetid\") | not)\n| { id }",
      ".data.items[]\n| select(.customProperties | from_entries | has(\"jira.assetid\") | not)\n| { id }",
      ".data.items[]\n| select(.customProperties | from_entries | has(\"jira.assetid\") | not)\n| .id"
    ],
    "utterance": "List each item's id and its assetId value if it exists; otherwise, list only the id for items without assetId.",
    "expressions": [
      ".data.items[] | { id, assetId: (.customProperties[] | select(.name == \"jira.assetid\").value) }",
      ".data.items[] | { id, assetId: (.customProperties | from_entries.\"jira.assetid\") } | select(.assetId)",
      ".data.items[] | { id, assetId: (.customProperties | from_entries.\"jira.assetid\" // empty) }",
      ".data.items[] | select(any(.customProperties[]; .name == \"jira.assetid\") | not) | { id }",
      ".data.items[] | select(.customProperties | from_entries | has(\"jira.assetid\") | not) | { id }",
      ".data.items[] | select(.customProperties | from_entries | has(\"jira.assetid\") | not) | .id"
    ],
    "data": [
      {
        "input": {
          "data": {
            "items": [
              {
                "id": 2584,
                "customProperties": [
                  {
                    "name": "jira.assetid",
                    "value": "1"
                  },
                  {
                    "name": "system.categories",
                    "value": "collector"
                  }
                ]
              },
              {
                "id": 2603,
                "customProperties": [
                  {
                    "name": "system.categories",
                    "value": "snmp"
                  }
                ]
              },
              {
                "id": 2703,
                "customProperties": [
                  {
                    "name": "jira.assetid",
                    "value": "5"
                  },
                  {
                    "name": "system.categories",
                    "value": "snmpTCPUDP,Netsnmp,snmpHR,snmp"
                  }
                ]
              }
            ]
          }
        },
        "output": [
          {
            "id": 2584,
            "assetId": "1"
          },
          {
            "id": 2703,
            "assetId": "5"
          },
          {
            "id": 2603
          }
        ]
      }
    ],
    "identifier": 74927012
  },
  {
    "context": [
      "And I am looking for a way to filter from my JSON only the positions of object names that exist in the array",
      "then display all objects in a CSV like this:",
      "$ < input.json jq -r --argjson arr '[\"test1\",\"test3\"]' '\n.[].key.objects[]\n| select(.name | IN($arr[]))\n| to_entries\n| map(.[])\n| @csv\n'",
      "\"name\",\"test1\",\"some_values\",\"some values\""
    ],
    "utterance": "Filter objects by name values that exist in the array [\"test1\", \"test3\"] and output their properties as CSV.",
    "expressions": [
      ".[].key.objects[] | select(.name | IN($arr[])) | to_entries | map(.[]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "key": {
              "objects": [
                {
                  "name": "test1",
                  "some_values": "some values"
                },
                {
                  "name": "test2",
                  "other values": "other values"
                }
              ]
            }
          }
        ],
        "output": [
          "\"name\",\"test1\",\"some_values\",\"some values\""
        ]
      }
    ],
    "identifier": 74955986
  },
  {
    "context": [
      ".customer | {\"company\": .companyName, \"email\": .email, \"phone\": .phone,\n                 \"type\": if .customerType.name == \"A\" then \"SOHO\" else \"Other\" end\n                }",
      "\"type\": (if .customerType.name == \"A\" then \"SOHO\" else \"Other\" end)"
    ],
    "utterance": "Create a new object with company, email, phone, and a type field set to 'SOHO' if customerType.name is 'A', otherwise 'Other'.",
    "expressions": [
      ".customer | {\"company\": .companyName, \"email\": .email, \"phone\": .phone, \"type\": (if .customerType.name == \"A\" then \"SOHO\" else \"Other\" end)}"
    ],
    "identifier": 74960809
  },
  {
    "context": [
      "given a string, if this string matches the regex pattern of one of the keys, then return the value stored in the `k` field of the first matching object.",
      "For example, if I have the string `MAIN`, then this script should return `test1` because the given string matches the pattern in the key of the first object.",
      "Here is how you do it in JQ:\n```\nfirst(.[keys_unsorted[] | select(. as $re | \"MAIN\" | test($re))].k)\n```"
    ],
    "utterance": "Given the string MAIN, return the value of k from the first object whose key regex matches the string.",
    "expressions": [
      "first(.[keys_unsorted[] | select(. as $re | \"MAIN\" | test($re))].k)"
    ],
    "data": [
      {
        "input": {
          "[A-Z]+": {
            "k": "test1",
            "c": "stg1"
          },
          "[a-z]+": {
            "k": "test2",
            "c": "stg2"
          }
        },
        "output": "test1"
      }
    ],
    "identifier": 74968774
  },
  {
    "context": [
      "I am trying to reedit json file to print only subgroups that has any attributes marked as \"change\": false.",
      "cat test.json | jq '.group[] | select (.attributes[].change==false)'",
      "`any` filter ... with the meaning of \"at least one\":",
      ".group[] | select(any(.attributes[]; .change==false))"
    ],
    "utterance": "Return all subgroups where at least one attribute has change equal to false.",
    "expressions": [
      ".group[] | select(any(.attributes[]; .change==false))"
    ],
    "data": [
      {
        "input": {
          "group": {
            "subgroup1": {
              "attributes": [
                {
                  "change": false,
                  "name": "Name"
                },
                {
                  "change": false,
                  "name": "SecondName"
                }
              ],
              "id": 1,
              "name": "MasterTest"
            },
            "subgroup2": {
              "attributes": [
                {
                  "change": true,
                  "name": "Name"
                },
                {
                  "change": false,
                  "name": "Newname"
                }
              ],
              "id": 2,
              "name": "MasterSet"
            }
          }
        },
        "output": [
          {
            "attributes": [
              {
                "change": false,
                "name": "Name"
              },
              {
                "change": false,
                "name": "SecondName"
              }
            ],
            "id": 1,
            "name": "MasterTest"
          },
          {
            "attributes": [
              {
                "change": true,
                "name": "Name"
              },
              {
                "change": false,
                "name": "Newname"
              }
            ],
            "id": 2,
            "name": "MasterSet"
          }
        ]
      }
    ],
    "identifier": 74966596
  },
  {
    "context": [
      "titles=($(echo \"${json}\" | jq '.data.children[].data.title'))",
      "But instead I get this: \n\"Developers",
      "the easy way to do this is:\n\n```\nreadarray -t titles < <(jq -r '.data.children[].data.title' <<<\"$json\")",
      "using `jq -r` makes jq's output line-oriented without extra JSON quoting/escaping.",
      "declare -a titles=\"($(jq -r '.data.children[].data.title | @sh' <<< \"$json\"))\""
    ],
    "utterance": "Extract all values at .data.children[].data.title so each element is a complete sentence without extra quoting or splitting on spaces.",
    "expressions": [
      ".data.children[].data.title",
      ".data.children[].data.title | @sh"
    ],
    "data": [
      {
        "input": {
          "data": {
            "children": [
              {
                "data": {
                  "title": "Developers Should Celebrate Software Development Being Hard"
                }
              },
              {
                "data": {
                  "title": "Lies we tell ourselves to keep using Golang"
                }
              }
            ]
          }
        },
        "output": [
          "Developers Should Celebrate Software Development Being Hard",
          "Lies we tell ourselves to keep using Golang"
        ]
      }
    ],
    "identifier": 74970394
  },
  {
    "context": [
      "I am trying to extract the value of the field \"Health\" for the element of the array with a certain id",
      "cat file.json | jq '.Name[].key2[] | select(.Id==\"049f2c34\") | .Health'",
      "but instead of `Bad` I get empty (the issue has to do with the `.Name[].key2[]` I have also tried `.Name[].key2`)"
    ],
    "utterance": "Extract the value of the Health field where Id equals \"049f2c34\" inside the key2 array within Name.",
    "expressions": [
      ".Name[].key2[] | select(.Id==\"049f2c34\") | .Health"
    ],
    "data": [
      {
        "input": {
          "Name": [
            {
              "key1": "value1",
              "key2": [
                {
                  "sub-key1": false,
                  "sub-key-2": "val2",
                  "Id": "049f2fa1",
                  "Health": "Good"
                },
                {
                  "sub-key1": false,
                  "sub-key-2": "val23",
                  "Id": "049f2c34",
                  "Health": "Bad"
                }
              ],
              "key3": 2
            }
          ]
        },
        "output": "Bad"
      }
    ],
    "identifier": 74979847
  },
  {
    "context": [
      "All the \"id\" in the 'region_file_id' equal to a \"titleId\" somewhere in 'cnmts_titleId_otherApplicationId' (the reverse is not true though as it included id from different regions). I'm trying to grab the \"otherApplicationId\" values for each \"id\" in 'region_file_id' by cross referencing them and creating a json like: (repeated for every 'id' in region_file_id)\n\n    {\n     \"id\": \"111000\"\n     \"titleId\": \"111000\" (this one is optional as it is a duplicate from 'id')\n     \"otherApplicationId\": 111800\"\n    }",
      "< cnmts_titleId_otherApplicationId.txt jq -n --slurpfile ids region_file_id.txt  '\n  INDEX(inputs; .titleId) as $dict\n  | $ids[].id as $id\n  | {$id} + $dict[$id]\n' "
    ],
    "utterance": "For every id in region_file_id.txt, retrieve the matching object from cnmts_titleId_otherApplicationId.txt where id equals titleId, and merge their fields, including otherApplicationId.",
    "expressions": [
      "jq -n --slurpfile ids region_file_id.txt '\n  INDEX(inputs; .titleId) as $dict\n  | $ids[].id as $id\n  | {$id} + $dict[$id]\n' cnmts_titleId_otherApplicationId.txt"
    ],
    "data": [
      {
        "input": {
          "region_file_id.txt": [
            {
              "id": "01007EF00011E000"
            },
            {
              "id": "0100225000FEE000"
            }
          ],
          "cnmts_titleId_otherApplicationId.txt": [
            {
              "titleId": "01007EF00011E000",
              "otherApplicationId": "01007EF00011E800"
            },
            {
              "titleId": "0100225000FEE000",
              "otherApplicationId": "0100225000FEE800"
            }
          ]
        },
        "output": [
          {
            "id": "01007EF00011E000",
            "titleId": "01007EF00011E000",
            "otherApplicationId": "01007EF00011E800"
          },
          {
            "id": "0100225000FEE000",
            "titleId": "0100225000FEE000",
            "otherApplicationId": "0100225000FEE800"
          }
        ]
      }
    ],
    "identifier": 74966034
  },
  {
    "context": [
      "def Services= sh(script: \"curl -s --header \\\"PRIVATE-TOKEN: ${gittoken}\\\" ${url}| jq -r .${Servicename}[]\", returnStdout: true)",
      "file which I am downloading is like below.",
      "{\n  \"FrameWork1\": [\n    \"sample/sample1\",\n    \"sample/sample2\"\n  ]\n \n}",
      "`jq` filter should be `.FrameWork1[]` to get a list of strings",
      "... | jq -r --arg svc \"$Servicename\" '.[$svc][]'"
    ],
    "utterance": "Extract all values from the array under the key FrameWork1.",
    "expressions": [
      ".FrameWork1[]",
      "--arg svc \"$Servicename\" '.[$svc][]'"
    ],
    "data": [
      {
        "input": {
          "FrameWork1": [
            "sample/sample1",
            "sample/sample2"
          ]
        },
        "output": [
          "sample/sample1",
          "sample/sample2"
        ]
      }
    ],
    "identifier": 75035176
  },
  {
    "context": [
      "jq --arg host \"proxy.hub.gcp.url.com\" --arg port \"80\" '.proxySettings = { host: $host, port: $port }, .mailSettings = '{value1: \"Value1\"}' file.json",
      "The command was printing the first change, then the second one. I had to create two seperate jq command.",
      "If two filters are separated by a comma, then the same input will be fed into both and the two filters' output value streams will be concatenated in order: first, all of the outputs produced by the left expression, and then all of the outputs produced by the right.",
      "Instead, you want to combine both filters sequentially with the [pipe filter `|`](https://stedolan.github.io/jq/manual/#Pipe:|), since the [plain assignment operator `=`](https://stedolan.github.io/jq/manual/#Plainassignment:=) outputs its modified input.",
      "jq --arg host \"proxy.hub.gcp.url.com\" \\\n   --arg port \"80\" \\\n   '.proxySettings = { host: $host, port: $port } | .mailSettings = {value1: \"Value1\"}'"
    ],
    "utterance": "Set the 'proxySettings' object to have host 'proxy.hub.gcp.url.com' and port '80', and set 'mailSettings' to {value1: 'Value1'}, outputting the modified file only once.",
    "expressions": [
      ".proxySettings = { host: $host, port: $port } | .mailSettings = {value1: \"Value1\"}"
    ],
    "data": [
      {
        "input": {
          "Balise1": true,
          "Balise2": true,
          "OtherThingEnabled": false,
          "proxySettings": {
            "port": 0
          },
          "mailSettings": {},
          "maxRunningActivitiesPerJob": 5,
          "maxRunningActivities": 5
        },
        "output": {
          "Balise1": true,
          "Balise2": true,
          "OtherThingEnabled": false,
          "proxySettings": {
            "host": "proxy.hub.gcp.url.com",
            "port": "80"
          },
          "mailSettings": {
            "value1": "Value1"
          },
          "maxRunningActivitiesPerJob": 5,
          "maxRunningActivities": 5
        }
      }
    ],
    "identifier": 74991562
  },
  {
    "context": [
      "The goal is to find the distinct values in a file",
      "\"Expect output\"\n```\nbob\ncat\n```",
      "I have tried JQ, awk but given file is big is cannot be sorted or slurpped."
    ],
    "utterance": "Find all unique values of the caller field from a large log file.",
    "expressions": [
      ".caller | select(.) | unique"
    ],
    "data": [
      {
        "input": [
          {
            "requestID": "1234",
            "caller": "bob"
          },
          {
            "requestID": "1235",
            "caller": "cat"
          },
          {
            "requestID": "1236",
            "caller": "bob"
          }
        ],
        "output": [
          "bob",
          "cat"
        ]
      }
    ],
    "identifier": 75053594
  },
  {
    "context": [
      "Now, what I want is the last output for this IP `1.1.1.1` with the last_scan_date `1673152750`.",
      "The expected output is:\n{\n  \"ip\": \"1.1.1.1\",\n  \"tested_count\": 10,\n  \"last_scan_date\": \"1673152750\"\n}",
      "You don't need to add arrays brackets beforehand. Either make the input stream an array by using the `-s` command-line option, and access the items with `.[]`, or use `inputs` to fetch the items (which requires the `-n` option). Then, `last` can give you the preferred item.",
      "Using `-s` and `.[]`:\njq -sr --arg ip '1.1.1.1' 'last(.[] | select(.ip==$ip))'",
      "Using `-n` and `inputs`:\njq -nr --arg ip '1.1.1.1' 'last(inputs | select(.ip==$ip))'"
    ],
    "utterance": "Select the last object for which ip is 1.1.1.1.",
    "expressions": [
      "jq -sr --arg ip '1.1.1.1' 'last(.[] | select(.ip==$ip))'",
      "jq -nr --arg ip '1.1.1.1' 'last(inputs | select(.ip==$ip))'"
    ],
    "data": [
      {
        "input": [
          {
            "ip": "1.1.1.1",
            "tested_count": 17,
            "last_scan_date": "1673146101"
          },
          {
            "ip": "1.1.1.1",
            "tested_count": 17,
            "last_scan_date": "1673146107"
          },
          {
            "ip": "2.2.2.2",
            "tested_count": 17,
            "last_scan_date": "1673146109"
          },
          {
            "ip": "1.1.1.1",
            "tested_count": 10,
            "last_scan_date": "1673152750"
          },
          {
            "ip": "1.2.3.4",
            "tested_count": 11,
            "last_scan_date": "1673152755"
          }
        ],
        "output": {
          "ip": "1.1.1.1",
          "tested_count": 10,
          "last_scan_date": "1673152750"
        }
      }
    ],
    "identifier": 75045682
  },
  {
    "context": [
      "Using jq, I want to test wether each objects 'titleId' in _titles2.txt exists in titles.json as 'id'. If it does exist, I would like for a third json file to be created with all the \"matches\" that were made.",
      "For example, if your goal is to produce a single JSON object, you could go with:",
      "< titles.json jq --slurpfile titleIds _titles2.txt '\n  INDEX($titleIds[]; .titleId) as $dict\n  | with_entries( select($dict[.value.id]))\n'",
      "For the followup question: you could handle both cases by calling INDEX as follows:\n\n    INDEX($titleIds[]; .titleId//.TITLEID)"
    ],
    "utterance": "Return all objects from titles.json where the id matches any titleId in _titles2.txt.",
    "expressions": [
      "jq --slurpfile titleIds _titles2.txt 'INDEX($titleIds[]; .titleId) as $dict | with_entries(select($dict[.value.id]))' titles.json"
    ],
    "data": [
      {
        "input": {
          "titles.json": {
            "1": {
              "id": "0100000000000816",
              "other": "..."
            },
            "2": {
              "id": "0100000000010000",
              "other": "..."
            },
            "3": {
              "id": "0100000000010800",
              "other": "..."
            },
            "4": {
              "id": "010000000E5EE000",
              "other": "..."
            },
            "5": {
              "id": "010000000EEF0000",
              "other": "..."
            }
          },
          "_titles2.txt": [
            {
              "titleId": "0100000000010800"
            },
            {
              "titleId": "010000000EEF0800"
            },
            {
              "titleId": "0100000011D90800"
            },
            {
              "titleId": "010000001260E800"
            },
            {
              "titleId": "01000000160F6800"
            },
            {
              "titleId": "010000100C4B8800"
            }
          ]
        },
        "output": {
          "3": {
            "id": "0100000000010800",
            "other": "..."
          }
        }
      }
    ],
    "identifier": 74978311
  },
  {
    "context": [
      "I would like to get the status of each value either UP or DOWN for each key.",
      "Desired output should be:\n\n                  app_custom,db=UP status_code=1\n                  app_custom,angleDS=UP status_code=1\n                  app_custom,argosleDS=UP status_code=1",
      "Your filter does not match up with the structure of your input. Your input has a recursive structure and your filter is only looking at the top level. The status is on the children of each component object so `.value.components.status` is incorrect.",
      "since this is recursive, you could use `..` to descend through the tree and filter objects that have a `components` property and pick values to display.",
      "jq -r '\n.. | .components? // empty | to_entries[]\n    | [.key, .value.status] as [$id, $status]\n    | \"app_custom,\\($id)=\\($status) status_code=\\(if $status==\"UP\" then 1 else 0 end)\"\n'",
      "app_custom,db=UP status_code=1",
      "app_custom,angusDS=UP status_code=1",
      "app_custom,argyleDS=UP status_code=1"
    ],
    "utterance": "Extract all component keys and their status; output each as app_custom,<key>=<status> status_code=1 if status is UP, else status_code=0.",
    "expressions": [
      ".. | .components? // empty | to_entries[] | [.key, .value.status] as [$id, $status] | \"app_custom,\\($id)=\\($status) status_code=\\(if $status==\\\"UP\\\" then 1 else 0 end)\""
    ],
    "data": [
      {
        "input": {
          "status": "UP",
          "components": {
            "db": {
              "status": "UP",
              "components": {
                "DS": {
                  "status": "UP",
                  "details": {
                    "database": "Informix Dynamic Server",
                    "validationQuery": "select count(1) from systables",
                    "result": 194
                  }
                },
                "angusDS": {
                  "status": "UP",
                  "details": {
                    "database": "Informix Dynamic Server",
                    "validationQuery": "select count(1) from systables",
                    "result": 166
                  }
                },
                "argyleDS": {
                  "status": "UP",
                  "details": {
                    "database": "Informix Dynamic Server",
                    "validationQuery": "select count(1) from systables",
                    "result": 155
                  }
                }
              }
            },
            "discoveryComposite": {
              "description": "Discovery Client not initialized",
              "status": "UNKNOWN",
              "components": {
                "discoveryClient": {
                  "description": "Discovery Client not initialized",
                  "status": "UNKNOWN"
                }
              }
            },
            "diskSpace": {
              "status": "UP",
              "details": {
                "total": 128300593152,
                "free": 37138010112,
                "threshold": 10485760,
                "exists": true
              }
            }
          },
          "groups": [
            "liveness",
            "readiness"
          ]
        },
        "output": [
          "app_custom,db=UP status_code=1",
          "app_custom,discoveryComposite=UNKNOWN status_code=0",
          "app_custom,diskSpace=UP status_code=1",
          "app_custom,DS=UP status_code=1",
          "app_custom,angusDS=UP status_code=1",
          "app_custom,argyleDS=UP status_code=1",
          "app_custom,discoveryClient=UNKNOWN status_code=0"
        ]
      }
    ],
    "identifier": 74939957
  },
  {
    "context": [
      "my csv looks like:\r\n\r\n```\r\ncat output.csv\r\n\"k\",\"a1\",1,\"b1\",\"c1\",\"d1\",1\r\n\"l\",\"a2\",2,\"b2\",\"c2\",\"d2\",2\r\n\"m\",\"a3\",3,\"b3\",\"c3\",\"d3\",3\r\n\"n\",\"a4\",4,\"b4\",\"c4\",\"d4\",4\r\n\"o\",\"a5\",5,\"b5\",\"c5\",\"d5\",5\r\n```",
      "Required output:\r\n\r\nnote: I need key `configuration` to be added to json.\r\n\r\n```\r\n{\r\n    \"configuration\": {\r\n      \"k\": {\r\n        \"a\": \"a1\",\r\n        \"number1\": \"1\",\r\n        \"c\": \"b1\",\r\n        \"d\": \"c1\",\r\n        \"e\": \"d1\",\r\n        \"number2\": \"1\"\r\n      },\r\n      \"l\": {\r\n        \"a\": \"a2\",\r\n        \"number1\": \"2\",\r\n        \"c\": \"b2\",\r\n        \"d\": \"c2\",\r\n        \"e\": \"d2\",\r\n        \"number2\": \"2\"\r\n      },\r\n      .\r\n      .\r\n      .\r\n    }\r\n}\r\n```",
      "jq's `from_entries` can be used to generate objects with chosen keys.",
      "jq '{configuration: ([.[]|{key: .k,value: (.|del(.k))}]|from_entries)}' output.json",
      "cat <(echo k,a,number1,c,d,e,number2) output.csv | mlr --icsv --ojson cat | jq '{configuration: ([.[]|{key: .k,value: (.|del(.k))}]|from_entries)}'",
      "[\n\tinputs |\n\tsplit(\",\") |\n\tmap(ltrimstr(\"\\\"\")) |\n\tmap(rtrimstr(\"\\\"\")) |\n\t{\n\t\t\"key\": .[0],\n\t\t\"value\": {\n\t\t\t\"a\": .[1],\n\t\t\t\"number1\": .[2],\n\t\t\t\"c\": .[3],\n\t\t\t\"d\": .[4],\n\t\t\t\"e\": .[5],\n\t\t\t\"number2\": .[6]\n\t\t}\n\t}\n] |\nfrom_entries |\n{ configuration: . }"
    ],
    "utterance": "Transform CSV rows where the first column is the key and the remaining columns become fields in an object, outputting a single object under the configuration key.",
    "expressions": [
      "jq '{configuration: ([.[]|{key: .k,value: (.|del(.k))}]|from_entries)}' output.json",
      "[inputs | split(\",\") | map(ltrimstr(\"\\\"\")) | map(rtrimstr(\"\\\"\")) | {\"key\": .[0], \"value\": {\"a\": .[1], \"number1\": .[2], \"c\": .[3], \"d\": .[4], \"e\": .[5], \"number2\": .[6]}} ] | from_entries | { configuration: . }"
    ],
    "data": [
      {
        "input": [
          "\"k\",\"a1\",1,\"b1\",\"c1\",\"d1\",1",
          "\"l\",\"a2\",2,\"b2\",\"c2\",\"d2\",2",
          "\"m\",\"a3\",3,\"b3\",\"c3\",\"d3\",3",
          "\"n\",\"a4\",4,\"b4\",\"c4\",\"d4\",4",
          "\"o\",\"a5\",5,\"b5\",\"c5\",\"d5\",5"
        ],
        "output": {
          "configuration": {
            "k": {
              "a": "a1",
              "number1": "1",
              "c": "b1",
              "d": "c1",
              "e": "d1",
              "number2": "1"
            },
            "l": {
              "a": "a2",
              "number1": "2",
              "c": "b2",
              "d": "c2",
              "e": "d2",
              "number2": "2"
            },
            "m": {
              "a": "a3",
              "number1": "3",
              "c": "b3",
              "d": "c3",
              "e": "d3",
              "number2": "3"
            },
            "n": {
              "a": "a4",
              "number1": "4",
              "c": "b4",
              "d": "c4",
              "e": "d4",
              "number2": "4"
            },
            "o": {
              "a": "a5",
              "number1": "5",
              "c": "b5",
              "d": "c5",
              "e": "d5",
              "number2": "5"
            }
          }
        }
      }
    ],
    "identifier": 74891569
  },
  {
    "context": [
      "Using jq I wanted the original object format back filtering on status FAILED",
      "Your `Status` property is nested inside a `Result` object, but you are selecting `Status` directly. You must select on `.value.Result.Status`:",
      "with_entries(select(.value.Result.Status == \"FAIL\"))",
      "map_values(select(.Result.Status == \"FAIL\"))"
    ],
    "utterance": "Select all top-level objects where the nested field Result.Status equals FAIL, preserving the original key structure.",
    "expressions": [
      "with_entries(select(.value.Result.Status == \"FAIL\"))",
      "map_values(select(.Result.Status == \"FAIL\"))"
    ],
    "data": [
      {
        "input": {
          "FOO": {
            "id": "23432423",
            "Result": {
              "Status": "SUCCESS",
              "Reason": ""
            }
          },
          "BAR": {
            "id": "45345535",
            "Result": {
              "Status": "FAIL",
              "Reason": ""
            }
          },
          "BAZ": {
            "id": "123432423",
            "Result": {
              "Status": "SUCCESS",
              "Reason": ""
            }
          }
        },
        "output": {
          "BAR": {
            "id": "45345535",
            "Result": {
              "Status": "FAIL",
              "Reason": ""
            }
          }
        }
      }
    ],
    "identifier": 75057679
  },
  {
    "context": [
      "Update after clarifying edit of the question: It has become clear that you want to transform the value into a string. jq has the `tostring` filter for that, the program thus becomes:",
      "to_entries | map({\n    Name: .key,\n    Value: (.value | tostring),\n    Type: \"String\",\n    Overwrite: true\n})",
      "This should achieve what's expected :",
      "jq 'to_entries | map({\n    Name: .key,\n    Value: (.value|if (type == \"object\")\n                   then tojson\n                   else tostring\n                   end),\n    Type: \"String\",\n    Overwrite: true})\n' input.json",
      "To JSON-encode data from within jq you can use the [`tojson`](https://stedolan.github.io/jq/manual/#Convertto/fromJSON) (or [`@json`](https://stedolan.github.io/jq/manual/#Formatstringsandescaping)) builtins.",
      "Maybe you are trying to accomplish something like this:",
      "jq 'to_entries | map({Name: .key} + (.value | {\n      EncodedValue: tojson,\n      OriginalType: type,\n      Overwrite:    true\n    }))' <<< \"$json\" > \"$new_file_name\""
    ],
    "utterance": "Convert each top-level key-value pair into an object with keys Name, Value, Type, and Overwrite, with Value always a string, properly escaped if the original value is an object.",
    "expressions": [
      "to_entries | map({\n    Name: .key,\n    Value: (.value | tostring),\n    Type: \"String\",\n    Overwrite: true\n})",
      "to_entries | map({\n    Name: .key,\n    Value: (.value|if (type == \"object\")\n                   then tojson\n                   else tostring\n                   end),\n    Type: \"String\",\n    Overwrite: true\n})"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2,
          "c": {
            "id": "9ee ...",
            "parent": "abc..."
          }
        },
        "output": [
          {
            "Name": "a",
            "Value": "1",
            "Type": "String",
            "Overwrite": true
          },
          {
            "Name": "b",
            "Value": "2",
            "Type": "String",
            "Overwrite": true
          },
          {
            "Name": "c",
            "Value": "{\"id\":\"9ee ...\",\"parent\":\"abc...\"}",
            "Type": "String",
            "Overwrite": true
          }
        ]
      }
    ],
    "identifier": 75036633
  },
  {
    "context": [
      "Use `map({ name, folder_id })` with `--slurp`:\n```\ncommand | jq --slurp 'map({ name, folder_id })'\n```",
      "If yc outputs multiple JSON objects and you need the output to be an array, then slurp the input with `-s`/`--slurp` into one big array and then apply the map operation:\n\n```\n$ yc ...\n{...}\n{...}\n$ yc ... | jq -s 'map({ name, folder_id })'\n[\n  {...},\n  {...}\n]\n```",
      "Assuming calling `yc vpc networks list --format json` just by itself produces something structured like\n```json\n{\n  \"networks\": [\n    { ... }\n  ]\n}\n```\nThen piping this into `jq '.networks | map({name, folder_id})'` would give you\n```json\n[\n  {\n    \"name\": \"my-network\",\n    \"folder_id\": \"b1g7f0d3-2e0a-4714-ba6a-b1g7f0d32e0a\"\n  }\n]\n```"
    ],
    "utterance": "Extract an array of objects with the keys name and folder_id from multi-object input where each object has those fields.",
    "expressions": [
      "map({ name, folder_id })",
      "--slurp 'map({ name, folder_id })'",
      ".networks | map({ name, folder_id })"
    ],
    "data": [
      {
        "input": [
          {
            "id": "ccm979ujel7gpcq6aulc",
            "folder_id": "b489aa1fe17nphuomth8",
            "created_at": "2022-12-12T17:47:24Z",
            "name": "default",
            "description": "Auto-created network"
          },
          {
            "id": "ccmn8qvg1uaaaiblc05e",
            "folder_id": "b4aaav1fe1gnphuomth8",
            "created_at": "2022-12-29T12:07:40Z",
            "name": "my-network"
          },
          {
            "id": "campid2asepq3bc68fn6",
            "folder_id": "b489kv3ae1ga1huomth8",
            "created_at": "2021-12-18T09:54:01Z",
            "name": "my-nw",
            "description": "Auto-created network"
          }
        ],
        "output": [
          {
            "name": "default",
            "folder_id": "b489aa1fe17nphuomth8"
          },
          {
            "name": "my-network",
            "folder_id": "b4aaav1fe1gnphuomth8"
          },
          {
            "name": "my-nw",
            "folder_id": "b489kv3ae1ga1huomth8"
          }
        ]
      }
    ],
    "identifier": 75005663
  },
  {
    "context": [
      "I want to convert the below content from JSON to CSV with the keys as headers thru jq. Please help.",
      "The below command works to convert JSON to CSV of the values. Cant figure out to put the keys as headers.",
      "Keys are AccountId, BackupJobId, BackupVaultName......"
    ],
    "utterance": "Convert an array of objects to CSV with a header row containing specified keys: AccountId, BackupJobId, BackupVaultName, RecoveryPointArn, ResourceArn, CreationDate, CompletionDate, State, PercentDone, BackupSizeInBytes, ResourceType.",
    "expressions": [
      "jq -r '.BackupJobs as $rows | ([\"AccountId\",\"BackupJobId\",\"BackupVaultName\",\"RecoveryPointArn\",\"ResourceArn\",\"CreationDate\",\"CompletionDate\",\"State\",\"PercentDone\",\"BackupSizeInBytes\",\"ResourceType\"] | @csv), ($rows[] | [.AccountId, .BackupJobId, .BackupVaultName, .RecoveryPointArn, .ResourceArn, .CreationDate, .CompletionDate, .State, .PercentDone, (.BackupSizeInBytes|tostring), .ResourceType] | @csv)'"
    ],
    "data": [
      {
        "input": {
          "BackupJobs": [
            {
              "AccountId": "12345678",
              "BackupJobId": "asd8f6wehrnvas-cker2-dfne",
              "BackupVaultName": "aws/efs/automatic-backup-vault",
              "BackupVaultArn": "arn:aws:backup:ha-middleeast-1:12345678:backup-vault:aws/efs/automatic-backup-vault",
              "RecoveryPointArn": "arn:aws:backup:ha-middleeast-1:12345678:recovery-point:asd8f6wehrnvas-cker2-dfne",
              "ResourceArn": "arn:aws:elasticfilesystem:ha-middleeast-1:12345678:file-system/fs-47jsg3y47",
              "CreationDate": "2023-12-31T10:30:00+05:30",
              "CompletionDate": "2023-01-09T11:56:40.074000+05:30",
              "State": "COMPLETED",
              "PercentDone": "100.0",
              "BackupSizeInBytes": 0,
              "IamRoleArn": "arn:aws:iam::12345678:role/aws-service-role/backup.amazonaws.com/backuprole",
              "CreatedBy": {
                "BackupPlanId": "aws/efs/asd8f6wehrnvas-cker2-dfne",
                "BackupPlanArn": "arn:aws:backup:ha-middleeast-1:12345678:backup-plan:aws/efs/asd8f6wehrnvas-cker2-dfne",
                "BackupPlanVersion": "asd8f6wehrnvas-cker2-dfne",
                "BackupRuleId": "asd8f6wehrnvas-cker2-dfne"
              },
              "StartBy": "2023-01-09T18:30:00+05:30",
              "ResourceType": "EFS",
              "IsParent": false
            }
          ]
        },
        "output": "AccountId,BackupJobId,BackupVaultName,RecoveryPointArn,ResourceArn,CreationDate,CompletionDate,State,PercentDone,BackupSizeInBytes,ResourceType\n\"12345678\",\"asd8f6wehrnvas-cker2-dfne\",\"aws/efs/automatic-backup-vault\",\"arn:aws:backup:ha-middleeast-1:12345678:recovery-point:asd8f6wehrnvas-cker2-dfne\",\"arn:aws:elasticfilesystem:ha-middleeast-1:12345678:file-system/fs-47jsg3y47\",\"2023-12-31T10:30:00+05:30\",\"2023-01-09T11:56:40.074000+05:30\",\"COMPLETED\",\"100.0\",\"0\",\"EFS\""
      }
    ],
    "identifier": 75054505
  },
  {
    "context": [
      "I failed to set the key as a prefix of the array.",
      "expected output:  \n    [\n      \"qa:app-a\",\n      \"qa:app-b\",\n      \"qa:app-c\",\n      \"prod:app-a\",\n      \"prod:app-c\",\n      \"prod:app-e\",\n    ]",
      "Here you go:\n\nto_entries | map(.key + \":\" + .value[])"
    ],
    "utterance": "Create an array where each application's name is prefixed by its environment key, using the pattern 'environment:application', for all applications in all environments.",
    "expressions": [
      "to_entries | map(.key + \":\" + .value[])"
    ],
    "data": [
      {
        "input": {
          "qa": [
            "app-a",
            "app-b",
            "app-c"
          ],
          "prod": [
            "app-a",
            "app-c",
            "app-e"
          ]
        },
        "output": [
          "qa:app-a",
          "qa:app-b",
          "qa:app-c",
          "prod:app-a",
          "prod:app-c",
          "prod:app-e"
        ]
      }
    ],
    "identifier": 75078326
  },
  {
    "context": [
      "Doing `jq '.cases[] | { \"\\(.id)\" : .count }' test.json` gives\n{\n  \"1\": 2\n}\n{\n  \"2\": 7\n}\n{\n  \"3\": 11\n}\nbut I need\n{ \n  \"1\": 2, \n  \"2\": 7, \n  \"3\": 11 \n}\nHow can I get there?",
      "You need to collect the results into an array and `add` them\n.cases | map({ \"\\(.id)\" : .count }) | add",
      ".cases | map({ key: .id, value: .count }) | from_entries",
      "Here's an approach using `reduce` which iteratively builds up the result object:\nreduce .cases[] as {$id, $count} ({}; .[$id] = $count)"
    ],
    "utterance": "Produce an object mapping each id to its count using the cases array.",
    "expressions": [
      ".cases | map({ \"\\(.id)\" : .count }) | add",
      ".cases | map({ key: .id, value: .count }) | from_entries",
      "reduce .cases[] as {$id, $count} ({}; .[$id] = $count)"
    ],
    "data": [
      {
        "input": {
          "cases": [
            {
              "id": "1",
              "count": 2,
              "ignore": "f"
            },
            {
              "id": "2",
              "count": 7,
              "ignore": "o"
            },
            {
              "id": "3",
              "count": 11,
              "ignore": "o"
            }
          ]
        },
        "output": {
          "1": 2,
          "2": 7,
          "3": 11
        }
      }
    ],
    "identifier": 75070752
  },
  {
    "context": [
      "I have a json file (origin.json) generated locally, I'd like to replace some keys in this origin.json and generate a remote.json so that I could send it to a remote server following it's endpoint payload format.",
      "The keys I need to replace located in different embed layer and blocks of this json.",
      "Is there any suggestion on how to replace those keys in an efficient way ?",
      "To rename a field name, you could use `with_entries`, which gives you access to each `.key`. Reset it by assignment.",
      "If their locations are static, and you know them, address them individually, as in:",
      ".requestContext.starSettings |= with_entries((.key | select(. == \"canStarUserSeeFreeRoomUpgrade\")) = \"freeroom_upgrade\") | .hits[].ppblock.allMatchingBlocks[].rawBlock |= with_entries((.key | select(. == \"bundleId\")) = \"bundle_id\")",
      "def rename($old; $new): with_entries((.key | select(. == $old)) = $new);",
      "def rename_at(path; $old; $new): path |= with_entries((.key | select(. == $old)) = $new);",
      "If their location is unknown, and you want to replace them just based on their (local) name, you need to traverse the document, and check if you hit a matching name. The `walk` function provides you with the traversal, `objects` reduces the action to objects:",
      "walk(objects |= with_entries( if .key == \"canStarUserSeeFreeRoomUpgrade\" then .key = \"freeroom_upgrade\" elif .key == \"bundleId\" then .key = \"bundle_id\" # and so on... else . end ))"
    ],
    "utterance": "Rename specific keys at known or unknown nested locations: e.g., rename 'canStarUserSeeFreeRoomUpgrade' to 'freeroom_upgrade' and 'bundleId' to 'bundle_id'.",
    "expressions": [
      ".requestContext.starSettings |= with_entries((.key | select(. == \"canStarUserSeeFreeRoomUpgrade\")) = \"freeroom_upgrade\") | .hits[].ppblock.allMatchingBlocks[].rawBlock |= with_entries((.key | select(. == \"bundleId\")) = \"bundle_id\")",
      "def rename($old; $new): with_entries((.key | select(. == $old)) = $new); .requestContext.starSettings |= rename(\"canStarUserSeeFreeRoomUpgrade\"; \"freeroom_upgrade\") | .hits[].ppblock.allMatchingBlocks[].rawBlock |= rename(\"bundleId\";  \"bundle_id\")",
      "def rename_at(path; $old; $new): path |= with_entries((.key | select(. == $old)) = $new); rename_at(.requestContext.starSettings; \"canStarUserSeeFreeRoomUpgrade\"; \"freeroom_upgrade\") | rename_at(.hits[].ppblock.allMatchingBlocks[].rawBlock; \"bundleId\";  \"bundle_id\")",
      "walk(objects |= with_entries( if .key == \"canStarUserSeeFreeRoomUpgrade\" then .key = \"freeroom_upgrade\" elif .key == \"bundleId\" then .key = \"bundle_id\" else . end ))"
    ],
    "identifier": 75037983
  },
  {
    "context": [
      "I have 2 files (which are quite long):",
      "file1.json (540 objects - i'll write just 2 mockups for ease of use)",
      "file2.json (540 objects - i'll write just 2 mockups for ease of use)",
      "expected result",
      "Is this possible to achieve this with jq or should I process it through other programming languages like python or javascript?",
      "jq is a perfect choice for all kinds of JSON processing. In this case, you could transpose an array of the contents of both files, then add up the aligned items using a map:",
      "jq -n '[inputs] | transpose | map(add)' file1.json file2.json"
    ],
    "utterance": "Merge two arrays of objects from separate files, aligning objects by position and adding a field from the second file's objects to the corresponding objects in the first file.",
    "expressions": [
      "jq -n '[inputs] | transpose | map(add)' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "a": "apple",
              "b": "banana",
              "c": [
                "car1",
                "car2",
                "car3"
              ],
              "d": [
                "doodle1",
                "doodle2",
                "doodle3"
              ],
              "e": "elephant"
            },
            {
              "a": "aqua",
              "b": "bay",
              "c": [
                "carrot",
                "chile",
                "cucumber"
              ],
              "d": [
                "dice",
                "drop",
                "dang"
              ],
              "e": "elastic"
            }
          ],
          [
            {
              "l": [
                "link1",
                "link2",
                "link3"
              ]
            },
            {
              "l": [
                "link4",
                "link5",
                "link6"
              ]
            }
          ]
        ],
        "output": [
          {
            "a": "apple",
            "b": "banana",
            "c": [
              "car1",
              "car2",
              "car3"
            ],
            "d": [
              "doodle1",
              "doodle2",
              "doodle3"
            ],
            "e": "elephant",
            "l": [
              "link1",
              "link2",
              "link3"
            ]
          },
          {
            "a": "aqua",
            "b": "bay",
            "c": [
              "carrot",
              "chile",
              "cucumber"
            ],
            "d": [
              "dice",
              "drop",
              "dang"
            ],
            "e": "elastic",
            "l": [
              "link4",
              "link5",
              "link6"
            ]
          }
        ]
      }
    ],
    "identifier": 75060372
  },
  {
    "context": [
      "I have a few JSON files such as:\r\n```\r\nrun1.json                                   run2.json\r\n{                                           {\r\n  \"Paris\": 1, \"London\": 2                     \"Paris\": 7, \"London\": 8, \"Perth\": 9\r\n}                                           }\r\n```",
      "I would like to get out a file such as\r\n```\r\n{\r\n  \"Paris\": { \"run1\": 1, \"run2\": 7 },\r\n  \"London\": { \"run1\": 2, \"run2\": 8 },\r\n  \"Perth\": { \"run2\": 9 }\r\n}\r\n```",
      "jq -n '\r\n  reduce (inputs | to_entries[]) as {$key, $value} ({};\r\n    .[$key][input_filename | rtrimstr(\".json\")] = $value\r\n  )\r\n' run1.json run2.json",
      "[inputs | map_values({ (input_filename|rtrimstr(\".json\")): . })] | merge",
      "merge(inputs | map_values({ (input_filename|rtrimstr(\".json\")): . }))"
    ],
    "utterance": "Aggregate key-value pairs across multiple files so that each top-level key maps to an object whose keys are the source filenames (without the .json extension) and values are the corresponding values from each file.",
    "expressions": [
      "jq -n '\n  reduce (inputs | to_entries[]) as {$key, $value} ({};\n    .[$key][input_filename | rtrimstr(\".json\")] = $value\n  )\n' run1.json run2.json",
      "[inputs | map_values({ (input_filename|rtrimstr(\".json\")): . })] | merge",
      "merge(inputs | map_values({ (input_filename|rtrimstr(\".json\")): . }))"
    ],
    "data": [
      {
        "input": [
          {
            "Paris": 1,
            "London": 2
          },
          {
            "Paris": 7,
            "London": 8,
            "Perth": 9
          }
        ],
        "output": {
          "Paris": {
            "run1": 1,
            "run2": 7
          },
          "London": {
            "run1": 2,
            "run2": 8
          },
          "Perth": {
            "run2": 9
          }
        }
      }
    ],
    "identifier": 75073912
  }
]