[
  {
    "context": [
      "curl -X GET -s -H \"Authorization: Bearer ${do_token//\\\"}\" \"https://api.digitalocean.com/v2/account/keys?page=1\" | jq -r --arg queryname \"User's key\" '.ssh_keys[] | select(.name == $queryname).public_key'",
      "jq: error (at <stdin>:0): Cannot iterate over null (null)"
    ],
    "utterance": "Extract the public_key field for the SSH key entry with the name \"User's key\" from an array named ssh_keys, where ssh_keys may be null or empty.",
    "expressions": [
      ".ssh_keys[] | select(.name == $queryname).public_key"
    ],
    "identifier": 67951747,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I need modify few elements values and also extract only the contents inside containerDefinitions while retaining the square bracket.",
      "The below script works in replacing the required value and extract the json inside the square brack inside containerDefinitions but leaves out the square bracket. Is there additinal command that can retain the square brackets.",
      "If you want to process _all_ items, not just the first one (and thus to generate a stream of items), and want to put that stream into a list, you might instead want:",
      "Note the removal of `[0]`, and the use of `map()` to pass all the list elements through the transforming function.",
      "the following variation of your jq program retains the `[0]` and produces the \"expected output\":",
      "[.taskDefinition.containerDefinitions[0]\n | ( .environment[] |= if .name | IN(\"SMT_PORT_3306_TCP_ADDR\", \"SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST\")\n                       then .value = \"myvalue\" else . end)\n | .logConfiguration.options.\"awslogs-group\" = \"myvalue\"\n]\n"
    ],
    "utterance": "Update the value of environment variables named SMT_PORT_3306_TCP_ADDR and SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST to \"myvalue\" in the first element of containerDefinitions, and output the modified element inside an array.",
    "expressions": [
      "[.taskDefinition.containerDefinitions[0]\n | ( .environment[] |= if .name | IN(\"SMT_PORT_3306_TCP_ADDR\", \"SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST\")\n                       then .value = \"myvalue\" else . end)\n | .logConfiguration.options.\"awslogs-group\" = \"myvalue\"\n]"
    ],
    "data": [
      {
        "input": {
          "taskDefinition": {
            "taskDefinitionArn": "some value",
            "containerDefinitions": [
              {
                "name": "common-api-img",
                "environment": [
                  {
                    "name": "SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST",
                    "value": "false"
                  },
                  {
                    "name": "SMT_PORT_3306_TCP_ADDR",
                    "value": "valueToReplace"
                  }
                ],
                "mountPoints": [],
                "volumesFrom": []
              }
            ],
            "revision": 65,
            "volumes": [],
            "status": "ACTIVE"
          }
        },
        "output": [
          {
            "name": "common-api-img",
            "environment": [
              {
                "name": "SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST",
                "value": "myvalue"
              },
              {
                "name": "SMT_PORT_3306_TCP_ADDR",
                "value": "myvalue"
              }
            ],
            "mountPoints": [],
            "volumesFrom": []
          }
        ]
      }
    ],
    "identifier": 67959650,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have the input JSON data at the bottom.",
      "I\u2019d like to generate a TSV output like the following. <TAB> is the TAB character. How can I do it in jq?",
      "(.events.dividends|map_values(.amount)) as $dividends\n| [\"timestamp\", \"open\", \"high\", \"dividends\"],\n  ( [.timestamp, (.indicators.quote[0] | .open, .high),\n     [$dividends[.timestamp[]|tostring]]]\n    | transpose[])\n| @tsv"
    ],
    "utterance": "Output a TSV table with columns timestamp, open, high, and dividends; for each record, include the dividend amount if available for that timestamp, otherwise leave empty.",
    "expressions": [
      "(.events.dividends|map_values(.amount)) as $dividends | [\"timestamp\", \"open\", \"high\", \"dividends\"], ( [.timestamp, (.indicators.quote[0] | .open, .high), [$dividends[.timestamp[]|tostring]]] | transpose[]) | @tsv"
    ],
    "data": [
      {
        "input": {
          "timestamp": [
            1623072600,
            1623159000,
            1623245400,
            1623331800,
            1623418200
          ],
          "indicators": {
            "quote": [
              {
                "open": [
                  4229.33984375,
                  4233.81005859375,
                  4232.990234375,
                  4228.56005859375,
                  4242.89990234375
                ],
                "high": [
                  4232.33984375,
                  4236.740234375,
                  4237.08984375,
                  4249.740234375,
                  4248.3798828125
                ]
              }
            ]
          },
          "events": {
            "dividends": {
              "1623245400": {
                "amount": 0.42,
                "date": 1623245400
              }
            }
          }
        },
        "output": "timestamp\topen\thigh\tdividends\n1623072600\t4229.33984375\t4232.33984375\t\n1623159000\t4233.81005859375\t4236.740234375\t\n1623245400\t4232.990234375\t4237.08984375\t0.42\n1623331800\t4228.56005859375\t4249.740234375\t\n1623418200\t4242.89990234375\t4248.3798828125\t"
      }
    ],
    "identifier": 67964539,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I would like to create a JSON with array of nested objects with a grouping for different fields. ... Iwould like to group it by sid, year and quarter (first three fields):",
      "But for each sid I would like to get an array of objects nested like this :",
      "And, to get your expected output you can append these lines to the above program.",
      "reduce (inputs / \",\")\n  as [$sid, $year, $quarter, $type, $obj]\n(.; .[$sid][$year][$quarter] += [{$type, $obj}])",
      "| .[][] |= (to_entries | map({quarter: .key, customer_type: .value}))\n| .[]   |= (to_entries | map({year:    .key, quarters:      .value}))\n| .     |= (to_entries | map({sid:     .key, years:         .value}))"
    ],
    "utterance": "Group tabular records by sid, year, and quarter and nest them so that for each sid, years is an array of objects, each year contains quarters as an array, and each quarter contains customer_type array with type and obj values.",
    "expressions": [
      "reduce (inputs / \",\") as [$sid, $year, $quarter, $type, $obj] (.; .[$sid][$year][$quarter] += [{$type, $obj}])\n| .[][] |= (to_entries | map({quarter: .key, customer_type: .value}))\n| .[]   |= (to_entries | map({year:    .key, quarters:      .value}))\n| .     |= (to_entries | map({sid:     .key, years:         .value}))"
    ],
    "data": [
      {
        "input": [
          "S4446B3,2020,202001,2,345.45",
          "S4446B3,2020,202001,4,24.44",
          "S4446B3,2021,202102,5,314.55",
          "S6506LK,2020,202002,3,376.55",
          "S6506LK,2020,202003,3,76.23"
        ],
        "output": [
          {
            "sid": "S4446B3",
            "years": [
              {
                "year": "2020",
                "quarters": [
                  {
                    "quarter": "202001",
                    "customer_type": [
                      {
                        "type": "2",
                        "obj": "345.45"
                      },
                      {
                        "type": "4",
                        "obj": "24.44"
                      }
                    ]
                  }
                ]
              },
              {
                "year": "2021",
                "quarters": [
                  {
                    "quarter": "202102",
                    "customer_type": [
                      {
                        "type": "5",
                        "obj": "314.55"
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "sid": "S6506LK",
            "years": [
              {
                "year": "2020",
                "quarters": [
                  {
                    "quarter": "202002",
                    "customer_type": [
                      {
                        "type": "3",
                        "obj": "376.55"
                      }
                    ]
                  },
                  {
                    "quarter": "202003",
                    "customer_type": [
                      {
                        "type": "3",
                        "obj": "76.23"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 67971376,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "There are more than 6k JSON files, each containing exactly one JSON object. I want to prepare one list of objects from these JSONs.",
      "I am running below `jq` command I am getting an error.",
      "jq -s '.' inventoryItem_*.json > inventory_items_result_$(date +\"%Y%m%d_%H%M%S\").json",
      "bash: /usr/bin/jq: Argument list too long",
      "printf '%s\\0' inventoryItem_*.json \\\n  | xargs -0 cat \\\n  | jq -s . \\\n  >\"inventory_items_result_$(date +\"%Y%m%d_%H%M%S\").json\""
    ],
    "utterance": "Create a single array containing the objects from more than 6000 files, each holding exactly one object, using a command that avoids the 'Argument list too long' error.",
    "expressions": [
      "printf '%s\\0' inventoryItem_*.json | xargs -0 cat | jq -s ."
    ],
    "identifier": 67975407,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": true,
        "multiple": true,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Input is data extracted from card.",
      "\"doc\": {\n    \"0.jpg\": {\n      \"cNumber\": \"6218961 450 3875\",\n      \"cNames\": \" 1 VEN NUT 2 SIRKA SARTH\",\n      \"cExpiry\": \"09/2025\"\n    },\n    \"number\": {\n      \"nTotal\": 3,\n      \"nRequires\": 3,\n      \"nDocuments\": 1\n    }\n  }",
      "I should be able to extract the names based on the number in cNames",
      "Output should be\n\n\"doc\": {\n    \"0.jpg\": {\n      \"cNumber\": \"6218961 450 3875\",\n      \"cNames\": [ \"VEN NUT\",\n                  \"SIRKA SARTH\"],\n      \"cExpiry\": \"09/2025\"\n    },\n    \"number\": {\n      \"nTotal\": 3,\n      \"nRequires\": 3,\n      \"nDocuments\": 1\n    }\n  }",
      ".doc |= map_values(if has(\"cNames\")\n                   then .cNames |= [splits(\" *[0-9]+ *\")][1:]\n                   else . end)"
    ],
    "utterance": "Split the cNames field under any key in doc into an array, using numbers as delimiters, so that \" 1 VEN NUT 2 SIRKA SARTH\" becomes [\"VEN NUT\", \"SIRKA SARTH\"]",
    "expressions": [
      ".doc |= map_values(if has(\"cNames\") then .cNames |= [splits(\" *[0-9]+ *\")][1:] else . end)"
    ],
    "data": [
      {
        "input": {
          "doc": {
            "0.jpg": {
              "cNumber": "6218961 450 3875",
              "cNames": " 1 VEN NUT 2 SIRKA SARTH",
              "cExpiry": "09/2025"
            },
            "number": {
              "nTotal": 3,
              "nRequires": 3,
              "nDocuments": 1
            }
          }
        },
        "output": {
          "doc": {
            "0.jpg": {
              "cNumber": "6218961 450 3875",
              "cNames": [
                "VEN NUT",
                "SIRKA SARTH"
              ],
              "cExpiry": "09/2025"
            },
            "number": {
              "nTotal": 3,
              "nRequires": 3,
              "nDocuments": 1
            }
          }
        }
      }
    ],
    "identifier": 67977314,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I would like to filter the output with 2 more tags with their values but not all of them:",
      "To achieve the \"expected\" output given the \"actual\" output, you could use the following filter:",
      ".ResourceTagMappingList[].Tags\r\n |= map(select(.Key|IN(\"ApplicationName\",\"Owner\",\"ProjectName\")))"
    ],
    "utterance": "Filter each resource's Tags array so it only includes tags where Key is ApplicationName, Owner, or ProjectName.",
    "expressions": [
      ".ResourceTagMappingList[].Tags |= map(select(.Key|IN(\"ApplicationName\",\"Owner\",\"ProjectName\")))"
    ],
    "data": [
      {
        "input": {
          "ResourceTagMappingList": [
            {
              "ResourceARN": "arn:aws:app:us-east-1:XXXX/mesh/Avenger1",
              "Tags": [
                {
                  "Key": "ApplicationName",
                  "Value": "HULK"
                },
                {
                  "Key": "Owner",
                  "Value": "Mark Ruffalo"
                },
                {
                  "Key": "Costume",
                  "Value": "GREEN"
                },
                {
                  "Key": "Power",
                  "Value": "SMASH"
                },
                {
                  "Key": "ProjectName",
                  "Value": "Avengers"
                }
              ]
            },
            {
              "ResourceARN": "arn:aws:app:us-east-1:XXXX:mesh/Avenger2",
              "Tags": [
                {
                  "Key": "ApplicationName",
                  "Value": "IRON-MAN"
                },
                {
                  "Key": "Owner",
                  "Value": "Robert Downey Jr."
                },
                {
                  "Key": "Costume",
                  "Value": "RED"
                },
                {
                  "Key": "Power",
                  "Value": "SuperSonic"
                },
                {
                  "Key": "ProjectName",
                  "Value": "Avengers"
                }
              ]
            }
          ]
        },
        "output": {
          "ResourceTagMappingList": [
            {
              "ResourceARN": "arn:aws:app:us-east-1:XXXX/mesh/Avenger1",
              "Tags": [
                {
                  "Key": "ApplicationName",
                  "Value": "HULK"
                },
                {
                  "Key": "Owner",
                  "Value": "Mark Ruffalo"
                },
                {
                  "Key": "ProjectName",
                  "Value": "Avengers"
                }
              ]
            },
            {
              "ResourceARN": "arn:aws:app:us-east-1:XXXX:mesh/Avenger2",
              "Tags": [
                {
                  "Key": "ApplicationName",
                  "Value": "IRON-MAN"
                },
                {
                  "Key": "Owner",
                  "Value": "Robert Downey Jr."
                },
                {
                  "Key": "ProjectName",
                  "Value": "Avengers"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 67978941,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "jq '.Changes[0].ResourceRecordSet.Name = \"word-is-here.domain.com\"' file.json",
      "Quote the string you are assigning. Or pass it to jq via an argument:",
      "jq --arg foo 'words-here' '.Changes[0].ResourceRecordSet.Name = $foo' file.json",
      "jq --argjson path '[\"Changes\",0,\"ResourceRecordSet\",\"Name\"]' \\\n  --arg val 'word-is-here.domain.com' \\\n  'getpath($path) = $val' file.json",
      "the string: `word-is-here.domain.com`, since jq is interpreting the dash (\"-\") as an operation (\"minus\").",
      "If so, you would have to present it as a JSON string.  So in a bash or bash-like environment, you could write: \n```\njq '.Changes[0].ResourceRecordSet.Name = \"word-is-here.domain.com\"' someFile.json\n```",
      "If the LHS path must be specified by a shell variable, it should if possible be passed in as a JSON array, e.g. using the `--argjson` command-line option; one can then use an expression of the form `setpath($path; $value)` to update the path."
    ],
    "utterance": "Assign the string value 'word-is-here.domain.com' to the Name property at .Changes[0].ResourceRecordSet.",
    "expressions": [
      ".Changes[0].ResourceRecordSet.Name = \"word-is-here.domain.com\"",
      "--arg foo 'word-is-here.domain.com' '.Changes[0].ResourceRecordSet.Name = $foo'",
      "--argjson path '[\"Changes\",0,\"ResourceRecordSet\",\"Name\"]' --arg val 'word-is-here.domain.com' 'setpath($path; $val)'"
    ],
    "data": [
      {
        "input": {
          "Changes": [
            {
              "Action": "do something",
              "ResourceRecordSet": {
                "Name": "some name here to replace"
              }
            }
          ]
        },
        "output": {
          "Changes": [
            {
              "Action": "do something",
              "ResourceRecordSet": {
                "Name": "word-is-here.domain.com"
              }
            }
          ]
        }
      }
    ],
    "identifier": 67980820,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to add a string (which is a script argument - in this case \"tenant-lta\") in JSON objects to a value in field \"alertruleindexpattern\" and truncate `-*` or `*` if it is at the end of the string.",
      "Desired output in field `alertruleindexpattern`:",
      "{\n    \"alertruleindexpattern\": \"tenant-lta-winlogbeat\",\n    \n}",
      "the jq filter would be along these lines:\n\n    ._source.alertruleindexpattern \n    |= $tenantname + \"-\" + sub(\"-?[*]$\";\"\")",
      "jq --arg prefix tenant-lta- \\\n  '{alertruleindexpattern: ($prefix + (._source.alertruleindexpattern | match(\"(.*?)(?=-\\\\*$|$)\").captures[0].string))}'"
    ],
    "utterance": "Prepend 'tenant-lta-' to the value of 'alertruleindexpattern' and remove a trailing '-*' or '*' from the original value.",
    "expressions": [
      "._source.alertruleindexpattern |= $tenantname + \"-\" + sub(\"-?[*]$\";\"\")",
      "{alertruleindexpattern: ($prefix + (._source.alertruleindexpattern | match(\"(.*?)(?=-\\\\*$|$\").captures[0].string))}"
    ],
    "data": [
      {
        "input": {
          "_index": ".alertrules",
          "_type": "_doc",
          "_id": "tenant-lta_Windows_Admin_task_as_user",
          "_score": 0.07554413,
          "_source": {
            "alertrulemethoddata": "",
            "alertruleimportance": 50,
            "alertruletype": "any",
            "alertrule_any": "filter:\n - query_string:\n     query: \"event_id:4732 AND NOT user.role:admin\"",
            "alertrulemethodusers": [],
            "alertrulemethod": "none",
            "alertruleindexpattern": "winlogbeat-*",
            "alertruleplaybooks": [],
            "alertrulefilename": "tenant-lta_Windows_Admin_task_as_user",
            "alertrulename": "tenant-lta-Windows - Admin task as user",
            "enable": "N",
            "selectedroles": [
              "tenant-lta"
            ],
            "alertruleriskkeyaggregation": "MAX",
            "authenticator": "index",
            "alertruleriskkey": "",
            "changed": false
          }
        },
        "output": {
          "alertruleindexpattern": "tenant-lta-winlogbeat"
        }
      }
    ],
    "identifier": 67982781,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "print the number of pull requests of each contributor has created with the labels.",
      "I was able to filter pull requests by contributor:",
      "curl ... | jq '. [] | .user.login, .labels'",
      "But how to deal next, maybe U can sugest something."
    ],
    "utterance": "For each contributor, count the number of pull requests they have created and list the labels on those pull requests.",
    "expressions": [
      "group_by(.user.login) | map({contributor: .[0].user.login, count: length, labels: map(.labels | map(.name)) | add | unique})"
    ],
    "identifier": 67986766,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": "The task does not specify the input JSON structure (e.g., how contributors, pull requests, and labels are represented), so it is unclear how to perform the transformation.",
      "other_environment": null
    }
  },
  {
    "context": [
      "I can't seem to find a way to include values when `\"Actions\" == []`",
      "What I want to get as output:",
      "\"Campaign One\",\"Open\"\n\"Campaign One\",\"Click\"\n\"Campaign Two\",\"none\"",
      "What I currently get",
      "\"Campaign One\",\"Open\"\n\"Campaign One\",\"Click\"",
      "With the [alternative operator `//`][1]:",
      "jq -r '.[] | (.Actions[].Event // \"none\") as $e | [ .Name, $e ] | @csv'"
    ],
    "utterance": "Output all items as CSV with the Name and for each Action's Event, or 'none' if the Actions array is empty",
    "expressions": [
      ".[] | (.Actions[].Event // \"none\") as $e | [ .Name, $e ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "ID": "fc0ce7105baeaf97f47c99be31d02a91",
            "Type": "Campaign",
            "Name": "Campaign One",
            "Actions": [
              {
                "Event": "Open",
                "Date": "2010-10-12 13:18:00",
                "IPAddress": "192.168.126.87",
                "Detail": ""
              },
              {
                "Event": "Click",
                "Date": "2010-10-12 13:16:00",
                "IPAddress": "192.168.126.87",
                "Detail": "https://example.com/post/12323/"
              }
            ]
          },
          {
            "ID": "dsadsamdkl9309ujd432",
            "Type": "Campaign",
            "Name": "Campaign Two",
            "Actions": []
          }
        ],
        "output": [
          "\"Campaign One\",\"Open\"",
          "\"Campaign One\",\"Click\"",
          "\"Campaign Two\",\"none\""
        ]
      }
    ],
    "identifier": 67987088,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Im trying to get the first 2 names in the following example json, without having to call them",
      "what i want to get is ```BI_Arch Data_Engineers``` without having to resort in naming them, something like the opposite response of ```jq .[] test.json``` that writes down only those names, is there a way to get it?",
      "You can use the `keys` function as in:\r\n```\r\njq keys test.json\r\n[\r\n  \"BI_Arch\",\r\n  \"Data_Engineers\"\r\n]\r\n```",
      "possibly obtaining \"raw\" output with:\r\n```\r\njq -r keys[] test.json\r\nBI_Arch\r\nData_Engineers\r\n```",
      "Pipe the object through the `keys` filter, and slice it if you really want the first 2 of more-than-2:",
      "% jq 'keys[:2]' tmp.json",
      "[\r\n  \"BI_Arch\",\r\n  \"Data_Engineers\"\r\n]"
    ],
    "utterance": "List the first two top-level object property names.",
    "expressions": [
      "keys[:2]",
      "keys",
      "-r keys[]"
    ],
    "data": [
      {
        "input": {
          "BI_Arch": [
            {
              "Read": [
                "RDS",
                "Redshift",
                "Athena"
              ],
              "Write": [
                "Quicksight"
              ]
            }
          ],
          "Data_Engineers": [
            {
              "Write": [
                "S3",
                "Glue",
                "Lambda",
                "Athena",
                "EMR",
                "Databricks",
                "RDS",
                "Redshift",
                "Kinesis",
                "SQS",
                "SES",
                "SNS",
                "AWS SFTP"
              ],
              "Read": [
                "KMS",
                "Secret_Manager"
              ]
            }
          ]
        },
        "output": [
          "BI_Arch",
          "Data_Engineers"
        ]
      }
    ],
    "identifier": 67989350,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to add a sum/total at the end of that, something like `Total: $1775`, so that the entire output would look like this:",
      "jq -Cr '\n  ([.data[]\n    | {invoice_id: .id,\n       client: .customer_name,\n       date: .date | strftime(\"%Y-%m-%d\"),\n       amount: .total,\n       status: .status}\n    | .amount = \"$\" + (.amount/100|tostring)\n   ] | sort_by(.date)),\n  \"Total: $\\([.data[] | .total] | add | . / 100)\"\n'",
      "\"Total: $\\([.data[] | .total] | add | . / 100)\"",
      "[.data[] | {invoice_id: .id, client: .customer_name, date: .date | strftime(\"%Y-%m-%d\"), amount: .total, status: .status} | .amount = \"$\" + (.amount/100|tostring)] | sort_by(.date)"
    ],
    "utterance": "Display a list of invoices with formatted amounts and their total sum as 'Total: $1775' at the end.",
    "expressions": [
      "([.data[]\n  | {invoice_id: .id,\n     client: .customer_name,\n     date: .date | strftime(\"%Y-%m-%d\"),\n     amount: .total,\n     status: .status}\n  | .amount = \"$\" + (.amount/100|tostring)\n ] | sort_by(.date)),\n\"Total: $\\([.data[] | .total] | add | . / 100)\""
    ],
    "data": [
      {
        "input": {
          "object": "list",
          "data": [
            {
              "id": "in_1HW85aFGUwFHXzvl8wJbW7V7",
              "object": "invoice",
              "account_country": "US",
              "customer_name": "clientOne",
              "date": 1601244686,
              "livemode": true,
              "metadata": {},
              "paid": true,
              "status": "paid",
              "total": 49500
            },
            {
              "id": "in_1HJlIZFGUwFHXzvlWqhegRkf",
              "object": "invoice",
              "account_country": "US",
              "customer_name": "clientTwo",
              "date": 1598297143,
              "livemode": true,
              "metadata": {},
              "paid": true,
              "status": "paid",
              "total": 51000
            },
            {
              "id": "in_1HJkg5FGUwFHXzvlYp2uC63C",
              "object": "invoice",
              "account_country": "US",
              "customer_name": "clientThree",
              "date": 1598294757,
              "livemode": true,
              "metadata": {},
              "paid": true,
              "status": "paid",
              "total": 57000
            },
            {
              "id": "in_1H8B0pFGUwFHXzvlU6nrOm6I",
              "object": "invoice",
              "account_country": "US",
              "customer_name": "clientThree",
              "date": 1595536051,
              "livemode": true,
              "metadata": {},
              "paid": true,
              "status": "paid",
              "total": 20000
            }
          ],
          "has_more": true,
          "url": "/v1/invoices"
        },
        "output": "[\n  {\n    \"invoice_id\": \"in_1H8B0pFGUwFHXzvlU6nrOm6I\",\n    \"client\": \"clientThree\",\n    \"date\": \"2020-07-23\",\n    \"amount\": \"$200\",\n    \"status\": \"paid\"\n  },\n  {\n    \"invoice_id\": \"in_1HJlIZFGUwFHXzvlWqhegRkf\",\n    \"client\": \"clientTwo\",\n    \"date\": \"2020-08-24\",\n    \"amount\": \"$510\",\n    \"status\": \"paid\"\n  },\n  {\n    \"invoice_id\": \"in_1HJkg5FGUwFHXzvlYp2uC63C\",\n    \"client\": \"clientThree\",\n    \"date\": \"2020-08-24\",\n    \"amount\": \"$570\",\n    \"status\": \"paid\"\n  },\n  {\n    \"invoice_id\": \"in_1HW85aFGUwFHXzvl8wJbW7V7\",\n    \"client\": \"clientOne\",\n    \"date\": \"2020-09-27\",\n    \"amount\": \"$495\",\n    \"status\": \"paid\"\n  }\n]\nTotal: $1775"
      }
    ],
    "identifier": 67993813,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "looking for solution where i could loop and get \"id\" for a given \"Version\"",
      "for suppose the while i pass argument \"Version\" = 3.0.0 expecting the output to be as \"X3\"( which is the key value of \"id\"",
      "echo \"$x\" | jq -r 'map(select(any(.version[]; contains(\"3.0.0\"))|not)|.id)[]'",
      "jq: error (at <stdin>:1): Cannot index number with string \"version\""
    ],
    "utterance": "Select the id of the item whose version is 3.0.0.",
    "expressions": [
      ".list[] | select(.version == \"3.0.0\") | .id"
    ],
    "data": [
      {
        "input": {
          "count": 3,
          "next": "",
          "previous": "",
          "list": [
            {
              "id": "X1",
              "name": "STAGING",
              "description": null,
              "context": "STAGING",
              "version": "1.0.0",
              "provider": "user0",
              "status": "PUBLISHED",
              "thumbnailUri": null
            },
            {
              "id": "X2",
              "name": "STAGING",
              "description": null,
              "context": "STAGING",
              "version": "2.0.0",
              "provider": "user1",
              "status": "PUBLISHED",
              "thumbnailUri": null
            },
            {
              "id": "X3",
              "name": "STAGING",
              "description": null,
              "context": "STAGING",
              "version": "3.0.0",
              "provider": "user2",
              "status": "CREATED",
              "thumbnailUri": null
            }
          ],
          "pagination": {
            "total": 3,
            "offset": 0,
            "limit": 25
          }
        },
        "output": "X3"
      }
    ],
    "identifier": 67994766,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Is there some way to use the name of an argument in the code?",
      "Is it possible to get this output?:\n{\n  \"name\": \"value\"\n}",
      "If you remove the `($name):` JQ will use the name as the key fallback:",
      "$ jq -n --arg name value '{$name}'\n{\n  \"name\": \"value\"\n}\n$"
    ],
    "utterance": "Create an object with a key named 'name' and value 'value' when 'name' is supplied as an argument.",
    "expressions": [
      "{$name}"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "name": "value"
        }
      }
    ],
    "identifier": 68002556,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "How do you handle dynamic JSON where in you're not aware of elements or even multiple values that you will encounter and then convert into a format that can be easily loaded into Snowflake or any other relational database?",
      "We tried converting the entire JSON row into a single row but then we don't know how to parse multiple columns (ABC0, ABC1) for the same column (ABC).",
      "\"Job_Profile_Reference\": {\n      \"ID\": [\n      {\n        \"@type\": \"WI\",\n        \"__text\": \"4acf03b2e8e301fab3caeab105020f\"\n      },\n      {\n        \"@type\": \"Job_Profile_ID\",\n        \"__text\": \"112\"\n      }\n      ]\n    }",
      "output\n```\nJob_Profile.Job_Profile_Reference.ID.0.@type,Job_Profile.Job_Profile_Reference.ID.0.__text,Job_Profile.Job_Profile_Reference.ID.1.@type,Job_Profile.Job_Profile_Reference.ID.1.__text\nWI,4acf03b2e8e301fab3caeab105020f,Job_Profile_ID,112\n```"
    ],
    "utterance": "Flatten nested arrays so each object's values become distinct columns with dot-numbered paths as headers, e.g., ID.0.@type, ID.0.__text, ID.1.@type, ID.1.__text.",
    "expressions": [
      "def flatten_object(obj; prefix):\n  reduce (obj | to_entries[]) as {key: k, value: v} ({};\n    if (v | type == \"object\") then\n      . + (flatten_object(v; (prefix + [k])))\n    elif (v | type == \"array\") then\n      . + [ range(0; v | length) ]\n           | map({ ((prefix + [k, tostring(. )]) | join(\".\")): (v[.]) })\n           | add // {}\n    else\n      . + { ((prefix + [k]) | join(\".\")): v }\n    end);\n\nflatten_object(.; [])"
    ],
    "data": [
      {
        "input": {
          "Job_Profile_Reference": {
            "ID": [
              {
                "@type": "WI",
                "__text": "4acf03b2e8e301fab3caeab105020f"
              },
              {
                "@type": "Job_Profile_ID",
                "__text": "112"
              }
            ]
          }
        },
        "output": {
          "Job_Profile_Reference.ID.0.@type": "WI",
          "Job_Profile_Reference.ID.0.__text": "4acf03b2e8e301fab3caeab105020f",
          "Job_Profile_Reference.ID.1.@type": "Job_Profile_ID",
          "Job_Profile_Reference.ID.1.__text": "112"
        }
      }
    ],
    "identifier": 68006188,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "The value of $myHosts should get replaced in hosts elements key.",
      "jq --argjson hosts \"[$myHosts]\" '.hosts = $hosts | .adminserver = .hosts[0]' rds.json"
    ],
    "utterance": "Replace the hosts array with values from the shell variable myHosts and set adminserver to the first host.",
    "expressions": [
      ".hosts = $hosts | .adminserver = .hosts[0]"
    ],
    "data": [
      {
        "input": {
          "lob": "coaching",
          "function": "badminton",
          "hosts": [
            "node1.rds.sports.com",
            "node2.rds.sports.com",
            "node3.rds.sports.com"
          ],
          "adminserver": "node1.rds.sports.com",
          "user_name": "coach",
          "sudo_type": "sudo",
          "group_name": "admin"
        },
        "output": {
          "lob": "coaching",
          "function": "badminton",
          "hosts": [
            "host1.rds.sports.com",
            "host2.rds.sports.com",
            "host3.rds.sports.com",
            "host4.rds.sports.com",
            "host5.rds.sports.com",
            "host6.rds.sports.com",
            "host7.rds.sports.com",
            "host8.rds.sports.com"
          ],
          "adminserver": "host1.rds.sports.com",
          "user_name": "coach",
          "sudo_type": "sudo",
          "group_name": "admin"
        }
      }
    ],
    "identifier": 68006550,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "How to match each username (Value A, ValueB ...) to its password ?",
      "while read -r CredId Username\r\ndo\r\n    secret=$(curl -l -k -X GET -H \"Content-Type: application/json\" -H \"Authorization: ${token}\" \"$PasswordServerURL/api/v6/rest/credential/$CredId/password\")\r\n    export \"$Username=$secret\"\r\n    echo \"Username:secret=$Username:$secret\"\r\ndone < <(jq -r '.[] | \"\\(.Id) \\(.Username)\"' < so-loop-over-json.json)"
    ],
    "utterance": "Extract each object's Id and Username as space-separated pairs for further use in a shell script.",
    "expressions": [
      ".[] | \"\\(.Id) \\(.Username)\""
    ],
    "data": [
      {
        "input": [
          {
            "CustomUserFields": {},
            "CustomApplicationFields": {},
            "Attachments": [],
            "Tags": [],
            "HasModifyEntriesAccess": true,
            "HasViewEntryContentsAccess": true,
            "HasViewEntryPasswordAccess": true,
            "CommentPrompts": {
              "AskForCommentOnViewPassword": false,
              "AskForCommentOnViewOffline": false,
              "AskForCommentOnModifyEntries": false,
              "AskForCommentOnMoveEntries": false,
              "AskForCommentOnMoveFolders": false,
              "AskForCommentOnModifyFolders": false
            },
            "Id": "34307337-6b90-4b6f-bc1d-3dba50fa9cbd",
            "Name": "valueA",
            "Username": "valueA",
            "Password": null,
            "Url": "",
            "Notes": "",
            "GroupId": "cd52d662-0771-4eb6-9309-d12aff60b6bb",
            "Created": "2021-06-16T00:07:44+02:00",
            "Modified": "2021-06-16T18:52:00+02:00",
            "Expires": null
          },
          {
            "CustomUserFields": {},
            "CustomApplicationFields": {},
            "Attachments": [],
            "Tags": [],
            "HasModifyEntriesAccess": true,
            "HasViewEntryContentsAccess": true,
            "HasViewEntryPasswordAccess": true,
            "CommentPrompts": {
              "AskForCommentOnViewPassword": false,
              "AskForCommentOnViewOffline": false,
              "AskForCommentOnModifyEntries": false,
              "AskForCommentOnMoveEntries": false,
              "AskForCommentOnMoveFolders": false,
              "AskForCommentOnModifyFolders": false
            },
            "Id": "c92729e3-1325-4725-ae8e-baba4a0d31b5",
            "Name": "ValueB",
            "Username": "ValueB",
            "Password": null,
            "Url": "",
            "Notes": "",
            "GroupId": "cd52d662-0771-4eb6-9309-d12aff60b6bb",
            "Created": "2021-06-16T00:08:05+02:00",
            "Modified": "2021-06-16T18:51:48+02:00",
            "Expires": null
          }
        ],
        "output": [
          "34307337-6b90-4b6f-bc1d-3dba50fa9cbd valueA",
          "c92729e3-1325-4725-ae8e-baba4a0d31b5 ValueB"
        ]
      }
    ],
    "identifier": 68007200,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Here is json:\r\n\r\n    {\r\n          \"id\": 5679162,\r\n          \"username\": \"ryderw1\"\r\n        }\r\n        {\r\n          \"id\": 5679163,\r\n          \"username\": \"ryderw3\"\r\n        }\r\n        {\r\n          \"id\": 5679164,\r\n          \"username\": \"ryderw4\"\r\n        }",
      "My desired o/p should be:\r\n\r\n    5679162\r\n    5679163\r\n    5679164",
      "I suggest this to read output from `jq` to an array.\r\n\r\n    mapfile -t idd < <(jq '.id' /Users/f.json)"
    ],
    "utterance": "Extract all id values from a sequence of objects and output them as a list.",
    "expressions": [
      ".id"
    ],
    "data": [
      {
        "input": [
          {
            "id": 5679162,
            "username": "ryderw1"
          },
          {
            "id": 5679163,
            "username": "ryderw3"
          },
          {
            "id": 5679164,
            "username": "ryderw4"
          }
        ],
        "output": [
          5679162,
          5679163,
          5679164
        ]
      }
    ],
    "identifier": 68010556,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "How do I grab the \".name\" and \".commit.url\" for each of these object before I move onto the next one?",
      "Consider, for example:",
      "while read -r name ; do",
      "    read -r url",
      "    echo \"$name\" \"$url\"",
      "done < <( curl .... | jq -r '.[] | .name, .commit.url' )"
    ],
    "utterance": "Extract the values of the top-level 'name' field and the nested 'commit.url' field for each object in an array.",
    "expressions": [
      ".[] | .name, .commit.url"
    ],
    "data": [
      {
        "input": [
          {
            "name": "my-tag-name",
            "zipball_url": "https://api.github.com/repos/path-to-my-tag-name",
            "tarball_url": "https://api.github.com/repos/path-to-my-tag-name-tarball",
            "commit": {
              "sha": "commit-sha",
              "url": "https://api.github.com/repos/path-to-my-commit-sha"
            },
            "node_id": "node-id"
          },
          {
            "name": "another-tag-name",
            "zipball_url": "https://api.github.com/repos/path-to-my-tag-name",
            "tarball_url": "https://api.github.com/repos/path-to-my-tag-name-tarball",
            "commit": {
              "sha": "commit-sha",
              "url": "https://api.github.com/repos/path-to-my-commit-sha"
            },
            "node_id": "node-id"
          }
        ],
        "output": [
          "my-tag-name",
          "https://api.github.com/repos/path-to-my-commit-sha",
          "another-tag-name",
          "https://api.github.com/repos/path-to-my-commit-sha"
        ]
      }
    ],
    "identifier": 68012288,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Simply put, I need to figure out some kind of ternary operator for transforming lists.",
      "I need\r\n\r\n    \"msg\": \"['baz', 'bar']\"",
      "For example\r\n\r\n```yaml\r\n    - debug:\r\n        msg: \"{{ _list }}\"\r\n      vars:\r\n        _list: \"{{ _list_str|from_yaml }}\"\r\n        _list_str: |\r\n          [\r\n          {% for i in daemons %}\r\n          {% if i.docker.network is defined %}\r\n          {{ i.docker.network }},\r\n          {% else %}\r\n          {{ i.id }},\r\n          {% endif %}\r\n          {% endfor %}\r\n          ]\r\n```\r\n\r\ngives\r\n\r\n```yaml\r\n  msg:\r\n  - baz\r\n  - bar\r\n```"
    ],
    "utterance": "Return a list where each element is the value of .docker.network if it exists, otherwise the value of .id",
    "expressions": [
      "map(.docker.network // .id)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "foo",
            "docker": {
              "network": "baz"
            }
          },
          {
            "id": "bar",
            "docker": {}
          }
        ],
        "output": [
          "baz",
          "bar"
        ]
      }
    ],
    "identifier": 68014727,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have a `json` object that looks like below:",
      "1. First get the value of `Quantity`",
      "2. Increment it by 1",
      "3. Then change that value so it looks like `\"Quantity\": 4,`",
      "4. And I need to add another entry at the bottom of the `Items` array.",
      ".Aliases.Quantity += 1 To increment `Quantity` by `1`",
      ".Aliases.Items += [ \"Example\" ] To add a new index to the `Items` array",
      "Full command:\n```jq\njq '.Aliases.Quantity += 1 | .Aliases.Items += [ \"Example\" ]'\n```"
    ],
    "utterance": "Increment the value of Aliases.Quantity by 1 and append the string \"Example\" to the Aliases.Items array.",
    "expressions": [
      ".Aliases.Quantity += 1 | .Aliases.Items += [ \"Example\" ]"
    ],
    "data": [
      {
        "input": {
          "CallerReference": "terraform-20210518124856158900000001",
          "Aliases": {
            "Quantity": 3,
            "Items": [
              "consumer-portal.mlb.effi.com.au",
              "*.mlb.effi.com.au",
              "coolvalue.mylocalbroker.com.au"
            ]
          }
        },
        "output": {
          "CallerReference": "terraform-20210518124856158900000001",
          "Aliases": {
            "Quantity": 4,
            "Items": [
              "consumer-portal.mlb.effi.com.au",
              "*.mlb.effi.com.au",
              "coolvalue.mylocalbroker.com.au",
              "Example"
            ]
          }
        }
      }
    ],
    "identifier": 68017243,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I am trying to group several items by their name based on the JSON-Data. Furthermore I want to calculate the sum of the size.",
      "The transformed data should be structered like this:\n[\n  {\n    \"item\": \"Hardware\",\n    \"size\": 0.58\n  },\n  {\n    \"item\": \"Server\",\n    \"size\": 4\n  }\n]",
      "Almost there. To construct objects, you need object contructors.\n```\n  group_by(.fields.issuetype.name)\n| map({item: .[0].fields.issuetype.name, size: map(.fields.size) | add})\n```"
    ],
    "utterance": "Group items by fields.issuetype.name and calculate the sum of fields.size for each group.",
    "expressions": [
      "group_by(.fields.issuetype.name) | map({item: .[0].fields.issuetype.name, size: map(.fields.size) | add})"
    ],
    "data": [
      {
        "input": [
          {
            "fields": {
              "issuetype": {
                "name": "Server"
              },
              "size": 2
            }
          },
          {
            "fields": {
              "issuetype": {
                "name": "Server"
              },
              "size": 2
            }
          },
          {
            "fields": {
              "issuetype": {
                "name": "Hardware"
              },
              "size": 0.58
            }
          }
        ],
        "output": [
          {
            "item": "Hardware",
            "size": 0.58
          },
          {
            "item": "Server",
            "size": 4
          }
        ]
      }
    ],
    "identifier": 68018808,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I would now like to get the following result:\r\n\r\n    \"https://www.myurl.com, https://www.anotherurl.com, https://www.andanotherurl.com\"",
      "echo $MY_JSON | jq '[ .content[].content[] | select(.type | contains(\"inlineCard\")) | .attrs.url ] | join(\",\")'"
    ],
    "utterance": "Extract the URLs from all objects of type 'inlineCard' within each 'paragraph' and concatenate them into a single string separated by commas.",
    "expressions": [
      "[ .content[].content[] | select(.type == \"inlineCard\") | .attrs.url ] | join(\", \")",
      "[ .content[].content[] | select(.type | contains(\"inlineCard\")) | .attrs.url ] | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "content": [
            {
              "type": "paragraph",
              "content": [
                {
                  "type": "inlineCard",
                  "attrs": {
                    "url": "https://www.myurl.com"
                  }
                },
                {
                  "type": "text",
                  "text": " "
                }
              ]
            },
            {
              "type": "paragraph",
              "content": [
                {
                  "type": "inlineCard",
                  "attrs": {
                    "url": "https://www.anotherurl.com"
                  }
                },
                {
                  "type": "text",
                  "text": " "
                }
              ]
            },
            {
              "type": "paragraph",
              "content": [
                {
                  "type": "inlineCard",
                  "attrs": {
                    "url": "https://www.andanotherurl.com"
                  }
                },
                {
                  "type": "text",
                  "text": " "
                }
              ]
            }
          ]
        },
        "output": "https://www.myurl.com, https://www.anotherurl.com, https://www.andanotherurl.com"
      }
    ],
    "identifier": 68022774,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to update the `time` property of `observer01` with channel `info`, so the second object in the example data above.",
      "jq '(.notifications[] | select(.source == \"observer01\" and .channel == \"info\").time) = \"NEWTIME\"' data.json",
      "This produces the desired output, the original valid JSON with the updated `time` property:"
    ],
    "utterance": "Update the time property to NEWTIME for the notification where source is observer01 and channel is info, returning the original structure with the change.",
    "expressions": [
      "(.notifications[] | select(.source == \"observer01\" and .channel == \"info\").time) = \"NEWTIME\""
    ],
    "data": [
      {
        "input": {
          "notifications": [
            {
              "source": "observer01",
              "channel": "error",
              "time": "2021-01-01 01:01:01"
            },
            {
              "source": "observer01",
              "channel": "info",
              "time": "2021-02-02 02:02:02"
            }
          ]
        },
        "output": {
          "notifications": [
            {
              "source": "observer01",
              "channel": "error",
              "time": "2021-01-01 01:01:01"
            },
            {
              "source": "observer01",
              "channel": "info",
              "time": "NEWTIME"
            }
          ]
        }
      }
    ],
    "identifier": 68023759,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Assuming I want to extract the time part of a date/time string on the shell I can do something like:",
      "How can I achieve the same with `jq` and `sub()`?",
      "In JQ we use [named capture groups](https://www.pcre.org/current/doc/html/pcre2pattern.html#SEC16) for that.\n```\nsub(\".*T(?<x>.*)\\\\..*\"; .x)\n```",
      "you may remove all up to `T` and all the text starting with (and including) a dot with `.*T|\\.[^.]*$` regex:\n```bash\njq '.node |= gsub(\".*T|\\\\.[^.]*$\"; \"\")' <<< \"$s\"\n```"
    ],
    "utterance": "Extract the time part before the dot from an ISO8601 datetime string containing 'T' as the separator.",
    "expressions": [
      "sub(\".*T(?<x>.*)\\\\..*\"; .x)",
      ".node |= gsub(\".*T|\\\\.[^.]*$\"; \"\")"
    ],
    "data": [
      {
        "input": {
          "node": "2021-06-10T10:42:30.016+0200"
        },
        "output": {
          "node": "10:42:30"
        }
      }
    ],
    "identifier": 68024571,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to append the following JSON object to it using shell script (*.sh) in my ubuntu 18.04. How can I achieve this?",
      "You can use `jq` to add a new key-value pair to the object in `config.json`, then write the new object back to disk.",
      "jq '.proxies = { \"default\": { \"httpProxy\": \"http://proxy.xyz.com:123\", \"httpsProxy\": \"http://proxy.xyz.com:123\", \"noProxy\": \"127.0.0.1,localhost\" } }'  ~/.docker/config.json > tmp && mv tmp ~/.docker/config.json"
    ],
    "utterance": "Add a 'proxies' object with a 'default' key containing 'httpProxy', 'httpsProxy', and 'noProxy' fields to an existing config file.",
    "expressions": [
      ".proxies = { \"default\": { \"httpProxy\": \"http://proxy.xyz.com:123\", \"httpsProxy\": \"http://proxy.xyz.com:123\", \"noProxy\": \"127.0.0.1,localhost\" } }"
    ],
    "data": [
      {
        "input": {
          "auths": {
            "https://index.docker.io/v1/": {
              "auth": "bmFnZGVlcGdrOk5hZzEzNDFkb2NrZXJA"
            }
          }
        },
        "output": {
          "auths": {
            "https://index.docker.io/v1/": {
              "auth": "bmFnZGVlcGdrOk5hZzEzNDFkb2NrZXJA"
            }
          },
          "proxies": {
            "default": {
              "httpProxy": "http://proxy.xyz.com:123",
              "httpsProxy": "http://proxy.xyz.com:123",
              "noProxy": "127.0.0.1,localhost"
            }
          }
        }
      }
    ],
    "identifier": 68025031,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "echo \"$verses\" | jq .verse | jq '[.[]|select(.text)][0]' | jq -r .text",
      "Please help me to make this with just one jq.",
      "I need to select the result of text and only the first one.",
      "I suggest:",
      "echo \"$verses\" | jq -r '.verse[1].text'"
    ],
    "utterance": "Extract the text field from the first element in the verse array.",
    "expressions": [
      ".verse[0].text",
      "-r .verse[0].text"
    ],
    "identifier": 68025092,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "The second command below does not have any output. But I'd expect to see \"xxxx\". Could anybody show me how to fix the jq code that the else branch can be used? Thanks.",
      "jq programs are always filters. The maxim \u201cNo input, no output.\u201d properly understood, always holds, though you might be able to achieve whatever it is you really want by using the -n option, e.g. using `inputs`:",
      "jq -n '(inputs | if ... end) // \"xxxx\"'"
    ],
    "utterance": "Return the value of the 'data' field if present, otherwise output \"xxxx\", and ensure the else branch is used when there is no input.",
    "expressions": [
      "(inputs | if has(\"data\") then .data else null end) // \"xxxx\""
    ],
    "data": [
      {
        "input": {
          "data": 42
        },
        "output": 42
      },
      {
        "input": null,
        "output": "xxxx"
      }
    ],
    "identifier": 68029752,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to use the value of a variable USER_PROXY in the JQ query statement.",
      "export USER_PROXY= \"proxy.zyz.com:122\"",
      "jq -r --arg UPROXY ${USER_PROXY} '.proxies = {\n                \"default\": {\n                \"httpProxy\": \"http://$UPROXY\\\",\n                \"httpsProxy\": \"http://$UPROXY\\\",\n                \"noProxy\": \"127.0.0.1,localhost\"\n                }\n                }'",
      "This isn't the syntax for using variables inside a string in jq. Instead of \"...$UPROXY...\" you need \"...\\($UPROXY)...\"",
      "You need quotes around `${USER_PROXY}` otherwise any whitespace in it will break it. Instead use `--arg UPROXY \"${USER_PROXY}\"`."
    ],
    "utterance": "Assign the value of the shell variable USER_PROXY to httpProxy and httpsProxy fields in the proxies.default object, prefixing the value by 'http://'.",
    "expressions": [
      ".proxies = {\"default\": {\"httpProxy\": (\"http://\" + $UPROXY), \"httpsProxy\": (\"http://\" + $UPROXY), \"noProxy\": \"127.0.0.1,localhost\"}}"
    ],
    "identifier": 68031453,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Unfortunately, for the line with \"id\" equal to \"2\", the date column was not set to \"null\" - instead, it was empty. This in turn makes MySQL error on import if it's a datetime column (it expects a literal \"null\" if we don't have a date, and errors on \"\").",
      "How can I make jq print the literal \"null\", and not \"\"?",
      "Use `//` as alternative operator for your cell value:\n\n`jq -r '(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.] // \"null\")) as $rows | $cols, $rows[] | @csv' < test.json`",
      "You can \"stringify\" the value using [`tostring`](https://stedolan.github.io/jq/manual/#tostring) by changing `map($row[.])` into `map($row[.]|tostring)`:",
      "$ jq --slurp --raw-output '(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.]|tostring)) as $rows | $cols, $rows[] | @csv' so2332.json",
      "I'd go with:\n```\n(map(keys_unsorted) | add | unique) as $cols\n| $cols,\n  (.[] | [.[$cols[]]] | map(. // \"null\") )\n| @csv\n```"
    ],
    "utterance": "Convert an array of objects to a CSV where null values are represented as the string \"null\" instead of an empty field.",
    "expressions": [
      "(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.] // \"null\")) as $rows | $cols, $rows[] | @csv",
      "(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.]|tostring)) as $rows | $cols, $rows[] | @csv",
      "(map(keys_unsorted) | add | unique) as $cols | $cols, (.[] | [.[$cols[]]] | map(. // \"null\")) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "date": "2014-05-05T19:07:48.577"
          },
          {
            "id": 2,
            "date": null
          }
        ],
        "output": [
          "\"date\",\"id\"",
          "\"2014-05-05T19:07:48.577\",1",
          "\"null\",2"
        ]
      }
    ],
    "identifier": 68042332,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have JSON looking like that:\r\n[\r\n  {\r\n    \"file\": \"aaa.txt\",\r\n    \"destination\": 1\r\n  },\r\n  {\r\n    \"file\": \"bbb.txt\",\r\n    \"destination\": 2\r\n  },\r\n  {\r\n    \"file\": \"ccc.txt\",\r\n    \"destination\": 3\r\n  },\r\n  {\r\n    \"file\": \"ddd.txt\",\r\n    \"destination\": 4\r\n  },\r\n  {\r\n    \"file\": \"eee.txt\",\r\n    \"destination\": 9\r\n  }\r\n]",
      "I want to build while loop from 5 to 1 to put file value into (nomen omen) file (script in the loop should create file called [destination] with [file] as content (example: for firstone file should by called 1 with aaa.txt as a content).",
      "Can you help me please?",
      "while IFS= read -r destination; do\n    IFS= read -r file\n    printf \"%s\" \"$file\" > \"$destination\"\ndone < <(jq -r '.[] | .destination,.file' input.json )"
    ],
    "utterance": "Extract destination and file values in order from the data so that each destination value and its corresponding file value can be used in a loop.",
    "expressions": [
      ".[] | .destination,.file",
      "-r '.[] | .destination,.file'"
    ],
    "data": [
      {
        "input": [
          {
            "file": "aaa.txt",
            "destination": 1
          },
          {
            "file": "bbb.txt",
            "destination": 2
          },
          {
            "file": "ccc.txt",
            "destination": 3
          },
          {
            "file": "ddd.txt",
            "destination": 4
          },
          {
            "file": "eee.txt",
            "destination": 9
          }
        ],
        "output": [
          1,
          "aaa.txt",
          2,
          "bbb.txt",
          3,
          "ccc.txt",
          4,
          "ddd.txt",
          9,
          "eee.txt"
        ]
      }
    ],
    "identifier": 68051269,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have thousands of individually named `json` files in a single windows directory. I&#39;m trying to use `jq` to merge them all into a single file I can then import into a jupyter notebook.",
      "jq --slurp &#39;map(.[])&#39; bill",
      "jq --slurp &#39;map(.[])&#39; bill/*.json",
      "cat bill/a.json bill/b.json bill/c.json | jq --slurp 'map(.[])'",
      "find bill -mindepth 1 -maxdepth 1 -name '*.json' -exec cat {} \\; | jq --slurp 'map(.[])'",
      "jq --slurp 'map(.[])' bill\\*.json",
      "copy /y nul+bill\\*.json bill.jsonl\njq --slurp \"map(.[])\" bill.jsonl\ndel bill.jsonl",
      "%{ Get-Content bill\\*.json } | jq --slurp 'map(.[])'"
    ],
    "utterance": "Combine the contents of many files located in a directory named 'bill', where each file contains an array, into a single array containing all the items from all the files.",
    "expressions": [
      "jq --slurp 'map(.[])' bill/*.json",
      "cat bill/*.json | jq --slurp 'map(.[])'",
      "find bill -mindepth 1 -maxdepth 1 -name '*.json' -exec cat {} \\; | jq --slurp 'map(.[])'",
      "jq --slurp 'map(.[])' bill\\*.json",
      "copy /y nul+bill\\*.json bill.jsonl && jq --slurp \"map(.[])\" bill.jsonl && del bill.jsonl",
      "%{ Get-Content bill\\*.json } | jq --slurp 'map(.[])'"
    ],
    "identifier": 68062772,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": true,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I would like to transform it into\n{\n  \"title\": \"title 1\",\n  \"description\": \"desc 1\",\n  \"message\": \"msg 1\",\n  \"data\": [\n           {\"region 1\":\"resource 1\"},\n           {\"region 2\":\"resource 2\"}\n          ]\n}",
      "My idea would be to transform the json and make title, description, message that are repeating unique (thus removing the duplicate) while keeping the changing region and resources into a data object.",
      "My current query is\njq '.[] | {title : .title, description : .description, message : .message, data: [{region: .region, resource: .resource}] } | group_by(.title,.description,.message)'",
      "jq -s '[.[]\n        | { title : .title,\n            description : .description,\n            message : .message,\n            data: [{region: [.region], resource: [.resource]}]\n          }\n       ]\n       | group_by(.title, .descripiton, .message)\n       | .[]\n       | { title: .[0].title,\n           description: .[0].description,\n           message: .[0].message,\n           data:{\n               region: [.[].data[].region | add],\n               resource: [.[].data[].resource | add]\n           }}'",
      "map( . + {data: [{region: [.region], resource: [.resource]}]}\n     | del(.region, .resource) )\n| group_by(.title, .description, .message)[]\n| .[0] +\n    { data: {\n        region:   [.[].data[].region   | add],\n        resource: [.[].data[].resource | add]\n      }\n    }"
    ],
    "utterance": "Transform a sequence of objects with duplicate title, description, and message into a single object per group with matching values, consolidating the differing region and resource pairs into a data array.",
    "expressions": [
      "jq -s '[.[]\n        | { title : .title,\n            description : .description,\n            message : .message,\n            data: [{region: [.region], resource: [.resource]}]\n          }\n       ]\n       | group_by(.title, .description, .message)\n       | .[]\n       | { title: .[0].title,\n           description: .[0].description,\n           message: .[0].message,\n           data: [range(0; length) as $i | { (.[ $i ].region): .[ $i ].resource }]}'",
      "map( . + {data: [{region: [.region], resource: [.resource]}]}\n     | del(.region, .resource) )\n| group_by(.title, .description, .message)[]\n| .[0] + {\n    data: [.[].data[] | { (.region[0]): .resource[0] }] \n}"
    ],
    "data": [
      {
        "input": [
          {
            "title": "title 1",
            "description": "desc 1",
            "message": "msg 1",
            "region": "region 1",
            "resource": "resource 1"
          },
          {
            "title": "title 1",
            "description": "desc 1",
            "message": "msg 1",
            "region": "region 2",
            "resource": "resource 2"
          }
        ],
        "output": {
          "title": "title 1",
          "description": "desc 1",
          "message": "msg 1",
          "data": [
            {
              "region 1": "resource 1"
            },
            {
              "region 2": "resource 2"
            }
          ]
        }
      }
    ],
    "identifier": 68064881,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "So instead, I\u2019d like to match based on the `Id` property.",
      "How can I filter an array for a field that has a certain value, and still output the whole document?",
      ".ETag = \"\"\n| .DistributionConfig.Origins.Items[] |=\n   if .Id == \"redacted-2\" then .OriginPath = \"myvalue\" else . end",
      ".ETag = \"\"\n    | (.DistributionConfig.Origins.Items[] | \n          select(.Id == \"redacted-2\")\n      ).OriginPath = \"foo\""
    ],
    "utterance": "Update the OriginPath field to a specified value for the item in DistributionConfig.Origins.Items whose Id field is 'redacted-2', and set the ETag field to an empty string, outputting the entire modified document.",
    "expressions": [
      ".ETag = \"\" | .DistributionConfig.Origins.Items[] |= if .Id == \"redacted-2\" then .OriginPath = \"myvalue\" else . end",
      ".ETag = \"\" | (.DistributionConfig.Origins.Items[] | select(.Id == \"redacted-2\")).OriginPath = \"foo\""
    ],
    "data": [
      {
        "input": {
          "ETag": "REDACTED",
          "DistributionConfig": {
            "Origins": {
              "Quantity": 2,
              "Items": [
                {
                  "Id": "redacted-1",
                  "DomainName": "redacted1.us-east-1.amazonaws.com",
                  "OriginPath": "/redacted"
                },
                {
                  "Id": "redacted-2",
                  "DomainName": "redacted2.s3.amazonaws.com",
                  "OriginPath": ""
                }
              ]
            }
          }
        },
        "output": {
          "ETag": "",
          "DistributionConfig": {
            "Origins": {
              "Quantity": 2,
              "Items": [
                {
                  "Id": "redacted-1",
                  "DomainName": "redacted1.us-east-1.amazonaws.com",
                  "OriginPath": "/redacted"
                },
                {
                  "Id": "redacted-2",
                  "DomainName": "redacted2.s3.amazonaws.com",
                  "OriginPath": "myvalue"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 68074046,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "aws ecr list-images --repository-name itaig | jq -r --arg travis_branch ${TRAVIS_BRANCH} --arg travis_build_number ${TRAVIS_BUILD_NUMBER}  '.imageIds[] | select(.imageTag==\"$travis_branch-$travis_build_number\") .imageDigest'",
      "If I don't use args, it works like a charm:",
      "aws ecr list-images --repository-name itaig | jq -r '.imageIds[] | select(.imageTag==\"main-49\") .imageDigest'",
      "jq -r --arg travis_search \"$TRAVIS_BRANCH-$TRAVIS_BUILD_NUMBER\" '.imageIds[] | select(.imageTag == $travis_search) | .imageDigest'",
      ".imageIds[] | select(.imageTag == \"\\($travis_branch)-\\($travis_build_number)\") | .imageDigest"
    ],
    "utterance": "Extract the imageDigest where imageTag equals the concatenation of the current branch and build number, such as main-49.",
    "expressions": [
      ".imageIds[] | select(.imageTag == \"$travis_branch-$travis_build_number\") | .imageDigest",
      ".imageIds[] | select(.imageTag == $travis_search) | .imageDigest",
      ".imageIds[] | select(.imageTag == \"\\($travis_branch)-\\($travis_build_number)\") | .imageDigest"
    ],
    "data": [
      {
        "input": {
          "imageIds": [
            {
              "imageDigest": "sha256:ec2ad330fadaf1ef05e30b8ba1ee5a92efb8b39c8d51bbcfb706b1b1a1981020",
              "imageTag": "latest"
            },
            {
              "imageDigest": "sha256:9377451ac4ea941e49d3176457b3d285d6418fec883a9a8fee87a491b79ac06a"
            },
            {
              "imageDigest": "sha256:1fb63f185c11a3300d394f83f8152d391b5f37ee3b17b73702296e979fb42576"
            },
            {
              "imageDigest": "sha256:4fc44daf69561482c9b00858b1a60e6590444703b75d49fed7d46c025520ddac"
            },
            {
              "imageDigest": "sha256:ce109ba9df0e566a4bd9d0a8311596b61def59d51c1b42455170dcb41451f4b0",
              "imageTag": "main-48"
            },
            {
              "imageDigest": "sha256:928950d4cab36d434f99e65bb75e65e4a6218760b1a32a08ac7212b2b6b9b9b0",
              "imageTag": "main-49"
            },
            {
              "imageDigest": "sha256:30a7f57f1a8aea4b00a441fff139806662342f0b584651231ed99738bf9d00b8"
            },
            {
              "imageDigest": "sha256:2319a7b3d5a030cc22efc06be780d6789cbf575822dd96bffbb550e3d20faefd"
            }
          ]
        },
        "output": "sha256:928950d4cab36d434f99e65bb75e65e4a6218760b1a32a08ac7212b2b6b9b9b0"
      }
    ],
    "identifier": 68074909,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I need to delete the first and second items as they don't have the key \"Case\".",
      "Just figured out my solution:",
      "del(.[] | select(.Case == null))",
      "This can be achieved by keeping the elements that have `.Case` defined.",
      "map(select(.Case != null))",
      "If `.Case == false` won't be encountered, the above simplifies to",
      "map(select(.Case))"
    ],
    "utterance": "Remove all elements that do not have the key Case.",
    "expressions": [
      "del(.[] | select(.Case == null))",
      "map(select(.Case != null))",
      "map(select(.Case))"
    ],
    "data": [
      {
        "input": [
          {
            "label": "US : USA : English",
            "Country": "USA",
            "region": "US",
            "Language": "English",
            "locale": "en",
            "currency": "USD",
            "number": "USD"
          },
          {
            "label": "AU : Australia : English",
            "Country": "Australia",
            "region": "AU",
            "Language": "English",
            "locale": "en",
            "currency": "AUD",
            "number": "AUD"
          },
          {
            "Case": "1",
            "label": "CA : Canada : English",
            "Country": "Canada",
            "region": "CA",
            "Language": "English",
            "locale": "en",
            "currency": "CAD",
            "number": "CAD"
          }
        ],
        "output": [
          {
            "Case": "1",
            "label": "CA : Canada : English",
            "Country": "Canada",
            "region": "CA",
            "Language": "English",
            "locale": "en",
            "currency": "CAD",
            "number": "CAD"
          }
        ]
      }
    ],
    "identifier": 68075040,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "how to find an element given a condition and modify one of its fields.  The doc should be fully output (`sed` style) with the edit made.",
      "Pipe the output of `.steps[][]` into a `select` call that chooses the objects with the desired `name` and `state` values, then set the `state` value on the result.",
      "$ jq '(.steps[][] | select(.name == \"Foo\" and .state == \"wait\")).state = \"ready\"' tmp.json"
    ],
    "utterance": "Update the field 'state' to 'ready' for all objects with 'name' equal to 'Foo' and 'state' equal to 'wait' within arrays nested in the 'steps' object, and output the whole document with the change.",
    "expressions": [
      "(.steps[][] | select(.name == \"Foo\" and .state == \"wait\")).state = \"ready\""
    ],
    "data": [
      {
        "input": {
          "state": "wait",
          "steps": {
            "step1": [
              {
                "name": "Foo",
                "state": "wait"
              },
              {
                "name": "Bar",
                "state": "wait"
              }
            ],
            "step2": [
              {
                "name": "Foo",
                "state": "wait"
              },
              {
                "name": "Zoinks",
                "state": "ready"
              }
            ],
            "step3": [
              {
                "name": "Foo",
                "state": "cancel"
              }
            ]
          }
        },
        "output": {
          "state": "wait",
          "steps": {
            "step1": [
              {
                "name": "Foo",
                "state": "ready"
              },
              {
                "name": "Bar",
                "state": "wait"
              }
            ],
            "step2": [
              {
                "name": "Foo",
                "state": "ready"
              },
              {
                "name": "Zoinks",
                "state": "ready"
              }
            ],
            "step3": [
              {
                "name": "Foo",
                "state": "cancel"
              }
            ]
          }
        }
      }
    ],
    "identifier": 68075978,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Let&#39;s say I have two input JSON files.",
      "I&#39;d like to create a logic that when `.[].name` from the first file is equals to `.features[].name` from the second file I concatenate its corresponding keys from the first file on the second file (considering that the value of `.[].name` on the first file is always unique).",
      "Is it possible to do with jq? Can I work with two JSON files in a way that I get parameters from one file to give it to another one?",
      "Yeah, just save the first one in a variable.",
      "INDEX(.name) as $p | inputs | .features |= map($p[.name] + .)"
    ],
    "utterance": "For each object in the features array in the second input, append the key-value pairs (except 'name') from the first input where the 'name' fields match.",
    "expressions": [
      "INDEX(.name) as $p | inputs | .features |= map($p[.name] + .)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "one",
              "keyB": "2",
              "keyC": "3"
            },
            {
              "name": "two",
              "keyB": "15",
              "keyC": "20"
            }
          ],
          {
            "name": "one",
            "type": "FeatureCollection",
            "features": [
              {
                "name": "one",
                "valueA": "0",
                "valueB": "0"
              },
              {
                "name": "two",
                "valueA": "11",
                "valueB": "21"
              },
              {
                "name": "one",
                "valueA": "21",
                "valueB": "30"
              },
              {
                "name": "two",
                "valueA": "1",
                "valueB": "2"
              },
              {
                "name": "one",
                "valueA": "2",
                "valueB": "3"
              },
              {
                "name": "two",
                "valueA": "5",
                "valueB": "3"
              }
            ]
          }
        ],
        "output": {
          "name": "one",
          "type": "FeatureCollection",
          "features": [
            {
              "name": "one",
              "valueA": "0",
              "valueB": "0",
              "keyB": "2",
              "keyC": "3"
            },
            {
              "name": "two",
              "valueA": "11",
              "valueB": "21",
              "keyB": "15",
              "keyC": "20"
            },
            {
              "name": "one",
              "valueA": "21",
              "valueB": "30",
              "keyB": "2",
              "keyC": "3"
            },
            {
              "name": "two",
              "valueA": "1",
              "valueB": "2",
              "keyB": "15",
              "keyC": "20"
            },
            {
              "name": "one",
              "valueA": "2",
              "valueB": "3",
              "keyB": "2",
              "keyC": "3"
            },
            {
              "name": "two",
              "valueA": "5",
              "valueB": "3",
              "keyB": "15",
              "keyC": "20"
            }
          ]
        }
      }
    ],
    "identifier": 68076934,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "My jenkins pipeline needs to manipulate **.updateApp.json** and set the name of an S3 bucket that contains **colons** as a value to the key `BucketARNUpdate`",
      "My second approach was using the --arg argument and I tried",
      "`sh(script: 'jq --arg var \\\"${arn}\\\"  \".BucketARNUpdate=${var}\" .updateApp.json', returnStdout: true)`",
      "One can only use the abbreviated form `.foo` if the key name is alphanumeric...",
      "The basic form for referring to the value of a key named \"KEY\" is `.[\"KEY\"]`, but recent versions of jq also allow `.\"KEY\"`.",
      "Your second approach, however, is perhaps safer.  Again ignoring whatever escapes may be required by jenkins, the invocation would look like this:",
      "jq --arg var \"${arn}\"  '[\"BucketARNUpdate=\"] + $var' .updateApp.json"
    ],
    "utterance": "Set the value of the key BucketARNUpdate to a string containing colons (e.g., an S3 bucket ARN) in the file .updateApp.json.",
    "expressions": [
      ".BucketARNUpdate = $var",
      ".[\"BucketARNUpdate\"] = $var"
    ],
    "identifier": 68078448,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "How do I get it to set .circulationNotes.id a uuid when it is null (or any number of elements) while returning the full document so I get:",
      "Try\n\n    jq --arg CHECKIN $(uuidgen)  '(.permanentLocation.id = \"1d0ec5e4-ba80-4eb9-8b0c-53da40d6335b\")| (.circulationNotes[] |(select(.noteType == \"Check in\" and .id == null) | .id)) = $CHECKIN'"
    ],
    "utterance": "Update all elements in the circulationNotes array so that elements with noteType equal to \"Check in\" and id null have their id set to a specified uuid, while also setting permanentLocation.id to a specific value, and return the full modified document.",
    "expressions": [
      "(.permanentLocation.id = \"1d0ec5e4-ba80-4eb9-8b0c-53da40d6335b\")|(.circulationNotes[]|(select(.noteType == \"Check in\" and .id == null)|.id)) = $CHECKIN"
    ],
    "data": [
      {
        "input": {
          "circulationNotes": [
            {
              "id": null,
              "noteType": "Check in",
              "note": "Original location pmgd1 Gov. Documents - 2nd Fl.",
              "staffOnly": true,
              "source": {
                "id": "affd2a52-2f04-40e3-8da3-37c2de08e338",
                "personal": {
                  "lastName": "Data",
                  "firstName": "Migration"
                }
              },
              "date": null
            },
            {
              "id": null,
              "noteType": "Check out",
              "note": "Original location pmgd1 Gov. Documents - 2nd Fl.",
              "staffOnly": true,
              "source": {
                "id": "affd2a52-2f04-40e3-8da3-37c2de08e338",
                "personal": {
                  "lastName": "Data",
                  "firstName": "Migration"
                }
              },
              "date": null
            }
          ],
          "permanentLoanType": {
            "id": "cf424b8f-ae2b-4d01-8365-b412c7815ba9",
            "name": "PML 1st Fl. - Circulating"
          }
        },
        "output": {
          "circulationNotes": [
            {
              "id": "bd5379f7-69fc-48f5-8461-8dcc59883ae0",
              "noteType": "Check in",
              "note": "Original location pmgd1 Gov. Documents - 2nd Fl.",
              "staffOnly": true,
              "source": {
                "id": "affd2a52-2f04-40e3-8da3-37c2de08e338",
                "personal": {
                  "lastName": "Data",
                  "firstName": "Migration"
                }
              },
              "date": null
            },
            {
              "id": "33f60901-33a8-43d1-a2ce-e22d8be87d15",
              "noteType": "Check out",
              "note": "Original location pmgd1 Gov. Documents - 2nd Fl.",
              "staffOnly": true,
              "source": {
                "id": "affd2a52-2f04-40e3-8da3-37c2de08e338",
                "personal": {
                  "lastName": "Data",
                  "firstName": "Migration"
                }
              },
              "date": null
            }
          ],
          "permanentLoanType": {
            "id": "cf424b8f-ae2b-4d01-8365-b412c7815ba9",
            "name": "PML 1st Fl. - Circulating"
          },
          "permanentLocation": {
            "id": "1d0ec5e4-ba80-4eb9-8b0c-53da40d6335b"
          }
        }
      }
    ],
    "identifier": 68085571,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I need to add `\"TAGS\":{}` to encompass these two fields: `BATCH_TAG` and `TASK_TYPE_NAME`, so the desired output looks like this:",
      "The tricky bit here is ensuring the new TAGS key is inserted in the desired position.  Using jq, this can be done with `with_entries`:",
      "if has(\"BATCH_TAG\")\nthen .BATCH_TAG = {BATCH_TAG, TASK_TYPE_NAME}\n| with_entries(.key |= if . == \"BATCH_TAG\" \n                       then \"TAGS\"\n                       else . end)\n| del(.TASK_TYPE_NAME)\nelse .\nend"
    ],
    "utterance": "Combine BATCH_TAG and TASK_TYPE_NAME fields into a single TAGS object at the BATCH_TAG position in each object, then remove TASK_TYPE_NAME.",
    "expressions": [
      "if has(\"BATCH_TAG\")\nthen .BATCH_TAG = {BATCH_TAG, TASK_TYPE_NAME}\n| with_entries(.key |= if . == \"BATCH_TAG\" then \"TAGS\" else . end)\n| del(.TASK_TYPE_NAME)\nelse .\nend"
    ],
    "data": [
      {
        "input": {
          "LAST_MODIFIED_BY": "john",
          "CREATED_BY": "david",
          "LAST_MODIFIED_DATE": "2018-01-11T06:39:11.000Z",
          "CREATION_DATE": "2018-01-11T06:39:11.000Z",
          "INGESTION_DATE": "2018-01-11T06:39:11.000Z",
          "DECISION": "AGREE",
          "BATCH_TAG": "",
          "TASK_TYPE_NAME": "Test",
          "PUBLISHER_ID": "abc123",
          "ID": "700adca2-c4d4-4245-8174-0479f7123a63"
        },
        "output": {
          "LAST_MODIFIED_BY": "john",
          "CREATED_BY": "david",
          "LAST_MODIFIED_DATE": "2018-01-11T06:39:11.000Z",
          "CREATION_DATE": "2018-01-11T06:39:11.000Z",
          "INGESTION_DATE": "2018-01-11T06:39:11.000Z",
          "DECISION": "AGREE",
          "TAGS": {
            "BATCH_TAG": "",
            "TASK_TYPE_NAME": "Test"
          },
          "PUBLISHER_ID": "abc123",
          "ID": "700adca2-c4d4-4245-8174-0479f7123a63"
        }
      }
    ],
    "identifier": 68088473,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Is there a way to merge two JSON files on a key but preserve empty keys, preferably in JQ?",
      "The files are merged on `url`.",
      "Desired result:",
      "{\n  \"url\": \"ABC\",\n  \"title\": \"\",\n  \"name\": \"Search\",\n  \"version\": \"2020\",\n  \"Ocurrences\": \"25\"\n},\n{\n  \"url\": \"DEF\",\n  \"title\": \"Support\",\n  \"name\": \"Welcome\",\n  \"version\": \"2021\",\n  \"Ocurrences\": \"10\"\n},\n{\n  \"url\": \"GHI\",\n  \"title\": \"Contact\",\n  \"name\": \"\",\n  \"version\": \"\",\n  \"Ocurrences\": \"\"\n}",
      "Current JQ script:",
      "jq -M '[group_by(.url)[]|add]' fi1e1.json file2.json > output.json",
      "Current result:",
      "{\n  \"url\": \"ABC\",\n  \"name\": \"Search\",\n  \"version\": \"2020\",\n  \"Ocurrences\": \"25\"\n},\n{\n  \"url\": \"DEF\",\n  \"title\": \"Support\",\n  \"name\": \"Welcome\",\n  \"version\": \"2021\",\n  \"Ocurrences\": \"10\"\n},\n{\n  \"url\": \"GHI\",\n  \"title\": \"Contact\"\n}",
      "Using `reduce` avoids the sorting that is entailed by `group_by`.  For example, you could write:",
      ". as $one\n| input as $two\n| ($one[0] + $two[0] | map_values(\"\") ) as $defaults\n| INDEX($one[]; .url) as $one\n| INDEX($two[]; .url) as $two\n| reduce ($one+$two|keys_unsorted)[] as $k ({}; \n    .[$k] = ($defaults + $one[$k] + $two[$k]) )\n| [.[]]"
    ],
    "utterance": "Merge two arrays of objects on the 'url' key, ensuring that missing fields in any merged object are present with empty string values.",
    "expressions": [
      ". as $one\n| input as $two\n| ($one[0] + $two[0] | map_values(\"\") ) as $defaults\n| INDEX($one[]; .url) as $one\n| INDEX($two[]; .url) as $two\n| reduce ($one+$two|keys_unsorted)[] as $k ({}; \n    .[$k] = ($defaults + $one[$k] + $two[$k]) )\n| [.[]]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "url": "ABC",
              "name": "Search",
              "version": "2020",
              "Ocurrences": "25"
            },
            {
              "url": "DEF",
              "name": "Welcome",
              "version": "2021",
              "Ocurrences": "10"
            }
          ],
          [
            {
              "url": "DEF",
              "title": "Support"
            },
            {
              "url": "GHI",
              "title": "Contact"
            }
          ]
        ],
        "output": [
          {
            "url": "ABC",
            "title": "",
            "name": "Search",
            "version": "2020",
            "Ocurrences": "25"
          },
          {
            "url": "DEF",
            "title": "Support",
            "name": "Welcome",
            "version": "2021",
            "Ocurrences": "10"
          },
          {
            "url": "GHI",
            "title": "Contact",
            "name": "",
            "version": "",
            "Ocurrences": ""
          }
        ]
      }
    ],
    "identifier": 68092167,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "the script fills the field \"file\" with .o instead of .c files",
      "How shall I modified the script for having the `.c` files instead of the `.o` files in the field `\"file\"`?",
      "If it's known there's at most one .c file, and that it is reasonably named (e.g., no embedded spaces), then it would be simplest to \"capture\" the filename along these lines:\n\n    capture(\"(^| )(?<c>[^ ]+[.]c)( |$)\")",
      "However, if there might be more than one .c file, then you could iteratively use the following \"capture\" expression:\n\n    capture(\"(^| )(?<c>[^ ]+[.]c)( |$)(?<etc>.*)\")",
      "def filenames($suffix):\n  def one:\n    capture(\"(^| )(?<c>[^ ]+[.]\"+$suffix+\" )( |$) *(?<etc>.*)\");\n  def names:\n    one | .c, (.etc | names);\n  names;"
    ],
    "utterance": "Extract the .c source file path from each compile command line and use it as the value for the 'file' field in the output.",
    "expressions": [
      "match(\" [^ ]+\\.c\").string[1:]",
      "capture(\"(^| )(?<c>[^ ]+[.]c)( |$)\").c"
    ],
    "data": [
      {
        "input": "  /cygwin/c/Dev/bin/tricore-gcc.exe   -isystem     all_inc     -W     -Wall  -c     software/ProjectA/src/file1.c     -o     _objs/ccLib/file1.o",
        "output": "software/ProjectA/src/file1.c"
      }
    ],
    "identifier": 68105261,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I&#39;m trying to get this output the device name &quot;test&quot;",
      "My filter is `.[] | [.deviceName]` and it&#39;s returning error: (at &lt;stdin&gt;:7): `Cannot index array with string &quot;deviceName&quot;`",
      "Presumably you meant:\r\n\r\n    jq &#39;.test[] | [.deviceName]&#39;",
      "or perhaps:\r\n\r\n    jq &#39;.[][] | [.deviceName]&#39;"
    ],
    "utterance": "Extract the deviceName value 'test' from an object whose key is 'test' and holds an array of devices.",
    "expressions": [
      ".test[] | [.deviceName]",
      ".[][] | [.deviceName]"
    ],
    "data": [
      {
        "input": {
          "test": [
            {
              "deviceName": "test",
              "monitoringServer": "server1"
            }
          ]
        },
        "output": [
          [
            "test"
          ]
        ]
      }
    ],
    "identifier": 68105706,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Given a huge (15GB) deeply nested (12+ object layers) JSON file how can I find the paths to all the keys named `id` whose values are type `string`?",
      "jq --stream 'select(.[0][-1] == \"id\" and (.[1] | strings)) | .[0]' file",
      "jq 'path(.. .id? | strings)' file",
      "jq --stream '\nselect(.[0][-1] == \"id\" and (.[1]|type) == \"string\")[0]\n  | join(\".\")\n' huge.json",
      "jq --stream -c 'select(.[0][-1] == \"id\" and (.[1]|type) == \"string\")' huge.json"
    ],
    "utterance": "List the paths to all keys named id where the corresponding value is a string.",
    "expressions": [
      "jq --stream 'select(.[0][-1] == \"id\" and (.[1] | strings)) | .[0]' file",
      "jq 'path(.. .id? | strings)' file",
      "jq --stream 'select(.[0][-1] == \"id\" and (.[1]|type) == \"string\")[0] | join(\".\")' huge.json",
      "jq --stream -c 'select(.[0][-1] == \"id\" and (.[1]|type) == \"string\")' huge.json"
    ],
    "data": [
      {
        "input": {
          "a": [
            {
              "id": 3,
              "foo": "red"
            }
          ],
          "b": [
            {
              "id": "7",
              "bar": "orange",
              "baz": {
                "id": 13
              },
              "bax": {
                "id": "12"
              }
            }
          ]
        },
        "output": [
          [
            "b",
            0,
            "id"
          ],
          [
            "b",
            0,
            "bax",
            "id"
          ]
        ]
      }
    ],
    "identifier": 68109003,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "What I hope to get : \r\n\r\n```\r\n[{ \"id\": \"200\", \"project_name\": \"spring-boot-remove\", \"project_path\": \"agpm / templates / ansible / spring-boot-remove\", \"project_variables\": \"[]\" },\r\n{ \"id\": \"199\", \"project_name\": \"agpm-gitleaks\", \"project_path\": \"DevSecOps / agpm-gitleaks\", \"project_variables\": \"[]\" },\r\n{ \"id\": \"198\", \"project_name\": \"haproxy\", \"project_path\": \"Infra / Projets / nexo / haproxy\", \"project_variables\": \"[]\" }]\r\n```",
      "This is because you produce the JSON object line by line in a bash read loop. I think the fastest way to achieve your goal is dealing with the output file (`variables_projects.json`).",
      "```\r\njq -s . variables_projects.json | sponge variables_projects.json\r\n```",
      "For a compact output, add the `-c` option:\r\n```\r\njq -cs . variables_projects.json | sponge variables_projects.json\r\n```"
    ],
    "utterance": "Combine multiple newline-delimited objects in a file into a single array.",
    "expressions": [
      "jq -s . variables_projects.json",
      "jq -cs . variables_projects.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": "200",
            "project_name": "spring-boot-remove",
            "project_path": "agpm / templates / ansible / spring-boot-remove",
            "project_variables": "[]"
          },
          {
            "id": "199",
            "project_name": "agpm-gitleaks",
            "project_path": "DevSecOps / agpm-gitleaks",
            "project_variables": "[]"
          },
          {
            "id": "198",
            "project_name": "haproxy",
            "project_path": "Infra / Projets / nexo / haproxy",
            "project_variables": "[]"
          }
        ],
        "output": [
          {
            "id": "200",
            "project_name": "spring-boot-remove",
            "project_path": "agpm / templates / ansible / spring-boot-remove",
            "project_variables": "[]"
          },
          {
            "id": "199",
            "project_name": "agpm-gitleaks",
            "project_path": "DevSecOps / agpm-gitleaks",
            "project_variables": "[]"
          },
          {
            "id": "198",
            "project_name": "haproxy",
            "project_path": "Infra / Projets / nexo / haproxy",
            "project_variables": "[]"
          }
        ]
      }
    ],
    "identifier": 68111789,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "My json looks like the following \n[\n  {\n    \"100\": \"ONE\",\n    \"200\": \"TWO\"\n  },\n  {\n    \"100\": \"1\",\n    \"200\": \"2\"\n  }\n]\n\nand I am expecting the following output\n\n{\n  \"1\": \"ONE\",\n  \"2\": \"TWO\"\n} \n",
      "Here is one way:\n. as [$V, $K]\n| reduce ($K | keys_unsorted)[] as $k ({};\n  . + {($K[$k]): $V[$k]}\n)\nThis iterates over the second object's keys, retrieves values associated with each key in both objects, and pairs them in a new one.",
      "Here's a reduce-free solution to the first problem that hopefully also elucidates the general approach:\n.[0] as $dict\n| .[1]\n| with_entries( {value: $dict[.key], key: (.value|tostring) } )"
    ],
    "utterance": "Combine two objects in an array by using the values from the second object as keys and values from corresponding keys in the first object as values.",
    "expressions": [
      ". as [$V, $K]\n| reduce ($K | keys_unsorted)[] as $k ({};\n  . + {($K[$k]): $V[$k]}\n)",
      ".[0] as $dict\n| .[1]\n| with_entries( {value: $dict[.key], key: (.value|tostring) } )"
    ],
    "data": [
      {
        "input": [
          {
            "100": "ONE",
            "200": "TWO"
          },
          {
            "100": "1",
            "200": "2"
          }
        ],
        "output": {
          "1": "ONE",
          "2": "TWO"
        }
      }
    ],
    "identifier": 68112580,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "echo \"$REPOS\" | jq -r '.repositories[].repositoryName' | while read name ; do\n    git clone ssh://git-codecommit.us-east-1.amazonaws.com/v1/repos/$name\ndone",
      "I wasn't considering the 'repositories' field in jq.....",
      "Returns a json like this:\n{ \"repositories\": [\n  { \"repositoryName\": \"repo_a\", \"repositoryId\": \"XXXXXX\" },\n  { \"repositoryName\": \"repo_b\", \"repositoryId\": \"XXXXXX\" },\n  { \"repositoryName\": \"repo_c\", \"repositoryId\": \"XXXXXX\" },\n  { \"repositoryName\": \"repo_d\", \"repositoryId\": \"XXXXXX\" }\n]\n}"
    ],
    "utterance": "List all repository names by extracting the repositoryName field from every element in the repositories array.",
    "expressions": [
      ".repositories[].repositoryName",
      ".repositories[].repositoryName | @text"
    ],
    "data": [
      {
        "input": {
          "repositories": [
            {
              "repositoryName": "repo_a",
              "repositoryId": "XXXXXX"
            },
            {
              "repositoryName": "repo_b",
              "repositoryId": "XXXXXX"
            },
            {
              "repositoryName": "repo_c",
              "repositoryId": "XXXXXX"
            },
            {
              "repositoryName": "repo_d",
              "repositoryId": "XXXXXX"
            }
          ]
        },
        "output": [
          "repo_a",
          "repo_b",
          "repo_c",
          "repo_d"
        ]
      }
    ],
    "identifier": 68121082,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "The working code which outputs the value at the specified key\n```\njq '.regions.\"us-west-2\"' ids.json \n```",
      "The code that's outputting `null`\n```\njq --arg region \"us-east-1\" '.regions.\"$region\"' ids.json\n```",
      "Use the index notation instead of the dot notation:\n```bash\njq --arg region \"us-east-1\" '.regions[$region]' ids.json\n```"
    ],
    "utterance": "Retrieve the value for the region key specified by a variable passed with --arg.",
    "expressions": [
      ".regions[$region]"
    ],
    "identifier": 68134398,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want it to replace the file it reads from.",
      "What I'm doing here is invoking PowerShell to handle the minification, and using the Set-Content cmdlet.",
      "PowerShell users can use SetContent:",
      "You can't overwrite the file you are reading from, because the first action will be the (re)creation of the file by the redirection, then `jq` will read from an empty file.",
      "Just redirect to a temporary file and replace the original file after finishing.",
      "One easy fix suggested there is using `sponge` from [`moreutils`](https://joeyh.name/code/moreutils/).",
      "`$ jq . my.json | sponge my.json`"
    ],
    "utterance": "Replace each file with its minified contents by processing all *.json files in-place.",
    "expressions": [
      "powershell -Command \"& {jq . --unbuffered --compact-output \\\"%%f\\\" | Set-Content \\\"%%f\\\"}\"",
      "jq . --unbuffered --compact-output \"input.json\" | sponge input.json",
      "jq . --unbuffered --compact-output \"input.json\" > temp.json && move /Y temp.json input.json"
    ],
    "identifier": 68135435,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": true,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Am trying to replace the slug entries in \"fromRef\" & \"toRef\"  from dummyrepo1 to dummyrepo2 using the below code",
      "Am expecting the output  as \n    {\n          \"title\": \"test comment\"\n          \"description: \"testing\"\n          \"fromRef\": {\n             \"id\": \"refs/heads/testbranch\"\n              \"repository\" : {\n                \"slug\": \"dummyrepo2\"\n                \"project\": {\n                     \"key\": \"TEST\"\n                  }\n                 }\n              },\n           \"toRef\":{\n              \"id\": \"refs/heads/master\"\n               \"repository\" : {\n               \"slug\" : \"dummyrepo2\"\n               \"project\": {\n                    \"key\": \"TEST\"\n                 }\n               }\n             }\n        }",
      "After making your input json valid, I could correct your update statement for `slug` in `fromRef` and `toRef`:",
      "jq --arg update_slug 'dummyrepo2' '\n  .fromRef.repository.slug |= $update_slug\n  | .toRef.repository.slug |= $update_slug\n' <<< \"$JSON\""
    ],
    "utterance": "Replace both fromRef.repository.slug and toRef.repository.slug from dummyrepo1 to dummyrepo2",
    "expressions": [
      ".fromRef.repository.slug |= $update_slug | .toRef.repository.slug |= $update_slug"
    ],
    "data": [
      {
        "input": {
          "title": "test comment",
          "description": "testing",
          "fromRef": {
            "id": "refs/heads/testbranch",
            "repository": {
              "slug": "dummyrepo1",
              "project": {
                "key": "TEST"
              }
            }
          },
          "toRef": {
            "id": "refs/heads/master",
            "repository": {
              "slug": "dummyrepo1",
              "project": {
                "key": "TEST"
              }
            }
          }
        },
        "output": {
          "title": "test comment",
          "description": "testing",
          "fromRef": {
            "id": "refs/heads/testbranch",
            "repository": {
              "slug": "dummyrepo2",
              "project": {
                "key": "TEST"
              }
            }
          },
          "toRef": {
            "id": "refs/heads/master",
            "repository": {
              "slug": "dummyrepo2",
              "project": {
                "key": "TEST"
              }
            }
          }
        }
      }
    ],
    "identifier": 68142795,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "To do just that, how to convert a multi-level JSON including arrays to a prepared SQL STATEMENT using just `jq`?",
      "Expected SQL statement:",
      "INSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES \n(2020-09-10,4170,1,0,-1,0,0),\n(2020-09-10,4170,1,0,-1,300,0),\n....\n(2020-09-10,8888,2,0,-1,0,0)\n",
      "jq -r '\n(\"INSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES \"),\n([ \"(\\(.date as $date | .events[] | [.node, .sensor] as $d | .intervals[] | [$date, $d[], values[]] | join(\",\")))\"] | join(\",\\n\")),\n(\"ON CONFLICT DO NOTHING;\")\n'",
      "jq -r '\n(\"INSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES \"),\n([.date as $date | .events[] | [.node, .sensor] as $d | .intervals[] | [ $date, $d[], values[] ]] | ( .[:-1][] | \"(\" + join(\",\") + \"),\"), (last | \"(\" + join(\",\") + \")\")),\n(\"ON CONFLICT DO NOTHING;\")\n'"
    ],
    "utterance": "Generate a SQL INSERT statement with values for date, node, sensor, prop1, prop2, prop3, and prop4, extracted from a multi-level structure where each event contains sensor, node, and an intervals array, flattening all intervals for all events for a single date.",
    "expressions": [
      "jq -r '\n(\"INSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES \"),\n([ \"(\\(.date as $date | .events[] | [.node, .sensor] as $d | .intervals[] | [$date, $d[], values[]] | join(\",\")))\"] | join(\",\\n\")),\n(\"ON CONFLICT DO NOTHING;\")\n'",
      "jq -r '\n(\"INSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES \"),\n([.date as $date | .events[] | [.node, .sensor] as $d | .intervals[] | [ $date, $d[], values[] ]] | ( .[:-1][] | \"(\" + join(\",\") + \"),\"), (last | \"(\" + join(\",\") + \")\")),\n(\"ON CONFLICT DO NOTHING;\")\n'"
    ],
    "data": [
      {
        "input": {
          "date": "2020-09-10",
          "events": [
            {
              "sensor": 1,
              "intervals": [
                {
                  "prop1": 0,
                  "prop2": -1,
                  "prop3": 0,
                  "prop4": 0
                },
                {
                  "prop1": 0,
                  "prop2": -1,
                  "prop3": 300,
                  "prop4": 0
                }
              ],
              "node": 4170
            },
            {
              "sensor": 2,
              "intervals": [
                {
                  "prop1": 0,
                  "prop2": -1,
                  "prop3": 0,
                  "prop4": 0
                }
              ],
              "node": 8888
            }
          ]
        },
        "output": "INSERT INTO events (date,node,sensor,prop1,prop2,prop3,prop4) VALUES \n(2020-09-10,4170,1,0,-1,0,0),\n(2020-09-10,4170,1,0,-1,300,0),\n(2020-09-10,8888,2,0,-1,0,0)\nON CONFLICT DO NOTHING;"
      }
    ],
    "identifier": 68146903,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "How to get value key (0 is this case) with the value of \"name\", for store into variable after ? (to avoid duplicates)",
      "cat File.json  | jq '.Channels | to_entries[]'",
      "key_=\"$(cat file.json | jq ????????? search=\"name\": \"$get_name\" ???? .key)\"",
      "You were so close - just one misplaced parenthesis:"
    ],
    "utterance": "Find the index of an object in the Channels array whose \"name\" property equals \"TFX\".",
    "expressions": [
      ".Channels | to_entries[] | select(.value.name == \"TFX\") | .key"
    ],
    "data": [
      {
        "input": {
          "Channels": [
            {
              "name": "TFX",
              "old_name": "NT1"
            },
            {
              "name": "France 2",
              "old_name": ""
            }
          ]
        },
        "output": 0
      }
    ],
    "identifier": 68147007,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want only `bar`",
      "You can use [`first/1`](https://stedolan.github.io/jq/manual/#first(expr),last(expr),nth(n;expr)) in conjunction with **-n**/**--null-input** flag.",
      "jq -n 'first(inputs.name)'",
      "There's also [`input`](https://jqlang.github.io/jq/manual/#input) (whithout \"s\") which in combination with the `--null-input` (or `-n`) flag emits just the first item:",
      "jq -n 'input.name'"
    ],
    "utterance": "Return the 'name' field of only the first object from a stream of objects where the first has 'name': 'bar'.",
    "expressions": [
      "first(inputs.name)",
      "input.name"
    ],
    "data": [
      {
        "input": {
          "name": "bar",
          "thing": true,
          "new_key": 0
        },
        "output": "bar"
      },
      {
        "input": {
          "name": "baz",
          "thing": false,
          "new_key": 0
        }
      }
    ],
    "identifier": 68149782,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": true,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "So, my problem was if name contains \"random\" add key value \"Contains\" : 1 else \"contains\" : 0",
      "What I need is ",
      "{\n  \"name\": \"bar some random string\",\n  \"thing\": true,\n  \"new_key\": 0\n  \"Contains\": 1\n}\n{\n  \"name\": \"biz again another length words\",\n  \"thing\": true,\n  \"new_key\": 0\n  \"Contains\": 0\n}",
      "Found the answer \n```\nif .name  | contains(\"random\") then . |= . + {\"Contains\": 1} else . |= . + {\"Contains\": 0} end \n```",
      "Keeping it short and sweet:\n\n    .Contains = (if .name | contains(\"random\")\n                 then 1 else 0 end)"
    ],
    "utterance": "Add a key 'Contains' with value 1 if the 'name' field contains the substring 'random', otherwise set it to 0.",
    "expressions": [
      "if .name | contains(\"random\") then . |= . + {\"Contains\": 1} else . |= . + {\"Contains\": 0} end",
      ".Contains = (if .name | contains(\"random\") then 1 else 0 end)"
    ],
    "data": [
      {
        "input": {
          "name": "bar some random string",
          "thing": true,
          "new_key": 0
        },
        "output": {
          "name": "bar some random string",
          "thing": true,
          "new_key": 0,
          "Contains": 1
        }
      },
      {
        "input": {
          "name": "biz again another length words",
          "thing": true,
          "new_key": 0
        },
        "output": {
          "name": "biz again another length words",
          "thing": true,
          "new_key": 0,
          "Contains": 0
        }
      }
    ],
    "identifier": 68150808,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "How to wrap double quotes around a variable",
      "The Output I want is\nif .tweet | contains(\"accelerite\") then . |= . + {\"accelerite\": 1} else . |= . + {\"accelerite\": 0} end",
      "Nevermind got it,\n\njq 'if .tweet | contains(\"$p\") then . |= . + {'$p': 1} else . |= . + {'$p': 0} end' newfirst.json",
      "Writing such a function would be cumbersome, instead pass the variable to jq and let jq figure it out. Research jq documentation and quoting in shell.",
      "jq --arg p \"$p\" 'if .tweet | contains($p) then . |= . + {$p: 1} else . |= . + {$p: 0} end' newfirst.json"
    ],
    "utterance": "Dynamically add a key with the value of a shell variable to an object if a field contains that variable's value, ensuring the key is properly quoted.",
    "expressions": [
      "jq --arg p \"$p\" 'if .tweet | contains($p) then . |= . + {$p: 1} else . |= . + {$p: 0} end' newfirst.json"
    ],
    "identifier": 68151639,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "**how could it be done with jq, awk, paste, sed or something similar to make it look like this and put a 0 in front of every 1-9?**",
      "jq --raw-output '[.[].result] | add | .item.file, ( .time | .hours * 3600 + .minutes * 60 + .seconds | strftime(\"%H%M%S\") )'",
      "Output:\nplugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\n020305"
    ],
    "utterance": "Output the 'file' link, then print hours, minutes, and seconds as a single concatenated string, zero-padded to two digits each, on the next line.",
    "expressions": [
      "[.[].result] | add | .item.file, ( .time | .hours * 3600 + .minutes * 60 + .seconds | strftime(\"%H%M%S\") )"
    ],
    "data": [
      {
        "input": [
          {
            "id": 17,
            "jsonrpc": "2.0",
            "result": {
              "time": {
                "hours": 2,
                "milliseconds": 200,
                "minutes": 3,
                "seconds": 5
              }
            }
          },
          {
            "id": 18,
            "jsonrpc": "2.0",
            "result": {
              "item": {
                "file": "plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA",
                "label": "FULL SHOW - Burton US Open Men's Slopestyle Semi-Finals",
                "type": "unknown"
              }
            }
          }
        ],
        "output": "plugin://plugin.video.youtube/play/?video_id=rhMTZB2WJWA\n020305"
      }
    ],
    "identifier": 68153214,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "How to change the .enabled.key in \".anomalyDetection.loadingTimeThresholds\" Object dynamically using the jq in the same modify_json function.",
      "Am Expecting output like this, existing value anomalyDetection.loadingTimeThresholds.enabled also to be replaced by true in addition to above",
      "You could (for example) simply prepend the following to the jq filter:",
      ".anomalyDetection.loadingTimeThresholds.enabled = true |"
    ],
    "utterance": "Set .anomalyDetection.loadingTimeThresholds.enabled to true while also updating .anomalyDetection.outageHandling.localOutagePolicy.affectedLocations and .consecutiveRuns.",
    "expressions": [
      ".anomalyDetection.loadingTimeThresholds.enabled = true | (.anomalyDetection.outageHandling.localOutagePolicy |= (.affectedLocations |= $update_affectedLocations | .consecutiveRuns |= $update_consecutiveRuns ))"
    ],
    "data": [
      {
        "input": {
          "anomalyDetection": {
            "loadingTimeThresholds": {
              "enabled": false,
              "thresholds": []
            },
            "outageHandling": {
              "globalOutage": true,
              "localOutage": true,
              "localOutagePolicy": {
                "affectedLocations": 1,
                "consecutiveRuns": 2
              }
            }
          }
        },
        "output": {
          "anomalyDetection": {
            "loadingTimeThresholds": {
              "enabled": true,
              "thresholds": []
            },
            "outageHandling": {
              "globalOutage": true,
              "localOutage": true,
              "localOutagePolicy": {
                "affectedLocations": 42,
                "consecutiveRuns": 666
              }
            }
          }
        }
      }
    ],
    "identifier": 68153993,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "So I have this json,I want to restructure it so far it's in a single array. Now I want to sort it according to the vendors.",
      "How do I restructure it to\n[\n  {\n    \"vendor\": \"openbugbounty\",\n    \"tweets\": [ ... ]\n  }, ...\n]",
      "Right now the structure is \nkey1\nkey2\nkey3\n\nkey1\nkey2\nkey3",
      "output = []\n\nfor key, group in grouped:\n    output.append({\n        'vendor': key,\n        'tweets': [{j:i[j] for j in i if j != 'vendor'} for i in group]\n    })\n    "
    ],
    "utterance": "Group objects by their vendor field and output an array where each element is an object with vendor and an array of tweets (excluding vendor field).",
    "expressions": [
      "group_by(.vendor) | map({vendor: .[0].vendor, tweets: map(del(.vendor))})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1335735520073232385",
            "created_at": "2020-12-07 05:28:59 IST",
            "username": "kristinaforest",
            "tweet": "@iamsandyhall It\u2019s the look of surprise on her face and the vulnerability on his \ud83d\udc97",
            "vendor": "null"
          },
          {
            "id": "1335735456223399937",
            "created_at": "2020-12-07 05:28:44 IST",
            "username": "openbugbounty",
            "tweet": "@lyrsense please notify your IT security team about a security vulnerability OBB-1583432 on your website  ",
            "vendor": "openbugbounty"
          },
          {
            "id": "1335735446496817152",
            "created_at": "2020-12-07 05:28:41 IST",
            "username": "openbugbounty",
            "tweet": "@arstechnica please notify your IT security team about a security vulnerability OBB-1583440 on your website  ",
            "vendor": "openbugbounty"
          },
          {
            "id": "1335735260957564929",
            "created_at": "2020-12-07 05:27:57 IST",
            "username": "tpwk_falls",
            "tweet": "2 years into a song of vulnerability - a catchy melody embedded with honest lyrics opening up about a difficult time. Thank u for sharing with us  @zaynmalik I\u2019m so proud of how far you\u2019ve come and continue to go. Forever supporting ur journey #2yearsofgoodyears   PROUD OF ZAYN ",
            "vendor": "zayn malik"
          }
        ],
        "output": [
          {
            "vendor": "null",
            "tweets": [
              {
                "id": "1335735520073232385",
                "created_at": "2020-12-07 05:28:59 IST",
                "username": "kristinaforest",
                "tweet": "@iamsandyhall It\u2019s the look of surprise on her face and the vulnerability on his \ud83d\udc97"
              }
            ]
          },
          {
            "vendor": "openbugbounty",
            "tweets": [
              {
                "id": "1335735456223399937",
                "created_at": "2020-12-07 05:28:44 IST",
                "username": "openbugbounty",
                "tweet": "@lyrsense please notify your IT security team about a security vulnerability OBB-1583432 on your website  "
              },
              {
                "id": "1335735446496817152",
                "created_at": "2020-12-07 05:28:41 IST",
                "username": "openbugbounty",
                "tweet": "@arstechnica please notify your IT security team about a security vulnerability OBB-1583440 on your website  "
              }
            ]
          },
          {
            "vendor": "zayn malik",
            "tweets": [
              {
                "id": "1335735260957564929",
                "created_at": "2020-12-07 05:27:57 IST",
                "username": "tpwk_falls",
                "tweet": "2 years into a song of vulnerability - a catchy melody embedded with honest lyrics opening up about a difficult time. Thank u for sharing with us  @zaynmalik I\u2019m so proud of how far you\u2019ve come and continue to go. Forever supporting ur journey #2yearsofgoodyears   PROUD OF ZAYN "
              }
            ]
          }
        ]
      }
    ],
    "identifier": 68157950,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I wrote this as bash",
      "yq -y -i  \".tokens += { $alias: { value: $token }}\" /root/.github.yml",
      "jq: error: abc/0 is not defined at <top-level>, line 1:",
      ".tokens += { alias1: { value: abc }}",
      "One way would be to pass the arg via command line with the --arg support",
      "yq -y -i --arg t \"$token\" --arg a \"$alias\" '.tokens += { ($a): { value: $t } }' /root/.github.yml"
    ],
    "utterance": "Update the tokens field by adding a key with the value of alias, whose value is an object with value set to token, with both values correctly interpolated.",
    "expressions": [
      ".tokens += { ($a): { value: $t } }"
    ],
    "identifier": 68158827,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Does jq contains support case insensitive matching?",
      ".user | contains(\"thinking\")",
      "jq has an `i` flag for `test` and `match`. Is there anything similar for `contains`?",
      "If you're ok with providing a regular expression, you can use `test`.",
      ".user | test(\"thinking\"; \"i\")",
      "It often suffices to convert both strings to the same typographical case using `ascii_upcase` or `ascii_downcase`, as in your case:",
      ".user | ascii_downcase | contains(\"thinking\")"
    ],
    "utterance": "Test whether the 'user' field includes the substring 'thinking', ignoring case sensitivity.",
    "expressions": [
      ".user | test(\"thinking\"; \"i\")",
      ".user | ascii_downcase | contains(\"thinking\")"
    ],
    "data": [
      {
        "input": {
          "id": "1338268256814161923",
          "user": "Thinking of going through the Venmo transactions on my feed and liking all of them just to create a little sense of vulnerability"
        },
        "output": true
      }
    ],
    "identifier": 68159673,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Following your suggestion it will be more concise and doesn\u2019t need the ugly workaround:",
      "def numberify($x): $x | tonumber? // 0;",
      "\"1\" as $sumReqSize",
      "| \"10\" as $sumResSize",
      "| { statistics: { count: 1, sumReqSize: 2, sumResSize: 20 } }",
      "| .statistics.count += 1",
      "| .statistics.sumReqSize += numberify($sumReqSize)",
      "| .statistics.sumResSize += numberify($sumResSize)"
    ],
    "utterance": "Increment the fields count, sumReqSize, and sumResSize in the statistics object by 1, numberified value of \"1\", and numberified value of \"10\" respectively.",
    "expressions": [
      "def numberify($x): $x | tonumber? // 0;\n\n\"1\" as $sumReqSize\n| \"10\" as $sumResSize\n| { statistics: { count: 1, sumReqSize: 2, sumResSize: 20 } }\n| .statistics.count += 1\n| .statistics.sumReqSize += numberify($sumReqSize)\n| .statistics.sumResSize += numberify($sumResSize)"
    ],
    "data": [
      {
        "input": {
          "statistics": {
            "count": 1,
            "sumReqSize": 2,
            "sumResSize": 20
          }
        },
        "output": {
          "statistics": {
            "count": 2,
            "sumReqSize": 3,
            "sumResSize": 30
          }
        }
      }
    ],
    "identifier": 68160740,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "\".contains does not work with case insensitive; where as test and match creates lots of noise cause it is not string matching.\"",
      "\"if contains_i(.tweet; $p) then . |= . + {vendor: $p} else empty end\"",
      "\"def contains_i($C; $c): $C | ascii_downcase | contains($c|ascii_downcase);\"",
      "\"test(\\\"\\\\Qstring\\\\E\\\"; \\\"i\\\")\""
    ],
    "utterance": "Match a fixed string case-insensitively within a field and, if matched, augment the object with a vendor field containing the matched string.",
    "expressions": [
      "def contains_i($C; $c): $C | ascii_downcase | contains($c|ascii_downcase); if contains_i(.tweet; $p) then . |= . + {vendor: $p} else empty end",
      "if (.tweet | test(\"\\\\Q\" + $p + \"\\\\E\"; \"i\")) then . + {vendor: $p} else empty end"
    ],
    "identifier": 68160918,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": "The task does not specify the input JSON structure, the field to match against, or the fixed string to match. Therefore, it is missing necessary information to perform the transformation.",
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to generate lines from each of these to be later used as CSV, something like:\n\n```\nRole1Name, Role1ID, null, Role1Manager, Role1User\nRole2Name, Role2ID, Role2Creator, null, Role2User\nRole3Name, Role3ID, Role3Creator, Role3Manager, Role3User\n```\n\nFor the header line\nName, ID, Creator, Manager, User",
      "I'm able to get all the \"Value\" but not able to print null for missing \"Key\"",
      "jq -r '.Tags | from_entries | [ .[\"Name\",\"ID\",\"Creator\",\"Manager\",\"User\"] | . // \"null\" ] | join(\", \")' role*.json",
      "$jq -rc  '.Tags | from_entries | [.Name, .ID, .Creator, .Manager, .User]' role*.json"
    ],
    "utterance": "Output the values for Name, ID, Creator, Manager, and User in that order from each object's Tags, and insert null if any are missing.",
    "expressions": [
      ".Tags | from_entries | [.Name, .ID, .Creator, .Manager, .User]",
      ".Tags | from_entries | [. [\"Name\",\"ID\",\"Creator\",\"Manager\",\"User\"] | . // \"null\" ]",
      ".Tags | from_entries | [ .[\"Name\",\"ID\",\"Creator\",\"Manager\",\"User\"] | . // \"null\" ] | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "Tags": [
            {
              "Key": "Name",
              "Value": "Role1Name"
            },
            {
              "Key": "ID",
              "Value": "Role1ID"
            },
            {
              "Key": "Manager",
              "Value": "Role1Manager"
            },
            {
              "Key": "User",
              "Value": "Role1User"
            },
            {
              "Key": "Country",
              "Value": "USA"
            }
          ]
        },
        "output": [
          "Role1Name",
          "Role1ID",
          null,
          "Role1Manager",
          "Role1User"
        ]
      },
      {
        "input": {
          "Tags": [
            {
              "Key": "Name",
              "Value": "Role2Name"
            },
            {
              "Key": "ID",
              "Value": "Role2ID"
            },
            {
              "Key": "City",
              "Value": "NewYork"
            },
            {
              "Key": "Creator",
              "Value": "Role2Creator"
            },
            {
              "Key": "User",
              "Value": "Role2User"
            }
          ]
        },
        "output": [
          "Role2Name",
          "Role2ID",
          "Role2Creator",
          null,
          "Role2User"
        ]
      },
      {
        "input": {
          "Tags": [
            {
              "Key": "Name",
              "Value": "Role3Name"
            },
            {
              "Key": "ID",
              "Value": "Role3ID"
            },
            {
              "Key": "Creator",
              "Value": "Role3Creator"
            },
            {
              "Key": "ZIP",
              "Value": 82378
            },
            {
              "Key": "Manager",
              "Value": "Role3Manager"
            },
            {
              "Key": "User",
              "Value": "Role3User"
            }
          ]
        },
        "output": [
          "Role3Name",
          "Role3ID",
          "Role3Creator",
          "Role3Manager",
          "Role3User"
        ]
      }
    ],
    "identifier": 68171713,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "It should be transformed into \r\n\r\n```\r\n{\r\n\u201cinn\u201d : \u201cqwerty\u201d,\r\n\u201creqId\u201d : \u201casdfg\u201d\r\n}\r\n\r\n```\r\n\r\nor into \r\n\r\n```\r\n{\r\n\u201ccuid\u201d : \u201c1234\u201d,\r\n\u201creqId\u201d : \u201casdfg\u201d\r\n}\r\n\r\nit depends on a value of \"type\" field. How can I do that with JQ?",
      "if .type == \"person\" then { inn } else { cuid } end + { reqId }",
      "jq 'if .type == \"person\"\n    then {inn, reqId}\n    else {cuid, reqId}\n    end'"
    ],
    "utterance": "Select either the inn and reqId fields or the cuid and reqId fields depending on whether type is person.",
    "expressions": [
      "if .type == \"person\" then { inn } else { cuid } end + { reqId }",
      "if .type == \"person\" then {inn, reqId} else {cuid, reqId} end"
    ],
    "data": [
      {
        "input": {
          "inn": "qwerty",
          "cuid": "1234",
          "type": "legal",
          "reqId": "asdfg"
        },
        "output": {
          "cuid": "1234",
          "reqId": "asdfg"
        }
      },
      {
        "input": {
          "inn": "qwerty",
          "cuid": "1234",
          "type": "person",
          "reqId": "asdfg"
        },
        "output": {
          "inn": "qwerty",
          "reqId": "asdfg"
        }
      }
    ],
    "identifier": 68176925,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "while read p; do \r\n    jq 'if .tweet | test('\\\"$p\\\"'; \"i\") then . |= . + {vendor: '\\\"$p\\\"'} else empty end' sfilter.json\r\ndone < $filename",
      "pass the value of ```p``` to your jq program like this:\r\n\r\n```\r\nwhile read p; do\r\n    jq --arg p \"$p\" 'if .tweet | test($p; \"i\") then . |= . + {vendor: $p} else empty end' sfilter.json\r\ndone < $filename\r\n```",
      "Don't generate a dynamic `jq` filter using string interpolation. Pass the value via the `--arg` option.",
      "jq --arg p \"$p\" 'if .tweet | test($p; \"i\") then . |= . + {vendor: $p} else empty end' sfilter.json"
    ],
    "utterance": "For each line in a file, filter objects where the tweet text matches the line (case-insensitive), and add a vendor field with the matching line's content.",
    "expressions": [
      "jq --arg p \"$p\" 'if .tweet | test($p; \"i\") then . |= . + {vendor: $p} else empty end' sfilter.json"
    ],
    "data": [
      {
        "input": {
          "tweet": "sdas adssad"
        },
        "output": {
          "tweet": "sdas adssad",
          "vendor": "sdas adssad"
        }
      }
    ],
    "identifier": 68177864,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": true,
        "multiple": false,
        "missing": true
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "i want to read each value of the array in the data field and put it line by line in another file. such as below",
      "{ \"id\":\"id1\",\"value\":\"value1\"}\n{\"id\":\"id2\",\"value\":\"value2\"}\n{\"id\":\"id3\",\"value\":\"value3\"}",
      "you can process them one by one and extract the field `.data[]`.",
      "echo '\n{ \"key\":\"A1\", \"property\":\"A2\", \"data\":[1,2,3] }{\"key\":\"B1\",\"property\":\"B2\",\"data\":[4,5,6]}\n{ \n   \"key\":\"C1\", \n   \"property\":\"C2\", \n   \"data\":[7,8,9] \n}' | jq -cr '.data[]'",
      "For your example, the following would suffice:\n\n    jq -cn --stream 'fromstream( inputs|(.[0] |= .[2:]) | select(. != [[]]) )'",
      "If you only wanted the .data array to be itemized, replace `inputs` in the above by:\n\n    inputs|select(first|first==\"data\")"
    ],
    "utterance": "Output each entry from the data array as a separate object, one per line.",
    "expressions": [
      ".data[]",
      "jq -cn --stream 'fromstream( inputs|(.[0] |= .[2:]) | select(. != [[]]) )'",
      "jq -cn --stream 'fromstream( inputs|select(first|first==\"data\") )'"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "id1",
              "value": "value1"
            },
            {
              "id": "id2",
              "value": "value2"
            },
            {
              "id": "id3",
              "value": "value3"
            }
          ]
        },
        "output": [
          {
            "id": "id1",
            "value": "value1"
          },
          {
            "id": "id2",
            "value": "value2"
          },
          {
            "id": "id3",
            "value": "value3"
          }
        ]
      }
    ],
    "identifier": 68180419,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "When trying to run a jq command to select using `fromdate` like this:",
      "`cat output.json | jq '.[] | .[] | select ( .LastAccessedDate | fromdate > \"2021-01-01T02:00:00+02:00\")'`",
      "then I get the error message:\njq: error (at <stdin>:8): date \"2021-06-29T02:00:00+02:00\" does not match format \"%Y-%m-%dT%H:%M:%SZ\"",
      "One way would be to use a custom function to strip off the timezone part and format the date string to a format compatible that `jq` can parse.",
      "jq --arg ref \"2021-01-01T02:00:00+02:00\" '\n  def c(str): str | (split(\"+\")[0] + \"Z\") | fromdate ; \n  .MyList | map(select( c(.LastAccessedDate) > c($ref) ))' json"
    ],
    "utterance": "Filter objects where LastAccessedDate is after 2021-01-01T02:00:00+02:00, correctly handling the input's timezone offsets.",
    "expressions": [
      "jq --arg ref \"2021-01-01T02:00:00+02:00\" '\n  def c(str): str | (split(\"+\")[0] + \"Z\") | fromdate ; \n  .MyList | map(select( c(.LastAccessedDate) > c($ref) ))' json"
    ],
    "data": [
      {
        "input": {
          "MyList": [
            {
              "Name": "MyName1",
              "LastAccessedDate": "2021-06-29T02:00:00+02:00"
            }
          ]
        },
        "output": [
          {
            "Name": "MyName1",
            "LastAccessedDate": "2021-06-29T02:00:00+02:00"
          }
        ]
      }
    ],
    "identifier": 68180684,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Parsing a JSON file with this:\n\n    cat file.json | jq -r \".[] | select(.name == \\\"${VALUE}\\\" or .guid == \\\"${VALUE}\\\") | .name\"\n\nworks as expected, it selects the item where either the .name or .guid equals ${VALUE} and prints out the name.",
      "However, I would like the .guid match to be a substring or regex match.  Trying this does not work:\n\n    cat file.json | jq -r  \".[] | select(.name == \\\"${VALUE}\\\" or .guid | contains(\\\"${VALUE}\\\")) | .name\"",
      "You're missing a pair of parens.  Also, it's usually much better to pass in variables using `--arg` ...\n\n   .[]\n   | select( (.name == $VALUE) or (.guid | contains($VALUE)) )\n   | .name",
      "Or, depending on your requirements, you might prefer to use this `select` clause:\n\n    select( (.name == $VALUE) or (.guid // \"\" | contains($VALUE)) )"
    ],
    "utterance": "Select and output the name of each item where the name equals a specific value or the guid contains that value as a substring.",
    "expressions": [
      ".[] | select((.name == $VALUE) or (.guid | contains($VALUE))) | .name",
      ".[] | select((.name == $VALUE) or ((.guid // \"\") | contains($VALUE))) | .name"
    ],
    "identifier": 68183429,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "My desired outcome is that if the values of a key exist in both places but are different, they should be put into an array and that array would then be the value of that key. Any keys that exist in one but not the other should also be added. Lastly, for any key that exists in both places, where the value is the same, there should only be one key/value for that item.",
      "I'd like to put those differering values in an array instead of a single string. Is there a clean, easy way to do that?",
      "The idea is to collect the values for all keys in arrays in the first step (also for keys that occur only once) and at the end remove duplicates from all arrays and unpack the arrays with only one element.",
      "jq -n '  reduce inputs as $input         ({}; reduce ($input | keys_unsorted)[] as $key                     (.; .[$key] += [$input[$key]])         )  | with_entries(.value |= (flatten                            | unique                            | if length == 1 then .[0] else . end)                 )'"
    ],
    "utterance": "Combine two objects so that keys with different values become arrays of those values, unique same values remain as single values, and keys unique to either object are preserved.",
    "expressions": [
      "reduce inputs as $input ({}; reduce ($input | keys_unsorted)[] as $key (.; .[$key] += [$input[$key]])) | with_entries(.value |= (flatten | unique | if length == 1 then .[0] else . end))"
    ],
    "data": [
      {
        "input": [
          {
            "primaryKey": "thisValueIsTheSameInBoth",
            "aOnlyField": "thisIsOnlyInA",
            "sharedField": "thisIsInBoth-AAA",
            "sharedField2": "thisIsInBothAgain-AAA"
          },
          {
            "primaryKey": "thisValueIsTheSameInBoth",
            "bOnlyField": "thisIsOnlyInB",
            "sharedField": "thisIsInBothButDifferentInB",
            "sharedField2": "thisIsInBothAgainButStillDifferentInB"
          }
        ],
        "output": {
          "primaryKey": "thisValueIsTheSameInBoth",
          "aOnlyField": "thisIsOnlyInA",
          "bOnlyField": "thisIsOnlyInB",
          "sharedField": [
            "thisIsInBoth-AAA",
            "thisIsInBothButDifferentInB"
          ],
          "sharedField2": [
            "thisIsInBothAgain-AAA",
            "thisIsInBothAgainButStillDifferentInB"
          ]
        }
      }
    ],
    "identifier": 68184175,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Accessing non existing keys produces `null`. The filter `join(\" \")` then fails.",
      "A possible solution to fix this would be to provide an empty array as a default wherever it may be missing in the source:\n\n```\nsrc=$(jq --raw-output '.source? // [] | join(\" \")' <<< ${rule})\ncidr=$(jq --raw-output '.cidr? // [] | join(\" \")' <<< ${rule})\nports=$(jq --raw-output '.ports? // [] | join(\" \")' <<< ${rule})\n```"
    ],
    "utterance": "Join the values of a property as a string, using an empty array if the property may be missing or null.",
    "expressions": [
      ".source? // [] | join(\" \")",
      ".cidr? // [] | join(\" \")",
      ".ports? // [] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "name": "AllowHttpsInBound",
          "protocol": "tcp"
        },
        "output": ""
      },
      {
        "input": {
          "name": "WithSource",
          "source": [
            "a",
            "b",
            "c"
          ]
        },
        "output": "a b c"
      }
    ],
    "identifier": 68184497,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I'm trying to use ```jq``` to process a json input:\r\n```\r\n{\r\n\"foo\":\"xxx\",\r\n\"bar\":\"yyy\"\r\n}\r\n```\r\n\r\nTrying to get the following desired json output:\r\n\r\n```{\"path\":\"xxx/yyy\"}```",
      ".|.foo as $path1|.bar as $path2|{\"path\":?????}",
      "$path1+\"/\"+$path2 does not work.",
      "You are really close.  I think you just need some parenthesis:",
      "    .|.foo as $path1|.bar as $path2|{\"path\":($path1 + \"/\" + $path2)}",
      "Or just:",
      "    {\"path\":(.foo + \"/\" + .bar)}",
      "or perhaps better (in case conversion to strings is needed):",
      "    {\"path\": \"\\(.foo)/\\(.bar)\"}"
    ],
    "utterance": "Combine the values of the keys foo and bar separated by a slash and store the result in the key path.",
    "expressions": [
      ".|.foo as $path1|.bar as $path2|{\"path\":($path1 + \"/\" + $path2)}",
      "{\"path\": (.foo + \"/\" + .bar)}",
      "{\"path\": \"\\(.foo)/\\(.bar)\"}"
    ],
    "data": [
      {
        "input": {
          "foo": "xxx",
          "bar": "yyy"
        },
        "output": {
          "path": "xxx/yyy"
        }
      }
    ],
    "identifier": 68187302,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Im trying to use jq on kubernetes json output, to create new json object containing list of objects - container and image per pod, however im getting cartesian product.",
      "You get the desired output using this `jq` filter on your input:",
      "jq '\n  .items[]\n  | {\n      \"name\": .metadata.name,\n      \"containers\": .spec.containers\n                    | map({name, image})\n    }'",
      "output:\n{\n  \"name\": \"pod-1\",\n  \"containers\": [\n    {\n      \"name\": \"container-1\",\n      \"image\": \"image-1\"\n    },\n    {\n      \"name\": \"container-2\",\n      \"image\": \"image-2\"\n    }\n  ]\n}"
    ],
    "utterance": "Extract for each pod an object with the pod's name and a list of its containers, where each container object contains only 'name' and 'image' fields.",
    "expressions": [
      ".items[] | { \"name\": .metadata.name, \"containers\": .spec.containers | map({name, image}) }"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "items": [
            {
              "apiVersion": "v1",
              "kind": "Pod",
              "metadata": {
                "creationTimestamp": "2021-06-30T12:45:40Z",
                "name": "pod-1",
                "namespace": "default",
                "resourceVersion": "757679286",
                "selfLink": "/api/v1/namespaces/default/pods/pod-1"
              },
              "spec": {
                "containers": [
                  {
                    "image": "image-1",
                    "imagePullPolicy": "Always",
                    "name": "container-1",
                    "resources": {},
                    "terminationMessagePath": "/dev/termination-log",
                    "terminationMessagePolicy": "File",
                    "volumeMounts": [
                      {
                        "mountPath": "/var/run/secrets/kubernetes.io/serviceaccount",
                        "readOnly": true
                      }
                    ]
                  },
                  {
                    "image": "image-2",
                    "imagePullPolicy": "Always",
                    "name": "container-2",
                    "resources": {},
                    "terminationMessagePath": "/dev/termination-log",
                    "terminationMessagePolicy": "File",
                    "volumeMounts": [
                      {
                        "mountPath": "/var/run/secrets/kubernetes.io/serviceaccount",
                        "readOnly": true
                      }
                    ]
                  }
                ],
                "dnsPolicy": "ClusterFirst",
                "enableServiceLinks": true,
                "priority": 0,
                "restartPolicy": "Always",
                "schedulerName": "default-scheduler",
                "securityContext": {},
                "serviceAccount": "default",
                "serviceAccountName": "default",
                "terminationGracePeriodSeconds": 30,
                "tolerations": [
                  {
                    "effect": "NoExecute",
                    "key": "node.kubernetes.io/not-ready",
                    "operator": "Exists",
                    "tolerationSeconds": 300
                  },
                  {
                    "effect": "NoExecute",
                    "key": "node.kubernetes.io/unreachable",
                    "operator": "Exists",
                    "tolerationSeconds": 300
                  }
                ],
                "volumes": [
                  {
                    "name": "default-token-b954f",
                    "secret": {
                      "defaultMode": 420,
                      "secretName": "default-token-b954f"
                    }
                  }
                ]
              },
              "status": {
                "conditions": [
                  {
                    "lastProbeTime": null,
                    "lastTransitionTime": "2021-06-30T12:45:40Z",
                    "status": "True",
                    "type": "Initialized"
                  },
                  {
                    "lastProbeTime": null,
                    "lastTransitionTime": "2021-06-30T12:45:40Z",
                    "message": "containers with unready status: [container-1 container-2]",
                    "reason": "ContainersNotReady",
                    "status": "False",
                    "type": "Ready"
                  },
                  {
                    "lastProbeTime": null,
                    "lastTransitionTime": "2021-06-30T12:45:40Z",
                    "message": "containers with unready status: [container-1 container-2]",
                    "reason": "ContainersNotReady",
                    "status": "False",
                    "type": "ContainersReady"
                  },
                  {
                    "lastProbeTime": null,
                    "lastTransitionTime": "2021-06-30T12:45:40Z",
                    "status": "True",
                    "type": "PodScheduled"
                  }
                ],
                "containerStatuses": [
                  {
                    "image": "image-1",
                    "imageID": "",
                    "lastState": {},
                    "name": "container-1",
                    "ready": false,
                    "restartCount": 0,
                    "started": false,
                    "state": {
                      "waiting": {
                        "message": "Back-off pulling image \\\"image-1\\\"",
                        "reason": "ImagePullBackOff"
                      }
                    }
                  },
                  {
                    "image": "image-2",
                    "imageID": "",
                    "lastState": {},
                    "name": "container-2",
                    "ready": false,
                    "restartCount": 0,
                    "started": false,
                    "state": {
                      "waiting": {
                        "message": "Back-off pulling image \\\"image-2\\\"",
                        "reason": "ImagePullBackOff"
                      }
                    }
                  }
                ],
                "qosClass": "BestEffort",
                "startTime": "2021-06-30T12:45:40Z"
              }
            }
          ],
          "kind": "List",
          "metadata": {
            "resourceVersion": "",
            "selfLink": ""
          }
        },
        "output": {
          "name": "pod-1",
          "containers": [
            {
              "name": "container-1",
              "image": "image-1"
            },
            {
              "name": "container-2",
              "image": "image-2"
            }
          ]
        }
      }
    ],
    "identifier": 68193777,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "The goal is to delete an entire object in a JSON file that contain a key/value pair specified in a JQ script.",
      "For example, all objects with `/unwanted-path/` in `path` would be removed:",
      "The key will always be `path`, but there are several `path` values I will filter against. If there is a way to filter against more than one `path` value a time, that is ideal, but not critical.",
      "example 4: delete objects that have one of unwanted paths '[\"/unwanted-path-4/\", \"/unwanted-path-7/\"]' (deep search)",
      "jq --argjson unwantedPath \"$UNWANTED\" \\\n   'del(..| objects | select(.path | IN($unwantedPath[]))) ' <<<$FILE"
    ],
    "utterance": "Remove all objects where the 'path' key matches any value from a given list, even if nested at any depth.",
    "expressions": [
      "del(..| objects | select(.path | IN([\"/unwanted-path-4/\", \"/unwanted-path-7/\"])))"
    ],
    "data": [
      {
        "input": [
          {
            "path": "/path-1/",
            "guide": "Guide 1"
          },
          {
            "path": "/unwanted-path-2/",
            "guide": "Guide 2"
          },
          {
            "path": "/path-3/",
            "guide": "Guide 3",
            "sub": [
              {
                "path": "/unwanted-path-4/",
                "guide": "Guide 4"
              },
              {
                "path": "/path-5/",
                "guide": "Guide 5"
              },
              [
                {
                  "path": "/path-6/",
                  "guide": "Guide 6"
                },
                {
                  "path": "/unwanted-path-7/",
                  "guide": "Guide 7"
                }
              ]
            ]
          }
        ],
        "output": [
          {
            "path": "/path-1/",
            "guide": "Guide 1"
          },
          {
            "path": "/unwanted-path-2/",
            "guide": "Guide 2"
          },
          {
            "path": "/path-3/",
            "guide": "Guide 3",
            "sub": [
              {
                "path": "/path-5/",
                "guide": "Guide 5"
              },
              [
                {
                  "path": "/path-6/",
                  "guide": "Guide 6"
                }
              ]
            ]
          }
        ]
      }
    ],
    "identifier": 68214943,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to update both tags to a new value (same value for both), so I've got this command, that works:",
      "However I want to update different tags in different runs and would like to pass them as another argument.",
      "jq --argjson TAGS '[\"Tag1\",\"Tag2\"]' --arg NEW_VALUE '987-654' \\\n    '[.[] |= if(.Key|in($TAGS)) then (.Value=$NEW_VALUE) else . end]'",
      "You can use `IN` to see if the value is part of the list and use a much simpler update assignment using select as",
      "jq --arg NEW_VALUE '987-654' --argjson TAGS '[\"Tag1\",\"Tag2\"]' '\n   map(select( .Key | IN($TAGS[] ) ).Value |= $NEW_VALUE )' json",
      "jq --arg NEW_VALUE '987-654' --argjson TAGS '[\"Tag1\",\"Tag2\"]' '\n   def IN(s): first((s == .) // empty) // false;\n   map(if .Key | IN($TAGS[]) then .Value = $NEW_VALUE else . end)\n'"
    ],
    "utterance": "Update the Value field to '987-654' for all objects where the Key field matches any of the provided tags, with the tags and new value supplied as parameters.",
    "expressions": [
      "map(select(.Key | IN($TAGS[])).Value |= $NEW_VALUE)",
      "def IN(s): first((s == .) // empty) // false; map(if .Key | IN($TAGS[]) then .Value = $NEW_VALUE else . end)",
      "($TAGS|fromjson) as $TAGS | map(if [.Key == $TAGS[]]|any then .Value = $NEW_VALUE else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "Key": "IDontCare",
            "Value": "something"
          },
          {
            "Key": "Tag1",
            "Value": "123-456"
          },
          {
            "Key": "Tag2",
            "Value": "121-717"
          }
        ],
        "output": [
          {
            "Key": "IDontCare",
            "Value": "something"
          },
          {
            "Key": "Tag1",
            "Value": "987-654"
          },
          {
            "Key": "Tag2",
            "Value": "987-654"
          }
        ]
      }
    ],
    "identifier": 68219855,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Using JQ, if the first element of array `category` in the second object contains `/technology`, I want to add a new field named `relevant` with `1` as value (which I managed), and copy the `text` field from the first object.",
      "Your input consists of two separate objects. In order to be able to access the first while processing the second, you could save the first into a variable.",
      "```\n. as {$text} | input | if .categories[0].label | test(\"/technology\"; \"i\") then . + {relevant: 1, $text} else . + {relevant: 0} end\n```"
    ],
    "utterance": "If the first category label in the second object contains '/technology', add a 'relevant' field with value 1 and copy the 'text' field from the first object; otherwise, set 'relevant' to 0.",
    "expressions": [
      ". as {$text} | input | if .categories[0].label | test(\"/technology\"; \"i\") then . + {relevant: 1, $text} else . + {relevant: 0} end"
    ],
    "data": [
      {
        "input": [
          {
            "text": "Some text here"
          },
          {
            "usage": {
              "text_units": 1,
              "text_characters": 101,
              "features": 1
            },
            "language": "en",
            "categories": [
              {
                "score": 0.655041,
                "label": "/technology law, govt and politics/espionage and intelligence/surveillance"
              },
              {
                "score": 0.639809,
                "label": "/technology and computing/computer security/network security"
              },
              {
                "score": 0.624533,
                "label": "/business and industrial/business operations"
              }
            ]
          }
        ],
        "output": {
          "usage": {
            "text_units": 1,
            "text_characters": 101,
            "features": 1
          },
          "language": "en",
          "categories": [
            {
              "score": 0.655041,
              "label": "/technology law, govt and politics/espionage and intelligence/surveillance"
            },
            {
              "score": 0.639809,
              "label": "/technology and computing/computer security/network security"
            },
            {
              "score": 0.624533,
              "label": "/business and industrial/business operations"
            }
          ],
          "relevant": 1,
          "text": "Some text here"
        }
      }
    ],
    "identifier": 68222227,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Specifically, I want to select the values of **only those** `\"two\"` attributes for which the value of array `\"three\"` is **not empty**. So, in the above example, only the value **\"B\"** should be returned, and all other values should be **ignored**.",
      "jq --raw-output 'if (.three | length > 0) then .two else empty end'",
      "jq -r 'select(.three | length > 0) | .two' < file_in.json > file_out.json"
    ],
    "utterance": "Select values of the 'two' attribute from objects where the 'three' array is not empty, writing one unquoted value per line to a text file.",
    "expressions": [
      "jq --raw-output 'if (.three | length > 0) then .two else empty end'",
      "jq -r 'select(.three | length > 0) | .two'",
      "jq -rn 'inputs | select(.three != []) | .two'"
    ],
    "data": [
      {
        "input": [
          {
            "one": "Some string",
            "two": "A",
            "three": []
          },
          {
            "one": "Some string",
            "two": "B",
            "three": [
              {
                "a": 1,
                "b": 2
              }
            ]
          },
          {
            "one": "Some string",
            "two": "C",
            "three": []
          }
        ],
        "output": [
          "B"
        ]
      }
    ],
    "identifier": 68230320,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": "The task requests output as one unquoted value per line to a text file, but the example output is a JSON array. The task description and example output are inconsistent, so the transformation is underspecified.",
      "other_environment": null
    }
  },
  {
    "context": [
      "I need to retrieve the IP address from it.",
      "Try `jq '.items[].Hosts.ip'`. This grabs the `.items` key from the outer object, iterates the items array, then pulls the value from the path `.Hosts.ip` from each object.",
      "PS > cat a.json | jq '.items[].Hosts.ip'\n\"10.135.3.119\"\n\"10.0.0.33\"\n\"10.0.0.34\"\n\"10.0.0.35\"\nPS > cat a.json | jq -r '.items[].Hosts.ip'\n10.135.3.119\n10.0.0.33\n10.0.0.34\n10.0.0.35"
    ],
    "utterance": "Extract all the IP addresses from the Hosts.ip field within each item under items.",
    "expressions": [
      ".items[].Hosts.ip",
      "-r .items[].Hosts.ip"
    ],
    "data": [
      {
        "input": {
          "href": "http://10.0.0.33:8080/api/v1/hosts?fields=Hosts/host_name,Hosts/ip",
          "items": [
            {
              "href": "http://10.0.0.33:8080/api/v1/hosts/sil.dev.test.com",
              "Hosts": {
                "host_name": "test123.sil.dev.test.com",
                "ip": "10.135.3.119"
              }
            },
            {
              "href": "http://10.0.0.33:8080/api/v1/hosts/test001.sil.dev.test.com",
              "Hosts": {
                "cluster_name": "test_cluster",
                "host_name": "test001.sil.dev.test.com",
                "ip": "10.0.0.33"
              }
            },
            {
              "href": "http://10.0.0.33:8080/api/v1/hosts/test002.sil.dev.test.com",
              "Hosts": {
                "cluster_name": "test_cluster",
                "host_name": "test002.sil.dev.test.com",
                "ip": "10.0.0.34"
              }
            },
            {
              "href": "http://10.0.0.33:8080/api/v1/hosts/test003.sil.dev.test.com",
              "Hosts": {
                "cluster_name": "test_cluster",
                "host_name": "test003.sil.dev.test.com",
                "ip": "10.0.0.35"
              }
            }
          ]
        },
        "output": [
          "10.135.3.119",
          "10.0.0.33",
          "10.0.0.34",
          "10.0.0.35"
        ]
      }
    ],
    "identifier": 68231416,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to update each value of type \"string\" in an entire json to a number if possible.",
      "If the value cannot be parsed as a number, the string should be kept.",
      "walk(if type == \"string\" then . as $in | try tonumber catch $in else . end)",
      "walk(if type == \"string\" then tonumber? // . else . end)",
      "reduce paths(strings) as $p (. ; getpath($p) as $x | setpath($p; $x | tonumber? // $x))"
    ],
    "utterance": "Convert all values of type string to a number if possible; otherwise, keep the original string.",
    "expressions": [
      "walk(if type == \"string\" then . as $in | try tonumber catch $in else . end)",
      "walk(if type == \"string\" then tonumber? // . else . end)",
      "reduce paths(strings) as $p (. ; getpath($p) as $x | setpath($p; $x | tonumber? // $x))"
    ],
    "data": [
      {
        "input": {
          "outer": {
            "inner": [
              {
                "foo": "foo",
                "bar": "11",
                "count": 12,
                "data": [
                  "13",
                  "14"
                ]
              },
              {
                "foo": "foo",
                "bar": "15",
                "count": 16,
                "child": {
                  "otherData": [
                    "17",
                    "18"
                  ]
                }
              }
            ]
          }
        },
        "output": {
          "outer": {
            "inner": [
              {
                "foo": "foo",
                "bar": 11,
                "count": 12,
                "data": [
                  13,
                  14
                ]
              },
              {
                "foo": "foo",
                "bar": 15,
                "count": 16,
                "child": {
                  "otherData": [
                    17,
                    18
                  ]
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 68238661,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have  jsonlines data which and would like to find 1. value is empty object  or 2. key is not exist . In the following sample, I wonder take the result of items which .items.spec.resource={} or .items.spec.limits|requests which key not exist.",
      "jq -c '\n.items[]\n| .metadata.name as $podname\n| .spec.containers[] \n| select(.resources.requests == null or \n         .resources.limits == null or \n         .resources == {})\n| [$podname, .name]\n'",
      "The test for the third condition (.resources == {}) is actually redundant, so the above jq filter is equivalent to:\n.items[]\n| .metadata.name as $podname\n| .spec.containers[] \n| select(.resources | (.requests == null or .limits == null ))\n| [$podname, .name]",
      "To check for the existence of a key, it is generally appropriate to use `has/1` since `{} | .key` evaluates to `null`. Thus you might wish to replace the `select()` above with:\nselect( any(.resources | has(\"requests\", \"limits\"); not) )"
    ],
    "utterance": "List all containers where the resources object is empty or lacks either the requests or limits keys, showing the pod name and container name.",
    "expressions": [
      ".items[] | .metadata.name as $podname | .spec.containers[] | select(.resources.requests == null or .resources.limits == null or .resources == {}) | [$podname, .name]",
      ".items[] | .metadata.name as $podname | .spec.containers[] | select(.resources | (.requests == null or .limits == null )) | [$podname, .name]",
      ".items[] | .metadata.name as $podname | .spec.containers[] | select(any(.resources | has(\"requests\", \"limits\"); not)) | [$podname, .name]"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "pod01"
              },
              "spec": {
                "containers": [
                  {
                    "name": "con01_01",
                    "resources": {
                      "limits": {
                        "cpu": "100m"
                      },
                      "requests": {
                        "cpu": "100m"
                      }
                    }
                  },
                  {
                    "name": "con01_02",
                    "resources": {
                      "limits": {
                        "cpu": "100m"
                      },
                      "requests": {
                        "cpu": "100m"
                      }
                    }
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "pod02"
              },
              "spec": {
                "containers": [
                  {
                    "name": "con02_01",
                    "resources": {
                      "limits": {
                        "cpu": "100m"
                      },
                      "requests": {
                        "cpu": "100m"
                      }
                    }
                  },
                  {
                    "name": "con02_02",
                    "resources": {
                      "limits": {
                        "cpu": "100m"
                      }
                    }
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "pod03"
              },
              "spec": {
                "containers": [
                  {
                    "name": "con03_01",
                    "resources": {
                      "limits": {
                        "cpu": "100m"
                      },
                      "requests": {
                        "cpu": "100m"
                      }
                    }
                  },
                  {
                    "name": "con03_02",
                    "resources": {}
                  }
                ]
              }
            }
          ]
        },
        "output": [
          [
            "pod02",
            "con02_02"
          ],
          [
            "pod03",
            "con03_02"
          ]
        ]
      }
    ],
    "identifier": 68251963,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I wanted to beautify my code for example passing the list as an argument rather than having it hardcoded in code.",
      "The simplest way to achieve your goal would be to define `requiredViewers` as a JSON array, and to pass it in using `--argjson` instead of `--arg` (assuming your version of jq supports --argjson):",
      "jq --argjson items \"$requiredViewers\" ' ( map( select( .state==\"APPROVED\" ) ) | map( { user: .user.login, state, submitted_at } ) | unique_by( .user ) | sort_by( .submitted_at ) | reverse ) | any( .[].user; IN ( $items[] ) ) and length>=2 '"
    ],
    "utterance": "Filter approvals where the number is at least two and at least one approver is in a specified list supplied externally as an argument.",
    "expressions": [
      "( map( select( .state==\"APPROVED\" ) ) | map( { user: .user.login, state, submitted_at } ) | unique_by( .user ) | sort_by( .submitted_at ) | reverse ) | any( .[].user; IN ( $items[] ) ) and length>=2"
    ],
    "identifier": 68255795,
    "annotated": {
      "invalid": {
        "variables": true,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "What I need to do is to create a list, that contains:\n\n    UserId: user1  email: email1@email.cccc\n    UserId: user2  email: email2@email.cccc\n    UserId: user3  email: email3@email.cccc\n    ...",
      "My problem is that the username key, is basically always changing and it doesn't have a fix key name.",
      "Would this work for you?\n\n```\njq -c 'to_entries[] | \"UserId: \" + .key + \"  email: \" + .value.email '\n```",
      "Another approach:\n```\n  keys_unsorted[] as $key\n  | \"UserId: \\($key)  email: \\(.[$key].email)\"\n```"
    ],
    "utterance": "Produce a list of lines with each user's key and email in the format: UserId: <key>  email: <email>, regardless of the username key name.",
    "expressions": [
      "to_entries[] | \"UserId: \" + .key + \"  email: \" + .value.email",
      "keys_unsorted[] as $key | \"UserId: \\($key)  email: \\(.[$key].email)\""
    ],
    "data": [
      {
        "input": {
          "user1": {
            "email": "email1@email.cccc",
            "shell": "/usr/local/bin/bash",
            "status": "ACTIVE",
            "userId": "user1",
            "homeDir": "/home/user1",
            "unixUid": 123456,
            "accesses": [
              "computer1"
            ],
            "personId": 1234,
            "isPrimary": true,
            "projectGroupIds": [
              "bigproj"
            ],
            "primaryProjectGroupId": "bigproj"
          },
          "user2": {
            "email": "email2@email.cccc",
            "shell": "/usr/local/bin/bash",
            "status": "ACTIVE",
            "userId": "user2",
            "homeDir": "/home/user2",
            "unixUid": 9876564,
            "accesses": [
              "computer1"
            ],
            "personId": 5678,
            "isPrimary": true,
            "projectGroupIds": [
              "smallporj"
            ],
            "primaryProjectGroupId": "smallproj"
          }
        },
        "output": [
          "UserId: user1  email: email1@email.cccc",
          "UserId: user2  email: email2@email.cccc"
        ]
      }
    ],
    "identifier": 68256334,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have these variables in bash.\n\n```\nDOC='ABC=123;CDE=345;CDE=IOP'\nNEWVAR='101808'\nNEWVAR2='10240404'\n```\n\nI want to combine them and create a json string in bash.",
      "only 'DOC' is in semicolon-separated values.\nNEWVAR and NEWVAR2 are just plain texts.",
      "jq --arg DOC \"$DOC\" --arg NEWVAR \"$NEWVAR\" --arg NEWVAR2 \"$NEWVAR2\" '$DOC | split(\";\") | map(split(\"=\") | { (.[0]) : .[1] }) | add + { NEWVAR: $NEWVAR } + { NEWVAR2: $NEWVAR2 }' -Rn",
      "jq --null-input  \"${args[@]}\" '$ARGS.named'",
      "jq clearly ignores duplicate --arg variables.",
      "outputs\n```none\n{\n  \"ABC\": \"123\",\n  \"CDE\": \"345\",\n  \"NEWVAR\": \"101808\",\n  \"NEWVAR2\": \"10240404\"\n}\n```"
    ],
    "utterance": "Combine a semicolon-separated key-value string ('DOC') with two plain variables ('NEWVAR', 'NEWVAR2') into an object mapping keys to their values, including all three sources.",
    "expressions": [
      "$DOC | split(\";\") | map(split(\"=\") | { (.[0]) : .[1] }) | add + { NEWVAR: $NEWVAR } + { NEWVAR2: $NEWVAR2 }",
      "$ARGS.named"
    ],
    "data": [
      {
        "input": {
          "DOC": "ABC=123;CDE=345;CDE=IOP",
          "NEWVAR": "101808",
          "NEWVAR2": "10240404"
        },
        "output": {
          "ABC": "123",
          "CDE": "IOP",
          "NEWVAR": "101808",
          "NEWVAR2": "10240404"
        }
      }
    ],
    "identifier": 68271887,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "how can I have transformed my json",
      "{\n    \"clients\": [\n    {\n     \"id\" : \"qwerty\",\n     \"accounts\" : [{\"number\" : \"6666\"}, {\"number\" : \"7777\"}]\n    },\n    {\n     \"id\" : \"zxcvb\",\n     \"accounts\" : [{\"number\" : \"1111\"}, {\"number\" : \"2222\"}] \n    }\n]\n}",
      "into following type of json? using **JQ**",
      "{\n\"items\": [\n{\n\"id\" : \"qwerty\",\n\"number\" : \"6666\"\n},{\n\"id\" : \"qwerty\",\n\"number\" : \"7777\"\n},{\n\"id\" : \"zxcvb\",\n\"number\" : \"1111\"\n},{\n\"id\" : \"zxcvb\",\n\"number\" : \"2222\"\n}]\n}",
      "Something like this should do the trick:",
      "{items: [.clients[] | {id} + .accounts[]]}"
    ],
    "utterance": "Produce an object with a key 'items' containing a flat array where each entry combines a client's 'id' with each of their account 'number' values.",
    "expressions": [
      "{items: [.clients[] | {id} + .accounts[]]}"
    ],
    "data": [
      {
        "input": {
          "clients": [
            {
              "id": "qwerty",
              "accounts": [
                {
                  "number": "6666"
                },
                {
                  "number": "7777"
                }
              ]
            },
            {
              "id": "zxcvb",
              "accounts": [
                {
                  "number": "1111"
                },
                {
                  "number": "2222"
                }
              ]
            }
          ]
        },
        "output": {
          "items": [
            {
              "id": "qwerty",
              "number": "6666"
            },
            {
              "id": "qwerty",
              "number": "7777"
            },
            {
              "id": "zxcvb",
              "number": "1111"
            },
            {
              "id": "zxcvb",
              "number": "2222"
            }
          ]
        }
      }
    ],
    "identifier": 68276052,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "Is there a way using (`jq` probably?) to print:\n\na) all elements of the `DBInstances` array\n\nand for each element print only\n\nthe `DBInstanceIdentifier` and the `EngineVersion`?",
      "You can use the following JQ filter:\n```\n.DBInstances[] | [ .DBInstanceIdentifier, .EngineVersion ]\n```",
      "jq '.DBInstances[] | [ .DBInstanceIdentifier, .EngineVersion ]'"
    ],
    "utterance": "For each element in the DBInstances array, output only the DBInstanceIdentifier and EngineVersion fields.",
    "expressions": [
      ".DBInstances[] | [ .DBInstanceIdentifier, .EngineVersion ]"
    ],
    "data": [
      {
        "input": {
          "DBInstances": [
            {
              "DBInstanceIdentifier": "my-rds",
              "Endpoint": {
                "HostedZoneId": "XXXXXXXXXXXX"
              },
              "DBSecurityGroups": [],
              "VpcSecurityGroups": [
                {
                  "VpcSecurityGroupId": "sg-12345",
                  "Status": "active"
                },
                {
                  "VpcSecurityGroupId": "sg-12345",
                  "Status": "active"
                }
              ],
              "DBParameterGroups": [
                {
                  "DBParameterGroupName": "postgres-12",
                  "ParameterApplyStatus": "in-sync"
                }
              ],
              "AvailabilityZone": "us-west-1c",
              "DBSubnetGroup": {
                "VpcId": "vpc-123456",
                "SubnetGroupStatus": "Complete",
                "Subnets": [
                  {
                    "SubnetIdentifier": "subnet-123456",
                    "SubnetAvailabilityZone": {
                      "Name": "us-west-1b"
                    },
                    "SubnetOutpost": {},
                    "SubnetStatus": "Active"
                  },
                  {
                    "SubnetIdentifier": "subnet-12345",
                    "SubnetAvailabilityZone": {
                      "Name": "us-west-1c"
                    },
                    "SubnetOutpost": {},
                    "SubnetStatus": "Active"
                  },
                  {
                    "SubnetIdentifier": "subnet-12345",
                    "SubnetAvailabilityZone": {
                      "Name": "us-west-1e"
                    },
                    "SubnetOutpost": {},
                    "SubnetStatus": "Active"
                  }
                ]
              },
              "EngineVersion": "11.9",
              "AutoMinorVersionUpgrade": true,
              "ReadReplicaDBInstanceIdentifiers": [],
              "LicenseModel": "foobar",
              "OptionGroupMemberships": [
                {
                  "OptionGroupName": "randomname",
                  "Status": "in-sync"
                }
              ]
            }
          ]
        },
        "output": [
          "my-rds",
          "11.9"
        ]
      }
    ],
    "identifier": 68282553,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "When timestamp is not the same length for each array variable,\r\nI want to display only values \u200b\u200bin the same timestamp as a single string.",
      "I mean group by Timestamps. Like this\r\n{\r\n    \"MetricDataResults\": [\r\n        {\r\n            \"Timestamps\": \"2021-07-07T13:28:00Z\",\r\n            \"Label\" : [\r\n               \"CPUUtilization\",\r\n               \"NetworkReceiveThroughput\"\r\n            ],\r\n            \"Values\" : [\r\n               12.750425014167137,\r\n               0.7\r\n            ]\r\n         },\r\n         {\r\n            \"Timestamps\": \"2021-07-07T13:27:00Z\",\r\n            \"Label\" : [\r\n               \"CPUUtilization\",\r\n               \"NetworkReceiveThroughput\"\r\n            ],\r\n            \"Values\" : [\r\n               13.033116114731422,\r\n               0.6999533364442371\r\n            ]\r\n         },\r\n         {\r\n            \"Timestamps\": \"2021-07-07T13:26:00Z\",\r\n            \"Label\" : [\r\n               \"CPUUtilization\",\r\n               \"NetworkReceiveThroughput\",\r\n               \"CPUSurplusCreditsCharged\"\r\n            ],\r\n            \"Values\" : [\r\n               12.70812153130781,\r\n               0.6998833527745376,\r\n               0.0\r\n            ]\r\n        }\r\n    ]\r\n}",
      "The first `jq` command of the shell script produces:\r\n\r\n```text\r\n2021-07-07T13:23:00Z\r\nCPUUtilization=12.916451392476791\r\nNetworkReceiveThroughput=0.6998950157476379\r\n\r\n2021-07-07T13:24:00Z\r\nCPUUtilization=15.441924032067199\r\nNetworkReceiveThroughput=0.7001166861143524\r\n\r\n2021-07-07T13:25:00Z\r\nCPUUtilization=12.975\r\nNetworkReceiveThroughput=0.7\r\n\r\n2021-07-07T13:26:00Z\r\nCPUSurplusCreditsCharged=0\r\nCPUUtilization=12.70812153130781\r\nNetworkReceiveThroughput=0.6999416715273727\r\n\r\n2021-07-07T13:27:00Z\r\nCPUUtilization=13.033116114731422\r\nNetworkReceiveThroughput=0.6998833527745376\r\n\r\n2021-07-07T13:28:00Z\r\nCPUUtilization=12.750425014167137\r\nNetworkReceiveThroughput=0.6999533364442371\r\n\r\n2021-07-07T13:29:00Z\r\nNetworkReceiveThroughput=0.7\r\n```",
      "Here is a simple, idiomatic solution for the case of text output; it can be used with any version of jq from 1.3 onwards.  Note in particular that it does not rely on `foreach`, the use of which here is overly complicated:\r\n\r\n```\r\n< input.json jq -r '\r\n  .MetricDataResults\r\n  | map(.Values as $values\r\n        | .Timestamps as $timestamps\r\n        | {Label} +\r\n           (range(0; .Timestamps|length) as $idx\r\n            | {Timestamp: $timestamps[$idx], \r\n               Value:     $values[$idx]} ))\r\n  | group_by(.Timestamp)[]\r\n  | .[0].Timestamp, (.[]|\"\\(.Label)=\\(.Value)\"), \"\"\r\n'\r\n\r\n\r\n"
    ],
    "utterance": "Group metric results by timestamp, so that for each timestamp, display the corresponding metric label-value pairs on the same line or grouped output.",
    "expressions": [
      ".MetricDataResults\n| map(.Values as $values | .Timestamps as $timestamps | {Label} + foreach range(.Timestamps | length) as $idx (null; {\"Timestamp\": $timestamps[$idx], \"Value\": $values[$idx]}; .))\n| group_by(.Timestamp)[]\n| [.[0].Timestamp]\n  + map(\"\\(.Label)=\\(.Value)\")\n  | join(\"\\n\") + \"\\n\"",
      ".MetricDataResults\n| map(.Values as $values\n      | .Timestamps as $timestamps\n      | {Label} +\n         (range(0; .Timestamps|length) as $idx\n          | {Timestamp: $timestamps[$idx], \n             Value:     $values[$idx]} ))\n| group_by(.Timestamp)[]\n| .[0].Timestamp, (.[]|\"\\(.Label)=\\(.Value)\"), \"\""
    ],
    "data": [
      {
        "input": {
          "Messages": [],
          "MetricDataResults": [
            {
              "Timestamps": [
                "2021-07-07T13:26:00Z"
              ],
              "StatusCode": "Complete",
              "Values": [
                0.0
              ],
              "Id": "m19",
              "Label": "CPUSurplusCreditsCharged"
            },
            {
              "Timestamps": [
                "2021-07-07T13:28:00Z",
                "2021-07-07T13:27:00Z",
                "2021-07-07T13:26:00Z",
                "2021-07-07T13:25:00Z",
                "2021-07-07T13:24:00Z",
                "2021-07-07T13:23:00Z"
              ],
              "StatusCode": "Complete",
              "Values": [
                12.750425014167137,
                13.033116114731422,
                12.70812153130781,
                12.975,
                15.441924032067199,
                12.916451392476791
              ],
              "Id": "m20",
              "Label": "CPUUtilization"
            },
            {
              "Timestamps": [
                "2021-07-07T13:29:00Z",
                "2021-07-07T13:28:00Z",
                "2021-07-07T13:27:00Z",
                "2021-07-07T13:26:00Z",
                "2021-07-07T13:25:00Z",
                "2021-07-07T13:24:00Z",
                "2021-07-07T13:23:00Z"
              ],
              "StatusCode": "Complete",
              "Values": [
                0.7,
                0.6999533364442371,
                0.6998833527745376,
                0.6999416715273727,
                0.7,
                0.7001166861143524,
                0.6998950157476379
              ],
              "Id": "m21",
              "Label": "NetworkReceiveThroughput"
            }
          ]
        },
        "output": "2021-07-07T13:23:00Z\nCPUUtilization=12.916451392476791\nNetworkReceiveThroughput=0.6998950157476379\n\n2021-07-07T13:24:00Z\nCPUUtilization=15.441924032067199\nNetworkReceiveThroughput=0.7001166861143524\n\n2021-07-07T13:25:00Z\nCPUUtilization=12.975\nNetworkReceiveThroughput=0.7\n\n2021-07-07T13:26:00Z\nCPUSurplusCreditsCharged=0\nCPUUtilization=12.70812153130781\nNetworkReceiveThroughput=0.6999416715273727\n\n2021-07-07T13:27:00Z\nCPUUtilization=13.033116114731422\nNetworkReceiveThroughput=0.6998833527745376\n\n2021-07-07T13:28:00Z\nCPUUtilization=12.750425014167137\nNetworkReceiveThroughput=0.6999533364442371\n\n2021-07-07T13:29:00Z\nNetworkReceiveThroughput=0.7\n"
      }
    ],
    "identifier": 68296364,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "echo '{\"nodes\":[{\"id\":\"1\"}]}' | jq '.nodes[?(@.id==\"1\")]'",
      "jq: error: syntax error, unexpected '?' (Unix shell quoting issues?) at <top-level>, line 1:",
      "jq '.nodes[] | select(.id == \"1\")'"
    ],
    "utterance": "Select elements from the 'nodes' array whose 'id' is equal to '1'.",
    "expressions": [
      ".nodes[] | select(.id == \"1\")"
    ],
    "data": [
      {
        "input": {
          "nodes": [
            {
              "id": "1"
            }
          ]
        },
        "output": {
          "id": "1"
        }
      }
    ],
    "identifier": 68315788,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I'm trying to come up with the correct jq syntax to convert json to csv.",
      "note that also need to ignore objects with empty \"agent_priorities\"",
      "Desired results:\n\n    <email>,<id>,<name>\n    e.g. \n    user1@whatever.nevermind.no,0,general\n    user2@whatever.nevermind.no,0,general\n    user1@whatever.nevermind.no,1,local\n    ...",
      "jq -r '.[] \n           | .id as $id \n           | .name as $name \n           | .agent_priorities \n           | keys \n           | .[] \n           | [., $id, $name ] \n           | @csv\n          ' file.json",
      "The following variant of the accepted answer checks for the existence of the \"agent_priorities\" key as per the requirements, and uses `keys_unsorted` to preserve the order of the keys:\n```\njq -r '\n       .[] \n       | select(has(\"agent_priorities\"))\n       | .id as $id \n       | .name as $name \n       | .agent_priorities \n       | keys_unsorted[]\n       | [., $id, $name ] \n       | @csv\n      ' file.json\n```"
    ],
    "utterance": "Extract all combinations of agent email, id, and name from each object, skipping objects where agent_priorities is empty or missing.",
    "expressions": [
      ".[] | .id as $id | .name as $name | .agent_priorities | keys[] | [., $id, $name] | @csv",
      ".[] | select(has(\"agent_priorities\")) | .id as $id | .name as $name | .agent_priorities | keys_unsorted[] | [., $id, $name] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "id": 0,
            "name": "General",
            "agent_priorities": {
              "user1@whatever.nevermind.no": "normal",
              "user2@whatever.nevermind.no": "normal"
            }
          },
          {
            "id": 1,
            "name": "local",
            "agent_priorities": {
              "user1@whatever.nevermind.no": "normal"
            }
          },
          {
            "id": 2,
            "name": "Engineering"
          }
        ],
        "output": [
          "\"user1@whatever.nevermind.no\",0,\"General\"",
          "\"user2@whatever.nevermind.no\",0,\"General\"",
          "\"user1@whatever.nevermind.no\",1,\"local\""
        ]
      }
    ],
    "identifier": 68316206,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "and my **desired output** should be like:\r\n\r\n    country:India, city:India1\r\n    country:India, city:India2\r\n    country:India, city:India3\r\n    \r\n    country:USA, city:USA1\r\n    country:USA, city:USA2\r\n    country:USA, city:USA3",
      "If you don't need that blank line, it's a lot simpler.\r\n\r\n```sh\r\njq -r '\r\n   .countries[] |\r\n   .country as $country |\r\n   .city[] |\r\n   \"country: \\( $country ), city: \\( . )\"\r\n'\r\n```",
      "The later can be reduced to\r\n\r\n```sh\r\njq -r '.countries[] | \"country: \\( .country ), city: \\( .city[] )\"'\r\n```"
    ],
    "utterance": "List each country and its cities as lines in the format 'country:<country>, city:<city>' for all combinations.",
    "expressions": [
      ".countries[] | \"country: \\( .country ), city: \\( .city[] )\"",
      ".countries[] | .country as $country | .city[] | \"country: \\($country), city: \\(.)\""
    ],
    "data": [
      {
        "input": {
          "countries": [
            {
              "country": "India",
              "city": [
                "India1",
                "India2",
                "India3"
              ]
            },
            {
              "country": "USA",
              "city": [
                "USA1",
                "USA2",
                "USA3"
              ]
            }
          ]
        },
        "output": [
          "country: India, city: India1",
          "country: India, city: India2",
          "country: India, city: India3",
          "country: USA, city: USA1",
          "country: USA, city: USA2",
          "country: USA, city: USA3"
        ]
      }
    ],
    "identifier": 68328848,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I\u2019d like to select/identity-output all objects in arrays under \"emp\" keys into a flat array of those objects.",
      "I'm looking for a flat array of arbitrary objects found in arbitrary locations within the document (in this example, under \"emp\" parent/keys).",
      "Use `recurse` to walk the structure. From all the substrucures, select objects with the `emp` key. Output the corresponding values and merge the resulting arrays.",
      "jq '[recurse | select (type == \"object\" and .emp) | .emp ] | add' file.json"
    ],
    "utterance": "Extract all objects inside every array found at any 'emp' key, regardless of their location, into a single flat array.",
    "expressions": [
      "[recurse | select (type == \"object\" and .emp) | .emp ] | add"
    ],
    "data": [
      {
        "input": [
          {
            "eng": {
              "dev": {
                "dir": {
                  "name": "Mickey"
                },
                "emp": [
                  {
                    "name": "Goofy",
                    "job": "laugh",
                    "start": "today"
                  },
                  {
                    "name": "Minnie",
                    "job": "laugh"
                  }
                ]
              }
            }
          },
          {
            "mgmt": {
              "dir": {
                "name": "Donald"
              },
              "emp": [
                {
                  "name": "Woody",
                  "job": "smile"
                },
                {
                  "name": "Buzz",
                  "job": "smile"
                }
              ]
            }
          }
        ],
        "output": [
          {
            "name": "Goofy",
            "job": "laugh",
            "start": "today"
          },
          {
            "name": "Minnie",
            "job": "laugh"
          },
          {
            "name": "Woody",
            "job": "smile"
          },
          {
            "name": "Buzz",
            "job": "smile"
          }
        ]
      }
    ],
    "identifier": 68332371,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have the following JSON\n\n    [\n     {\n      name : \"A\",\n      value : \"1\"\n     },\n     {\n      name : \"B\",\n      value : \"5\"\n     },\n     {\n      name : \"E\",\n      value : \"8\"\n     }\n    ]\n\nand I simply want to to be like \n\n     {\n      name : \"A\",\n      value : \"1\"\n     },\n     {\n      name : \"B\",\n      value : \"5\"\n     },\n     {\n      name : \"E\",\n      value : \"8\"\n     }",
      "I used jq normal filter so jq'.[]', however I get a list of objects separated by a return as such:\n```\n {\n  name : \"A\",\n  value : \"1\"\n }\n {\n  name : \"B\",\n  value : \"5\"\n }\n {\n  name : \"E\",\n  value : \"8\"\n }\n``` \nNotice that the commas between the objects have magically vanished.",
      "2. hjson, jq, and sed\n```\n   < qjson.txt hjson -j | jq -r '.[] | (,.',\")' | sed '$d'\n```",
      "3. hjson and jq\n```\n    < qjson.txt hjson -j | jq -r '\n        foreach .[] as $x (-1; .+1; \n          if . == 0 then $x else \",\", $x end)'\n```"
    ],
    "utterance": "Output each object in the array separated by commas, but not as a JSON array.",
    "expressions": [
      ".[] | (.,\",\")",
      "foreach .[] as $x (-1; .+1; if . == 0 then $x else \",\", $x end)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "A",
            "value": "1"
          },
          {
            "name": "B",
            "value": "5"
          },
          {
            "name": "E",
            "value": "8"
          }
        ],
        "output": "{ \"name\": \"A\", \"value\": \"1\" },\n{ \"name\": \"B\", \"value\": \"5\" },\n{ \"name\": \"E\", \"value\": \"8\" }"
      }
    ],
    "identifier": 68333885,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "jq -r '.countries[] | .country + \" \" + .city[]' country.json",
      "jq -r '.countries[]\n       | .country as $country\n       | .city[] | \"\\($country)\\t\\(.)\"' | \n  while IFS=$'\\t' read -r country city; do\n     ./child_script.sh \"$country\" \"$city\"\n  done",
      "jq -r '\n   .countries[] |\n   .country as $country |\n   .city[] |\n   @sh \"\\($country) \\(.)\"\n' country.json |\nxargs -rl ./child_script.sh"
    ],
    "utterance": "For each pair of country and city, print the country name and city name together, for all cities in all countries.",
    "expressions": [
      ".countries[] | .country + \" \" + .city[]",
      ".countries[] | .country as $country | .city[] | @sh \"\\($country) \\(.)\"",
      ".countries[] | .country as $country | .city[] | \"\\($country)\\t\\(.)\""
    ],
    "data": [
      {
        "input": {
          "countries": [
            {
              "country": "India",
              "city": [
                "India1",
                "India2",
                "India3"
              ]
            },
            {
              "country": "USA",
              "city": [
                "USA1",
                "USA2",
                "USA3"
              ]
            }
          ]
        },
        "output": [
          "India India1",
          "India India2",
          "India India3",
          "USA USA1",
          "USA USA2",
          "USA USA3"
        ]
      }
    ],
    "identifier": 68334498,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I have the following json file and I would like access the nth element in it.",
      "Here, the json file is in disassembled form.",
      "When I try\n\n    $ jq '[0]' a.json\n\nI get the error`jq: error (at a.json:1): Cannot index object with number`.",
      "The expected output is '{\"one\":1}'.",
      "jq has a built-in filter, `nth($n; s)` for solving this type of problem very efficiently.  For example, to emit the second item, you would simply invoke:\n\n    jq -n 'nth(1; inputs)' a.json",
      "You could slurp the whole input with `-s`, but you can also use `inputs` with `-n` (null input mode) and get the nth element by specifying the index, i.e to get element at index 2\n\n```bash\njq -n '[inputs] | nth(2)' a.json"
    ],
    "utterance": "Select the nth object from a file containing one JSON object per line, where indexing starts at 0.",
    "expressions": [
      "jq -n '[inputs][N]' a.json",
      "jq -n 'nth(N; inputs)' a.json",
      "jq -n '[inputs] | nth(N)' a.json"
    ],
    "data": [
      {
        "input": [
          {
            "one": 1
          },
          {
            "two": 2
          },
          {
            "three": 3
          }
        ],
        "output": {
          "one": 1
        }
      }
    ],
    "identifier": 68342224,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": true
      },
      "other_task": null,
      "other_environment": null
    }
  },
  {
    "context": [
      "I want to use `jq` or similar to return `.items[x].metadata.name` when that list element's `.status.conditions` list has a condition of `.type == \"Ready\"` and `.status == \"False\"`.",
      "The 'business case' is \"Get any custom resources that are not yet ready.\"",
      "With your input, the filter\n```\n.items[]\n| select( any(.status.conditions[];  .type == \"Ready\" and .status == \"False\") )\n| .metadata.name\n```\nreturns\n\n```\n\"return-me\"\n```\n"
    ],
    "utterance": "Find the names of items where any condition has type equal to \"Ready\" and status equal to \"False\".",
    "expressions": [
      ".items[] | select( any(.status.conditions[]; .type == \"Ready\" and .status == \"False\") ) | .metadata.name"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "items": [
            {
              "metadata": {
                "name": "return-me"
              },
              "spec": {
                "region": "ap-southeast-2"
              },
              "status": {
                "conditions": [
                  {
                    "message": "Some Condition A",
                    "reason": "Supported",
                    "status": "True",
                    "type": "IsSupported"
                  },
                  {
                    "message": "Some Condition B",
                    "reason": "Shared",
                    "status": "True",
                    "type": "IsShared"
                  },
                  {
                    "message": "Some Condition C",
                    "reason": "Accepted",
                    "status": "False",
                    "type": "IsAccepted"
                  },
                  {
                    "status": "True",
                    "type": "OthersReady"
                  },
                  {
                    "status": "False",
                    "type": "Ready"
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "dont-return-me"
              },
              "spec": {
                "region": "ap-northeast-1"
              },
              "status": {
                "conditions": [
                  {
                    "message": "Some Condition A",
                    "reason": "Supported",
                    "status": "True",
                    "type": "IsSupported"
                  },
                  {
                    "message": "Some Condition B",
                    "reason": "Shared",
                    "status": "True",
                    "type": "IsShared"
                  },
                  {
                    "message": "Some Condition C",
                    "reason": "Accepted",
                    "status": "False",
                    "type": "IsAccepted"
                  },
                  {
                    "status": "True",
                    "type": "OthersReady"
                  },
                  {
                    "status": "True",
                    "type": "Ready"
                  }
                ]
              }
            }
          ],
          "kind": "List",
          "metadata": {
            "resourceVersion": "",
            "selfLink": ""
          }
        },
        "output": "return-me"
      }
    ],
    "identifier": 68370257,
    "annotated": {
      "invalid": {
        "variables": false,
        "stream": false,
        "multiple": false,
        "missing": false
      },
      "other_task": null,
      "other_environment": null
    }
  }
]