[
  {
    "context": [
      "Is there a way to get the pod name as well in the same command?",
      "kubectl get pods -o=json |\n    jq -r '.items[] |\n        \"\\(.metadata.name) \\(.status.containerStatuses[]|select(.restartCount>0).name)\"'"
    ],
    "utterance": "List all pods that contain at least one container with a restart count greater than 0, showing both the pod name and the container name.",
    "expressions": [
      ".items[] | \"\u001b[36m\\(.metadata.name) \\(.status.containerStatuses[]|select(.restartCount>0).name)\u001b[39m\""
    ],
    "identifier": 71789787
  },
  {
    "context": [
      "Doesn't work:\n\n    echo '{\"profiles\": {\"a\":\"1\", \"b\":\"2\"}}' | jq --arg a '.a' '.profiles | del($a)'",
      "Works:\n\n    echo '{\"profiles\": {\"a\":\"1\", \"b\":\"2\"}}' | jq '.profiles | del(.a)'",
      "Thus, just use the field name as argument, and `.[$var]` to address it:",
      "echo '{\"profiles\": {\"a\":\"1\", \"b\":\"2\"}}' | jq --arg a 'a' '.profiles | del(.[$a])'",
      "{\n  \"b\": \"2\"\n}"
    ],
    "utterance": "Delete a field from the 'profiles' object where the field name is given as a variable.",
    "expressions": [
      ".profiles | del(.[$a])"
    ],
    "data": [
      {
        "input": {
          "profiles": {
            "a": "1",
            "b": "2"
          }
        },
        "output": {
          "b": "2"
        }
      }
    ],
    "identifier": 71787424
  },
  {
    "context": [
      "What I want is an output file that looks like this:\r\n\r\n{\r\n  \"<filename1>\": \"<value1>\", \r\n  \"<filename2>\": \"<value2>\", \r\n  \"<filename3>\": \"<value3>\", \r\n  ...\r\n}",
      "jq -n '[inputs | {(input_filename): .property}] | add' *",
      "jq -n 'reduce inputs as $in ({}; .[input_filename] = $in.property)' *"
    ],
    "utterance": "Aggregate the value of the property field from each file, keyed by filename, into a single object mapping filenames to their corresponding property values.",
    "expressions": [
      "[inputs | {(input_filename): .property}] | add",
      "reduce inputs as $in ({}; .[input_filename] = $in.property)"
    ],
    "identifier": 71794871
  },
  {
    "context": [
      "Given:\r\n```\r\n{\r\n  \"foo\": \"bizz\",\r\n  \"bar\": \"buzz\",\r\n  \"bat\": [\r\n    \"somestring\"\r\n  ]\r\n}\r\n```",
      "I would like to do something like `jq '. | {foobar.foo, foobar.bar}'`\r\nand have it output:\r\n```\r\n{\r\n  \"foobar\": {\r\n    \"foo\": \"bizz\",\r\n    \"bar\": \"buzz\"\r\n  }\r\n}\r\n```",
      "Another possibility to consider:\r\n\r\n    {foobar: del(.bat)}",
      "You don't have to \"create a dictionary\" first. Simply define your object's structure ('.|' is a redundant no-op, it can be left out):\r\n\r\n    jq '{ foobar: { foo, bar } }'"
    ],
    "utterance": "Wrap the fields foo and bar inside a new key foobar.",
    "expressions": [
      "{ foobar: { foo, bar } }",
      "{foobar: del(.bat)}"
    ],
    "data": [
      {
        "input": {
          "foo": "bizz",
          "bar": "buzz",
          "bat": [
            "somestring"
          ]
        },
        "output": {
          "foobar": {
            "foo": "bizz",
            "bar": "buzz"
          }
        }
      }
    ],
    "identifier": 71774941
  },
  {
    "context": [
      "I am trying to retrieve the value for name from the following JSON object:",
      "{\r\n\t\"ConfigurationRecorders\": [{\r\n\t\t\"name\": \"default\",\r\n\t\t\"roleARN\": \"arn:aws:iam::xxxxxxxxxxxx:role/Config-Recorder\",\r\n\t\t\"recordingGroup\": {\r\n\t\t\t\"allSupported\": true,\r\n\t\t\t\"includeGlobalResourceTypes\": true,\r\n\t\t\t\"resourceTypes\": []\r\n\t\t}\r\n\t}]\r\n}",
      "NAME=$(jq -r '.ConfigurationRecorders[].name' <<<\"$CONFIG_RECORDER\")",
      "[] in the jq query is necessary as ConfigurationRecorders is a JSON array."
    ],
    "utterance": "Extract the value of all name fields from the ConfigurationRecorders array.",
    "expressions": [
      ".ConfigurationRecorders[].name",
      "-r '.ConfigurationRecorders[].name'"
    ],
    "data": [
      {
        "input": {
          "ConfigurationRecorders": [
            {
              "name": "default",
              "roleARN": "arn:aws:iam::xxxxxxxxxxxx:role/Config-Recorder",
              "recordingGroup": {
                "allSupported": true,
                "includeGlobalResourceTypes": true,
                "resourceTypes": []
              }
            }
          ]
        },
        "output": [
          "default"
        ]
      }
    ],
    "identifier": 71789307
  },
  {
    "context": [
      "I would like, for every object in partitions[] to replace the value of the i th string in log_dirs[] by its concatenation with the i th number in replicas[] in order to have something like this",
      "Use a `reduce` loop with a `range`\n\n```\n.partitions[] |= reduce range(0; ( .replicas | length ) ) as $r \n  ( . ; .log_dirs[$r] += ( .replicas[$r] | tostring ) )\n```",
      "jq '.partitions[] |= . + (\n  . as $p | {\n    log_dirs: [\n      range(.replicas | length) |\n      \"\\($p.log_dirs[.])\\($p.replicas[.])\"\n    ]\n  }\n)' in.json"
    ],
    "utterance": "For each object in partitions, modify log_dirs so each entry is replaced by concatenating its original value and the corresponding value from replicas at the same index.",
    "expressions": [
      ".partitions[] |= reduce range(0; ( .replicas | length ) ) as $r ( . ; .log_dirs[$r] += ( .replicas[$r] | tostring ) )",
      ".partitions[] |= . + ( . as $p | { log_dirs: [ range(.replicas | length) | \"\\($p.log_dirs[.])\\($p.replicas[.])\" ] } )"
    ],
    "data": [
      {
        "input": {
          "partitions": [
            {
              "replicas": [
                0,
                1,
                2
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "replicas": [
                2,
                0,
                1
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            }
          ]
        },
        "output": {
          "partitions": [
            {
              "replicas": [
                0,
                1,
                2
              ],
              "log_dirs": [
                "any0",
                "any1",
                "any2"
              ]
            },
            {
              "replicas": [
                2,
                0,
                1
              ],
              "log_dirs": [
                "any2",
                "any0",
                "any1"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 71785892
  },
  {
    "context": [
      "How can I write the output to multiple files, each named `{.name}.sql` and containing `{.content.nested}`",
      "jq  -cr '.[] | [.name, .content.nested] | join(\"\\t\")'",
      "jq -cjr '.[] | (.name, \"\\u0000\", .content.nested)'"
    ],
    "utterance": "Write the value of 'content.nested' from each object into a separate file named after the object's 'name' with a .sql extension.",
    "expressions": [
      ".[] | [.name, .content.nested] | join(\"\\t\")",
      ".[] | (.name, \"\\u0000\", .content.nested)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "a",
            "content": {
              "nested": "important content"
            }
          },
          {
            "name": "b",
            "content": {
              "nested": "other content"
            }
          }
        ],
        "output": [
          {
            "file": "a.sql",
            "content": "important content"
          },
          {
            "file": "b.sql",
            "content": "other content"
          }
        ]
      }
    ],
    "identifier": 71796678
  },
  {
    "context": [
      "I have two json files,",
      "Expected result is:",
      "{\n    \"version\": 4,\n    \"group1\": [\n        {\n            \"name\":\"olditem1\",\n            \"content\": \"old content\"\n        },\n        {\n            \"name\" : \"newitem1\"\n        }\n    ],\n    \"group2\": [\n        {\n            \"name\":\"olditem2\"\n        },\n        {\n            \"name\" : \"newitem2\"\n        }\n    ]\n}",
      "Criterial for merge:\n1) Has to merge only group1 and group2\n2) Match only by name",
      "This approach uses `INDEX` to create a dictionary of unique elements based on their `.name` field, `reduce` to iterate over the group fields to be considered, and an initial state created by combining the slurped (`-s`) input files using `add` after removing the group fileds to be processed separately using `del`.",
      "jq -s '[ \"group1\", \"group2\" ] as $gs | . as $in | reduce $gs[] as $g ( map(del(.[$gs[]])) | add; .[$g] = [INDEX($in[][$g][]; .name)[]] )' file1.json file2.json"
    ],
    "utterance": "Combine two objects by merging only group1 and group2 arrays, matching items by name, and preserving other fields like version.",
    "expressions": [
      "[ \"group1\", \"group2\" ] as $gs | . as $in | reduce $gs[] as $g ( map(del(.[$gs[]])) | add; .[$g] = [INDEX($in[][$g][]; .name)[]] )"
    ],
    "data": [
      {
        "input": [
          {
            "version": 4,
            "group1": [
              {
                "name": "olditem1",
                "content": "old content"
              }
            ],
            "group2": [
              {
                "name": "olditem2"
              }
            ]
          },
          {
            "group1": [
              {
                "name": "newitem1"
              },
              {
                "name": "olditem1",
                "content": "new content"
              }
            ],
            "group2": [
              {
                "name": "newitem2"
              }
            ]
          }
        ],
        "output": {
          "version": 4,
          "group1": [
            {
              "name": "olditem1",
              "content": "new content"
            },
            {
              "name": "newitem1"
            }
          ],
          "group2": [
            {
              "name": "olditem2"
            },
            {
              "name": "newitem2"
            }
          ]
        }
      }
    ],
    "identifier": 71791959
  },
  {
    "context": [
      "I am need to decode the authorization value from apache in flow and replace the value with the username , returning the modified json.",
      "I want to get json:\r\n\r\n    { \"time\":\"2022-04-07T12:53:39.302+0300\", \r\n    .... \r\n    \"user\":\"<login>\" }",
      "But `jq` returns the value itself, not the modified json.",
      "Also, I get an error if json value (`user`) isn't base64",
      "How can I get the full modified json and avoid modification if the user value does not contain \"Basic\" ?",
      "Use `if ... then ... else ... end` to implement different behaviours depending  on a value.",
      "jq '.user |= if startswith(\"Basic \")\n             then .[6:] | @base64d\n             else . end\n  ' file.json"
    ],
    "utterance": "Replace the value of the user field with the decoded username portion if it starts with 'Basic ', returning the modified object and leaving the user value unchanged if it does not start with 'Basic '.",
    "expressions": [
      ".user |= if startswith(\"Basic \") then .[6:] | @base64d else . end"
    ],
    "data": [
      {
        "input": {
          "time": "2022-04-07T12:53:39.302+0300",
          "user": "Basic c2RwC2ZhcmZZc3Q6c2RfX2ZhcmVhz3Q="
        },
        "output": {
          "time": "2022-04-07T12:53:39.302+0300",
          "user": "sdpCfarvYst"
        }
      },
      {
        "input": {
          "time": "2022-04-07T12:53:39.302+0300",
          "user": "-"
        },
        "output": {
          "time": "2022-04-07T12:53:39.302+0300",
          "user": "-"
        }
      }
    ],
    "identifier": 71783196
  },
  {
    "context": [
      "curl -LH \"Accept: application/json\" http://doi.org/10.1016/someDOIvalue | jq '.title'"
    ],
    "utterance": "Extract the value of the 'title' field from HTTP response at http://doi.org/10.1016/someDOIvalue.",
    "expressions": [
      ".title"
    ],
    "identifier": 71809428
  },
  {
    "context": [
      "I want to get only the first url in the list of `options` for each `animal_potato_carrot` or `cat_dog_rabbit` nested tag only (note they have different structures)",
      "So my output will be first three urls in those blocks:\n\n```\n[\"https://example.com/text.txt\", \"https://example.com/text2.txt, \"https://example.com/text3.txt\"]\n```",
      "jq -c '[..|.animal_potato_carrot?|select(. != null)|.options[0].url] + [..|.cat_dog_rabbit?|select(. != null)|.[0].url]' json.txt",
      "jq -c '[..|(.animal_potato_carrot?.options),(.cat_dog_rabbit?)|.[0].url|select(. != null)]' json.txt"
    ],
    "utterance": "Extract the first url from the options array of each animal_potato_carrot or the first url of each cat_dog_rabbit block, preserving their occurrence order.",
    "expressions": [
      "[..|.animal_potato_carrot?|select(. != null)|.options[0].url] + [..|.cat_dog_rabbit?|select(. != null)|.[0].url]",
      "[..|(.animal_potato_carrot?.options),(.cat_dog_rabbit?)|.[0].url|select(. != null)]"
    ],
    "data": [
      {
        "input": {
          "files": [
            {
              "id": 49894894,
              "list": [
                {
                  "name": "one",
                  "animal_potato_carrot": {
                    "options": [
                      {
                        "id": 4989,
                        "url": "https://example.com/text.txt"
                      },
                      {
                        "id": 3994,
                        "url": "https://example.com/randomfile.json"
                      }
                    ]
                  }
                },
                {
                  "name": "two",
                  "cat_dog_rabbit": [
                    {
                      "id": 4989,
                      "url": "https://example.com/text2.txt"
                    },
                    {
                      "id": 3994,
                      "url": "https://example.com/randomfile.json"
                    }
                  ]
                },
                {
                  "name": "three",
                  "animal_potato_carrot": {
                    "options": [
                      {
                        "id": 4989,
                        "url": "https://example.com/text3.txt"
                      },
                      {
                        "id": 3994,
                        "url": "https://example.com/randomfile.json"
                      }
                    ]
                  }
                }
              ]
            }
          ]
        },
        "output": [
          "https://example.com/text.txt",
          "https://example.com/text2.txt",
          "https://example.com/text3.txt"
        ]
      }
    ],
    "identifier": 71799447
  },
  {
    "context": [
      "i have an array of urls like (coming out of a jq call):\n\n```\n[\"https://example.com/text.txt\", \"https://example.com/text2.txt\", \"https://example.com/text3.txt\"]\n```",
      "As the JSON array is \"coming out of a jq call\", just have jq output it as a list of raw-text urls using `.[]` and the `-r` option, then pipe that list into `xargs` using `curl`.",
      "jq -r '\u2026 | .[]' | xargs -I{} curl -O {}",
      "\u2026 | jq -r '.[]' | xargs -I{} curl -O {}",
      "Add the following to the end of your jq code, and pipe to `sh` to run it:",
      "jq -r '[ \"curl\", .[] ] | @sh' | sh",
      "echo '[\"https://example.com/text.txt\", \"https://example.com/text2.txt\", \"https://example.com/text3.txt\"]' | jq -r '[ \"curl\", .[] ] | @sh'",
      "Should produce:\n\n    'curl' 'https://example.com/text.txt' 'https://example.com/text2.txt' 'https://example.com/text3.txt'"
    ],
    "utterance": "Extract each link from an array of URLs so each appears on its own line suitable for shell scripting.",
    "expressions": [
      ".[]",
      "-r '.[]'"
    ],
    "data": [
      {
        "input": [
          "https://example.com/text.txt",
          "https://example.com/text2.txt",
          "https://example.com/text3.txt"
        ],
        "output": [
          "https://example.com/text.txt",
          "https://example.com/text2.txt",
          "https://example.com/text3.txt"
        ]
      }
    ],
    "identifier": 71806138
  },
  {
    "context": [
      "I am trying to extract objects, and get Code keys based on certain Type matches.",
      "Trying to where Type matches \"A\", \"B\", \"A, B\", or Universal, I am getting objects that contain both, or nothing in certain cases.",
      "Here is what I tried.",
      "jq -r '.[] | select(.Type[] == \"A\") | .Code'",
      "jq -r '.[] | select(.Type[] == \"A, B\") | .Code'",
      "jq -r '.[] | select(.Type[] == \"Universal\") | .Code'",
      "The jq program\n\n   .[] | select(any(.Type[]; IN(\"A\",\"B\",\"A, B\",\"Universal\"))) | .Code\n\nproduces:\n```\n\"DEF\"\n\"GHI\"\n\"JKL\"\n\"MNO\"\n```",
      "If you wanted exact match, save following into `script.jq` :\n\n```\n.[] | select(.Type == $match) | .Code\n```\n\nThen test with \n\n\n```\n$ jq -r --argjson match '[\"A\"]' -f script.jq test.json\nDEF\n$ jq -r --argjson match '[\"B\"]' -f script.jq test.json\nGHI\n$ jq -r --argjson match '[\"A\", \"B\"]' -f script.jq test.json\nJKL\n```"
    ],
    "utterance": "Return Code values where the Type array matches exactly [\"A\"], [\"B\"], or [\"A\", \"B\"]",
    "expressions": [
      ".[] | select(.Type == [\"A\"]) | .Code",
      ".[] | select(.Type == [\"B\"]) | .Code",
      ".[] | select(.Type == [\"A\", \"B\"]) | .Code"
    ],
    "data": [
      {
        "input": {
          "abc": {
            "Code": "ABC",
            "Type": []
          },
          "def": {
            "Code": "DEF",
            "Type": [
              "A"
            ]
          },
          "ghi": {
            "Code": "GHI",
            "Type": [
              "B"
            ]
          },
          "jkl": {
            "Code": "JKL",
            "Type": [
              "A",
              "B"
            ]
          },
          "mno": {
            "Code": "MNO",
            "Type": [
              "Universal"
            ]
          }
        },
        "output": [
          "DEF",
          "GHI",
          "JKL"
        ]
      }
    ],
    "identifier": 71804236
  },
  {
    "context": [
      "jq \".data[].paragraphs[].qas[].question\" dev-v2.0.json | head",
      "As of [jq 1.7](https://github.com/jqlang/jq/releases/tag/jq-1.7), `.data | .[]` can be abbreviated as either `.data[]` or `.data.[]`.",
      "Before [jq 1.7](https://github.com/jqlang/jq/releases/tag/jq-1.7), the only valid abbreviated form of `.x|.[]|.y` was `.x[].y`. Now, `.x.[].y` is equally valid."
    ],
    "utterance": "Select all question texts under every qas entry inside every paragraph in every data object",
    "expressions": [
      ".data[].paragraphs[].qas[].question",
      ".data.[].paragraphs.[].qas.[].question"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "paragraphs": [
                {
                  "qas": [
                    {
                      "question": "In what country is Normandy located?"
                    },
                    {
                      "question": "When were the Normans in Normandy?"
                    }
                  ]
                },
                {
                  "qas": [
                    {
                      "question": "Who was the Norse leader?"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "In what country is Normandy located?",
          "When were the Normans in Normandy?",
          "Who was the Norse leader?"
        ]
      }
    ],
    "identifier": 71809695
  },
  {
    "context": [
      "I want to have iteration at .items[0].spec where the key config,files,program's contents can be shown.. something like",
      "I know that I can get the list of keys by `jq -r '.items[0].spec| to_entries[].key'` but not sure about formating the output and getting the contents of .items[].spec.xxxxx like above.",
      "Also this got me even closer! but how do you get the json syntax of the object to display uncompressed?",
      "jq -r '.items[].spec | keys[] as $k | \"\\($k):\\n   \\(.[$k])\"'",
      "The \",\" operator is the magic ingredient you seem to be looking for:",
      ".items[].spec | keys[] as $k | $k, .[$k]"
    ],
    "utterance": "For each object in items, show each key in spec followed by its full value, separated and formatted one after another.",
    "expressions": [
      ".items[].spec | keys[] as $k | $k, .[$k]"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "name": "issue1",
              "spec": {
                "config": {
                  "setting1": "abc",
                  "setting2": {
                    "name": "xyz"
                  }
                },
                "files": {
                  "name": "cde",
                  "path": "/home"
                },
                "program": {
                  "name": "apache"
                }
              }
            }
          ]
        },
        "output": [
          "config",
          {
            "setting1": "abc",
            "setting2": {
              "name": "xyz"
            }
          },
          "files",
          {
            "name": "cde",
            "path": "/home"
          },
          "program",
          {
            "name": "apache"
          }
        ]
      }
    ],
    "identifier": 71821374
  },
  {
    "context": [
      "I would like to get string \"c,d,e,f,g,h\" using JQ query.",
      "\"cat /tmp/example.json  | jq -r '.a1[] | select(.group_sourceId | startswith(\"sunday\")) | .ids | join(\",\")'\"",
      "How to get \"c,d,e,f,g,h\" as a output considering there could be any number of \"ids\" in \"a1\" object and any number of strings in \"ids\" array?",
      "[.a1[] | select(.group_sourceId | startswith(\"sunday\")) | .ids[]] | sort[]",
      "jq -r '.a1 | map(select(.group_sourceId == \"sunday\").ids[]) | join(\",\")'",
      "c,d,e,f,g,h"
    ],
    "utterance": "Return all strings from the 'ids' arrays of 'a1' objects where 'group_sourceId' is 'sunday', combined into a comma-separated string.",
    "expressions": [
      "[.a1[] | select(.group_sourceId | startswith(\"sunday\")) | .ids[]] | join(\",\")",
      "[.a1[] | select(.group_sourceId == \"sunday\") | .ids[]] | join(\",\")",
      ".a1 | map(select(.group_sourceId == \"sunday\").ids[]) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "a1": [
            {
              "group_sourceId": "monday",
              "ids": [
                "a",
                "b"
              ]
            },
            {
              "group_sourceId": "sunday",
              "ids": [
                "c",
                "d"
              ]
            },
            {
              "group_sourceId": "sunday",
              "ids": [
                "e",
                "f"
              ]
            },
            {
              "group_sourceId": "sunday",
              "ids": [
                "g",
                "h"
              ]
            }
          ],
          "m1": [
            {
              "group_sourceId": "sunday"
            },
            {
              "group_sourceId": "sunday"
            }
          ]
        },
        "output": "c,d,e,f,g,h"
      }
    ],
    "identifier": 71811677
  },
  {
    "context": [
      "I'm trying to use [jq](https://stedolan.github.io/jq/) to replace all of the spaces with `+` signs so the final result would be:",
      "Given a string `\"Tiger Woods plays golf\"`",
      "using jq's expression `gsub(\"\\\\s\";\"+\")` - you should be able to replace those spaces by \"+\" characters",
      "result[1]: `\"Tiger+Woods+plays+golf\"`"
    ],
    "utterance": "Replace all spaces in the string 'Tiger Woods plays golf' with plus signs.",
    "expressions": [
      "gsub(\"\\s\"; \"+\")"
    ],
    "data": [
      {
        "input": "Tiger Woods plays golf",
        "output": "Tiger+Woods+plays+golf"
      }
    ],
    "identifier": 71834966
  },
  {
    "context": [
      "I want to manipulate the inner `\"c\": \"text1\"` and modify it to `\"c\": \"newtext\"`. But, also need to merge with the original JSON. IOW, it is not about extracting, but about manipulating.",
      "Just `walk` the path with the expression to select an object type when `.c` equals to your desired value",
      "jq 'walk(if type == \"object\" and .c == \"text1\" then .c |= \"newtext\" else . end)'",
      "(.. | objects | select(has(\"c\")) | .c) |= (sub(\"^text1$\";\"newtext\"))",
      "(.. | select(try has(\"c\")) | .c) |= (sub(\"^text1$\";\"newtext\"))",
      "(.. | select(has(\"c\")?) | .c) |= (sub(\"^text1$\";\"newtext\"))"
    ],
    "utterance": "Replace the value of every 'c' property equal to 'text1' deeply nested in the structure with 'newtext', preserving all other data.",
    "expressions": [
      "walk(if type == \"object\" and .c == \"text1\" then .c |= \"newtext\" else . end)",
      "(.. | objects | select(has(\"c\")) | .c) |= (sub(\"^text1$\";\"newtext\"))",
      "(.. | select(try has(\"c\")) | .c) |= (sub(\"^text1$\";\"newtext\"))",
      "(.. | select(has(\"c\")?) | .c) |= (sub(\"^text1$\";\"newtext\"))"
    ],
    "data": [
      {
        "input": {
          "a": {
            "1": {
              "c": "text1"
            },
            "999": {
              "c": "text99"
            }
          }
        },
        "output": {
          "a": {
            "1": {
              "c": "newtext"
            },
            "999": {
              "c": "text99"
            }
          }
        }
      }
    ],
    "identifier": 71818537
  },
  {
    "context": [
      "How can I (generically) transform the input file below to the output file below, using jq.  The record format of the output file is: array_index | key | value",
      "Input file:\n[{\"a\": 1, \"b\": 10},\n {\"a\": 2, \"d\": \"fred\", \"e\": 30}]\nOutput File:\n0|a|1\n0|b|10\n1|a|2\n1|d|fred\n1|e|30",
      "jq -r '\n   to_entries[] |\n   .key as $id |\n   .value |\n   to_entries[] |\n   [ $id, .key, .value ] |\n   join(\"|\")\n'",
      "jq -r 'tostream | select(has(1)) | flatten | join(\"|\")'",
      "jq -r 'paths(scalars) as $p | [$p[], getpath($p)] | join(\"|\")'"
    ],
    "utterance": "Output each object's array index, key, and value as lines in the format index|key|value for all key-value pairs in every object of the array.",
    "expressions": [
      "to_entries[] | .key as $id | .value | to_entries[] | [ $id, .key, .value ] | join(\"|\")",
      "tostream | select(has(1)) | flatten | join(\"|\")",
      "paths(scalars) as $p | [$p[], getpath($p)] | join(\"|\")"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 10
          },
          {
            "a": 2,
            "d": "fred",
            "e": 30
          }
        ],
        "output": "0|a|1\n0|b|10\n1|a|2\n1|d|fred\n1|e|30"
      }
    ],
    "identifier": 71825711
  },
  {
    "context": [
      "Is there a way I can return rows, even if .assignees is empty? Perhaps output a \"-\" or \"empty\" value?",
      "You can use the alternative operator //, and you parentheses to create 'temporary' values:",
      "curl https://MyUrl | jq -cr   '.[] | {id: .id, completed: .completed,  content: .content  | sub(\",\"; \"\") , assignee: ( .assignees[] | objects | .name ) // \"-\" } '",
      "assignee: (if .assignees|type == \"array\" \n           then .assignees[] | objects | .name\n           else \"-\" end)",
      "Thanks to all of you! This minor change seemed to do the trick, with //",
      "'.[] | {id: .id, completed: .completed,  content: .content  | sub(\",\"; \"\") , assignee:  (  .assignees[]  .name // \"TBD\" )} '"
    ],
    "utterance": "Return all rows, outputting a placeholder such as '-' or 'TBD' when 'assignees' is empty or missing.",
    "expressions": [
      ".[] | {id: .id, completed: .completed, content: .content | sub(\",\"; \"\"), assignee: ( .assignees[] | objects | .name ) // \"-\" }",
      ".[] | {id: .id, completed: .completed, content: .content | sub(\",\"; \"\"), assignee: (if .assignees|type == \"array\" then .assignees[] | objects | .name else \"-\" end)}",
      ".[] | {id: .id, completed: .completed, content: .content | sub(\",\"; \"\"), assignee: ( .assignees[] .name // \"TBD\" ) }"
    ],
    "identifier": 71834015
  },
  {
    "context": [
      "GET_FUNCTION_NAME_CMD=(jq --raw-output \"'map(select(.OutputKey == \\\"ProxyFunctionName\\\")) | .[].OutputValue'\")",
      "jq --raw-output 'map(select(.OutputKey == \"ProxyFunctionName\")) | .[].OutputValue' <<< \"$OUTPUTS\"",
      "GET_FUNCTION_NAME_CMD=\"jq -r '.[] | objects | select(.OutputKey == \\\"$OutputKey\\\") | .OutputValue'\"",
      "# jq -r '.[] | objects | select(.OutputKey == \"ProxyFunctionName\") | .OutputValue' <<<\"$OUTPUTS\""
    ],
    "utterance": "Extract the OutputValue where OutputKey equals ProxyFunctionName from the input where the top-level structure is an array of objects.",
    "expressions": [
      ".[] | select(.OutputKey == \"ProxyFunctionName\") | .OutputValue",
      "map(select(.OutputKey == \"ProxyFunctionName\")) | .[].OutputValue"
    ],
    "data": [
      {
        "input": [
          {
            "OutputKey": "ProxyFunctionName",
            "OutputValue": "MyFunctionName",
            "Description": "Proxy Lambda Function ARN"
          },
          {
            "OutputKey": "ProxyFunctionUrl",
            "OutputValue": "https://my.function.url",
            "Description": "Proxy Lambda Function invocation URL"
          }
        ],
        "output": "MyFunctionName"
      }
    ],
    "identifier": 71840560
  },
  {
    "context": [
      "If I do:\n\n$ jq -cn 'now | localtime'\n[2022,3,12,21,9,29.65448808670044,2,101]",
      "But If I do:\n\n$ jq -cn 'now | localtime | mktime | localtime'\n[2022,3,13,7,10,36,3,102]\n\nIt gives back a \"broken down time\" representation that is **different** than current local time.",
      "If I do:\n\n$ jq -cn 'now | gmtime | mktime | localtime'\n\nNow this gives correct results (gives \"broken down time\" representation of current local time).",
      "From the jq docs:\n\n> The `mktime` builtin consumes \"broken down time\" representations of time output by `gmtime` and `strptime`.\n\nYou originally passed a local time, but it expects a UTC time. As you surmised, this is why your original code failed and the latter code worked. jq's `mktime` is the inverse of `gmtime`.",
      "jq does not appear to provide a means to convert from a local time to epoch time."
    ],
    "utterance": "Convert the current time to broken-down time, round-trip it to epoch time and back, and preserve the correct local time representation.",
    "expressions": [
      "now | gmtime | mktime | localtime"
    ],
    "identifier": 71841835
  },
  {
    "context": [
      "curl -s \"https://search.maven.org/solrsearch/select?q=g:$s+AND+a:$e&core=gav&rows=1&wt=json\" | jq \".response.docs[].v\"",
      "curl -s \"https://search.maven.org/solrsearch/select?q=g:${s}+AND+a:${e}&core=gav&rows=1&wt=json\" | jq \".response.docs[].v\""
    ],
    "utterance": "Extract the value of the 'v' field from the 'docs' array inside the response object.",
    "expressions": [
      ".response.docs[].v"
    ],
    "identifier": 71855942
  },
  {
    "context": [
      "I want to get all the items where the \"employee\" had different teams over the year.",
      "I would like to query the array with jq and the output would return",
      "With `unique_by` you can reduce the `.teams` array to those that differ in their `.team_id`, and with `select` and `length` you can filter for those that have strictly more than just one such item.",
      "jq '.[] | select(.teams | unique_by(.team_id) | length > 1)'"
    ],
    "utterance": "Return all items where the employee's teams array includes more than one distinct team_id.",
    "expressions": [
      ".[] | select(.teams | unique_by(.team_id) | length > 1)",
      "map(select(.teams | unique_by(.team_id) | length > 1))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 122343,
            "name": "Tom Muller",
            "teams": [
              {
                "year": "2010-2011",
                "team_id": 27
              },
              {
                "year": "2011-2012",
                "team_id": 27
              },
              {
                "year": "2013-2014",
                "team_id": 27
              }
            ]
          },
          {
            "id": 338744,
            "name": "Eric Gonzales",
            "teams": [
              {
                "year": "2010-2011",
                "team_id": 12
              },
              {
                "year": "2011-2012",
                "team_id": 17
              },
              {
                "year": "2013-2014",
                "team_id": 17
              }
            ]
          }
        ],
        "output": {
          "id": 338744,
          "name": "Eric Gonzales",
          "teams": [
            {
              "year": "2010-2011",
              "team_id": 12
            },
            {
              "year": "2011-2012",
              "team_id": 17
            },
            {
              "year": "2013-2014",
              "team_id": 17
            }
          ]
        }
      }
    ],
    "identifier": 71843093
  },
  {
    "context": [
      "I have two json files which I need to merge but when I run",
      "jq -s '[0] * .[1]' web-apps.json android-apps.json | tee output.json",
      "command I get the following error.",
      "jq: error (at output.json:0): object ({\"apps\":{...) and null (null) cannot be multiplied",
      "Here are my json files.",
      "web-apps.json",
      "{ \"apps\": { \"app1\": [ \"v1.0\" ], \"app2\": [ \"v3.7.2\" ] } }",
      "android-apps.json",
      "{ \"apps\": { \"mob-app1\": [ \"v2.0\" ], \"mob-app2\": [ \"v2.1\" ] } }",
      "The expected output:",
      "{ \"apps\": { \"app1\": [ \"v1.0\" ], \"app2\": [ \"v3.7.2\" ], \"mob-app1\": [ \"v2.0\" ], \"mob-app2\": [ \"v2.1\" ] } }"
    ],
    "utterance": "Combine the 'apps' objects from two files so the result contains all key-value pairs from both under one 'apps' object.",
    "expressions": [
      "jq -s '{apps: (.[0].apps + .[1].apps)}' web-apps.json android-apps.json"
    ],
    "data": [
      {
        "input": {
          "web-apps.json": {
            "apps": {
              "app1": [
                "v1.0"
              ],
              "app2": [
                "v3.7.2"
              ]
            }
          },
          "android-apps.json": {
            "apps": {
              "mob-app1": [
                "v2.0"
              ],
              "mob-app2": [
                "v2.1"
              ]
            }
          }
        },
        "output": {
          "apps": {
            "app1": [
              "v1.0"
            ],
            "app2": [
              "v3.7.2"
            ],
            "mob-app1": [
              "v2.0"
            ],
            "mob-app2": [
              "v2.1"
            ]
          }
        }
      }
    ],
    "identifier": 71853834
  },
  {
    "context": [
      "Is it possible to combine the Text under a ParagraphSpan?",
      "If your input consists of a JSON array with {Path, Text} objects as shown, then you could achieve the merging you describe by:",
      "reduce .[] as $x (\n  null;\n  if $x|.Path|contains(\"/ParagraphSpan[\")\n  then .[-1].Text += $x.Text\n  else . + [$x] end) "
    ],
    "utterance": "Merge adjacent objects where Path contains '/ParagraphSpan[' by concatenating their Text values into the preceding object.",
    "expressions": [
      "reduce .[] as $x (null; if $x|.Path|contains(\"/ParagraphSpan[\") then .[-1].Text += $x.Text else . + [$x] end)"
    ],
    "data": [
      {
        "input": [
          {
            "Path": "//Document/P[5]",
            "Text": "WELLNESS AS A HEALTH GOAL "
          },
          {
            "Path": "//Document/P[6]/ParagraphSpan",
            "Text": "Although we use the words health and wellness interchangeably, they differ in two important ways. Health can be determined "
          },
          {
            "Path": "//Document/P[6]/ParagraphSpan[2]",
            "Text": "or influenced by factors beyond your control, such as your genes, age, and family history."
          },
          {
            "Path": "//Document/P[7]",
            "Text": "Dimensions of Wellness "
          }
        ],
        "output": [
          {
            "Path": "//Document/P[5]",
            "Text": "WELLNESS AS A HEALTH GOAL "
          },
          {
            "Path": "//Document/P[6]/ParagraphSpan",
            "Text": "Although we use the words health and wellness interchangeably, they differ in two important ways. Health can be determined or influenced by factors beyond your control, such as your genes, age, and family history."
          },
          {
            "Path": "//Document/P[7]",
            "Text": "Dimensions of Wellness "
          }
        ]
      }
    ],
    "identifier": 71865329
  },
  {
    "context": [
      "I want to check the presence of a particular key in some parents before replacing the child. *Loosely*, translated to CSS selector, I want something like `* > fixedKeyCheckPresence > * > fixedKeyCheckValue`",
      "Tried: `(.. | select(try has(\"fixedKeyCheckPresence\")) | .fixedKeyCheckValue) |= (sub(\"^Foo$\";\"Bar\"))`",
      "You can combine `walk` with `..` :",
      "jq 'walk(\n        (.fixedKeyCheckPresence? | .. |\n         select(has(\"fixedKeyCheckValue\")?).fixedKeyCheckValue) |= sub(\"^Foo$\";\"Bar\")\n    )' input.json",
      "`.fixedKeyCheckPresence?` takes care of find the object key `fixedKeyCheckPresence` and leaves everything else intact.\n\nThen under `.fixedKeyCheckPresence`, we enumerate all sub-nodes with `..` and select the object containing `fixedKeyCheckValue`."
    ],
    "utterance": "Replace all values 'Foo' with 'Bar' where the key 'fixedKeyCheckValue' appears as a descendant of an object under a parent 'fixedKeyCheckPresence', regardless of nesting depth.",
    "expressions": [
      "walk((.fixedKeyCheckPresence? | .. | select(has(\"fixedKeyCheckValue\")?).fixedKeyCheckValue) |= sub(\"^Foo$\";\"Bar\"))"
    ],
    "data": [
      {
        "input": {
          "randomKey1": {
            "randomKey2": [
              {
                "randomKeyUnderAnyLevel11": {
                  "fixedKeyCheckPresence": {
                    "randomeKeyUnderAnyLevel23": {
                      "fixedKeyCheckValue": "Foo"
                    }
                  }
                }
              }
            ]
          },
          "randomKey11": {
            "fixedKeyCheckPresence": {
              "randomeKeyUnderAnyLevel123": {
                "fixedKeyCheckValue": "Foo"
              }
            }
          }
        },
        "output": {
          "randomKey1": {
            "randomKey2": [
              {
                "randomKeyUnderAnyLevel11": {
                  "fixedKeyCheckPresence": {
                    "randomeKeyUnderAnyLevel23": {
                      "fixedKeyCheckValue": "Bar"
                    }
                  }
                }
              }
            ]
          },
          "randomKey11": {
            "fixedKeyCheckPresence": {
              "randomeKeyUnderAnyLevel123": {
                "fixedKeyCheckValue": "Bar"
              }
            }
          }
        }
      }
    ],
    "identifier": 71855587
  },
  {
    "context": [
      "I have a json file as this,\n\n```bash\n# cat input.json\n{\"foo\": 42, \"bar\": \"less interesting data\"}\n```",
      "and I want to generate a json file with jq as follow, \n\noutput: \nincrease the value of foo, \n```json\n[\n  {\n    \"leafCalls\": {\n      \"text\": 43\n    }\n  }\n]\n```",
      "To get the first output, increase the value directly. Parentheses are needed for precedence.\n```\njq '[. as { foo: $leafText } | {\n    leafCalls: {\n      text: ($leafText + 1)\n    },\n  }\n] ' input.json\n```"
    ],
    "utterance": "Produce an array containing an object with key 'leafCalls', whose 'text' value is the 'foo' property increased by 1.",
    "expressions": [
      "[. as { foo: $leafText } | { leafCalls: { text: ($leafText + 1) } }]"
    ],
    "data": [
      {
        "input": {
          "foo": 42,
          "bar": "less interesting data"
        },
        "output": [
          {
            "leafCalls": {
              "text": 43
            }
          }
        ]
      }
    ],
    "identifier": 71867828
  },
  {
    "context": [
      "I\u2019d like to merge each list of dictionaries into one dictionary. I\u2019d like the final result to be:",
      "I\u2019d like an expression that merges all kv-pairs into one dictionary. I don\u2019t want to hardcode the actual name of the keys in the expression.",
      "Based on your description, it would seem that could achieve what you describe as your \"final result\" just by adding `add` to your pipeline."
    ],
    "utterance": "Merge each list of single-key dictionaries into a single dictionary without hardcoding key names.",
    "expressions": [
      ".collection.rows[].rowAnswers | map({ (.refCode) : .answers[0].responseText }) | add"
    ],
    "data": [
      {
        "input": {
          "collection": {
            "rows": [
              {
                "rowAnswers": [
                  {
                    "refCode": "NAME",
                    "answers": [
                      {
                        "responseText": "some_name1"
                      }
                    ]
                  },
                  {
                    "refCode": "CODE",
                    "answers": [
                      {
                        "responseText": "code1"
                      }
                    ]
                  },
                  {
                    "refCode": "SERVER",
                    "answers": [
                      {
                        "responseText": "server1"
                      }
                    ]
                  }
                ]
              },
              {
                "rowAnswers": [
                  {
                    "refCode": "NAME",
                    "answers": [
                      {
                        "responseText": "name2"
                      }
                    ]
                  },
                  {
                    "refCode": "CODE",
                    "answers": [
                      {
                        "responseText": "code2"
                      }
                    ]
                  },
                  {
                    "refCode": "SERVER",
                    "answers": [
                      {
                        "responseText": "server2"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "NAME": "some_name1",
          "CODE": "code1",
          "SERVER": "server1"
        }
      },
      {
        "input": {
          "collection": {
            "rows": [
              {
                "rowAnswers": [
                  {
                    "refCode": "NAME",
                    "answers": [
                      {
                        "responseText": "some_name1"
                      }
                    ]
                  },
                  {
                    "refCode": "CODE",
                    "answers": [
                      {
                        "responseText": "code1"
                      }
                    ]
                  },
                  {
                    "refCode": "SERVER",
                    "answers": [
                      {
                        "responseText": "server1"
                      }
                    ]
                  }
                ]
              },
              {
                "rowAnswers": [
                  {
                    "refCode": "NAME",
                    "answers": [
                      {
                        "responseText": "name2"
                      }
                    ]
                  },
                  {
                    "refCode": "CODE",
                    "answers": [
                      {
                        "responseText": "code2"
                      }
                    ]
                  },
                  {
                    "refCode": "SERVER",
                    "answers": [
                      {
                        "responseText": "server2"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "NAME": "name2",
          "CODE": "code2",
          "SERVER": "server2"
        }
      }
    ],
    "identifier": 71864901
  },
  {
    "context": [
      "And I want to join all those strings (\"key1\", \"key2\", key3\") into one string, and I define the filter as this,",
      "But this doesn't work,",
      "concat with a string seems works.",
      "The problem is underspecified, but you might wish to consider:",
      "[.. | strings] | join(\" \")"
    ],
    "utterance": "Concatenate all string values inside the data into a single space-separated string.",
    "expressions": [
      "[.. | strings] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "foo": [
            "key1",
            "key2"
          ],
          "bar": "key3"
        },
        "output": "key1 key2 key3"
      }
    ],
    "identifier": 71870855
  },
  {
    "context": [
      "if I try to build an object with a key, whose value would be the result of subtraction operator, I can't:",
      "type sample.json| jq \".[] | {c: .a - .b}\"",
      "Put the expression in parentheses:",
      "jq \".[] | {c: (.a - .b)}\" sample.json",
      "{\n  \"c\": -1\n}",
      "jq \".[] | {c: (.a + .b)}\" sample.json",
      "{\n  \"c\": 3\n}"
    ],
    "utterance": "For each entry, output an object with key c whose value is the difference between the fields a and b.",
    "expressions": [
      ".[] | {c: (.a - .b)}"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 2
          }
        ],
        "output": {
          "c": -1
        }
      }
    ],
    "identifier": 71873741
  },
  {
    "context": [
      "Now I want to append the `key3` to the output json and define the filter as this,",
      "Wouldn&#39;t it be simpler to use `map` and build the objects directly?",
      "`map({values: (.foo + [.bar] | map({key:.}))})`",
      "Can this achieve what you wanted :",
      "`[\n    .[] | . as { foo: $names,  bar: $name} |\n    {\n        names: ([\n            $names | range(0;length) as $i |\n            { key: ($names[$i]) }\n        ] + [{ key: $name }])\n    } |\n    {\n    values: .names,\n    }\n]`"
    ],
    "utterance": "Append the value of 'bar' as an object with key property to the array generated from values of 'foo' as objects with key property, outputting an object with a 'values' property containing the array.",
    "expressions": [
      "map({values: (.foo + [.bar] | map({key:.}))})",
      "[.[] | . as { foo: $names,  bar: $name} | { names: ([ $names | range(0;length) as $i | { key: ($names[$i]) }] + [{ key: $name }]) } | { values: .names }]"
    ],
    "data": [
      {
        "input": {
          "foo": [
            "key1",
            "key2"
          ],
          "bar": "key3"
        },
        "output": [
          {
            "values": [
              {
                "key": "key1"
              },
              {
                "key": "key2"
              },
              {
                "key": "key3"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 71869690
  },
  {
    "context": [
      "I have a huge JSON file with lots of stuff I don't care about, and I want to filter it down to only the few keys I care about, preserving the structure.",
      "So how could this be done, delete everything but a set of key values?",
      "INDEX( \"foo\", \"bar\" ) as $keep | walk( if type == \"object\" then with_entries( select( $keep[ .key ] ) ) else . end )",
      "jq --argjson whitelist WHITELIST '\ndef retainKeys($array):\n  INDEX($array[]; .) as $keys\n  | def r:\n      if type == \"object\" \n      then with_entries( select($keys[.key]) )\n      | map_values( r )\n      elif type == \"array\" then map( r )\n      else .\n      end;\n  r;\n\n  retainKeys($whitelist)\n\n' input.json"
    ],
    "utterance": "Retain only keys named \"foo\" and \"bar\" throughout the structure, removing all other keys, but preserving the nested structure.",
    "expressions": [
      "INDEX( \"foo\", \"bar\" ) as $keep | walk( if type == \"object\" then with_entries( select( $keep[ .key ] ) ) else . end )",
      "INDEX( \"foo\", \"bar\" ) as $keep | walk( if type == \"object\" then del( .[ keys_unsorted[] | select( $keep[ . ] | not ) ] ) else . end )",
      "delpaths([paths | select(all(IN(\"foo\", \"bar\") or type == \"number\") | not)])",
      "def retainKeys($array):\n  INDEX($array[]; .) as $keys\n  | def r:\n      if type == \"object\" \n      then with_entries( select($keys[.key]) )\n      | map_values( r )\n      elif type == \"array\" then map( r )\n      else .\n      end;\n  r;\nretainKeys([\"foo\", \"bar\"])"
    ],
    "data": [
      {
        "input": {
          "keep": "this",
          "remove": "that",
          "foo": {
            "foo": "ok",
            "bar": "yes",
            "baz": "no"
          },
          "bar": [
            {
              "foo": 1,
              "bar": 2,
              "baz": 3
            },
            {
              "foo": 4
            }
          ]
        },
        "output": {
          "foo": {
            "foo": "ok",
            "bar": "yes"
          },
          "bar": [
            {
              "foo": 1,
              "bar": 2
            },
            {
              "foo": 4
            }
          ]
        }
      }
    ],
    "identifier": 71851534
  },
  {
    "context": [
      "How do I extract the Instance ID and the Tag Name so that it prints like this:\n\n    Instance ID: i-01e625ed10dadda91\n    Name: Some Server",
      "If you want to join multiple tags together and produce as a single result, combine them together in a CSV format like below",
      "jq --raw-output '.[] | \n  \"Instance ID: \\(.InstanceId)\\nTag Name: \\( .Tags | map(select(.Key == \"Name\").Value) |join(\",\"))\"'",
      "If you want to skip printing the Name field, in case if its empty, you need to add a bit more logic",
      "jq --raw-output '.[] | \n  \"Instance ID: \\(.InstanceId)\" as $x | \n  ( .Tags | map(select(.Key == \"Name\") ) ) as $y | \n  if ( $y | length ) > 0 then \n    $x + \"\\nName: \\( $y | map(.Value) | join(\",\") )\" \n  else $x end'"
    ],
    "utterance": "For each element, print the InstanceId and the value(s) of the tag whose Key is \"Name\"; if there are multiple such tags, join their values with commas; omit the Name field if no such tag exists.",
    "expressions": [
      ".[] | \"Instance ID: \\(.InstanceId)\\nTag Name: \\( .Tags | map(select(.Key == \\\"Name\\\").Value) | join(\",\") )\"",
      ".[] | \"Instance ID: \\(.InstanceId)\" as $x | ( .Tags | map(select(.Key == \"Name\") ) ) as $y | if ( $y | length ) > 0 then $x + \"\\nName: \\( $y | map(.Value) | join(\",\") )\" else $x end"
    ],
    "data": [
      {
        "input": [
          {
            "AmiLaunchIndex": 0,
            "ImageId": "ami-03ededff12e34e59e",
            "InstanceId": "i-01e625ed10dadda91",
            "InstanceType": "t2.micro",
            "LaunchTime": "2022-04-18T02:35:03+00:00",
            "Monitoring": {
              "State": "disabled"
            },
            "Tags": [
              {
                "Key": "Name",
                "Value": "Some Server"
              }
            ]
          }
        ],
        "output": "Instance ID: i-01e625ed10dadda91\nName: Some Server"
      }
    ],
    "identifier": 71909924
  },
  {
    "context": [
      "I have a separate list of names (e.g. Tom, Sarah, Jenny, Trinh, Nancy) and I want to find out if they're associated with a country in any of the JSON's I'm running the curl command on. If they exist in \"names\", I want to put the name of the person and the country into a new text file (or JSON file, doesn't matter - i just want it formatted properly), so at the end I have an output file that associates the name of the person and the country they belong to. If a country has multiple people, there shouldn't be a duplicate value for country in the output file; the names of the people should be listed under that one country.",
      "The output file (given above example) should be something like:\n\n    USA: Tom\n\n    Nigeria: Tom, Jenny",
      "jq -c -n --argjson list '[ \"Tom\", \"Sarah\", \"Jenny\", \"Trinh\", \"Nancy\"]' '\n  (reduce inputs as $in ({}; reduce $in.names[] as $name (.; .[$name] += [$in.country]))) as $dict\n  | reduce $list[] as $name ({}; \n      if $dict[$name] \n      then reduce $dict[$name][] as $country (.; .[$country] += [$name]) \n      else . end)\n' output.jsons",
      "produces:\n{\"USA\":[\"Tom\"],\"Nigeria\":[\"Tom\",\"Jenny\"]}",
      "One way to ensure uniqueness of the elements of each array would be to append the following to the filter: map_values(unique)."
    ],
    "utterance": "Find all specified names in input files and group them by country with each country's associated names listed without duplicates.",
    "expressions": [
      "jq -c -n --argjson list '[ \"Tom\", \"Sarah\", \"Jenny\", \"Trinh\", \"Nancy\"]' '  (reduce inputs as $in ({}; reduce $in.names[] as $name (.; .[$name] += [$in.country]))) as $dict  | reduce $list[] as $name ({};       if $dict[$name]       then reduce $dict[$name][] as $country (.; .[$country] += [$name])       else . end)' output.jsons",
      "jq -c -n --argjson list '[ \"Tom\", \"Sarah\", \"Jenny\", \"Trinh\", \"Nancy\"]' '  (reduce inputs as $in ({}; reduce $in.names[] as $name (.; .[$name] += [$in.country]))) as $dict  | reduce $list[] as $name ({};       if $dict[$name]       then reduce $dict[$name][] as $country (.; .[$country] += [$name])       else . end) | map_values(unique)' output.jsons"
    ],
    "data": [
      {
        "input": [
          {
            "names": [
              "Mary",
              "Tom",
              "Sue",
              "Rob"
            ],
            "country": "USA"
          },
          {
            "names": [
              "Sue"
            ],
            "country": "Russia"
          },
          {
            "names": [
              "Tom",
              "Jenny"
            ],
            "country": "Nigeria"
          }
        ],
        "output": {
          "USA": [
            "Tom"
          ],
          "Nigeria": [
            "Tom",
            "Jenny"
          ]
        }
      }
    ],
    "identifier": 71906496
  },
  {
    "context": [
      "I am having the below json array and i wanted to append two additional key value pairs  in the json array using bash.",
      "so the final json array should  look like as below,",
      "jq '. + [ { \"entry\": \"10.20.17.0/24\", \"comment\": \"test ip3\" }, { \"entry\": \"10.20.18.0/24\", \"comment\": \"test ip4\" } ]' file.json",
      "jq --argjson to_add '[ { \"entry\": \"10.20.17.0/24\", \"comment\": \"test ip3\" }, { \"entry\": \"10.20.18.0/24\", \"comment\": \"test ip4\" } ]' '. + $to_add' file.json",
      "jq --argfile to_add to_add.json '. + $to_add' file.json",
      "jq --slurp add file.json to_add.json"
    ],
    "utterance": "Append two objects with entry '10.20.17.0/24' and comment 'test ip3', and entry '10.20.18.0/24' and comment 'test ip4' to an existing array.",
    "expressions": [
      ". + [ { \"entry\": \"10.20.17.0/24\", \"comment\": \"test ip3\" }, { \"entry\": \"10.20.18.0/24\", \"comment\": \"test ip4\" } ]",
      ". + $to_add",
      "add"
    ],
    "data": [
      {
        "input": [
          {
            "entry": "10.20.15.0/24",
            "comment": "test ip1"
          },
          {
            "entry": "10.20.16.0/24",
            "comment": "test ip2"
          }
        ],
        "output": [
          {
            "entry": "10.20.15.0/24",
            "comment": "test ip1"
          },
          {
            "entry": "10.20.16.0/24",
            "comment": "test ip2"
          },
          {
            "entry": "10.20.17.0/24",
            "comment": "test ip3"
          },
          {
            "entry": "10.20.18.0/24",
            "comment": "test ip4"
          }
        ]
      }
    ],
    "identifier": 71927585
  },
  {
    "context": [
      "I would like to flatten the following (elasticsearch result, simplified) into a CSV file with repeating parent values.",
      "The aggregation has three levels that I would like to flatten, site name, account id, user names, and counted. The renaming of the CSV headers, as shown, would be nice.",
      "Desired Output",
      "\"Site\", \"Account\", \"User\", \"Counted\"",
      "It's a pretty simple combination of grabbing some information, then looping over descendants.",
      "(\n   [ \"Site\", \"Account\", \"User\", \"Counted\" ],\n   (\n      .aggregations.by_site_group_and_account_and_user_name.buckets[] |\n      .key as $site |\n      .by_account_Id.buckets[] |\n      .key as $account |\n      .by_user_name.buckets[] |\n      [ $site, $account, .key, .doc_count ]\n   )\n) | @csv"
    ],
    "utterance": "Extract all combinations of site name, account ID, user name, and user count from the nested structure, outputting a table with headers Site, Account, User, and Counted.",
    "expressions": [
      "(\n   [ \"Site\", \"Account\", \"User\", \"Counted\" ],\n   (\n      .aggregations.by_site_group_and_account_and_user_name.buckets[] |\n      .key as $site |\n      .by_account_Id.buckets[] |\n      .key as $account |\n      .by_user_name.buckets[] |\n      [ $site, $account, .key, .doc_count ]\n   )\n) | @csv"
    ],
    "data": [
      {
        "input": {
          "aggregations": {
            "by_site_group_and_account_and_user_name": {
              "doc_count_error_upper_bound": 4880,
              "sum_other_doc_count": 760270,
              "buckets": [
                {
                  "key": "S1",
                  "doc_count": 335216,
                  "by_account_Id": {
                    "doc_count_error_upper_bound": 429,
                    "sum_other_doc_count": 34655,
                    "buckets": [
                      {
                        "key": 1396220,
                        "doc_count": 277532,
                        "by_user_name": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 2580,
                          "buckets": [
                            {
                              "key": "S1_U1",
                              "doc_count": 244602
                            },
                            {
                              "key": "S1_U2",
                              "doc_count": 30350
                            }
                          ]
                        }
                      },
                      {
                        "key": 14770032,
                        "doc_count": 23029,
                        "by_user_name": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 0,
                          "buckets": [
                            {
                              "key": "S1_U3",
                              "doc_count": 23016
                            }
                          ]
                        }
                      }
                    ]
                  }
                },
                {
                  "key": "S2",
                  "doc_count": 146453,
                  "by_account_Id": {
                    "doc_count_error_upper_bound": 2380,
                    "sum_other_doc_count": 108259,
                    "buckets": [
                      {
                        "key": 14733289,
                        "doc_count": 20138,
                        "by_user_name": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 2406,
                          "buckets": [
                            {
                              "key": "S2_U1",
                              "doc_count": 13247
                            },
                            {
                              "key": "S2_U2",
                              "doc_count": 4485
                            }
                          ]
                        }
                      },
                      {
                        "key": 14769976,
                        "doc_count": 18056,
                        "by_user_name": {
                          "doc_count_error_upper_bound": 0,
                          "sum_other_doc_count": 0,
                          "buckets": [
                            {
                              "key": "S2_U3",
                              "doc_count": 17015
                            },
                            {
                              "key": "S2_U4",
                              "doc_count": 1041
                            }
                          ]
                        }
                      }
                    ]
                  }
                }
              ]
            }
          }
        },
        "output": [
          "\"Site\", \"Account\", \"User\", \"Counted\"",
          "\"S1\", 1396220, \"S1_U1\", 244602",
          "\"S1\", 1396220, \"S1_U2\", 30350",
          "\"S1\", 14770032, \"S1_U3\", 23016",
          "\"S2\", 14733289, \"S2_U1\", 13247",
          "\"S2\", 14733289, \"S2_U2\", 4485",
          "\"S2\", 14769976, \"S2_U3\", 17015",
          "\"S2\", 14769976, \"S2_U4\", 1041"
        ]
      }
    ],
    "identifier": 71891456
  },
  {
    "identifier": 71944396
  },
  {
    "context": [
      "How can read the value `\"http_httpCode#HTTP Code\"` if `1650468248` is a dynamic value?",
      "jq '.data | to_entries | first | .value.\"http_httpCode#HTTP Code\"'",
      "jq '.data | .. | .\"http_httpCode#HTTP Code\"? // empty'",
      "jq '.data | .[].\"http_httpCode#HTTP Code\"'",
      "jq -r '.data | .[].\"http_httpCode#HTTP Code\"'"
    ],
    "utterance": "Retrieve the value associated with the key \"http_httpCode#HTTP Code\" inside the object under the top-level \"data\" property without knowing the timestamp key name.",
    "expressions": [
      ".data | to_entries | first | .value.\"http_httpCode#HTTP Code\"",
      ".data | .. | .\"http_httpCode#HTTP Code\"? // empty",
      ".data | .[].\"http_httpCode#HTTP Code\""
    ],
    "data": [
      {
        "input": {
          "device": "mydevice",
          "object": "http--HTTP_v6_Global ",
          "object_descr": "HTTP download of http://192.168.0.1",
          "indicator": "http_httpCode",
          "indicator_descr": null,
          "plugin": "xxx",
          "starttime": 1650468121,
          "endtime": 1650468421,
          "data": {
            "1650468248": {
              "http_httpCode#HTTP Code": 200
            }
          }
        },
        "output": 200
      }
    ],
    "identifier": 71942506
  },
  {
    "context": [
      "However, how can the '.[0] * .[1]' part be generalised to work with an arbitrary number of input files?",
      "Is there an equivalent to add for *?",
      "Could be replaced with a [`reduce`][1] to match `n` files:",
      "jq 'reduce inputs as $i (.; . * $i)' file1.json file2.json",
      "Changing the command to include a wildcard (`*`) (lazy...):",
      "jq 'reduce inputs as $i (.; . * $i)' file*.json",
      "Gives the following output:",
      "{\n  \"key1\": {\n    \"key1.1\": \"foo\",\n    \"key1.2\": \"bar\",\n    \"key1.3\": \"dingo\"\n  },\n  \"key2\": {\n    \"key2.1\": \"daz\",\n    \"key2.2\": \"lorem\"\n  },\n  \"key7\": {\n    \"key7.3\": \"dingo\"\n  },\n  \"key8\": {\n    \"key8.2\": \"lorem\"\n  }\n}"
    ],
    "utterance": "Merge an arbitrary number of input objects recursively using the * operator.",
    "expressions": [
      "reduce inputs as $i (.; . * $i)"
    ],
    "data": [
      {
        "input": [
          {
            "key1": {
              "key1.1": "foo",
              "key1.2": "bar"
            },
            "key2": {
              "key2.1": "daz"
            }
          },
          {
            "key1": {
              "key1.3": "dingo"
            },
            "key2": {
              "key2.2": "lorem"
            }
          },
          {
            "key7": {
              "key7.3": "dingo"
            },
            "key8": {
              "key8.2": "lorem"
            }
          }
        ],
        "output": {
          "key1": {
            "key1.1": "foo",
            "key1.2": "bar",
            "key1.3": "dingo"
          },
          "key2": {
            "key2.1": "daz",
            "key2.2": "lorem"
          },
          "key7": {
            "key7.3": "dingo"
          },
          "key8": {
            "key8.2": "lorem"
          }
        }
      }
    ],
    "identifier": 71941009
  },
  {
    "context": [
      "how to list the Kubernetes pod which has CharDevice in it ?",
      "I could able to get the pod with CharDevice, but need to print the pod name only",
      "You can get json first and use `jq` to get desired result :",
      "kubectl get pod -o json |\njq -r '.items[]|select(any(.spec.volumes[];.hostPath.type==\"CharDevice\")).metadata.name'"
    ],
    "utterance": "List the names of pods that contain at least one volume with hostPath.type equal to CharDevice.",
    "expressions": [
      ".items[] | select(any(.spec.volumes[]; .hostPath.type==\"CharDevice\")).metadata.name"
    ],
    "identifier": 71953051
  },
  {
    "context": [
      "I have a log file from our friends at Microsoft in a very challenging format. The file is as follows:\r\n\r\n - File is a .CSV\r\n - Four fields, the fourth contains JSON\r\n - All JSON key pairs are wrapped with two sets of double quotes",
      "grep FileViewed AnnoyingLogFile.csv | cut -d, -f 4- | sed -e 's/\"\"/\"/g' -e 's/^\"//' -e 's/\"$//' | jq .",
      "First sed replace '\"\"' with '\"', the second remove '\"' at the beginning and third at the end",
      "Output I want:\r\n\r\n    {\r\n        \"AppAccessContext\":\r\n        {\r\n            \"CorrelationId\": \"f6298547-d934-4c79-8bab-c5c394f31f65\"\r\n        },\r\n        ...\r\n    }"
    ],
    "utterance": "Extract the fourth field from each CSV line where the third field is 'FileViewed', normalize the doubled double quotes in the field to valid structure, and parse it to recover the data object.",
    "expressions": [
      "grep FileViewed AnnoyingLogFile.csv | cut -d, -f 4- | sed -e 's/\"\"/\"/g' -e 's/^\"//' -e 's/\"$//' | jq ."
    ],
    "data": [
      {
        "input": "2022-01-01T15:00:00.0000000Z,username@domain.com,FileViewed,\"{\"\"AppAccessContext\"\":{\"\"CorrelationId\"\":\r\n\"\"f6298547-d934-4c79-8bab-c5c394f31f65\"\"},\"\"CreationTime\"\":\r\n\"\"2022-01-01T15:00:00\"\",...}\"",
        "output": {
          "AppAccessContext": {
            "CorrelationId": "f6298547-d934-4c79-8bab-c5c394f31f65"
          },
          "CreationTime": "2022-01-01T15:00:00",
          "Id": "f6298547-d934-4c79-8bab-c5c394f31f65",
          "Operation": "FileViewed",
          "OrganizationId": "f6298547-d934-4c79-8bab-c5c394f31f65",
          "RecordType": 0,
          "UserType": 0,
          "Version": 0,
          "Workload": "OneDrive",
          "ClientIP": "172.0.0.1",
          "ObjectId": "https://websitebame-my.sharepoint.com/personal/user_directory/Documents/TextFile.txt",
          "UserId": "username@domain.com",
          "CorrelationId": "f6298547-d934-4c79-8bab-c5c394f31f65",
          "EventSource": "SharePoint",
          "ItemType": "File",
          "ListId": "f6298547-d934-4c79-8bab-c5c394f31f65",
          "ListItemUniqueId": "f6298547-d934-4c79-8bab-c5c394f31f65",
          "Site": "f6298547-d934-4c79-8bab-c5c394f31f65",
          "WebId": "f6298547-d934-4c79-8bab-c5c394f31f65",
          "SourceFileName": "TextFile.txt",
          "SourceRelativeUrl": "Documents"
        }
      }
    ],
    "identifier": 71797910
  },
  {
    "context": [
      "\"if .Text !endswith(\"[punctuation mark][white space]\") then .Text + next .Text where .TextSize matches\"",
      "\"is there a way to merge the partial sentence (the one which does not end with a \\\"[punctuation mark][white space]\\\" pattern) with its remainder based on the matching TextSize?\"",
      "The following, which assumes the input is a valid JSON array, will merge every .Text with at most one successor ...",
      "elif .[$i].Text|test(\"[,.?:;]\\\\s*$\")|not then attempt_to_merge_next($i)",
      "def attempt_to_merge_next($i):\n  .[$i].TextSize as $class\n  | first( (range($i+1; length) as $j | select(.[$j].TextSize == $class) | $j) // null) as $j\n  | if $j then .[$i].Text += .[$j].Text | del(.[$j])\n    else .\n    end;"
    ],
    "utterance": "Merge the Text value of an object with the Text of the next object with the same TextSize if the first object's Text does not end with punctuation and whitespace.",
    "expressions": [
      "def attempt_to_merge_next($i):\n  .[$i].TextSize as $class\n  | first( (range($i+1; length) as $j | select(.[$j].TextSize == $class) | $j) // null) as $j\n  | if $j then .[$i].Text += .[$j].Text | del(.[$j])\n    else .\n    end;\n\nreduce range(0; length) as $i (.;\n  if .[$i] == null then .\n  elif .[$i].Text|test(\"[,.?:;]\\s*$\")|not\n  then attempt_to_merge_next($i)\n  else .\n  end)"
    ],
    "data": [
      {
        "input": [
          {
            "Text": "Was it political will that established social democratic policies in the 1930s and ",
            "Path": "P",
            "TextSize": 9
          },
          {
            "Text": "31 Lawrence Mishel and Jessica Schieder, Economic Policy Institute website, May 24, 2016 at (https://www.epi.org/publication/as-union-membership-has-fallen-the-top-10-percent-have-been-getting-a-larger-share-of-income/). ",
            "Path": "Footnote",
            "TextSize": 8
          },
          {
            "Text": "Fig. 9.2 Higher union membership has been associated with a higher share of income to lower income brackets (the lower 90%) and a lower share of income to the top 10% of earners. ",
            "Path": "P",
            "TextSize": 8
          },
          {
            "Text": "1940s, or that undermined them after the 1970s? Or was it abundant and cheap energy resources that enabled social democratic policies to work until the 1970s, and energy constraints that forced a restructuring of policy after the 1970s? ",
            "Path": "P",
            "TextSize": 9
          },
          {
            "Text": "Recall that my economic modeling discussed in Chap. 6 shows that, even with no change in the assumption related to labor \\u201cbargaining power,\\u201d you can explain a shift from increasing to declining income equality (higher equality expressed as a higher wage share) by a corresponding shift from a period of rapidly increasing per capita resource consumption to one of constant per capita resource consumption. ",
            "Path": "P",
            "TextSize": 9
          }
        ],
        "output": [
          {
            "Text": "Was it political will that established social democratic policies in the 1930s and 1940s, or that undermined them after the 1970s? Or was it abundant and cheap energy resources that enabled social democratic policies to work until the 1970s, and energy constraints that forced a restructuring of policy after the 1970s? ",
            "Path": "P",
            "TextSize": 9
          },
          {
            "Text": "31 Lawrence Mishel and Jessica Schieder, Economic Policy Institute website, May 24, 2016 at (https://www.epi.org/publication/as-union-membership-has-fallen-the-top-10-percent-have-been-getting-a-larger-share-of-income/). ",
            "Path": "Footnote",
            "TextSize": 8
          },
          {
            "Text": "Fig. 9.2 Higher union membership has been associated with a higher share of income to lower income brackets (the lower 90%) and a lower share of income to the top 10% of earners. ",
            "Path": "P",
            "TextSize": 8
          },
          {
            "Text": "Recall that my economic modeling discussed in Chap. 6 shows that, even with no change in the assumption related to labor \\u201cbargaining power,\\u201d you can explain a shift from increasing to declining income equality (higher equality expressed as a higher wage share) by a corresponding shift from a period of rapidly increasing per capita resource consumption to one of constant per capita resource consumption. ",
            "Path": "P",
            "TextSize": 9
          }
        ]
      }
    ],
    "identifier": 71918146
  },
  {
    "context": [
      "I have a comma separated string of IP addresses (one or more)",
      "Using `jq`, I would like to create a JSON document that looks like this:",
      "this has 2 problems:\n1) `.clusters[].nodes[].node` is not replicated.\n2) `.clusters[].nodes[].node.hostnames.storage` is missing.",
      "You could use the splitting result with `map` to create the array under `.clusters[0].nodes`:",
      "jq -R '\n  {clusters: [{nodes: (./\",\" | map({\n    node: {hostnames: {manage: [.], storage: [.]}, zone: 1},\n    devices: [{name: \"/dev/sdb\", destroydata: false}]\n  }))}]}\n' <<< \"$nodes\""
    ],
    "utterance": "Transform a comma-separated list of IP addresses into a structure where each address is an object under clusters[0].nodes, with manage and storage set to that address and zone equal to 1, plus a devices array containing /dev/sdb and destroydata false.",
    "expressions": [
      "{clusters: [{nodes: (./\",\" | map({ node: {hostnames: {manage: [.], storage: [.]}, zone: 1}, devices: [{name: \"/dev/sdb\", destroydata: false}] }))}]}"
    ],
    "data": [
      {
        "input": "192.168.56.111,192.168.56.112,192.168.56.113",
        "output": {
          "clusters": [
            {
              "nodes": [
                {
                  "node": {
                    "hostnames": {
                      "manage": [
                        "192.168.56.111"
                      ],
                      "storage": [
                        "192.168.56.111"
                      ]
                    },
                    "zone": 1
                  },
                  "devices": [
                    {
                      "name": "/dev/sdb",
                      "destroydata": false
                    }
                  ]
                },
                {
                  "node": {
                    "hostnames": {
                      "manage": [
                        "192.168.56.112"
                      ],
                      "storage": [
                        "192.168.56.112"
                      ]
                    },
                    "zone": 1
                  },
                  "devices": [
                    {
                      "name": "/dev/sdb",
                      "destroydata": false
                    }
                  ]
                },
                {
                  "node": {
                    "hostnames": {
                      "manage": [
                        "192.168.56.113"
                      ],
                      "storage": [
                        "192.168.56.113"
                      ]
                    },
                    "zone": 1
                  },
                  "devices": [
                    {
                      "name": "/dev/sdb",
                      "destroydata": false
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 71952200
  },
  {
    "context": [
      "I have a file (file.txt) like:\n```\nfield1|field2|field3 \nfield1|field2|field3 \nfield1|field2|field3 \n```",
      "I need to convert it into something like:\n\n```\nfield3.field2|{\"myname1\":\"field1\",\"myname2\":\"field2\",\"myname3\":\"field3\"}\nfield3.field2|{\"myname1\":\"field1\",\"myname2\":\"field2\",\"myname3\":\"field3\"}\nfield3.field2|{\"myname1\":\"field1\",\"myname2\":\"field2\",\"myname3\":\"field3\"}\n```",
      "Here's a solution using `jq` with string interpolation and conversion to JSON using `tojson`:\n~~~sh\njq -Rr './\"|\" | \"\\(.[2]).\\(.[1])|\\({\n  \"myname1\": .[0],\n  \"myname2\": .[1],\n  \"myname3\": .[2]\n} | tojson)\"' file.txt\n~~~"
    ],
    "utterance": "For each line, output the third field, a dot, the second field, a pipe character, and then a JSON object with custom keys mapping to the three fields.",
    "expressions": [
      "jq -Rr 'split(\"|\") | \"\\(.[2]).\\(.[1])|\\({\\\"myname1\\\": \\\"\\(.[0])\\\", \\\"myname2\\\": \\\"\\(.[1])\\\", \\\"myname3\\\": \\\"\\(.[2])\\\"})\"' file.txt",
      "jq -Rr 'split(\"|\") | \"\\(.[2]).\\(.[1])|\\({\\\"myname1\\\":\\\"\\(.[0])\\\",\\\"myname2\\\":\\\"\\(.[1])\\\",\\\"myname3\\\":\\\"\\(.[2])\\\"})\"' file.txt",
      "jq -Rr 'split(\"|\") | \"\\(.[2]).\\(.[1])|\\({\\\"myname1\\\": .[0], \\\"myname2\\\": .[1], \\\"myname3\\\": .[2]} | tojson)\"' file.txt"
    ],
    "data": [
      {
        "input": "field1|field2|field3\nfield4|field5|field6",
        "output": "field3.field2|{\"myname1\":\"field1\",\"myname2\":\"field2\",\"myname3\":\"field3\"}\nfield6.field5|{\"myname1\":\"field4\",\"myname2\":\"field5\",\"myname3\":\"field6\"}"
      }
    ],
    "identifier": 71950824
  },
  {
    "context": [
      "For each item, if it has `.status.conditions`, I want the message from the first element in `.status.conditions` that has a message.",
      "The problem is that when it gets to an item that doesn't have a `.status.conditions`, It returns the error `Cannot iterate over null (null)`.",
      "My attempted solution was to use various ways of `try-catch` to pass an empty list to map instead of null",
      "All of these attempts return `1 compile error` when written inside of an object constructor as shown, and work as expected when written on their own without an object constructor",
      "Thanks to @Fravadona, it was just a matter of parentheses. I had tried it at some point and made some mistake or other, but a working solution for my case is",
      "jq -r '{message: .status | (.conditions? // []) | map(select(has(\"message\")).message)[0]?}'"
    ],
    "utterance": "For each element, get the value of the 'message' property from the first object in 'status.conditions' that has a 'message', or null if none exists, avoiding errors if 'status.conditions' is missing.",
    "expressions": [
      ".items[] | {message: .status | (.conditions? // []) | map(select(has(\"message\")).message)[0]?}"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "status": {
                "conditions": [
                  {
                    "type": "Initialized",
                    "message": "foo"
                  },
                  {
                    "type": "Ready"
                  }
                ]
              }
            },
            {
              "status": {}
            }
          ]
        },
        "output": [
          {
            "message": "foo"
          },
          {
            "message": null
          }
        ]
      }
    ],
    "identifier": 71954738
  },
  {
    "context": [
      "I thought I could do with this with `del` but it is leaving behind a `null`.",
      "How do I get this output?",
      "`select` is already the tool you want! There is no need for `del` here at all. `select` is the mechanism to keep only _some_ of a stream of objects. Try:",
      "$ cat ~/scratch/test.yaml | yq -y 'select(.kind != \"Namespace\" or .metadata.name != \"bar\")'",
      "gojq --yaml-input --yaml-output 'select(.metadata.name != \"bar\")' test.yaml"
    ],
    "utterance": "Remove all resources where kind is Namespace and metadata.name is bar, keeping the others.",
    "expressions": [
      "select(.kind != \"Namespace\" or .metadata.name != \"bar\")",
      "select(.metadata.name != \"bar\")"
    ],
    "data": [
      {
        "input": [
          {
            "apiVersion": "v1",
            "kind": "Namespace",
            "metadata": {
              "name": "foo"
            },
            "spec": {},
            "status": {}
          },
          {
            "apiVersion": "v1",
            "kind": "Namespace",
            "metadata": {
              "name": "bar"
            },
            "spec": {},
            "status": {}
          },
          {
            "apiVersion": "v1",
            "kind": "Namespace",
            "metadata": {
              "name": "baz"
            },
            "spec": {},
            "status": {}
          }
        ],
        "output": [
          {
            "apiVersion": "v1",
            "kind": "Namespace",
            "metadata": {
              "name": "foo"
            },
            "spec": {},
            "status": {}
          },
          {
            "apiVersion": "v1",
            "kind": "Namespace",
            "metadata": {
              "name": "baz"
            },
            "spec": {},
            "status": {}
          }
        ]
      }
    ],
    "identifier": 71960890
  },
  {
    "context": [
      "Is it possible to obtain the following result using _jq_?",
      "Three points are crucial:\r\n\r\n1. Leave unchanged any field that is not `flag` or starts with `test `\r\n\r\n1. Transform `flag` (space separated values) into an array\r\n\r\n1. Any field that starts with `test ` is added to an array (`tests`) where the value is the remaining part of the field's name",
      "jq '\r\n  .flag /= \" \"\r\n  | .tests = (to_entries | map(.key | select(startswith(\"test \"))[5:]))\r\n  | with_entries(select(.key | startswith(\"test \") | not))\r\n'",
      "jq '\r\n  reduce to_entries[] as {$key, $value} (null;\r\n    if   $key == \"flag\"             then .flag = $value / \" \"\r\n    elif $key | startswith(\"test \") then .tests += [$key[5:]]\r\n    else                                 .[$key] = $value end\r\n  )\r\n'"
    ],
    "utterance": "Transform an object by splitting the value of the 'flag' field by spaces into an array, aggregating all object keys that start with 'test ' into a 'tests' array containing the suffixes, and leaving all other fields unchanged.",
    "expressions": [
      ".flag /= \" \" | .tests = (to_entries | map(.key | select(startswith(\"test \"))[5:])) | with_entries(select(.key | startswith(\"test \") | not))",
      "reduce to_entries[] as {$key, $value} (null; if $key == \"flag\" then .flag = $value / \" \" elif $key | startswith(\"test \") then .tests += [$key[5:]] else .[$key] = $value end)"
    ],
    "data": [
      {
        "input": {
          "one": "1",
          "two": "2",
          "flag": "f1 f2 f3",
          "test one": "",
          "test two": "",
          "test three": ""
        },
        "output": {
          "one": "1",
          "two": "2",
          "flag": [
            "f1",
            "f2",
            "f3"
          ],
          "tests": [
            "one",
            "two",
            "three"
          ]
        }
      }
    ],
    "identifier": 71961428
  },
  {
    "context": [
      "The main destination is to overwrite `environment` variables in the 1st file with `environment` variables in the 2nd.",
      "Could anyone help to find out how to reach the right result?",
      "Here\u0019s a solution using `tostream` and `has(1)` to read the values from the second file, and `setpath` to set them in the first file:\r\n~~~sh\r\njq \u0019reduce (input | tostream | select(has(1))) as $i (.; setpath($i[0]; $i[1]))\u0019 \\\r\n  1.json 2.json\r\n~~~",
      "Something like this will do the trick:\r\n```\r\n (input | .containerDefinitions[0].environment | from_entries) as $new_env\r\n| input | .containerDefinitions[].environment |= ((from_entries + $new_env) | to_entries)\r\n```"
    ],
    "utterance": "Overwrite the 'environment' variables in the first file's container definitions with the corresponding values from the second file.",
    "expressions": [
      "reduce (input | tostream | select(has(1))) as $i (.; setpath($i[0]; $i[1]))",
      "(input | .containerDefinitions[0].environment | from_entries) as $new_env | input | .containerDefinitions[].environment |= ((from_entries + $new_env) | to_entries)"
    ],
    "data": [
      {
        "input": [
          {
            "containerDefinitions": [
              {
                "name": "foo",
                "image": "nginx:latest",
                "cpu": 1024,
                "memory": 4096,
                "memoryReservation": 2048,
                "portMappings": [
                  {
                    "containerPort": 8080,
                    "hostPort": 0,
                    "protocol": "tcp"
                  }
                ],
                "essential": true,
                "environment": [
                  {
                    "name": "SERVER_PORT",
                    "value": "8080"
                  },
                  {
                    "name": "DB_NAME",
                    "value": "example_db"
                  }
                ],
                "mountPoints": [],
                "volumesFrom": [],
                "logConfiguration": {
                  "logDriver": "awslogs",
                  "options": {
                    "awslogs-group": "/dev/ecs/example",
                    "awslogs-region": "us-west-1",
                    "awslogs-stream-prefix": "ecs"
                  }
                }
              }
            ],
            "family": "bar",
            "taskRoleArn": "arn:aws:iam::111111111111:role/assume-ecs-role",
            "executionRoleArn": "arn:aws:iam::111111111111:role/ecs-task-execution-role",
            "networkMode": "bridge",
            "volumes": [],
            "placementConstraints": [],
            "requiresCompatibilities": [
              "EC2"
            ]
          },
          {
            "containerDefinitions": [
              {
                "environment": [
                  {
                    "name": "SERVER_PORT",
                    "value": "8081"
                  }
                ]
              }
            ]
          }
        ],
        "output": {
          "containerDefinitions": [
            {
              "name": "foo",
              "image": "nginx:latest",
              "cpu": 1024,
              "memory": 4096,
              "memoryReservation": 2048,
              "portMappings": [
                {
                  "containerPort": 8080,
                  "hostPort": 0,
                  "protocol": "tcp"
                }
              ],
              "essential": true,
              "environment": [
                {
                  "name": "SERVER_PORT",
                  "value": "8081"
                },
                {
                  "name": "DB_NAME",
                  "value": "example_db"
                }
              ],
              "mountPoints": [],
              "volumesFrom": [],
              "logConfiguration": {
                "logDriver": "awslogs",
                "options": {
                  "awslogs-group": "/dev/ecs/example",
                  "awslogs-region": "us-west-1",
                  "awslogs-stream-prefix": "ecs"
                }
              }
            }
          ],
          "family": "bar",
          "taskRoleArn": "arn:aws:iam::111111111111:role/assume-ecs-role",
          "executionRoleArn": "arn:aws:iam::111111111111:role/ecs-task-execution-role",
          "networkMode": "bridge",
          "volumes": [],
          "placementConstraints": [],
          "requiresCompatibilities": [
            "EC2"
          ]
        }
      }
    ],
    "identifier": 71902380
  },
  {
    "context": [
      "I have a jq filter that selects the rows I need. But sometimes these lines can be empty, and then everything breaks and the rule does not work.",
      "This is caused by the missing `any` key inside the `match` object.",
      "We can 'catch' that error using a `?` ([docs][1]):",
      "This should work :",
      ".metadata.namespace as $ns | ((.spec.rules[0].match | .. | (objects | .resources.kinds[]?)) / \"/\") | [select(.[1])[0] // null, select(.[2])[1] // null, last] as [$version,$group,$kind] | {namespace: $ns, kind: $kind, group: $version, version: $group} | with_entries(select(.value!=null))"
    ],
    "utterance": "Extract namespace, kind, group, and version from the first rule, handling missing or empty fields, and omit null values in the output.",
    "expressions": [
      ".metadata.namespace as $ns | ((.spec.rules[0].match | .. | (objects | .resources.kinds[]?)) / \"/\") | [select(.[1])[0] // null, select(.[2])[1] // null, last] as [$version,$group,$kind] | {namespace: $ns, kind: $kind, group: $version, version: $group} | with_entries(select(.value!=null))"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "kyverno.io/v1",
          "kind": "posdfsdf",
          "metadata": {
            "name": "e-eion",
            "namespace": "kke",
            "annotations": {
              "policies.kyverno.io/title": "Dation",
              "policies.kyverno.io/category": "Pod Security Standards (Restricted)",
              "policies.kyverno.io/severity": "medium",
              "policies.kyverno.io/subject": "Pod",
              "kyverno.io/kyverno-version": "1.6.0",
              "kyverno.io/kubernetes-version": "1.22-1.23",
              "policies.kyverno.io/description": "se`."
            }
          },
          "spec": {
            "validationFailureAction": "audit",
            "background": true,
            "rules": [
              {
                "name": "tion",
                "match": {
                  "any": [
                    {
                      "resources": {
                        "kinds": [
                          "Pod"
                        ]
                      }
                    }
                  ]
                },
                "validate": {
                  "message": "Prisd",
                  "pattern": {
                    "spec": {
                      "=(eners)": [
                        {
                          "secxt": {
                            "altion": "false"
                          }
                        }
                      ],
                      "=(i)": [
                        {
                          "sext": {
                            "alcalation": "false"
                          }
                        }
                      ],
                      "containers": [
                        {
                          "setext": {
                            "an": "false"
                          }
                        }
                      ]
                    }
                  }
                }
              }
            ]
          }
        },
        "output": {
          "namespace": "kke",
          "kind": "Pod"
        }
      },
      {
        "input": {
          "apiVersion": "k/v1",
          "kind": "Picy",
          "metadata": {
            "name": "denylation",
            "namespace": "what"
          },
          "spec": {
            "validationFailureAction": "audit",
            "background": true,
            "rules": [
              {
                "name": "deny-privilege-escalation",
                "match": {
                  "resources": {
                    "kinds": [
                      "Pod"
                    ]
                  }
                },
                "validate": {
                  "message": "Priviles[*].securityContext.allowPrind spec.initContalse`.",
                  "pattern": {
                    "spec": {
                      "=(iners)": [
                        {
                          "=(seext)": {
                            "=(aln)": "false"
                          }
                        }
                      ],
                      "containers": [
                        {
                          "=(stext)": {
                            "=(al)": "false"
                          }
                        }
                      ]
                    }
                  }
                }
              }
            ]
          }
        },
        "output": {
          "namespace": "what",
          "kind": "Pod"
        }
      }
    ],
    "identifier": 71953173
  },
  {
    "context": [
      "The output I'm after:\n\n```\n[...]\n  \"x-ourtime8-16\": 0,\n  \"zone-disallowed-notify\": 0,\n  \"response-by-qtype.A\": 8958,\n  \"response-by-qtype.NS\": 6,\n[...]\n```",
      "To transform this input :\n\n```\n{\n  \"x-ourtime8-16\": \"0\",\n  \"zone-disallowed-notify\": \"0\",\n  \"response-by-qtype\": [\n    {\n      \"name\": \"A\",\n      \"value\": \"8958\"\n    },\n    {\n      \"name\": \"NS\",\n      \"value\": \"6\"\n    }\n  ]\n}\n```",
      "You can run :\n\n```\njq ' to_entries |\n     map(if (.value | type) == \"string\"\n         then .value |= tonumber\n         else .key as $key | .value[] |\n              .name  |= $key+\".\"+.\n              .value |= tonumber\n         end\n     ) | from_entries\n' input.json\n```\n\nto get :\n\n```\n{\n  \"x-ourtime8-16\": 0,\n  \"zone-disallowed-notify\": 0,\n  \"response-by-qtype.A\": 8958,\n  \"response-by-qtype.NS\": 6\n}\n```"
    ],
    "utterance": "Convert all numeric string values to numbers, and flatten arrays of objects with 'name'/'value' pairs so that each becomes a key with dot notation combining the parent key and the object's 'name', mapping to the converted number value.",
    "expressions": [
      "to_entries |\n  map(\n    if (.value | type) == \"string\"\n      then .value |= tonumber\n      else [.key as $key | .value[] | {key: ($key + \".\" + .name), value: (.value | tonumber)}]\n    end\n  ) |\n  flatten | from_entries"
    ],
    "data": [
      {
        "input": {
          "x-ourtime8-16": "0",
          "zone-disallowed-notify": "0",
          "response-by-qtype": [
            {
              "name": "A",
              "value": "8958"
            },
            {
              "name": "NS",
              "value": "6"
            }
          ]
        },
        "output": {
          "x-ourtime8-16": 0,
          "zone-disallowed-notify": 0,
          "response-by-qtype.A": 8958,
          "response-by-qtype.NS": 6
        }
      }
    ],
    "identifier": 71957944
  },
  {
    "context": [
      "Now try the below command to get the id and name in one line but duplicate results are coming.",
      "how do I get rid of those duplicated values and basically get the below response?",
      "With `.[].name + \" \" + .[].id'` you iterate twice over the array. Iterate once and extract your data in one go:",
      "curl \u2026 | jq -r '.data[] | .name + \" \" + .id'",
      "You might also be interested in using string interpolation:",
      "curl \u2026 | jq -r '.data[] | \"\\(.name) \\(.id)\"'"
    ],
    "utterance": "Return each element's name and id, separated by a space, with one line per element.",
    "expressions": [
      ".data[] | .name + \" \" + .id",
      ".data[] | \"\\(.name) \\(.id)\""
    ],
    "data": [
      {
        "input": [
          {
            "id": "8a70803f8045722601804f62d54c5d9d",
            "createdBy": "8a70802980325cdc0180326b5fe60006",
            "createdDate": "2022-04-22T03:48:38.860+0000",
            "modifiedBy": "8a70802980325cdc0180326b5fe60006",
            "modifiedDate": "2022-04-22T03:48:38.860+0000",
            "version": null,
            "inactive": false,
            "name": "Netbank734113"
          },
          {
            "id": "8a70801c804568ae01804f625a923f8d",
            "createdBy": "8a70802980325cdc0180326b5fe60006",
            "createdDate": "2022-04-22T03:48:07.442+0000",
            "modifiedBy": "8a70802980325cdc0180326b5fe60006",
            "modifiedDate": "2022-04-22T03:48:07.442+0000",
            "version": null,
            "inactive": false,
            "name": "Netbank734112"
          }
        ],
        "output": [
          "Netbank734113 8a70803f8045722601804f62d54c5d9d",
          "Netbank734112 8a70801c804568ae01804f625a923f8d"
        ]
      }
    ],
    "identifier": 71963736
  },
  {
    "context": [
      "I have a json file named \"input.json\":\n```\n{\n  \"item1\": \"banana\",\n  \"item2\": false\n}\n```",
      "I have a bash command that takes in a json input, which then takes in the hash of the above file content as the value for the \"input\" key:",
      "How can I pass the json content from input.json file into the command?",
      "Create the one-line json hash from the input.json with `jq -c . input.json`",
      "json=$(jq -cn --arg b64 \"$base\" '{\"input\": $b64, \"option1\": \"value1\", \"option2\": \"value2\" }')"
    ],
    "utterance": "Construct a JSON object where the value of the 'input' key is the content of input.json, along with 'option1' and 'option2' set to 'value1' and 'value2'.",
    "expressions": [
      "jq -c . input.json",
      "jq -cn --argjson input \"$(jq . input.json)\" '{\"input\": $input, \"option1\": \"value1\", \"option2\": \"value2\"}'"
    ],
    "data": [
      {
        "input": {
          "item1": "banana",
          "item2": false
        },
        "output": {
          "input": {
            "item1": "banana",
            "item2": false
          },
          "option1": "value1",
          "option2": "value2"
        }
      }
    ],
    "identifier": 71971599
  },
  {
    "context": [
      "I want my response will be in 1 row regarding each volume.",
      "I want to check if the volume has the tag \"Name\" if so I want the value, otherwise the tags are not interest me.",
      "Use the -c option.",
      "Use a query of the form `select(any(Tags[]; CONDITION))`",
      "jq -c '.Volumes[] | {State, VolumeId, Tags} | select(any(.Tags[]; .Key == \"Name\"))'"
    ],
    "utterance": "Return each volume's State, VolumeId, and Tags on a single line only if the volume contains a tag with Key equal to \"Name\".",
    "expressions": [
      "jq -c '.Volumes[] | {State, VolumeId, Tags} | select(any(.Tags[]; .Key == \"Name\"))'"
    ],
    "identifier": 71990152
  },
  {
    "context": [
      "Specifically I want to check to make sure they are not using plain resource blocks in thier config as opposed to module blocks",
      "each address should start with `module`",
      "cat output.json| jq -r \".resource_changes[].address\""
    ],
    "utterance": "Extract resource addresses from the plan output that do not start with 'module'.",
    "expressions": [
      ".resource_changes[].address | select(startswith(\"module.\") | not)"
    ],
    "identifier": 72002210
  },
  {
    "context": [
      "Now I want to get the value of the ready and the message object from the above response and loop it until the value of ready is true.",
      "type jenkins.json | jq -r \".value.message\" | find \"Selenium Grid ready.\"",
      "After this the errorlevel will be 1 when the text \"Selenium Grid ready.\" is not found, and 0 when it is found."
    ],
    "utterance": "Extract the values of 'ready' and 'message' from the HTTP response under 'value'.",
    "expressions": [
      ".value.ready",
      ".value.message"
    ],
    "data": [
      {
        "input": {
          "value": {
            "ready": true,
            "message": "Selenium Grid ready.",
            "nodes": [
              {
                "id": "5150c3b9-9bc2-45ad-9605-21c1c4ed90e4",
                "uri": "http:\\/\\/172.27.0.3:5555",
                "maxSessions": 4,
                "osInfo": {
                  "arch": "amd64",
                  "name": "Linux",
                  "version": "5.10.16.3-microsoft-standard-WSL2"
                },
                "heartbeatPeriod": 60000,
                "availability": "UP",
                "version": "4.1.3 (revision 7b1ebf28ef)"
              }
            ]
          }
        },
        "output": {
          "ready": true,
          "message": "Selenium Grid ready."
        }
      }
    ],
    "identifier": 71978606
  },
  {
    "context": [
      "With JSON:\r\n\r\n    [\r\n        {\r\n            \"key\": \"1\",\r\n            \"value\": \"one\"\r\n        },\r\n        {\r\n            \"key\": \"2\",\r\n            \"value\": \"two\"\r\n        }\r\n    ]",
      "How do I use select() in a way that doesn't affect . ?  Or better put, what is the correct way to accomplish what I am looking for:\r\n\r\n    {\r\n      \"one\": \"one\",\r\n      \"two\": \"two\"\r\n    }",
      "The solution is:\r\n\r\n    .|{ one: (.[]|select(.key==\"1\").value), two: (.[]|select(.key==\"2\").value) }",
      "The *correct way* in this case is:\r\n```\r\nfrom_entries | {one: .\"1\", two: .\"2\"}\r\n```"
    ],
    "utterance": "Return an object with fields 'one' and 'two', whose values are the 'value' fields for objects in the array where 'key' is '1' and '2', respectively.",
    "expressions": [
      ".|{ one: (.[]|select(.key==\"1\").value), two: (.[]|select(.key==\"2\").value) }",
      "from_entries | {one: .\"1\", two: .\"2\"}"
    ],
    "data": [
      {
        "input": [
          {
            "key": "1",
            "value": "one"
          },
          {
            "key": "2",
            "value": "two"
          }
        ],
        "output": {
          "one": "one",
          "two": "two"
        }
      }
    ],
    "identifier": 71974388
  },
  {
    "context": [
      "I would like the file name to be the data contained in the first field of the output file.",
      "Each output file looks something like this:\n\n    {\n      \"name\": \"Bob Smith\",\n      \"description\": \"(some descriptive text)\",\n      \"image\": \"(link to an image file)\",\n      ...\n    }",
      "I have spent several hours trying to figure out how to get the output file names to be \"Bob Smith.json\", \"Jane Doe.json\" etc., instead of \"0.json\", \"1.json\", etc.",
      "you could use the following pipeline:\n\n```\njq -cr '.[] | \"\\(.name)\\t\\(.)\"' input.json |\n  awk -F\\t '{ print $2 >> \"/tmp/\" $1 \".json\" }' \n```"
    ],
    "utterance": "Write each object to a separate file named after the value of its \"name\" field.",
    "expressions": [
      ".[] | \"\\(.name)\\t\\(.)\""
    ],
    "data": [
      {
        "input": {
          "item1": {
            "name": "Bob Smith",
            "description": "some descriptive text",
            "image": "link to an image file"
          },
          "item2": {
            "name": "Jane Doe",
            "description": "another description",
            "image": "another image link"
          }
        }
      }
    ],
    "identifier": 71993824
  },
  {
    "context": [
      "Is there a way of compressing the output of arrays that contain only ints or strings?",
      "either do not display elements of these arrays, or",
      "show type of elements and count",
      "Of course the compression should happen anywhere in the json tree and it should only be done for int, str, float and not for objects.",
      "This will do it:",
      "def compress:\n  if type == \"array\"\n  then (if    all(.[]; type == \"string\") then \"[string]\"\n        elif  all(.[]; type == \"number\") then \"[number]\"\n        elif  all(.[]; type == \"boolean\") then \"[boolean]\"\n\t    else .\n\t    end)\n  else .\n  end;\nwalk(compress)",
      "To include the length and handle arrays of `null`:\ndef compress:\n  def check($t):\n    if all(.[]; type == $t) then \"[\\($t)[\\(length)]]\" else empty end;\n  if type == \"array\"\n  then check(\"string\") // check(\"number\") // check(\"boolean\") // check(\"null\") // .\n  else .\n  end;"
    ],
    "utterance": "Replace all arrays of only strings, numbers, booleans, or nulls anywhere in the data with a string showing only their type, or with their type and element count.",
    "expressions": [
      "def compress:\n  if type == \"array\"\n  then (if    all(.[]; type == \"string\") then \"[string]\"\n        elif  all(.[]; type == \"number\") then \"[number]\"\n        elif  all(.[]; type == \"boolean\") then \"[boolean]\"\n\t    else .\n\t    end)\n  else .\n  end;\nwalk(compress)",
      "def compress:\n  def check($t):\n    if all(.[]; type == $t) then \"[\\($t)[\\(length)]]\" else empty end;\n  if type == \"array\"\n  then check(\"string\") // check(\"number\") // check(\"boolean\") // check(\"null\") // .\n  else .\n  end;\nwalk(compress)"
    ],
    "data": [
      {
        "input": {
          "version": [
            "2.53.0",
            "2.53.0",
            "2.53.0",
            "2.53.0",
            "2.53.0",
            "2.53.3",
            "2.53.3",
            "2.53.0",
            "2.53.0",
            "2.53.3",
            "2.53.0",
            "2.53.0",
            "2.53.3",
            "2.53.0",
            "2.53.0",
            "2.53.0",
            "2.53.0",
            "2.53.0",
            "2.53.3",
            "2.53.0"
          ],
          "walltime_seconds": [
            0.165,
            0.199,
            0.415,
            0.193,
            12.114,
            0.227,
            12.341,
            12.145,
            0.135,
            0.326,
            0.293,
            0.19,
            0.271,
            0.103,
            0.196,
            0.18,
            0.177,
            0.166,
            0.506,
            0.568
          ]
        },
        "output": {
          "version": "[string]",
          "walltime_seconds": "[number]"
        }
      }
    ],
    "identifier": 71971940
  },
  {
    "context": [
      "just need to put it together with another data.",
      "Simply add the root path with the `.Tags` and delete it afterwards. You could use a temporary variable as well i.e. `.Tags as $v | del(.Tags) | . + $v`",
      "jq '. + .Tags | del(.Tags)'",
      "The simplest solution would be",
      "jq 'del(.Tags) + .Tags'",
      "{ \"Id\": \"i-0e27418e091ea97a7\", \"Name\": \"php\" }",
      "{ \"Id\": \"i-0b0a0cb6223701cb5\", \"Name\": \"Main\", \"q\": \"ngix\" }"
    ],
    "utterance": "Move all fields from the Tags property to the root of each object and remove the original Tags property, retaining all other fields.",
    "expressions": [
      ". + .Tags | del(.Tags)",
      "del(.Tags) + .Tags"
    ],
    "data": [
      {
        "input": {
          "Id": "i-0e27418e091ea97a7",
          "Tags": {
            "Name": "php"
          }
        },
        "output": {
          "Id": "i-0e27418e091ea97a7",
          "Name": "php"
        }
      },
      {
        "input": {
          "Id": "i-0b0a0cb6223701cb5",
          "Tags": {
            "Name": "Main",
            "q": "ngix"
          }
        },
        "output": {
          "Id": "i-0b0a0cb6223701cb5",
          "Name": "Main",
          "q": "ngix"
        }
      }
    ],
    "identifier": 71999637
  },
  {
    "context": [
      "Using `jq`, `keys_unsorted[0]` will give you the first key, and `--arg` lets you import values from outside.",
      "jq -r 'keys_unsorted[0]' input.json | while read -r animalVariableHere",
      "jq --arg a \"$animal\" '$a + \": \" + (.info | join(\", \"))' "
    ],
    "utterance": "Extract the first key from each object and output a string with the key followed by the joined values from its corresponding info array, separated by commas.",
    "expressions": [
      "jq -r 'keys_unsorted[0]' input.json",
      "jq --arg a \"$animal\" '$a + \": \" + (.info | join(\", \"))'"
    ],
    "data": [
      {
        "input": {
          "type": "animal",
          "info": [
            "house pet",
            "furry",
            "brown"
          ]
        },
        "output": "cat: house pet, furry, brown"
      }
    ],
    "identifier": 72006256
  },
  {
    "context": [
      "How can I programmatically remove this comma after each JSON record, or otherwise format this json to be parsed correctly?",
      "Using `jq`, read in the whole file as raw text using the `-R` option, receive it as one long string using the `-s` option, wrap that string in brackets and use `fromjson` to decode it from JSON. You should now have a valid array.",
      "jq -Rs '[\\(.)]' | fromjson myfile.json",
      "Use `.[]` to have individual items (without commas in between):",
      "jq -Rs '[\\(.)]' | fromjson[] myfile.json"
    ],
    "utterance": "Convert multi-line text containing comma-separated JSON objects into a valid array for querying, removing the problematic commas between objects.",
    "expressions": [
      "jq -Rs '[\\(.)]' | fromjson",
      "jq -Rs '[\\(.)]' | fromjson[]"
    ],
    "data": [
      {
        "input": "{\n    \"id\": \"01\",\n    \"Variables\": [\n        {\n            \"Name\": \"myvar\",\n            \"Value\": \"15\"\n        }\n    ]\n},\n{\n    \"id\": \"01\",\n    \"Variables\": [\n        {\n            \"Name\": \"myvar\",\n            \"Value\": \"15\"\n        }\n    ]\n}\n",
        "output": [
          {
            "id": "01",
            "Variables": [
              {
                "Name": "myvar",
                "Value": "15"
              }
            ]
          },
          {
            "id": "01",
            "Variables": [
              {
                "Name": "myvar",
                "Value": "15"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 72003765
  },
  {
    "context": [
      "I have one associative array of mapping parameter name to some internal name (see process.sh)",
      "cannot find a way to use the associative array `sshMap` inside jq map, to transform the parameter name from json into the mapped alias from sshMap.",
      "You&#39;re trying to access a shell var from jq.",
      "ssm_map=' {\n   \"some_great_key\": \"theGreatKEYAlias\",\n   \"api_magic\":      \"apiKey\"\n }'",
      "jq -r --argjson ssm_map \"$ssm_map\" '\n   .Parameters[] |\n   \"ssm_\\( $ssm_map[ .Name ] ): \\\"\\( .Value )\\\"\"'",
      "\"ssm_theGreatKEYAlias: magicvaluenotrelevant\nssm_apiKey: blabla\""
    ],
    "utterance": "For each object, output a line with the value from the mapping keyed by the object's Name as an alias, prefixed by 'ssm_', followed by ':', a space, and the object's Value in double quotes.",
    "expressions": [
      ".Parameters[] | \"ssm_\\($ssm_map[.Name]): \\\"\\(.Value)\\\"\""
    ],
    "data": [
      {
        "input": {
          "Parameters": [
            {
              "Name": "some_great_key",
              "Value": "magicvaluenotrelevant"
            },
            {
              "Name": "api_magic",
              "Value": "blabla"
            }
          ]
        },
        "output": "ssm_theGreatKEYAlias: \"magicvaluenotrelevant\"\nssm_apiKey: \"blabla\""
      }
    ],
    "identifier": 72002421
  },
  {
    "context": [
      "I\u2019m parsing below `JSON` using `jq` in my shell script, but I\u2019m getting `null` while parsing this field `config.subtype`.",
      "And I want to check if `config.subtype` value is `mobile`, I want to update the value as `1000` for this field `config.price` and print the complete JSON.",
      "Please find my code below:",
      "{ \"name\": \"myapp\", \"product\": { \"config.type\": \"electronics\", \"config.count\": \"5\", \"config.subtype\": \"mobile\", \"config.price\": \"\" } }"
    ],
    "utterance": "If the product's config.subtype value is mobile, update product.config.price to 1000 and print the entire object.",
    "expressions": [
      ". as $in | if .product[\"config.subtype\"] == \"mobile\" then .product[\"config.price\"] = 1000 | $in else $in end"
    ],
    "data": [
      {
        "input": {
          "name": "myapp",
          "product": {
            "config.type": "electronics",
            "config.count": "5",
            "config.subtype": "mobile",
            "config.price": ""
          }
        },
        "output": {
          "name": "myapp",
          "product": {
            "config.type": "electronics",
            "config.count": "5",
            "config.subtype": "mobile",
            "config.price": 1000
          }
        }
      }
    ],
    "identifier": 72007371
  },
  {
    "context": [
      "I can construct two expressions, `A` and `B`, which seem to produce the same output. And yet, when I surround them with `[]` array construction braces (as in `[A]` and `[B]`), they produce different output.",
      "$ echo '[1,2] [3,4]' | jq '. | add'",
      "3",
      "7",
      "$ echo '[1,2] [3,4]' | jq '[. | add]'",
      "[3]",
      "[7]",
      "$ echo '[1,2] [3,4]' | jq -s '[.[] | add]'",
      "[3,7]",
      "When `jq` is given the `--slurp` option, it combines the stream to an array, rendering it just one input. Therefore `jq -s '[.[] | add]'` will have one result only; the multiple additions will be caught by the array constructor, which is executed just once."
    ],
    "utterance": "Sum corresponding elements of each input array and collect all sums into a single array.",
    "expressions": [
      "[.[] | add]"
    ],
    "data": [
      {
        "input": [
          [
            1,
            2
          ],
          [
            3,
            4
          ]
        ],
        "output": [
          3,
          7
        ]
      }
    ],
    "identifier": 72019546
  },
  {
    "context": [
      "I want to read each value of csv and treat the input in jq query where $1 is mentioned.",
      "desired output:\nTest2 | 3389 | Linetest | Line is tested1 | Line is tested2 | Line is tested3",
      "jq -sr --rawfile lineArr line.csv '\n    (\n        $lineArr | split(\"\\n\") | del(.[-1]) | .[] | split(\",\")\n    ) as [$lineNum,$prefix] |\n    .[] | select(.scan.line == ($lineNum | tonumber)) |\n    [\n        $prefix,\n        .scan.line,\n        .scan.service,\n        .scan.comment_1,\n        .scan.comment_2,\n        .scan.comment_3\n    ] |\n    join(\" | \")\n' linescan.json",
      "jq -sr --slurpfile lineArr <(jq -R 'split(\",\")' line.csv) '\n    ($lineArr | .[]) as [$lineNum,$prefix] |\n    .[] | select(.scan.line == ($lineNum | tonumber)) |\n    [\n        $prefix,\n        (.scan.line | tostring),\n        .scan.service,\n        .scan.comment_1,\n        .scan.comment_2,\n        .scan.comment_3\n    ] |\n    join(\" | \")\n' linescan.json"
    ],
    "utterance": "Select and output entries where scan.line matches a line number from each row in a two-column CSV file, formatting results to include the prefix, the line number, service, and three comment fields separated by pipes.",
    "expressions": [
      "jq -sr --rawfile lineArr line.csv '\n    (\n        $lineArr | split(\"\\n\") | del(.[-1]) | .[] | split(\",\")\n    ) as [$lineNum,$prefix] |\n    .[] | select(.scan.line == ($lineNum | tonumber)) |\n    [\n        $prefix,\n        .scan.line,\n        .scan.service,\n        .scan.comment_1,\n        .scan.comment_2,\n        .scan.comment_3\n    ] |\n    join(\" | \")\n' linescan.json",
      "jq -sr --slurpfile lineArr <(jq -R 'split(\",\")' line.csv) '\n    ($lineArr | .[]) as [$lineNum,$prefix] |\n    .[] | select(.scan.line == ($lineNum | tonumber)) |\n    [\n        $prefix,\n        (.scan.line | tostring),\n        .scan.service,\n        .scan.comment_1,\n        .scan.comment_2,\n        .scan.comment_3\n    ] |\n    join(\" | \")\n' linescan.json"
    ],
    "data": [
      {
        "input": {
          "csv": "22,Test1\n3389,Test2\n10,Test3\n",
          "json": {
            "scan": {
              "line": 3389,
              "service": "Linetest",
              "comment_1": "Line is tested1",
              "comment_2": "Line is tested2",
              "comment_3": "Line is tested3"
            }
          }
        },
        "output": "Test2 | 3389 | Linetest | Line is tested1 | Line is tested2 | Line is tested3"
      }
    ],
    "identifier": 72005130
  },
  {
    "context": [
      "I want to filter on the \"languages\" field in jq stream so I only retain objects where languages==[\u201cde\u201d], then save it as a new csv file titled largefile.csv such that the new csv file looks like the following:\n\n```\n_id,time,body,percentage_region1,percentage_region2,reach_lower_bound,reach_upper_bound,languages\n\"1\",\"2021-07-22\",\"text1\",\"0.1\",\"0.9\",\"100\",\"200\",\"de\"\n```",
      "jq -rn --stream '\n  fromstream(1|truncate_stream(inputs))\n  | select( .languages == [\"de\"] ) \n  | [._id, .time, .body[0], .region[].percentage,\n     .reach.lower_bound, .reach.upper_bound, .languages[0]]\n  | @csv \n'"
    ],
    "utterance": "Filter input to retain only items where languages equals [\"de\"], then output selected fields as a single-row CSV with columns: _id, time, body, percentage_region1, percentage_region2, reach_lower_bound, reach_upper_bound, languages.",
    "expressions": [
      "jq -rn --stream '\n  fromstream(1|truncate_stream(inputs))\n  | select( .languages == [\"de\"] ) \n  | [._id, .time, .body[0], .region[].percentage,\n     .reach.lower_bound, .reach.upper_bound, .languages[0]]\n  | @csv \n'"
    ],
    "data": [
      {
        "input": [
          {
            "_id": "1",
            "time": "2021-07-22",
            "body": [
              "text1"
            ],
            "region": [
              {
                "percentage": "0.1",
                "region": "region1"
              },
              {
                "percentage": "0.9",
                "region": "region2"
              }
            ],
            "reach": {
              "lower_bound": "100",
              "upper_bound": "200"
            },
            "languages": [
              "de"
            ]
          },
          {
            "_id": "2",
            "time": "2021-07-23",
            "body": [
              "text2"
            ],
            "region": [
              {
                "percentage": "0.3",
                "region": "region1"
              },
              {
                "percentage": "0.7",
                "region": "region2"
              }
            ],
            "reach": {
              "lower_bound": "10",
              "upper_bound": "20"
            },
            "languages": [
              "en"
            ]
          }
        ],
        "output": "\"1\",\"2021-07-22\",\"text1\",\"0.1\",\"0.9\",\"100\",\"200\",\"de\""
      }
    ],
    "identifier": 72018324
  },
  {
    "context": [
      "When echoing message, as output I&#39;ve got\n```\nYou are ${age} years old\n```\nnot\n```\nYou are 22 years old\n```\nIs there some way in this scenario, to replace `${age}` with variable (for bash to know, that there&#39;s variable in there, not just plain string)?",
      "You can do with a single call to `jq` :\n\n```\njq -r '.age as $age|.message|sub(\"\\\\${age}\";$age)' input.json\n```"
    ],
    "utterance": "Replace ${age} with the age value in the message field",
    "expressions": [
      ".age as $age|.message|sub(\"\\\\${age}\";$age)"
    ],
    "data": [
      {
        "input": {
          "age": "22",
          "message": "You are ${age} years old"
        },
        "output": "You are 22 years old"
      }
    ],
    "identifier": 72026254
  },
  {
    "context": [
      "I would like to get all the entries in the array such that the key 3 (\"k3\") doesnt have the subkey \"sk2\".",
      "Note that some of the elements of the array dont have \"k3\" (so I would like to remove those) and then those that have \"k3\" sometimes dont have \"sk2\" (thats the ones I want).",
      "You can use `select` to filter, and `has` to check the keys:",
      "jq 'map(select(has(\"k3\") and (.k3 | has(\"sk2\") | not)))' file.json"
    ],
    "utterance": "Return all objects in the array that have k3 present, and k3 does not have a sk2 subkey.",
    "expressions": [
      "map(select(has(\"k3\") and (.k3 | has(\"sk2\") | not)))"
    ],
    "data": [
      {
        "input": [
          {
            "k1": "a",
            "k2": "aa",
            "k3": {
              "sk1": "a",
              "sk2": "cc",
              "sk3": "cc"
            },
            "k4": {
              "sk6": "zs",
              "sk8": "we"
            }
          },
          {
            "k1": "b",
            "k2": "ba",
            "k3": {
              "sk1": "a",
              "sk3": "cc"
            },
            "k4": {
              "sk6": "zs",
              "sk8": "we"
            }
          },
          {
            "k1": "b",
            "k2": "ba",
            "k4": {
              "sk6": "zs",
              "sk8": "we"
            }
          }
        ],
        "output": [
          {
            "k1": "b",
            "k2": "ba",
            "k3": {
              "sk1": "a",
              "sk3": "cc"
            },
            "k4": {
              "sk6": "zs",
              "sk8": "we"
            }
          }
        ]
      }
    ],
    "identifier": 72021075
  },
  {
    "context": [
      "I am looking to transform a set of rows that are `key value` (space seperated) to JSON.",
      "Anyone know how to go from `{{key}} {{val}}` to `{\"key\": \"value\"}`?",
      "jq -nR '[inputs] | map(split(\"\\\\s+\"; \"\")) | map({(.[0]): .[1]}) | add'",
      "jq -Rn '[inputs | capture(\"(?<key>\\\\S+)\\\\s+(?<value>.+)\")] | from_entries'",
      "jq -Rn 'reduce (inputs | [splits(\"\\\\s+\")]) as [$k,$v] ({}; .[$k] = $v)'",
      "jq -Rn '[inputs | [splits(\"\\\\s+\")] as [$k, $v] | {($k): $v}] | add'"
    ],
    "utterance": "Convert lines containing a key and value separated by whitespace into a single object mapping each key to its value as a string.",
    "expressions": [
      "jq -nR '[inputs] | map(split(\"\\s+\"; \"\")) | map({(.[0]): .[1]}) | add'",
      "jq -Rn '[inputs | capture(\"(?<key>\\S+)\\s+(?<value>.+)\")] | from_entries'",
      "jq -Rn 'reduce (inputs | [splits(\"\\s+\")]) as [$k,$v] ({}; .[$k] = $v)'",
      "jq -Rn '[inputs | [splits(\"\\s+\")] as [$k, $v] | {($k): $v}] | add'"
    ],
    "data": [
      {
        "input": "local.location.altitude   3.0\nlocal.location.latitude   40.025495\nlocal.location.longitude  -74.312501\nlocal.orientation.pitch   0.0\nlocal.orientation.roll    0.0\nlocal.orientation.yaw     0.0\nlocal.velocity.azimuth    0.0\nlocal.velocity.elevation  0.0\nlocal.velocity.magnitude  0.0",
        "output": {
          "local.location.altitude": "3.0",
          "local.location.latitude": "40.025495",
          "local.location.longitude": "-74.312501",
          "local.orientation.pitch": "0.0",
          "local.orientation.roll": "0.0",
          "local.orientation.yaw": "0.0",
          "local.velocity.azimuth": "0.0",
          "local.velocity.elevation": "0.0",
          "local.velocity.magnitude": "0.0"
        }
      }
    ],
    "identifier": 72022313
  },
  {
    "context": [
      "I want my response will include the just the tag `\"Name\"` and it's value.",
      "If the tag \"Name\" does not exist , I want in my response just the `\"State\"`,`\"VolumeId\"`.",
      "This can be achieved using an `if` statement:",
      "jq -c '.Volumes[] | {State, VolumeId} + (\n  {Tags: (.Tags | map(select(.Key == \"Name\")))} | if .Tags == [] then {} else . end\n)'",
      "{ \"State\":\"available\",\"VolumeId\":\"vol-094c79bc5e641bd7e\",\"Tags\":[{\"Key\":\"Name\",\"Value\":\"Adi\"}]}",
      "{ \"State\":\"available\",\"VolumeId\":\"vol-041485dd7394bbdd7\"}"
    ],
    "utterance": "Return 'State' and 'VolumeId' for each volume, and include 'Tags' with only elements where 'Key' is 'Name' if present; omit 'Tags' field if no such tag exists.",
    "expressions": [
      ".Volumes[] | {State, VolumeId} + ( {Tags: (.Tags | map(select(.Key == \"Name\")))} | if .Tags == [] then {} else . end )"
    ],
    "data": [
      {
        "input": {
          "Volumes": [
            {
              "State": "available",
              "VolumeId": "vol-094c79bc5e641bd7e",
              "Tags": [
                {
                  "Key": "Name",
                  "Value": "Adi"
                },
                {
                  "Key": "Team",
                  "Value": "SRE"
                }
              ]
            },
            {
              "State": "available",
              "VolumeId": "vol-041485dd7394bbdd7",
              "Tags": [
                {
                  "Key": "Team",
                  "Value": "SRE"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "State": "available",
            "VolumeId": "vol-094c79bc5e641bd7e",
            "Tags": [
              {
                "Key": "Name",
                "Value": "Adi"
              }
            ]
          },
          {
            "State": "available",
            "VolumeId": "vol-041485dd7394bbdd7"
          }
        ]
      }
    ],
    "identifier": 72026184
  },
  {
    "context": [
      "There are multiple objects in the `.ratings[]` that I would like to extract.",
      "How can I use the pipe operator in the `.ratings[]` array so that I don't have to retype `.ratings[]` for each piece of data that I would like to pull?",
      "You can enclose it in `()` to use the pipe sign:\r\n```none\r\n.players[] | [.firstName, .lastName, .tid, .pid, (.ratings[] | .spd, .jmp)] | join(\", \")\r\n```",
      "A different solution will print one line per rating, but duplicate the players' names. Running:\r\n\r\n```\r\n.players[] | [.firstName,.lastName,.tid,.pid] + (.ratings[]|[.spd,.jmp]) | join(\", \")\r\n```"
    ],
    "utterance": "List each player's firstName, lastName, tid, pid, and all spd and jmp values from every rating, joining all values with a comma and a space.",
    "expressions": [
      ".players[] | [.firstName, .lastName, .tid, .pid, (.ratings[] | .spd, .jmp)] | join(\", \")",
      ".players[] | [.firstName,.lastName,.tid,.pid] + (.ratings[]|[.spd,.jmp]) | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "players": [
            {
              "firstName": "fname1",
              "lastName": "lname1",
              "tid": "tid1",
              "pid": "pid1",
              "ratings": [
                {
                  "spd": "spd1-1",
                  "jmp": "jmp1-1"
                }
              ]
            },
            {
              "firstName": "fname2",
              "lastName": "lname2",
              "tid": "tid2",
              "pid": "pid2",
              "ratings": [
                {
                  "spd": "spd2-1",
                  "jmp": "jmp2-1"
                },
                {
                  "spd": "spd2-2",
                  "jmp": "jmp2-2"
                }
              ]
            },
            {
              "firstName": "fname3",
              "lastName": "lname3",
              "tid": "tid3",
              "pid": "pid3",
              "ratings": [
                {
                  "spd": "spd3-1",
                  "jmp": "jmp3-2"
                },
                {
                  "spd": "spd3-2",
                  "jmp": "jmp3-2"
                },
                {
                  "spd": "spd3-3",
                  "jmp": "jmp3-3"
                }
              ]
            }
          ]
        },
        "output": [
          "fname1, lname1, tid1, pid1, spd1-1, jmp1-1",
          "fname2, lname2, tid2, pid2, spd2-1, jmp2-1, spd2-2, jmp2-2",
          "fname3, lname3, tid3, pid3, spd3-1, jmp3-2, spd3-2, jmp3-2, spd3-3, jmp3-3"
        ]
      },
      {
        "input": {
          "players": [
            {
              "firstName": "fname1",
              "lastName": "lname1",
              "tid": "tid1",
              "pid": "pid1",
              "ratings": [
                {
                  "spd": "spd1-1",
                  "jmp": "jmp1-1"
                }
              ]
            },
            {
              "firstName": "fname2",
              "lastName": "lname2",
              "tid": "tid2",
              "pid": "pid2",
              "ratings": [
                {
                  "spd": "spd2-1",
                  "jmp": "jmp2-1"
                },
                {
                  "spd": "spd2-2",
                  "jmp": "jmp2-2"
                }
              ]
            },
            {
              "firstName": "fname3",
              "lastName": "lname3",
              "tid": "tid3",
              "pid": "pid3",
              "ratings": [
                {
                  "spd": "spd3-1",
                  "jmp": "jmp3-2"
                },
                {
                  "spd": "spd3-2",
                  "jmp": "jmp3-2"
                },
                {
                  "spd": "spd3-3",
                  "jmp": "jmp3-3"
                }
              ]
            }
          ]
        },
        "output": [
          "fname1, lname1, tid1, pid1, spd1-1, jmp1-1",
          "fname2, lname2, tid2, pid2, spd2-1, jmp2-1",
          "fname2, lname2, tid2, pid2, spd2-2, jmp2-2",
          "fname3, lname3, tid3, pid3, spd3-1, jmp3-2",
          "fname3, lname3, tid3, pid3, spd3-2, jmp3-2",
          "fname3, lname3, tid3, pid3, spd3-3, jmp3-3"
        ]
      }
    ],
    "identifier": 72013618
  },
  {
    "context": [
      "I have two files.  The first is a dnsmasq.leases file, text only.  I can read this file using the -R switch.  I have another file, macs.json, this file contains a json dictionary with mac address information in it.  What I'd like to do is read these two files from jq cli using",
      "is there a way to read one raw and the other json at the same time?",
      "You can always read a raw file using the `--rawfile VAR FILENAME` command-line option."
    ],
    "utterance": "Read a text file as a raw string into a variable while also reading a JSON file, so both are available in the same jq program invocation.",
    "expressions": [
      "jq --rawfile leases dnsmasq.leases -f program.jq macs.json"
    ],
    "identifier": 72034333
  },
  {
    "context": [
      "I need to get the public IP address to I can add the node to an inventory file.",
      "$ cat json.json | jq -r '[0].ipv4' | jq -r '[0]'",
      "$ cat json.json | jq -r '[0].ipv4' | jq -r '[1]'",
      "It seems you want:",
      "    jq -r '[0].ipv4[]'",
      "or perhaps:",
      "    jq -r '[].ipv4[]'"
    ],
    "utterance": "Extract all IPv4 addresses from the first cloud instance object in the array.",
    "expressions": [
      ".[0].ipv4[]"
    ],
    "data": [
      {
        "input": [
          {
            "alerts": {
              "cpu": 180,
              "io": 10000,
              "network_in": 10,
              "network_out": 10,
              "transfer_quota": 80
            },
            "backups": {
              "enabled": false,
              "last_successful": null,
              "schedule": {
                "day": null,
                "window": null
              }
            },
            "created": "2022-04",
            "group": "",
            "hypervisor": "kvm",
            "id": 36084613,
            "image": "ubuntu20.04",
            "ipv4": [
              "12.34.56.78",
              "192.168.x.x"
            ],
            "ipv6": "0000::0000/128",
            "label": "node-1",
            "region": "us",
            "specs": {
              "disk": 81920,
              "memory": 4096,
              "transfer": 4000,
              "vcpus": 2
            },
            "status": "running",
            "tags": [],
            "type": "standard",
            "updated": "2022-04",
            "watchdog_enabled": true
          }
        ],
        "output": [
          "12.34.56.78",
          "192.168.x.x"
        ]
      }
    ],
    "identifier": 72030231
  },
  {
    "context": [
      "I wish to match 2 json files based on common id",
      "they contain the common networkId, I only want the output to contain the entries from file2.",
      "file1.json:\n[\n  {\n    \"customerId\": \"id1\",\n    \"networkId\": \"L_653021545945744804\"\n  },\n  {\n    \"customerId\": \"id2\",\n    \"networkId\": \"L_653021545955724805\"\n  },\n  {\n    \"customerId\": \"id3\",\n    \"networkId\": \"L_655051945958724557\"\n  },\n  {\n    \"customerId\": \"id4\",\n    \"networkId\": \"L_655567989968735408\"\n  }\n]",
      "file2.json:\n[\n  {\n    \"name\": \"a\",\n    \"networkId\": \"L_653021545945744804\"\n  },\n  {\n    \"name\": \"b\",\n    \"networkId\": \"L_655051945958724557\"\n  }\n]",
      "Wanted output:\n[\n  {\n    \"customerId\": \"id1\",\n    \"name\": \"a\",\n    \"networkId\": \"L_653021545945744804\"\n  },\n  {\n    \"customerId\": \"id3\",\n    \"name\": \"b\",\n    \"networkId\": \"L_655051945958724557\"\n  }\n]",
      "This is a task for `INDEX`, `JOIN` and `add`:\n~~~sh\njq '[JOIN(INDEX(.networkId); input[]; .networkId; add)]' file1.json file2.json\n~~~"
    ],
    "utterance": "Combine entries from two files by matching networkId, including only records where the networkId exists in both, and merging their respective fields.",
    "expressions": [
      "[JOIN(INDEX(.networkId); input[]; .networkId; add)]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "customerId": "id1",
              "networkId": "L_653021545945744804"
            },
            {
              "customerId": "id2",
              "networkId": "L_653021545955724805"
            },
            {
              "customerId": "id3",
              "networkId": "L_655051945958724557"
            },
            {
              "customerId": "id4",
              "networkId": "L_655567989968735408"
            }
          ],
          [
            {
              "name": "a",
              "networkId": "L_653021545945744804"
            },
            {
              "name": "b",
              "networkId": "L_655051945958724557"
            }
          ]
        ],
        "output": [
          {
            "customerId": "id1",
            "name": "a",
            "networkId": "L_653021545945744804"
          },
          {
            "customerId": "id3",
            "name": "b",
            "networkId": "L_655051945958724557"
          }
        ]
      }
    ],
    "identifier": 72029655
  },
  {
    "context": [
      "Is there a way in Bash or `jq` itself, to stringify the output?",
      "I'm looking for an output that is `\"{\\\"foo\\\" : \\\"bar\\\"}\"`",
      "By \"stringify\", you seem to mean \"encode a JSON value as a JSON string\".",
      "$ echo '{\"foo\": \"bar\"}' | jq '@json'",
      "\"{\\\"foo\\\":\\\"bar\\\"}\""
    ],
    "utterance": "Convert an object to a string representation where all special characters are escaped, producing a single string.",
    "expressions": [
      "@json"
    ],
    "data": [
      {
        "input": {
          "foo": "bar"
        },
        "output": "\"{\\\"foo\\\":\\\"bar\\\"}\""
      }
    ],
    "identifier": 72047144
  },
  {
    "context": [
      "I have a JSON response from a API call as below and would like to write this to CSV file through a shell script.",
      "the CSV file should look something like below",
      "1986,2020-01-27T20:15:30:094Z,2020-02-24T20:15:00:000Z",
      "curl -X GET \\\n    --header 'Authorization: Basic <token>'  \\\n    --header 'Content-Type: application/json'\\\n     \"$url\" | jq -r '[.values[].id, .values[].startDate, .values[].endDate] | @csv ' >> dates.csv"
    ],
    "utterance": "Extract id, startDate, and endDate from each element of the values array and output each row as comma-separated fields.",
    "expressions": [
      ".values[] | [.id, .startDate, .endDate] | @csv"
    ],
    "data": [
      {
        "input": {
          "maxResults": 50,
          "startAt": 0,
          "isLast": true,
          "values": [
            {
              "id": 1986,
              "startDate": "2020-01-27T20:15:30.094Z",
              "endDate": "2020-02-24T20:15:00.000Z"
            },
            {
              "id": 1987,
              "startDate": "2020-02-24T20:48:40.618Z",
              "endDate": "2020-03-15T20:48:00.000Z"
            },
            {
              "id": 1988,
              "startDate": "2020-03-16T17:46:16.846Z",
              "endDate": "2020-04-24T17:46:00.000Z"
            },
            {
              "id": 1989,
              "startDate": "2020-04-20T17:59:30.920Z",
              "endDate": "2020-06-10T17:59:00.000Z"
            }
          ]
        },
        "output": [
          "\"1986\",\"2020-01-27T20:15:30.094Z\",\"2020-02-24T20:15:00.000Z\"",
          "\"1987\",\"2020-02-24T20:48:40.618Z\",\"2020-03-15T20:48:00.000Z\"",
          "\"1988\",\"2020-03-16T17:46:16.846Z\",\"2020-04-24T17:46:00.000Z\"",
          "\"1989\",\"2020-04-20T17:59:30.920Z\",\"2020-06-10T17:59:00.000Z\""
        ]
      }
    ],
    "identifier": 72027372
  },
  {
    "context": [
      "And I'm trying to add values dynamically to the inlines array",
      "I have tried finding solution to use dynamic values in the array but it doesn't expands it.",
      "Solution: Use `+=` on the array, and wrap the new item in brackets (making it another array of one item). This way you can successively populate the existing array.",
      ".body[2].inlines += [{\"type\": \"TextRun\",\"text\": \"Error: Failed Event in Activity Log $c\"}]",
      "jq --arg c \"$cluster\" '.body[2].inlines += [{\"type\": \"TextRun\",\"text\": \"Error: Failed Event in Activity Log $c\"}] | .body[2].inlines += [{\"type\": \"TextRun\",\"text\": \"VMs are in running state\"}] | .body[2].inlines += [{\"type\": \"TextRun\",\"text\": \"VMs are  NOT in running state\"}] | .body[2].inlines += [{\"type\": \"TextRun\",\"text\": \"VMs are OFCOURSE in running state\"}]' data.json",
      "jq --arg c \"$cluster\" '.body[2].inlines += [ {\"type\": \"TextRun\",\"text\": \"Error: Failed Event in Activity Log $c\"}, {\"type\": \"TextRun\",\"text\": \"VMs are in running state\"}, {\"type\": \"TextRun\",\"text\": \"VMs are  NOT in running state\"}, {\"type\": \"TextRun\",\"text\": \"VMs are OFCOURSE in running state\"} ]' data.json"
    ],
    "utterance": "Append multiple TextRun objects with specified text values to the inlines array inside body[2].",
    "expressions": [
      ".body[2].inlines += [{\"type\": \"TextRun\", \"text\": \"Error: Failed Event in Activity Log $c\"}]",
      ".body[2].inlines += [{\"type\": \"TextRun\", \"text\": \"VMs are in running state\"}]",
      ".body[2].inlines += [{\"type\": \"TextRun\", \"text\": \"VMs are  NOT in running state\"}]",
      ".body[2].inlines += [{\"type\": \"TextRun\", \"text\": \"VMs are OFCOURSE in running state\"}]",
      ".body[2].inlines += [ {\"type\": \"TextRun\", \"text\": \"Error: Failed Event in Activity Log $c\"}, {\"type\": \"TextRun\", \"text\": \"VMs are in running state\"}, {\"type\": \"TextRun\", \"text\": \"VMs are  NOT in running state\"}, {\"type\": \"TextRun\", \"text\": \"VMs are OFCOURSE in running state\"} ]"
    ],
    "data": [
      {
        "input": {
          "type": "AdaptiveCard",
          "body": [
            {
              "type": "TextBlock",
              "text": "Monitoring",
              "wrap": true,
              "weight": "bolder",
              "size": "large"
            },
            {
              "type": "TextBlock",
              "text": "23-04-2022 20:00",
              "wrap": true,
              "size": "Small",
              "isSubtle": true
            },
            {
              "type": "RichTextBlock",
              "inlines": []
            }
          ],
          "": "http://adaptivecards.io/schemas/adaptive-card.json",
          "version": "1.5"
        },
        "output": {
          "type": "AdaptiveCard",
          "body": [
            {
              "type": "TextBlock",
              "text": "Monitoring",
              "wrap": true,
              "weight": "bolder",
              "size": "large"
            },
            {
              "type": "TextBlock",
              "text": "23-04-2022 20:00",
              "wrap": true,
              "size": "Small",
              "isSubtle": true
            },
            {
              "type": "RichTextBlock",
              "inlines": [
                {
                  "type": "TextRun",
                  "text": "Error: Failed Event in Activity Log $c"
                },
                {
                  "type": "TextRun",
                  "text": "VMs are in running state"
                },
                {
                  "type": "TextRun",
                  "text": "VMs are  NOT in running state"
                },
                {
                  "type": "TextRun",
                  "text": "VMs are OFCOURSE in running state"
                }
              ]
            }
          ],
          "": "http://adaptivecards.io/schemas/adaptive-card.json",
          "version": "1.5"
        }
      }
    ],
    "identifier": 71990182
  },
  {
    "context": [
      "`IID=$(curl --verbose --request GET --header \"Content-Type: application/json\" --header \"PRIVATE-TOKEN: ${CI_PUSH_TOKEN}\" ${APP_REPO_URL}/merge_requests?author_id=xxxxxxxx\\&search=${CI_COMMIT_SHORT_SHA} | jq '[0].iid')`",
      "output jq: error (at <stdin>:0): Cannot index object with number"
    ],
    "utterance": "Extract the 'iid' value from the first element of the array returned by the API.",
    "expressions": [
      ".[0].iid"
    ],
    "identifier": 72057231
  },
  {
    "context": [
      "I have a list of country codes like FR, IT, DE and have been trying to figure out how to use this in a select statement.",
      "jq -c --argjson eu '[\"FR\", \"IT\"]' '.[]| select(.country_iso3166_alpha2 | IN($eu[]))' <stuff"
    ],
    "utterance": "Filter records where the country_iso3166_alpha2 field matches any code in the list FR, IT.",
    "expressions": [
      ".[] | select(.country_iso3166_alpha2 | IN($eu[]))"
    ],
    "data": [
      {
        "input": [
          {
            "country_iso3166_alpha2": "FR",
            "foo": 1
          },
          {
            "country_iso3166_alpha2": "DE",
            "foo": 2
          },
          {
            "country_iso3166_alpha2": "IT",
            "foo": 3
          },
          {
            "country_iso3166_alpha2": "US",
            "foo": 4
          }
        ],
        "output": [
          {
            "country_iso3166_alpha2": "FR",
            "foo": 1
          },
          {
            "country_iso3166_alpha2": "IT",
            "foo": 3
          }
        ]
      }
    ],
    "identifier": 72048835
  },
  {
    "context": [
      "I would like to use jq to get all the elements where the key `k2` exists and just return the array elements of `k2` that dont have the subkey `\"a2\"`. So for the example above I would like to return\n\n    [\n    {\n    \"k1\":\"n1\",\n    \"k2\":[         \n           {\"a1\":\"v12\",\n            \"a3\":\"v32\",...},\n           \n         ],\n    },\n    ...\n    ]",
      "Filter using `select` and `has`, adjust the output using `map`.\n~~~sh\njq 'map(\n  select(has(\"k2\") and any(.k2[]; has(\"a2\")))\n  | .k2 |= map(select(has(\"a2\") | not))\n)'\n~~~"
    ],
    "utterance": "Return all top-level objects containing key k2, and for each, only include elements of k2 whose subobjects do not have the key a2.",
    "expressions": [
      "map(\n  select(has(\"k2\") and any(.k2[]; has(\"a2\")))\n  | .k2 |= map(select(has(\"a2\") | not))\n)"
    ],
    "data": [
      {
        "input": [
          {
            "k1": "n1",
            "k2": [
              {
                "a1": "v1",
                "a2": [
                  {
                    "b1": "v11"
                  }
                ],
                "a3": "v3"
              },
              {
                "a1": "v12",
                "a3": "v32"
              }
            ]
          },
          {
            "k1": "n2",
            "k2": [
              {
                "a1": "v1",
                "a3": "v3"
              }
            ]
          },
          {
            "k1": "n2",
            "k3": [
              {
                "s1": "v1",
                "s3": "v3"
              }
            ]
          }
        ],
        "output": [
          {
            "k1": "n1",
            "k2": [
              {
                "a1": "v12",
                "a3": "v32"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 72035054
  },
  {
    "context": [
      "I want to remove `,` from a string in jq. Take the following example, how to remove `,` when outputting `1,2`?",
      "To remove one occurrence at any position, use `sub` to replace with the empty string",
      "To remove all occurrences, use `gsub` the same way",
      "But if `12` is indeed what's desired, adding a `join` will do the trick.",
      "You can use `sub`.\n\nFilter\n```\n.x | sub(\",\"; \" \")\n```"
    ],
    "utterance": "Remove all commas from the value of key x in the object {\"x\":\"1,2\"}, resulting in 12.",
    "expressions": [
      ".x | gsub(\",\"; \"\")",
      ".x | sub(\",\"; \"\")",
      ".x | split(\",\") | join(\"\")",
      ".x | .[:1] + .[2:]"
    ],
    "data": [
      {
        "input": {
          "x": "1,2"
        },
        "output": "12"
      }
    ],
    "identifier": 72051857
  },
  {
    "context": [
      "Given the input JSON, how would I use jq to produce the expected output?",
      "Input:",
      "{\n    \"items\": {\n        \"item1\": {\n            \"part1\": {\n                \"a\": {\n                    \"key1\": \"value\",\n                    \"key2\": \"value\"\n                },\n\t\t\t\t\"b\": {\n                    \"key1\": \"value\",\n                    \"key2\": \"value\"\n                }\n\t\t\t},\n\t\t\t\"part2\": {\n                \"c\": {\n                    \"key1\": \"value\",\n                    \"key2\": \"value\"\n                },\n\t\t\t\t\"d\": {\n                    \"key1\": \"value\",\n                    \"key2\": \"value\"\n                }\n\t\t\t}\n\t\t},\n\t\t\"item2\": {\n            \"part3\": {\n                \"e\": {\n                    \"key1\": \"value\",\n                    \"key2\": \"value\"\n                },\n\t\t\t\t\"f\": {\n                    \"key1\": \"value\",\n                    \"key2\": \"value\"\n                }\n\t\t\t},\n\t\t\t\"part4\": {\n                \"g\": {\n                    \"key1\": \"value\",\n                    \"key2\": \"value\"\n                },\n\t\t\t\t\"h\": {\n                    \"key1\": \"value\",\n                    \"key2\": \"value\"\n                }\n\t\t\t}\n\t\t}\n\t}\n}",
      "Expected output:",
      "{\n    \"item1\": [\n\t\t\"part1.a\",\n\t\t\"part1.b\",\n\t\t\"part2.c\",\n\t\t\"part2.d\"\n\t]\n\t\"item2\": [\n\t\t\"part3.e\",\n\t\t\"part3.f\"\n\t\t\"part4.g\",\n\t\t\"part4.h\"\n\t]\n}",
      "Here's one way how you would go two levels deep with the keys sorted alphabetically:",
      "jq '.items | .[] |= [keys[] as $k | $k + \".\" + (.[$k] | keys[])]'",
      "Here's another way how to go down until the second-to-last level:",
      "jq '.items | .[] |= ([path(.. | scalars)[:-1] | join(\".\")] | unique)'",
      "Try this:",
      ".items | map_values([path(.[][]) | join(\".\")])",
      "This would do it:",
      "# Output: a stream\n\ndef keyKey:\n  keys_unsorted[] as $k | $k + \".\" + (.[$k] | keys_unsorted[]);\n\n.items | map_values([keyKey])"
    ],
    "utterance": "For each top-level item, list all two-level-deep object key paths, joined with a dot, representing each leaf.",
    "expressions": [
      ".items | .[] |= [keys[] as $k | $k + \".\" + (.[$k] | keys[])]",
      ".items | .[] |= ([path(.. | scalars)[:-1] | join(\".\")] | unique)",
      ".items | map_values([path(.[][]) | join(\".\")])",
      "def keyKey:\n  keys_unsorted[] as $k | $k + \".\" + (.[$k] | keys_unsorted[]);\n.items | map_values([keyKey])"
    ],
    "data": [
      {
        "input": {
          "items": {
            "item1": {
              "part1": {
                "a": {
                  "key1": "value",
                  "key2": "value"
                },
                "b": {
                  "key1": "value",
                  "key2": "value"
                }
              },
              "part2": {
                "c": {
                  "key1": "value",
                  "key2": "value"
                },
                "d": {
                  "key1": "value",
                  "key2": "value"
                }
              }
            },
            "item2": {
              "part3": {
                "e": {
                  "key1": "value",
                  "key2": "value"
                },
                "f": {
                  "key1": "value",
                  "key2": "value"
                }
              },
              "part4": {
                "g": {
                  "key1": "value",
                  "key2": "value"
                },
                "h": {
                  "key1": "value",
                  "key2": "value"
                }
              }
            }
          }
        },
        "output": {
          "item1": [
            "part1.a",
            "part1.b",
            "part2.c",
            "part2.d"
          ],
          "item2": [
            "part3.e",
            "part3.f",
            "part4.g",
            "part4.h"
          ]
        }
      }
    ],
    "identifier": 72034427
  },
  {
    "context": [
      "I want to use jq to check if a keyword exists as a key in a JSON at any level.",
      "I want to map the output array to jq function `any()` and get an overall result as true if key exists or false if it doesn't.",
      "Provide `any` with an iterator and a condition",
      "jq 'any(paths; .[-1] == \"headline\")'",
      "any(paths[-1]; . == \"headline\")"
    ],
    "utterance": "Check if the key 'headline' exists anywhere in the structure, returning true if present and false if not.",
    "expressions": [
      "any(paths; .[-1] == \"headline\")",
      "any(paths[-1]; . == \"headline\")"
    ],
    "identifier": 72073109
  },
  {
    "context": [
      "How can I **get one step further** which is concat all elements in a single path.",
      "to turn my output from:\r\n\r\n    [\"data\",\"legacyCollection\",\"collectionsPage\",\"stream\",\"edges\",2,\"node\",\"headline\"]\r\n\r\nto \r\n\r\n    '.data.legacyCollection.collectionsPage.stream.edges[2].node'",
      "Remove the last element, prepend a dot to `strings`, wrap `numbers` in brackets, and `join` the array:",
      ".[:-1] | map(strings = \".\\(.)\" | numbers = \"[\\(.)]\") | join(\"\")",
      "\".data.legacyCollection.collectionsPage.stream.edges[0].node\"",
      "\".data.legacyCollection.collectionsPage.stream.edges[1].node\"",
      "\".data.legacyCollection.collectionsPage.stream.edges[2].node\""
    ],
    "utterance": "Convert an array of path elements representing a property ending with 'headline' to a single string-form path, joining keys and using brackets for array indices, omitting the last element.",
    "expressions": [
      ".[:-1] | map(strings = \".\\(.)\" | numbers = \"[\\(.)]\") | join(\"\")"
    ],
    "data": [
      {
        "input": [
          "data",
          "legacyCollection",
          "collectionsPage",
          "stream",
          "edges",
          2,
          "node",
          "headline"
        ],
        "output": ".data.legacyCollection.collectionsPage.stream.edges[2].node"
      },
      {
        "input": [
          "data",
          "legacyCollection",
          "collectionsPage",
          "stream",
          "edges",
          0,
          "node",
          "headline"
        ],
        "output": ".data.legacyCollection.collectionsPage.stream.edges[0].node"
      }
    ],
    "identifier": 72069045
  },
  {
    "context": [
      "export AWS_ACCESS_KEY_ID=$( jq -r '.Credentials.AccessKeyId' <<<$AWS_ASSUMED_ROLE )",
      "export AWS_SECRET_ACCESS_KEY=$( jq -r '.Credentials.SecretAccessKey' <<<$AWS_ASSUMED_ROLE )",
      "export AWS_SESSION_TOKEN=$( jq -r '.Credentials.SessionToken' <<<$AWS_ASSUMED_ROLE )",
      "$AWS_ACCESS_KEY_ID     = $( echo -n @$( echo @(AWS_ASSUMED_ROLE) | jq -r '.Credentials.AccessKeyId') )",
      "$AWS_SECRET_ACCESS_KEY = $( echo -n @$( echo @(AWS_ASSUMED_ROLE) | jq -r '.Credentials.SecretAccessKey' ) )",
      "$AWS_SESSION_TOKEN     = $( echo -n @$( echo @(AWS_ASSUMED_ROLE) | jq -r '.Credentials.SessionToken' ) )"
    ],
    "utterance": "Extract the values of Credentials.AccessKeyId, Credentials.SecretAccessKey, and Credentials.SessionToken from data.",
    "expressions": [
      ".Credentials.AccessKeyId",
      ".Credentials.SecretAccessKey",
      ".Credentials.SessionToken"
    ],
    "data": [
      {
        "input": {
          "Credentials": {
            "AccessKeyId": "AKIA123",
            "SecretAccessKey": "SECRET456",
            "SessionToken": "TOKEN789"
          }
        },
        "output": {
          "AccessKeyId": "AKIA123",
          "SecretAccessKey": "SECRET456",
          "SessionToken": "TOKEN789"
        }
      }
    ],
    "identifier": 72072644
  },
  {
    "context": [
      "Can I select them based on array index ?",
      "like Output[0:2] select just",
      "[\"data\",\"legacyCollection\",\"collectionsPage\",\"stream\",\"edges\",0,\"node\",\"headline\"]",
      "[\"data\",\"legacyCollection\",\"collectionsPage\",\"stream\",\"edges\",1,\"node\",\"headline\"]",
      "[\"data\",\"legacyCollection\",\"collectionsPage\",\"stream\",\"edges\",2,\"node\",\"headline\"]",
      "Or Output[-1] select just",
      "[\"data\",\"legacyCollection\",\"headline\"]",
      "I tried command below , but that seems not to be what I want, it just sliced each path I got, rather than select subset of all paths returned:",
      "jq -c 'paths | select(.[-1] == \"headline\")[:3]' nytimeseuro.json",
      "[paths | select(.[-1] == \"headline\")][0:2]"
    ],
    "utterance": "Retrieve only a specific range, such as the first three or last matching, of the paths where the last element equals 'headline'.",
    "expressions": [
      "[paths | select(.[-1] == \"headline\")][0:3]",
      "[paths | select(.[-1] == \"headline\")][-1:]"
    ],
    "identifier": 72073540
  },
  {
    "context": [
      "\"I want to convert the output `\"key:state\" \"value:pending\" \"key:options\" \"value:request\"` to array `[\"key:state\", \"value:pending\", \"key:options\", \"value:request\"]`.\"",
      "\"I want a solution *without* using `slurp` or `inputs`.\"",
      "One such way could be to manually build a JSON array from already JSON-encoded parts by adding commas and brackets:",
      "In the first instance, encode the items as JSON using `tojson`, and append a comma to each. In the second instance, remove the last character (the superfluous comma), wrap the string in brackets, and decode the ready JSON array using `fromjson`.",
      "~~~sh\r\njq -j '\"key:\\(.key)\", \"value:\\(.value)\" | \"\\(tojson),\"' | jq -R '\"[\\(.[:-1])]\" | fromjson'\r\n~~~",
      "~~~json\r\n[\r\n  \"key:state\",\r\n  \"value:pending\",\r\n  \"key:options\",\r\n  \"value:request\"\r\n]\r\n~~~"
    ],
    "utterance": "Combine multiple separately emitted strings like \"key:state\", \"value:pending\", etc., into a single array containing all those strings, without using slurp or inputs.",
    "expressions": [
      "jq -j '\"key:\\(.key)\", \"value:\\(.value)\" | \"\\(tojson),\"' | jq -R '\"[\\(.[:-1])]\" | fromjson'"
    ],
    "data": [
      {
        "input": [
          {
            "key": "state",
            "value": "pending"
          },
          {
            "key": "options",
            "value": "request"
          }
        ],
        "output": [
          "key:state",
          "value:pending",
          "key:options",
          "value:request"
        ]
      }
    ],
    "identifier": 72073744
  },
  {
    "context": [
      "The `index` field represents the currently-displayed history item per tab. Being 1-indexed, in the example above it represents the \"Foo bar 1\" entry.",
      "**How can I use that value in `jq` to get that tab?**",
      "Just index `entries` by `index` minus one?\n```\n.entries[.index - 1]\n```"
    ],
    "utterance": "Select the entry at the position specified by the 1-based field 'index', i.e., the entry currently displayed in the tab.",
    "expressions": [
      ".entries[.index - 1]"
    ],
    "data": [
      {
        "input": {
          "index": 2,
          "entries": [
            {
              "title": "Foo bar 0",
              "url": "https://example.com/bar"
            },
            {
              "title": "Foo bar 1",
              "url": "https://example.com/bar"
            },
            {
              "title": "Foo bar 2",
              "url": "https://example.com/bar"
            }
          ]
        },
        "output": {
          "title": "Foo bar 1",
          "url": "https://example.com/bar"
        }
      }
    ],
    "identifier": 72076678
  },
  {
    "context": [
      "I have the following input json which I obtain from a curl command and I'm feeding it to jq.",
      "I'm trying to use jq to extract just '14.10.0'.",
      "I have the following jq command but it's just returning \"14.10.0-ee\"",
      "Don\u2019t overcomplicate it ;)",
      ".version|scan(\"^[^-]+\")",
      ".version|split(\"-\")|first",
      ".version/\"-\"|first",
      "jq -r '.version| capture(\"(?<v>[[:digit:].]+)\").v'"
    ],
    "utterance": "Extract the numeric version string before the hyphen from the value of the version property when it contains a suffix such as '-ee'.",
    "expressions": [
      ".version|scan(\"^[^-]+\")",
      ".version|scan(\"^[0-9.]+\")",
      ".version|split(\"-\")|first",
      ".version/\"-\"|first",
      ".version|capture(\"(?<v>[[:digit:].]+)\").v"
    ],
    "data": [
      {
        "input": {
          "version": "14.10.0-ee",
          "revision": "ad109bc62af"
        },
        "output": "14.10.0"
      }
    ],
    "identifier": 72080532
  },
  {
    "context": [
      "I would like to sort it by `\"subscriptionId\"` and `\"serviceName\"`.",
      "You can parameterize `sort_by` by a list of keys like so:",
      "sort_by(.subscriptionId, .subscrCond.serviceName)"
    ],
    "utterance": "Sort the array of objects first by the value of subscriptionId and then by the value of subscrCond.serviceName.",
    "expressions": [
      "sort_by(.subscriptionId, .subscrCond.serviceName)"
    ],
    "data": [
      {
        "input": [
          {
            "nfStatusNotificationUri": "http://172.19.0.2:32672/callback/nnrf-nfm/v1/onNFStatusEventPost/4e0becf9-c3ec-4002-a32b-2e35b76469b2",
            "subscrCond": {
              "serviceName": "namf-evts"
            },
            "subscriptionId": "36bc52dfdbdd4044b97ef15684706205",
            "validityTime": "2022-04-30T16:40:48.274Z",
            "reqNotifEvents": [
              "NF_DEREGISTERED",
              "NF_PROFILE_CHANGED",
              "NF_REGISTERED"
            ]
          },
          {
            "nfStatusNotificationUri": "http://172.19.0.2:32672/callback/nnrf-nfm/v1/onNFStatusEventPost/5319def1-af0b-4b7b-a94e-b787e614c065",
            "subscrCond": {
              "serviceName": "nbsf-management"
            },
            "subscriptionId": "e2e904bb52ca4fd6b048841c83a4c38e",
            "validityTime": "2022-04-30T16:40:48.26Z",
            "reqNotifEvents": [
              "NF_DEREGISTERED",
              "NF_PROFILE_CHANGED",
              "NF_REGISTERED"
            ]
          },
          {
            "nfStatusNotificationUri": "http://172.19.0.2:32672/callback/nnrf-nfm/v1/onNFStatusEventPost/31dfe10b-4020-47bd-943e-a3e293086b29",
            "subscrCond": {
              "serviceName": "namf-comm"
            },
            "subscriptionId": "e508077fab4f4b8d9dd732176a3777b9",
            "validityTime": "2022-04-30T16:40:48.273Z",
            "reqNotifEvents": [
              "NF_DEREGISTERED",
              "NF_PROFILE_CHANGED",
              "NF_REGISTERED"
            ]
          }
        ]
      }
    ],
    "identifier": 72077342
  },
  {
    "context": [
      "I need to extract from it:\r\n```\r\naaaaa\r\nqqqqq\r\n```",
      "the problem is that it takes a very long time because the search continues on through the whole file, instead of stopping immediately after the first match.",
      "Please advise me a way to stop further scouting if an input has already been found. I know that there is a `first(inputs | )`, but I don&#39;t understand how to implements this command.",
      "jq --null-input --raw-output --stream 'label $out | inputs | if .[0][0] == \"0001\" then (if length == 2 then .[1] else break $out end) else empty end' file",
      "jq --stream -n 'first(fromstream(1 | truncate_stream(inputs|select(.[0][0] ==\"0001\"))))[]' input.json"
    ],
    "utterance": "Extract all array values for the key \"0001\" and stop processing as soon as this key is found.",
    "expressions": [
      "jq --null-input --raw-output --stream 'label $out | inputs | if .[0][0] == \"0001\" then (if length == 2 then .[1] else break $out end) else empty end' file",
      "jq --stream -n 'first(fromstream(1 | truncate_stream(inputs|select(.[0][0] ==\"0001\"))))[]' input.json"
    ],
    "data": [
      {
        "input": {
          "0001": [
            "aaaaa",
            "qqqqq"
          ],
          "0002": [
            "aaaaa"
          ],
          "0003": [
            "ccccc"
          ],
          "0004": [
            "bbbbb"
          ]
        },
        "output": [
          "aaaaa",
          "qqqqq"
        ]
      }
    ],
    "identifier": 72099320
  },
  {
    "context": [
      "\"Why is the first line skipped if I remove `echo \\\"prevent remove first line\\\"`?\"",
      "\"find ~/somedir -mindepth 1 -maxdepth 1 -type d | /usr/local/bin/jq -nR \\\n'{\n    \\\"items\\\": [      \n        inputs as $title |                  \n        {\n            \\\"title\\\": $title,\n        }\n    ]\n}'\"",
      "\"PS: As [`pmf`][1] pointed out, the whole solution can be simplified to:\nfind ~/somedir -mindepth 1 -maxdepth 1 -type d \\\n    jq -nR '{items: [{title: inputs}]}'\""
    ],
    "utterance": "Produce an array of objects with property 'title', each containing a directory path found in ~/somedir.",
    "expressions": [
      "{ \"items\": [ inputs as $title | { \"title\": $title } ] }",
      "{items: [{title: inputs}]}"
    ],
    "data": [
      {
        "input": [
          "/home/user/somedir/dir1",
          "/home/user/somedir/dir2"
        ],
        "output": {
          "items": [
            {
              "title": "/home/user/somedir/dir1"
            },
            {
              "title": "/home/user/somedir/dir2"
            }
          ]
        }
      }
    ],
    "identifier": 72110455
  },
  {
    "context": [
      "I have some properties like that.\r\nThere may be some spaces between key and equal.",
      "I wish to convert them to json with jq like that",
      "Using an invocation with the -nR (or -n -R) options, the following generates valid JSON, which you can readily massage (or mangle) into the format you want:",
      "def trim: sub(\"^ +\";\"\")|sub(\" +$\"; \"\"); ",
      "reduce inputs as $in (null;\n  ($in | capture(\"(?<k>^[^=]*)=(?<v>.*)\" ) | map_values(trim)) as $kv\n  | setpath( $kv.k | split(\".\"); $kv.v) )"
    ],
    "utterance": "Convert property lines with possible spaces around the equals sign, where keys use dot notation, into a nested object with numbers as object keys.",
    "expressions": [
      "def trim: sub(\"^ +\";\"\")|sub(\" +$\"; \"\"); reduce inputs as $in (null; ($in | capture(\"(?<k>^[^=]*)=(?<v>.*)\" ) | map_values(trim)) as $kv | setpath( $kv.k | split(\".\"); $kv.v) )"
    ],
    "data": [
      {
        "input": [
          "    error.code.400                  = Incorrect Request.",
          "    error.code.404                  = Requested resource not available.",
          "    error.code.500                  = Internal server error. It will soon be processed.",
          "    error.msg.1                     = Sorry for the inconvenience.<br />The page you have requested was not normally processed.",
          "    error.msg.2                     = Access Denied. Please contact the administrator."
        ],
        "output": {
          "error": {
            "code": {
              "400": "Incorrect Request.",
              "404": "Requested resource not available.",
              "500": "Internal server error. It will soon be processed."
            },
            "msg": {
              "1": "Sorry for the inconvenience.<br />The page you have requested was not normally processed.",
              "2": "Access Denied. Please contact the administrator."
            }
          }
        }
      }
    ],
    "identifier": 72106960
  },
  {
    "context": [
      "Example input:\n\n```\n[\n  {\n     \"id\": 1,\n     \"a\": \"value-in-a\",\n     \"b\": \"value-in-b\"\n  },\n  {\n     \"id\": 2,\n     \"c\": \"value-in-c\"\n  }\n]\n```",
      "Expected output:\n```\n[\n  {\n     \"id\": \"1\",\n     \"value\": \"value-in-a\"\n  },\n  {\n     \"id\": \"1\",\n     \"value\": \"value-in-b\"\n  },\n  {\n     \"id\": \"2\",\n     \"value\": \"value-in-c\"\n  }\n]\n```",
      "You can iterate over the other keys using `del` and `keys_unsorted`:\n~~~sh\njq 'map({id, value: (del(.id) | .[keys_unsorted[]])})'\n~~~"
    ],
    "utterance": "Transform an array of objects with an 'id' and arbitrary extra fields into an array where each additional field becomes a separate object containing 'id' and 'value'.",
    "expressions": [
      "map({id, value: (del(.id) | .[keys_unsorted[]])})"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "a": "value-in-a",
            "b": "value-in-b"
          },
          {
            "id": 2,
            "c": "value-in-c"
          }
        ],
        "output": [
          {
            "id": 1,
            "value": "value-in-a"
          },
          {
            "id": 1,
            "value": "value-in-b"
          },
          {
            "id": 2,
            "value": "value-in-c"
          }
        ]
      }
    ],
    "identifier": 72119183
  },
  {
    "context": [
      "I am looking to extract the cat facts from this JSON file:",
      "After running `curl 'https://cat-fact.herokuapp.com/facts' | jq '. | {text}'`,\r\n\r\nI get the error `jq: error (at <stdin>:0): Cannot index array with string \"text\"`.",
      "I\u2019d use the array/object value iterator `.[]` and then `[\"text\"]` to filter:",
      "```jq\r\njq '.[][\"text\"]'\r\n```",
      "Giving you example file as input would produce this output:",
      "\"Cats make about 100 different sounds. Dogs make only about 10.\"",
      "\"Domestic cats spend about 70 percent of the day sleeping and 15 percent of the day grooming.\"",
      "\"I don't know anything about cats.\"",
      "\"The technical term for a cat\u2019s hairball is a bezoar.\"",
      "\"Cats are the most popular pet in the United States: There are 88 million pet cats and 74 million dogs.\"",
      "The above is also the exact output you'd (currently) get from:",
      "curl -s 'https://cat-fact.herokuapp.com/facts' | jq '.[][\"text\"]'"
    ],
    "utterance": "Return all values of the 'text' field from every element in the top-level array.",
    "expressions": [
      ".[][\"text\"]"
    ],
    "data": [
      {
        "input": [
          {
            "status": {
              "verified": true,
              "feedback": "",
              "sentCount": 1
            },
            "_id": "5887e1d85c873e0011036889",
            "user": "5a9ac18c7478810ea6c06381",
            "text": "Cats make about 100 different sounds. Dogs make only about 10.",
            "__v": 0,
            "source": "user",
            "updatedAt": "2020-09-03T16:39:39.578Z",
            "type": "cat",
            "createdAt": "2018-01-15T21:20:00.003Z",
            "deleted": false,
            "used": true
          },
          {
            "status": {
              "verified": true,
              "sentCount": 1
            },
            "_id": "588e746706ac2b00110e59ff",
            "user": "588e6e8806ac2b00110e59c3",
            "text": "Domestic cats spend about 70 percent of the day sleeping and 15 percent of the day grooming.",
            "__v": 0,
            "source": "user",
            "updatedAt": "2020-08-26T20:20:02.359Z",
            "type": "cat",
            "createdAt": "2018-01-14T21:20:02.750Z",
            "deleted": false,
            "used": true
          },
          {
            "status": {
              "verified": true,
              "sentCount": 1
            },
            "_id": "58923f2fc3878c0011784c79",
            "user": "5887e9f65c873e001103688d",
            "text": "I don't know anything about cats.",
            "__v": 0,
            "source": "user",
            "updatedAt": "2020-08-23T20:20:01.611Z",
            "type": "cat",
            "createdAt": "2018-02-25T21:20:03.060Z",
            "deleted": false,
            "used": false
          },
          {
            "status": {
              "verified": true,
              "sentCount": 1
            },
            "_id": "5894af975cdc7400113ef7f9",
            "user": "5a9ac18c7478810ea6c06381",
            "text": "The technical term for a cat\u2019s hairball is a bezoar.",
            "__v": 0,
            "source": "user",
            "updatedAt": "2020-11-25T21:20:03.895Z",
            "type": "cat",
            "createdAt": "2018-02-27T21:20:02.854Z",
            "deleted": false,
            "used": true
          },
          {
            "status": {
              "verified": true,
              "sentCount": 1
            },
            "_id": "58e007cc0aac31001185ecf5",
            "user": "58e007480aac31001185ecef",
            "text": "Cats are the most popular pet in the United States: There are 88 million pet cats and 74 million dogs.",
            "__v": 0,
            "source": "user",
            "updatedAt": "2020-08-23T20:20:01.611Z",
            "type": "cat",
            "createdAt": "2018-03-01T21:20:02.713Z",
            "deleted": false,
            "used": false
          }
        ],
        "output": [
          "Cats make about 100 different sounds. Dogs make only about 10.",
          "Domestic cats spend about 70 percent of the day sleeping and 15 percent of the day grooming.",
          "I don't know anything about cats.",
          "The technical term for a cat\u2019s hairball is a bezoar.",
          "Cats are the most popular pet in the United States: There are 88 million pet cats and 74 million dogs."
        ]
      }
    ],
    "identifier": 72050957
  },
  {
    "context": [
      "As the keys inside id1 and id2 are not consistent, im trying to find a way/tool to make sure that the keys are consistant before i use them. also, as the export push the date to as in seconds, im also trying to convert it to a timestamp/string",
      "The final output ideally should be:\r\n\r\n    {\r\n\t\"task\": {\r\n\t\t\"id1\": {\r\n\t\t\t\"completed\": true,\r\n\t\t\t\"title\": \"Testing\",\r\n\t\t\t\"desc\": \"short desc\",\r\n\t\t\t\"status\": \"completed\",\r\n\t\t\t\"dueDate\": \"Wednesday, 2 June 2021 12:15:10.867 GMT+08:00\",\r\n\t\t\t\"citizenID\": \"Uvr0vZqIPON5UZsgJsMYPe2Qfsi2\",\r\n\t\t\t\"datePosted\": \"Wednesday, 2 June 2021 12:16:48.365 GMT+08:00\",\r\n\t\t\t\"genre\": \"Errands\"\r\n\t\t},\r\n\t\t\"id2\": {\r\n\t\t\t\"completed\": true,\r\n\t\t\t\"title\": \"Testing 2\",\r\n\t\t\t\"desc\": \"\",\r\n\t\t\t\"status\": \"completed\",\r\n\t\t\t\"dueDate\": \"Wednesday, 2 June 2021 12:36:16.476 GMT+08:00\",\r\n\t\t\t\"citizenID\": \"Uvr0vZqIPON5UZsgJsMYPe2Qfsi2\",\r\n\t\t\t\"datePosted\": \"Wednesday, 2 June 2021 12:36:32.628 GMT+08:00\",\r\n\t\t\t\"genre\": \"Errands\"\r\n\t\t}\r\n\t}",
      "Given your input file as `input.json` and the following JQ script as `transform.jq`:\r\n\r\n```\r\ndef stddate:\r\n\t._seconds | todate;\r\n\r\n.task\r\n| map_values(\r\n\t.dueDate |= stddate\r\n\t| .datePosted |= stddate\r\n)\r\n```",
      "This command\r\n\r\n    jq -f transform.jq input.json\r\n\r\nreturns this output:\r\n\r\n```\r\n{\r\n  \"id1\": {\r\n    \"completed\": true,\r\n    \"title\": \"Testing\",\r\n    \"desc\": \"short desc\",\r\n    \"status\": \"completed\",\r\n    \"dueDate\": \"2021-06-02T04:15:10Z\",\r\n    \"citizenID\": \"Uvr0vZqIPON5UZsgJsMYPe2Qfsi2\",\r\n    \"datePosted\": \"2021-06-02T04:16:48Z\",\r\n    \"genre\": \"Errands\"\r\n  },\r\n  \"id2\": {\r\n    \"completed\": true,\r\n    \"title\": \"Testing 2\",\r\n    \"status\": \"completed\",\r\n    \"dueDate\": \"2021-06-02T04:36:16Z\",\r\n    \"citizenID\": \"Uvr0vZqIPON5UZsgJsMYPe2Qfsi2\",\r\n    \"datePosted\": \"2021-06-02T04:36:32Z\",\r\n    \"genre\": \"Errands\",\r\n    \"latLng\": null\r\n  }\r\n}\r\n```"
    ],
    "utterance": "Convert all dueDate and datePosted fields inside each task entry from nested _seconds/_nanoseconds objects to ISO8601 strings using the _seconds field; ensure every entry has the same set of keys, adding missing keys with default values if needed.",
    "expressions": [
      "def stddate: ._seconds | todate; .task | map_values(.dueDate |= stddate | .datePosted |= stddate)",
      ".task |= map_values(. as $o | {completed, title, desc: (.desc // \"\"), status, dueDate: (.dueDate._seconds | todate), citizenID, datePosted: (.datePosted._seconds | todate), genre})"
    ],
    "data": [
      {
        "input": {
          "task": {
            "id1": {
              "completed": true,
              "title": "Testing",
              "desc": "short desc",
              "status": "completed",
              "dueDate": {
                "_seconds": 1622607310,
                "_nanoseconds": 867000000
              },
              "citizenID": "Uvr0vZqIPON5UZsgJsMYPe2Qfsi2",
              "datePosted": {
                "_seconds": 1622607408,
                "_nanoseconds": 365000000
              },
              "genre": "Errands"
            },
            "id2": {
              "completed": true,
              "title": "Testing 2",
              "status": "completed",
              "dueDate": {
                "_seconds": 1622608576,
                "_nanoseconds": 476999000
              },
              "citizenID": "Uvr0vZqIPON5UZsgJsMYPe2Qfsi2",
              "datePosted": {
                "_seconds": 1622608592,
                "_nanoseconds": 628999000
              },
              "genre": "Errands",
              "latLng": null
            }
          }
        },
        "output": {
          "id1": {
            "completed": true,
            "title": "Testing",
            "desc": "short desc",
            "status": "completed",
            "dueDate": "2021-06-02T04:15:10Z",
            "citizenID": "Uvr0vZqIPON5UZsgJsMYPe2Qfsi2",
            "datePosted": "2021-06-02T04:16:48Z",
            "genre": "Errands"
          },
          "id2": {
            "completed": true,
            "title": "Testing 2",
            "desc": "",
            "status": "completed",
            "dueDate": "2021-06-02T04:36:16Z",
            "citizenID": "Uvr0vZqIPON5UZsgJsMYPe2Qfsi2",
            "datePosted": "2021-06-02T04:36:32Z",
            "genre": "Errands"
          }
        }
      }
    ],
    "identifier": 72047013
  },
  {
    "context": [
      "I want to extract and parse only the subset I am interested in , in my case all content in 'node' key.",
      "in ''node'' session , I am interested in key:value pair of        .url,        .headline.default, (*this one is 'grandchild' of key 'node'*)        .firstPublished   I want to keep **only above 3 item inside 'node' key**",
      "I want to print out the super slim version of json file I need ?",
      "Here is the output I **expect to have**",
      "Here's a (somewhat) declarative solution:",
      "(.data.legacyCollection.collectionsPage.stream.edges\n | map( {node: (.node\n                | {url,\n                   firstPublished,\n\t\t           headline: {default: .headline.default} })})) as $edges\n| {data: {\n     legacyCollection: {\n       collectionsPage: {\n         stream: {\n           $edges\n         }\n       }\n     }\n   }\n  }"
    ],
    "utterance": "Extract an object containing only data.legacyCollection.collectionsPage.stream.edges[].node.url, .firstPublished, and .headline.default, preserving the original structure down to the edges array.",
    "expressions": [
      "(.data.legacyCollection.collectionsPage.stream.edges\n | map({node: (.node | {url, firstPublished, headline: {default: .headline.default}})})) as $edges\n| {data: {legacyCollection: {collectionsPage: {stream: {edges: $edges}}}}}"
    ],
    "data": [
      {
        "input": {
          "data": {
            "legacyCollection": {
              "longDescription": "The latest news, analysis and investigations from Europe.",
              "section": {
                "name": "world",
                "url": "/section/world"
              },
              "collectionsPage": {
                "stream": {
                  "pageInfo": {
                    "hasNextPage": true,
                    "__typename": "PageInfo"
                  },
                  "__typename": "AssetsConnection",
                  "edges": [
                    {
                      "node": {
                        "url": "https://www.nytimes.com/video/world/europe/100000008323381/icc-war-crimes-ukraine.html",
                        "firstPublished": "2022-04-27T23:28:33.241Z",
                        "headline": {
                          "default": "I.C.C. Joins Investigation of War Crimes in Ukraine",
                          "__typename": "CreativeWorkHeadline"
                        },
                        "summary": "Karim Khan, the chief prosecutor of the International Criminal Court, said that his organization would participate in a joint effort \u2014 with Ukraine, Poland and Lithuania \u2014 to investigate war crimes committed since Russia\u2019s invasion.",
                        "promotionalMedia": {
                          "__typename": "Image",
                          "id": "SW1hZ2U6bnl0Oi8vaW1hZ2UvYTY3MTVhNDUtZDE0NS01OWZjLThkZWItNzYxMWViN2UyODhk"
                        },
                        "embedded": false
                      },
                      "__typename": "AssetsEdge"
                    },
                    {
                      "node": {
                        "__typename": "Article",
                        "url": "https://www.nytimes.com/2022/04/27/sports/soccer/chelsea-sale-roman-abramovich.html",
                        "firstPublished": "2022-04-27T19:42:17.000Z",
                        "typeOfMaterials": [
                          "News"
                        ],
                        "archiveProperties": {
                          "lede": "",
                          "__typename": "ArticleArchiveProperties"
                        },
                        "headline": {
                          "default": "Endgame Nears in Bidding for Chelsea F.C.",
                          "__typename": "CreativeWorkHeadline"
                        },
                        "summary": "The American bank selling the English soccer team on behalf of its Russian owner could name its preferred suitor by the end of the week. But the drama isn\u2019t over.",
                        "translations": []
                      },
                      "__typename": "AssetsEdge"
                    }
                  ],
                  "totalCount": 52559
                }
              },
              "sourceId": "100000004047788",
              "tagline": "",
              "__typename": "LegacyCollection"
            }
          }
        },
        "output": {
          "data": {
            "legacyCollection": {
              "collectionsPage": {
                "stream": {
                  "edges": [
                    {
                      "node": {
                        "url": "https://www.nytimes.com/video/world/europe/100000008323381/icc-war-crimes-ukraine.html",
                        "firstPublished": "2022-04-27T23:28:33.241Z",
                        "headline": {
                          "default": "I.C.C. Joins Investigation of War Crimes in Ukraine"
                        }
                      }
                    },
                    {
                      "node": {
                        "url": "https://www.nytimes.com/2022/04/27/sports/soccer/chelsea-sale-roman-abramovich.html",
                        "firstPublished": "2022-04-27T19:42:17.000Z",
                        "headline": {
                          "default": "Endgame Nears in Bidding for Chelsea F.C."
                        }
                      }
                    }
                  ]
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 72081662
  },
  {
    "context": [
      "I have the following data:",
      "I would like 'regions' to be a single object with each region being a key within that object like this:",
      "Creating an object with `key` and `value` fields, then using `from_entries` would be one way:",
      "{\n  count: length,\n  regions: group_by(.\"company.u_ats_region\")\n  | map({\n      key: .[0].\"company.u_ats_region\",\n      value: map({name: \"\\(.hostname).\\(.os_domain)\", os})\n    })\n  | from_entries\n}",
      "Using `reduce` to iteratively build up the arrays would be another way:",
      "{\n  count: length,\n  regions: (\n    reduce .[] as $i ({};\n      .[$i.\"company.u_ats_region\"] += [$i | {name: \"\\(.hostname).\\(.os_domain)\", os}]\n    )\n  )\n}",
      "You can define a [custom function](https://stackoverflow.com/a/73893819/112968) which performs the grouping and then tranfsorm the result.",
      "{\n  count: length,\n  regions: group_to_obj(.\"company.u_ats_region\")\n    | map_values(map({name: \"\\(.hostname).\\(.os_domain)\", os}))\n}"
    ],
    "utterance": "Group the array by the value of the company.u_ats_region field and create an object whose keys are the region names and whose values are arrays of objects each containing name as hostname.os_domain and the os field; also include a count field with the total number of elements.",
    "expressions": [
      "{ count: length, regions: group_by(.\"company.u_ats_region\") | map({ key: .[0].\"company.u_ats_region\", value: map({name: \"\\(.hostname).\\(.os_domain)\", os}) }) | from_entries }",
      "{ count: length, regions: (reduce .[] as $i ({}; .[$i.\"company.u_ats_region\"] += [$i | {name: \"\\(.hostname).\\(.os_domain)\", os}])) }",
      "def group_to_obj(f): group_by(f) | map({key:first|f, value:.}) | from_entries;\n{\n  count: length,\n  regions: group_to_obj(.\"company.u_ats_region\") | map_values(map({name: \"\\(.hostname).\\(.os_domain)\", os}))\n}"
    ],
    "data": [
      {
        "input": [
          {
            "company.u_ats_region": "Region1",
            "hostname": "host1",
            "install_status": "1",
            "os": "Windows",
            "os_domain": "test.com"
          },
          {
            "company.u_ats_region": "Region2",
            "hostname": "host2",
            "install_status": "1",
            "os": "Windows",
            "os_domain": "test.com"
          },
          {
            "company.u_ats_region": "Region3",
            "hostname": "host3",
            "install_status": "7",
            "os": "Windows",
            "os_domain": "test.com"
          }
        ],
        "output": {
          "count": 3,
          "regions": {
            "Region1": [
              {
                "name": "host1.test.com",
                "os": "Windows"
              }
            ],
            "Region2": [
              {
                "name": "host2.test.com",
                "os": "Windows"
              }
            ],
            "Region3": [
              {
                "name": "host3.test.com",
                "os": "Windows"
              }
            ]
          }
        }
      }
    ],
    "identifier": 72126585
  },
  {
    "context": [
      "And I want to trim it down to this:",
      "But when I try to delete or filter for the fields I want from the `custom_fields` array, I get stuck (`Cannot index array with string \"custom fields\"`).",
      "Is there a cleaner way I could be selecting which fields to *keep* rather than specifying which to delete?",
      "How do I grab the fields I need from the nested array, and flattening them to the same level as the rest of the fields, while also renaming them?",
      "You can use a mapping to keep track of the custom fields wanted :",
      "jq '{\"os\"          : 360009431333,\n     \"is_signed_in\": 360054304553,\n     \"phone_model\" : 360009431353,\n     \"channel\"     : 1500001920482} as $mapping |\n.results |= map(\n   { url,created_at,subject,description,recipient,tags,\n   } +\n   (.custom_fields as $custom_fields |\n    $mapping |\n    with_entries(\n      .value |= (. as $id | $custom_fields[]?|select(.id==$id).value)\n    )\n   )\n)' input.json"
    ],
    "utterance": "Select specific top-level fields to keep in each result and flatten selected custom_fields by id into new fields with custom names.",
    "expressions": [
      "{\n  \"os\": 360009431333,\n  \"is_signed_in\": 360054304553,\n  \"phone_model\": 360009431353,\n  \"channel\": 1500001920482\n} as $mapping |\n.results |= map(\n  { url, created_at, subject, description, recipient, tags } +\n  (.custom_fields as $custom_fields |\n    $mapping |\n    with_entries(\n      .value |= (. as $id | $custom_fields[]? | select(.id == $id).value)\n    )\n  )\n)"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "url": "https://someresult.com",
              "id": 5192740,
              "external_id": null,
              "via": {
                "channel": "web",
                "source": {
                  "from": {},
                  "to": {},
                  "rel": null
                }
              },
              "created_at": "2022-04-29T15:19:37Z",
              "updated_at": "2022-04-29T15:19:38Z",
              "type": null,
              "subject": "My subject line",
              "raw_subject": "My subject line ",
              "description": "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Mauris et nulla ut sapien ultrices tempus.",
              "priority": "normal",
              "status": "new",
              "recipient": "somebody@email.com",
              "requester_id": 1234567891,
              "submitter_id": 1234567891,
              "assignee_id": null,
              "organization_id": null,
              "group_id": 123456789,
              "collaborator_ids": [],
              "follower_ids": [],
              "email_cc_ids": [],
              "forum_topic_id": null,
              "problem_id": null,
              "has_incidents": false,
              "is_public": true,
              "due_at": null,
              "tags": [
                "_tag_1",
                "_tag_2",
                "_tag_3"
              ],
              "custom_fields": [
                {
                  "id": 1500010396161,
                  "value": null
                },
                {
                  "id": 360009431333,
                  "value": "Keep this data"
                },
                {
                  "id": 360054304553,
                  "value": false
                },
                {
                  "id": 1900000317745,
                  "value": null
                },
                {
                  "id": 360002223154,
                  "value": null
                },
                {
                  "id": 360009431353,
                  "value": "Keep this too"
                },
                {
                  "id": 1500001920482,
                  "value": "Keep this data, as well!"
                }
              ],
              "followup_ids": [],
              "ticket_form_id": 12345678912,
              "brand_id": 112358,
              "allow_channelback": false,
              "allow_attachments": true,
              "result_type": "ticket"
            }
          ]
        },
        "output": {
          "results": [
            {
              "url": "https://someresult.com",
              "created_at": "2022-04-29T15:19:37Z",
              "subject": "My subject line",
              "description": "Lorem ipsum dolor sit amet, consectetur adipiscing elit. Mauris et nulla ut sapien ultrices tempus.",
              "recipient": "somebody@email.com",
              "tags": [
                "_tag_1",
                "_tag_2",
                "_tag_3"
              ],
              "os": "Keep this data",
              "is_signed_in": false,
              "phone_model": "Keep this too",
              "channel": "Keep this data, as well!"
            }
          ]
        }
      }
    ],
    "identifier": 72065049
  }
]