[
  {
    "context": [
      "I am trying to replace serviceName string from *ca-visual-node* to *ca-visual-node-canary*  if host name matches **test4.analytics.io** using jq utility.",
      "( \r\n  .spec.rules[]                             | \r\n  select(.host == \"test4.analytics.io\")?    | \r\n  .http.paths[].backend                     | \r\n  select(.serviceName == \"ca-visual-node\")? |\r\n  .serviceName\r\n)  |= \"ca-visual-node-canary\""
    ],
    "utterance": "Update serviceName from ca-visual-node to ca-visual-node-canary only where the rule's host is test4.analytics.io.",
    "expressions": [
      "(\n  .spec.rules[]                             |\n  select(.host == \"test4.analytics.io\")?    |\n  .http.paths[].backend                     |\n  select(.serviceName == \"ca-visual-node\")? |\n  .serviceName\n)  |= \"ca-visual-node-canary\""
    ],
    "data": [
      {
        "input": {
          "apiVersion": "extensions/v1beta1",
          "kind": "Ingress",
          "metadata": {
            "annotations": {
              "alb.ingress.kubernetes.io/actions.ssl-redirect": "{\"Type\": \"redirect\", \"RedirectConfig\": { \"Protocol\": \"HTTPS\", \"Port\": \"443\", \"StatusCode\": \"HTTP_301\"}}"
            },
            "finalizers": [
              "ingress.k8s.aws/resources"
            ],
            "name": "ca-visual",
            "namespace": "cloud-anaytics"
          },
          "spec": {
            "rules": [
              {
                "host": "test.analytics.io",
                "http": {
                  "paths": [
                    {
                      "backend": {
                        "serviceName": "ca-visual-play",
                        "servicePort": 9443
                      },
                      "path": "/apii/*",
                      "pathType": "ImplementationSpecific"
                    },
                    {
                      "backend": {
                        "serviceName": "ssl-redirect",
                        "servicePort": "use-annotation"
                      },
                      "path": "/*",
                      "pathType": "ImplementationSpecific"
                    },
                    {
                      "backend": {
                        "serviceName": "ca-visual-node",
                        "servicePort": 443
                      },
                      "path": "/*",
                      "pathType": "ImplementationSpecific"
                    }
                  ]
                }
              },
              {
                "host": "test4.analytics.io",
                "http": {
                  "paths": [
                    {
                      "backend": {
                        "serviceName": "ca-visual-play",
                        "servicePort": 9443
                      },
                      "path": "/apii/*",
                      "pathType": "ImplementationSpecific"
                    },
                    {
                      "backend": {
                        "serviceName": "ssl-redirect",
                        "servicePort": "use-annotation"
                      },
                      "path": "/*",
                      "pathType": "ImplementationSpecific"
                    },
                    {
                      "backend": {
                        "serviceName": "ca-visual-node",
                        "servicePort": 443
                      },
                      "path": "/*",
                      "pathType": "ImplementationSpecific"
                    }
                  ]
                }
              }
            ]
          },
          "status": {
            "loadBalancer": {
              "ingress": [
                {
                  "hostname": "16b3-cloudanaytics.us-xxxx-1.elb.amazonaws.com"
                }
              ]
            }
          }
        },
        "output": {
          "apiVersion": "extensions/v1beta1",
          "kind": "Ingress",
          "metadata": {
            "annotations": {
              "alb.ingress.kubernetes.io/actions.ssl-redirect": "{\"Type\": \"redirect\", \"RedirectConfig\": { \"Protocol\": \"HTTPS\", \"Port\": \"443\", \"StatusCode\": \"HTTP_301\"}}"
            },
            "finalizers": [
              "ingress.k8s.aws/resources"
            ],
            "name": "ca-visual",
            "namespace": "cloud-anaytics"
          },
          "spec": {
            "rules": [
              {
                "host": "test.analytics.io",
                "http": {
                  "paths": [
                    {
                      "backend": {
                        "serviceName": "ca-visual-play",
                        "servicePort": 9443
                      },
                      "path": "/apii/*",
                      "pathType": "ImplementationSpecific"
                    },
                    {
                      "backend": {
                        "serviceName": "ssl-redirect",
                        "servicePort": "use-annotation"
                      },
                      "path": "/*",
                      "pathType": "ImplementationSpecific"
                    },
                    {
                      "backend": {
                        "serviceName": "ca-visual-node",
                        "servicePort": 443
                      },
                      "path": "/*",
                      "pathType": "ImplementationSpecific"
                    }
                  ]
                }
              },
              {
                "host": "test4.analytics.io",
                "http": {
                  "paths": [
                    {
                      "backend": {
                        "serviceName": "ca-visual-play",
                        "servicePort": 9443
                      },
                      "path": "/apii/*",
                      "pathType": "ImplementationSpecific"
                    },
                    {
                      "backend": {
                        "serviceName": "ssl-redirect",
                        "servicePort": "use-annotation"
                      },
                      "path": "/*",
                      "pathType": "ImplementationSpecific"
                    },
                    {
                      "backend": {
                        "serviceName": "ca-visual-node-canary",
                        "servicePort": 443
                      },
                      "path": "/*",
                      "pathType": "ImplementationSpecific"
                    }
                  ]
                }
              }
            ]
          },
          "status": {
            "loadBalancer": {
              "ingress": [
                {
                  "hostname": "16b3-cloudanaytics.us-xxxx-1.elb.amazonaws.com"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 68821217
  },
  {
    "context": [
      "And I just want to get the \"version\" from the first object. Theres is a way to do that?",
      "The data you've extracted is a stream of JSON objects. You could extract the .version from the first of these by piping the data to:",
      "jq -n input.version"
    ],
    "utterance": "Get the version field from the first object in a stream of JSON objects.",
    "expressions": [
      "jq -n input.version"
    ],
    "data": [
      {
        "input": [
          {
            "attributes": {
              "env": "prod"
            },
            "created_by": "email@email.com",
            "id": "612",
            "state": "published",
            "version": "0.22.0"
          },
          {
            "attributes": {
              "env": "prod"
            },
            "created_by": "email@email.com",
            "id": "611",
            "state": "published",
            "version": "0.22.0"
          }
        ],
        "output": "0.22.0"
      }
    ],
    "identifier": 68839614
  },
  {
    "context": [
      "I am trying to convert map of objects to an array with jq",
      "My Input is",
      "{\n  \"fish-chips\": {\n    \"likeDislikeRatio\": [\"80%\", \"20%\"],\n    \"country\": [\"BRIT_FOOD\",\"USA_FOOD\"]\n  },\n  \"sausage\": {\n    \"likeDislikeRatio\": [\"75%\", \"25%\"],\n    \"country\": [\"EU_FOOD\"]\n  },\n  \"cheese-burger\": {\n    \"likeDislikeRatio\": [\"25%\", \"75%\"],\n    \"country\": [\n      \"BRIT_FOOD\",\n      \"USA_FOOD\",\n      \"EU_FOOD\",\n      \"DEFAULT\"\n    ]\n  }\n}",
      "And my expected output is",
      "[\n  {\n\"name\" : \"fish-chips\",    \n\"likeDislikeRatio\": [\n      \"80%\",\n      \"20%\"\n    ],\n    \"country\": [\n      \"BRIT_FOOD\",\n      \"USA_FOOD\"\n    ]\n  }\n]",
      "[\n  {\n\"name\" : \"sausage\",\n    \"likeDislikeRatio\": [\n      \"75%\",\n      \"25%\"\n    ],\n    \"country\": [\n      \"EU_FOOD\"\n    ]\n  }\n]",
      "[\n  {\n\"name\" : \"cheese-burger\",\n    \"likeDislikeRatio\": [\n      \"25%\",\n      \"75%\"\n    ],\n    \"country\": [\n      \"BRIT_FOOD\",\n      \"USA_FOOD\",\n      \"EU_FOOD\",\n      \"DEFAULT\"\n    ]\n  }\n]",
      "The closest filter I could find was to_entries[] | [.key, .value]",
      "but the output is not as what I expected and I feel that there should be one more filter with this to get the desired out put",
      "You were close.",
      "`to_entries[] | [{name: .key} + .value]`"
    ],
    "utterance": "Transform each key-value pair from an object where each key is a dish name and value is its properties into single-element arrays containing an object with a 'name' field set to the key and the rest of the fields copied from the value.",
    "expressions": [
      "to_entries[] | [{name: .key} + .value]"
    ],
    "data": [
      {
        "input": {
          "fish-chips": {
            "likeDislikeRatio": [
              "80%",
              "20%"
            ],
            "country": [
              "BRIT_FOOD",
              "USA_FOOD"
            ]
          },
          "sausage": {
            "likeDislikeRatio": [
              "75%",
              "25%"
            ],
            "country": [
              "EU_FOOD"
            ]
          },
          "cheese-burger": {
            "likeDislikeRatio": [
              "25%",
              "75%"
            ],
            "country": [
              "BRIT_FOOD",
              "USA_FOOD",
              "EU_FOOD",
              "DEFAULT"
            ]
          }
        },
        "output": [
          [
            {
              "name": "fish-chips",
              "likeDislikeRatio": [
                "80%",
                "20%"
              ],
              "country": [
                "BRIT_FOOD",
                "USA_FOOD"
              ]
            }
          ],
          [
            {
              "name": "sausage",
              "likeDislikeRatio": [
                "75%",
                "25%"
              ],
              "country": [
                "EU_FOOD"
              ]
            }
          ],
          [
            {
              "name": "cheese-burger",
              "likeDislikeRatio": [
                "25%",
                "75%"
              ],
              "country": [
                "BRIT_FOOD",
                "USA_FOOD",
                "EU_FOOD",
                "DEFAULT"
              ]
            }
          ]
        ]
      }
    ],
    "identifier": 68436928
  },
  {
    "context": [
      "My goal is to replace the value of `api-key` under `HeaderAuthentication` (it could be in any index , 0 , 2, 1, ...)",
      "The issue is seems `jq` is returning only the part that replaced, but I need the whole file, what I am doing wrong?",
      "Put your filter expression inside `(..)`, meaning it to apply to the node structure from root, and not within `.Headers[]` alone. Once under parens, use the update assignment `|=` or the normal assignment to make it work.",
      "```none\r\n( .HeaderAuthentication.Headers[] | select(.Name == \"api-key\") | .Value ) |= \"xxx\"\r\n```"
    ],
    "utterance": "Replace the value of the header whose Name is api-key under HeaderAuthentication.Headers, regardless of its index, and return the entire updated structure.",
    "expressions": [
      "( .HeaderAuthentication.Headers[] | select(.Name == \"api-key\") | .Value ) |= \"xxx\""
    ],
    "data": [
      {
        "input": {
          "AgentGroupId": null,
          "AgentId": null,
          "CreateType": "Website",
          "IsPrimary": true,
          "IsShared": true,
          "HeaderAuthentication": {
            "Headers": [
              {
                "Name": "api-key",
                "Value": "TEST_API_KEY_VALUE-2",
                "OriginalName": null,
                "IsReplacedCredentials": false
              },
              {
                "Name": "Authorization",
                "Value": "",
                "OriginalName": null,
                "IsReplacedCredentials": false
              }
            ],
            "IsEnabled": true
          },
          "IsTimeWindowEnabled": false,
          "AdditionalWebsites": [],
          "BasicAuthenticationApiModel": {
            "Credentials": null,
            "IsEnabled": false,
            "NoChallenge": false
          },
          "ClientCertificateAuthenticationSetting": null,
          "Cookies": null,
          "CrawlAndAttack": true,
          "EnableHeuristicChecksInCustomUrlRewrite": true,
          "ExcludedLinks": [
            {
              "RegexPattern": "gtm\\.js"
            },
            {
              "RegexPattern": "WebResource\\.axd"
            },
            {
              "RegexPattern": "ScriptResource\\.axd"
            }
          ],
          "ExcludedUsageTrackers": [],
          "DisallowedHttpMethods": [],
          "ExcludeLinks": true,
          "ExcludeAuthenticationPages": false,
          "FindAndFollowNewLinks": true,
          "FormAuthenticationSettingModel": {
            "Integrations": {},
            "CustomScripts": [],
            "InteractiveLoginRequired": false,
            "DefaultPersonaValidation": null,
            "DetectBearerToken": true,
            "DisableLogoutDetection": false,
            "IsEnabled": false,
            "LoginFormUrl": null,
            "LoginRequiredUrl": null,
            "LogoutKeywordPatterns": null,
            "LogoutKeywordPatternsValue": null,
            "LogoutRedirectPattern": null,
            "OverrideTargetUrl": false,
            "Personas": [],
            "PersonasValidation": null
          }
        },
        "output": {
          "AgentGroupId": null,
          "AgentId": null,
          "CreateType": "Website",
          "IsPrimary": true,
          "IsShared": true,
          "HeaderAuthentication": {
            "Headers": [
              {
                "Name": "api-key",
                "Value": "xxx",
                "OriginalName": null,
                "IsReplacedCredentials": false
              },
              {
                "Name": "Authorization",
                "Value": "",
                "OriginalName": null,
                "IsReplacedCredentials": false
              }
            ],
            "IsEnabled": true
          },
          "IsTimeWindowEnabled": false,
          "AdditionalWebsites": [],
          "BasicAuthenticationApiModel": {
            "Credentials": null,
            "IsEnabled": false,
            "NoChallenge": false
          },
          "ClientCertificateAuthenticationSetting": null,
          "Cookies": null,
          "CrawlAndAttack": true,
          "EnableHeuristicChecksInCustomUrlRewrite": true,
          "ExcludedLinks": [
            {
              "RegexPattern": "gtm\\.js"
            },
            {
              "RegexPattern": "WebResource\\.axd"
            },
            {
              "RegexPattern": "ScriptResource\\.axd"
            }
          ],
          "ExcludedUsageTrackers": [],
          "DisallowedHttpMethods": [],
          "ExcludeLinks": true,
          "ExcludeAuthenticationPages": false,
          "FindAndFollowNewLinks": true,
          "FormAuthenticationSettingModel": {
            "Integrations": {},
            "CustomScripts": [],
            "InteractiveLoginRequired": false,
            "DefaultPersonaValidation": null,
            "DetectBearerToken": true,
            "DisableLogoutDetection": false,
            "IsEnabled": false,
            "LoginFormUrl": null,
            "LoginRequiredUrl": null,
            "LogoutKeywordPatterns": null,
            "LogoutKeywordPatternsValue": null,
            "LogoutRedirectPattern": null,
            "OverrideTargetUrl": false,
            "Personas": [],
            "PersonasValidation": null
          }
        }
      }
    ],
    "identifier": 68839057
  },
  {
    "context": [
      "we want to replace the `DB_SERVER_CV02.localdomain` with `APP_SERVER_CV02.localdomain` name",
      "what is the right approach to replace the `DB_SERVER_CV02.localdomain` with `APP_SERVER_CV02.localdomain` with `jq` ?",
      "walk(if type == \"string\" \n         then sub(\"DB_SERVER_CV02[.]localdomain\"; \"APP_SERVER_CV02.localdomain\") \n         else . end)",
      "You may wish to tweak the `sub` command (or change it to `gsub`), depending on your actual requirements."
    ],
    "utterance": "Replace all occurrences of DB_SERVER_CV02.localdomain with APP_SERVER_CV02.localdomain in all string values throughout the data.",
    "expressions": [
      "walk(if type == \"string\" then gsub(\"DB_SERVER_CV02[.]localdomain\"; \"APP_SERVER_CV02.localdomain\") else . end)"
    ],
    "identifier": 68820793
  },
  {
    "context": [
      "For each string value within the nested list, look up the string value within the object and add all of its values into the current value.",
      "If we iterate through the values of `do` we come across `baz`. The value of `baz` within the object is `[[\"re\"]]`. Add `baz`'s value `[\"re\"]` to `do` so that `do` equals: `[[\"bar\",\"baz\"], [\"re\"]]`. Since `re` IS a key within the object, add the value of `[\"re\"]` which is `[\"zoo\"]`. Since `[\"zoo\"]` is NOT a key within the object finish `baz` and continue to the next key within the object.",
      "The following solves the problem as originally stated, but the \"expected\" output as shown does not quite match the stated problem.",
      "echo ${in} | jq -c '\n  . as $dict\n  | map_values(reduce (..|strings) as $v (.;\n                       . + $dict[$v] ))\n'"
    ],
    "utterance": "For each key, recursively expand all nested string references by including the lists of all referenced keys until no further references remain.",
    "expressions": [
      ". as $dict | map_values(reduce (..|strings) as $v (.; . + $dict[$v] ))"
    ],
    "data": [
      {
        "input": {
          "bar": [
            [
              "re",
              "de"
            ]
          ],
          "do": [
            [
              "bar",
              "baz"
            ]
          ],
          "baz": [
            [
              "re"
            ]
          ],
          "re": [
            [
              "zoo"
            ]
          ]
        },
        "output": {
          "bar": [
            [
              "re",
              "de"
            ],
            [
              "zoo"
            ]
          ],
          "do": [
            [
              "bar",
              "baz"
            ],
            [
              "re",
              "de"
            ],
            [
              "re"
            ]
          ],
          "baz": [
            [
              "re"
            ],
            [
              "zoo"
            ]
          ],
          "re": [
            [
              "zoo"
            ]
          ]
        }
      }
    ],
    "identifier": 68388431
  },
  {
    "context": [
      "I am trying to display only lines with second value greater than 1000.",
      "How can I discard lines with size less than 1000?",
      "Select objects, not fields.",
      ".[] | select(.size > 1000) | [.name, .size] | join(\",\")"
    ],
    "utterance": "Display only items where size is greater than 1000 as lines of 'name,size'.",
    "expressions": [
      ".[] | select(.size > 1000) | [.name, .size] | join(\",\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "name1",
            "size": 1024
          },
          {
            "name": "name2",
            "size": 300
          },
          {
            "name": "name3",
            "size": 512
          }
        ],
        "output": "name1,1024"
      }
    ],
    "identifier": 68818940
  },
  {
    "context": [
      "I need to find the value of the \"state\" key Using JQ and replace the value in JSON.",
      "My expected output",
      "{\n  \"firstName\": \"Rajesh\",\n  \"lastName\": \"Kumar\",\n  \"gender\": \"man\",\n  \"age\": 24,\n  \"address\": {\n    \"streetAddress\": \"126 Udhna\",\n    \"city\": \"Surat\",\n    \"state\": \"Bihar\",\n    \"postalCode\": \"394221\"\n  },\n  \"phoneNumbers\": [\n    {\n      \"type\": \"home\",\n      \"number\": \"7383627627\"\n    }\n  ]\n}",
      "jq '.address.state = \"Bihar\"' sample-json.json",
      "jq 'walk(if type == \"object\" and has(\"state\") then .state = \"Bihar\" else . end)' sample-json.json",
      "This last will replace all `.state` values."
    ],
    "utterance": "Replace every occurrence of the key 'state' with the value 'Bihar', without specifying its path directly.",
    "expressions": [
      ".address.state = \"Bihar\"",
      "walk(if type == \"object\" and has(\"state\") then .state = \"Bihar\" else . end)"
    ],
    "data": [
      {
        "input": {
          "firstName": "Rajesh",
          "lastName": "Kumar",
          "gender": "man",
          "age": 24,
          "address": {
            "streetAddress": "126 Udhna",
            "city": "Surat",
            "state": "WB",
            "postalCode": "394221"
          },
          "phoneNumbers": [
            {
              "type": "home",
              "number": "7383627627"
            }
          ]
        },
        "output": {
          "firstName": "Rajesh",
          "lastName": "Kumar",
          "gender": "man",
          "age": 24,
          "address": {
            "streetAddress": "126 Udhna",
            "city": "Surat",
            "state": "Bihar",
            "postalCode": "394221"
          },
          "phoneNumbers": [
            {
              "type": "home",
              "number": "7383627627"
            }
          ]
        }
      }
    ],
    "identifier": 68936535
  },
  {
    "context": [
      "I want to do two things:",
      "1. add a field named \"contexts\" that includes the value of the account_id, eg:",
      "2. If \"directory\" contains the text \"monitors\", I'd like to add another item to contexts, eg:",
      "However, I can't figure out how to do (2). In particular, I'm struggling to understand the if/then/else/end construct and how to use it in assignment, especially trying to use it with `test()` to check for the text \"monitors\".",
      "A simple `if`/`else` clause like below would suffice. For a simple boolean assertion, you could use `test`/`match` or `contains` and then add the field accordingly.",
      ".contexts += [ \"aws/\" + .account_id ] |  \nif   .directory | test(\"monitor\") \nthen .contexts  += [ \"datadog/m01\" ] else . end"
    ],
    "utterance": "Add a property named contexts as an array containing \"aws/\" followed by the account_id, and if the directory contains \"monitors\", also add \"datadog/m01\" to contexts.",
    "expressions": [
      ".contexts += [\"aws/\" + .account_id] | if .directory | test(\"monitors\") then .contexts += [\"datadog/m01\"] else . end"
    ],
    "data": [
      {
        "input": {
          "account_id": "a01",
          "name": "example01",
          "directory": "path/to/something"
        },
        "output": {
          "account_id": "a01",
          "contexts": [
            "aws/a01"
          ],
          "name": "example01",
          "directory": "path/to/something"
        }
      },
      {
        "input": {
          "account_id": "a01",
          "name": "example02",
          "directory": "path/to/monitors"
        },
        "output": {
          "account_id": "a01",
          "contexts": [
            "aws/a01",
            "datadog/m01"
          ],
          "name": "example02",
          "directory": "path/to/monitors"
        }
      }
    ],
    "identifier": 68377085
  },
  {
    "context": [
      "And we can use `as=\"text\"` to get the raw json text:",
      "content(r, as=\"text\")",
      "You should be able to process this json with anything json-processor, including `jsonlite::fromJSON` (confirmed) and likely `rjson` and `jqr` (or even `jq` on the command-line after saving it to a text file).",
      "Even though `content(r)` seems to be a JSON-encoded string, the jqr commands recognize it as JSON text, so that (when using jqr), there is no need to run it through jq's `fromjson` filter.",
      "So for example:",
      "> jq(content(r))",
      "> jq(content(r), \".name\")"
    ],
    "utterance": "Extract the 'name' field from the response content fetched via an HTTP GET request.",
    "expressions": [
      ".name"
    ],
    "data": [
      {
        "input": {
          "name": "httpbin",
          "description": "HTTP Request & Response Service, written in Python + Flask.",
          "repository": "https://github.com/requests/httpbin",
          "website": "https://httpbin.org",
          "logo": "https://s3.amazonaws.com/f.cl.ly/items/333Y191Z2C0G2J3m3Y0b/httpbin.svg",
          "keywords": [
            "http",
            "rest",
            "API",
            "testing",
            "integration",
            "python",
            "flask"
          ],
          "addons": "sentry"
        },
        "output": "httpbin"
      }
    ],
    "identifier": 68764306
  },
  {
    "context": [
      "unique_by(.first,.last, .roll) will remove other subject entries. I want convert 'subject' to an array with all the values in the source JSON array. How to map using jq for creating nested array of subject as below,",
      "JQ doesn&#39;t have a nice merge built-in for such tasks yet, but you can achieve this one using `group_by`.",
      "group_by(.first, .last, .roll) | map(\n  (.[0] | {first, last, roll}) + {subject: map(.subject)}\n)",
      "group_by(.first, .last, .roll)\n| map( map(.subject) as $subject\n     | .[0]\n     | {first, last, roll, $subject})"
    ],
    "utterance": "Group objects by first, last, and roll, and collect subject values into an array for each group.",
    "expressions": [
      "group_by(.first, .last, .roll) | map((.[0] | {first, last, roll}) + {subject: map(.subject)})",
      "group_by(.first, .last, .roll) | map(map(.subject) as $subject | .[0] | {first, last, roll, subject: $subject})"
    ],
    "data": [
      {
        "input": [
          {
            "first": "foo",
            "last": "bar",
            "roll": "32",
            "subject": "maths"
          },
          {
            "first": "joe",
            "last": "mighty",
            "roll": "31",
            "subject": "english"
          },
          {
            "first": "foo",
            "last": "bar",
            "roll": "32",
            "subject": "english"
          },
          {
            "first": "joe",
            "last": "mighty",
            "roll": "31",
            "subject": "maths"
          },
          {
            "first": "foo",
            "last": "bar",
            "roll": "32",
            "subject": "science"
          }
        ],
        "output": [
          {
            "first": "foo",
            "last": "bar",
            "roll": "32",
            "subject": [
              "maths",
              "english",
              "science"
            ]
          },
          {
            "first": "joe",
            "last": "mighty",
            "roll": "31",
            "subject": [
              "english",
              "maths"
            ]
          }
        ]
      }
    ],
    "identifier": 68923838
  },
  {
    "context": [
      "jq -r --arg env \"${ENV}\" '.Clusters[] | select (.Name==\"\\($env)-emr-cluster\") | .Id'",
      "jq -r --arg env \"${ENV}\" '.Clusters[] | select (.Name==\"\\($env)-emr-cluster\") | .Id'"
    ],
    "utterance": "Extract the Id field from each object in the Clusters array where the Name equals the value of the env variable followed by '-emr-cluster'.",
    "expressions": [
      "jq -r --arg env \"$ENV\" '.Clusters[] | select (.Name==\"\\($env)-emr-cluster\") | .Id'"
    ],
    "identifier": 68820930
  },
  {
    "context": [
      "before deployment, I need to change the value of GLOBAL_CONFIG with an stringify json of global_config.json. so env_config.json should look like this:\r\n\r\n    env_config.json\r\n    {\r\n      \"config\":\"{\\\"key\\\":\\\"value\\\"}\"",
      "The whole thing can be done in `jq` itself, which can slurp an input file and the contents of which can be used to update another file as below. The `tojson` function encodes your already existing string as JSON string with escapes added",
      "jq --slurpfile gc global_config.json '{ config: $gc[0] | tojson }' env_config.json"
    ],
    "utterance": "Replace the value of the key 'config' with a stringified version of the contents from another file, so that the output has properly escaped inner quotes.",
    "expressions": [
      "jq --slurpfile gc global_config.json '{ config: $gc[0] | tojson }' env_config.json"
    ],
    "data": [
      {
        "input": {
          "env_config.json": {
            "config": "GLOBAL_CONFIG"
          },
          "global_config.json": {
            "key": "value"
          }
        },
        "output": {
          "config": "{\"key\":\"value\"}"
        }
      }
    ],
    "identifier": 68391954
  },
  {
    "context": [
      "What would be the correct way to add a propetry where the whole path .item.property and the value itself are variable",
      "The jq filter should be:\r\n\r\n    .[$ITEM1][$PROPERTY2] = $VALUE",
      "You could also use `setpath/2`, e.g.\r\n\r\n    setpath([$ITEM1,$PROPERTY2]; $VALUE)"
    ],
    "utterance": "Add or update a property where both the top-level key and the property's name and value are specified as variables.",
    "expressions": [
      ".[$ITEM1][$PROPERTY2] = $VALUE",
      "setpath([$ITEM1,$PROPERTY2]; $VALUE)"
    ],
    "data": [
      {
        "input": {
          "item1": {
            "proerty1": "test"
          },
          "item2": {}
        },
        "output": {
          "item1": {
            "proerty1": "test",
            "property2": "test2"
          },
          "item2": {}
        }
      }
    ],
    "identifier": 68411502
  },
  {
    "context": [
      "I am running this command: {{ aws ec2 describe-availability-zones --region ca-central-1 | jq '.AvailabilityZones[]|(.ZoneName)}}'",
      "This error message indicates that the input piped to `jq` wasn&#39;t valid JSON.",
      "One possible cause could be that you have it configured via an environment variable (`AWS_DEFAULT_OUTPUT`) or configuration file (e.g. `~/.aws/config`) to output YAML or text or tables. ... You could rule this out by [explicitly specifying][1] `--output json`."
    ],
    "utterance": "Extract all ZoneName values from the AvailabilityZones array in the output of describing availability zones for the ca-central-1 region using AWS CLI.",
    "expressions": [
      ".AvailabilityZones[] | .ZoneName"
    ],
    "identifier": 68538777
  },
  {
    "context": [
      "And now I want to print out only the user objects.",
      "Is there any way I can print out the parent objects of those types instead of the type entities?  E.g. I\u2019d like to get out:",
      "[ { \"name\": \"user_1\", \"type\": \"user\" }, { \"name\": \"user_2\", \"type\": \"user\" } ]",
      "Without streaming, this is a pretty straightforward exercise.  E.g.: cat file.json | jq '.[] | select(.type==\"user\")'",
      "In reality the actual input file is around 5GB, so I need to use streaming input, but I can't seem to get the jq syntax right with --stream enabled.",
      "Just truncate the top-level array.\n``` shell\njq -n --stream 'fromstream(1 | truncate_stream(inputs)) | select(.type == \"user\")'\n```"
    ],
    "utterance": "Extract all objects with type equal to \"user\" from a large top-level array using streaming mode.",
    "expressions": [
      "jq -n --stream 'fromstream(1 | truncate_stream(inputs)) | select(.type == \"user\")'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "account_1",
            "type": "account"
          },
          {
            "name": "account_2",
            "type": "account"
          },
          {
            "name": "user_1",
            "type": "user"
          },
          {
            "name": "user_2",
            "type": "user"
          }
        ],
        "output": [
          {
            "name": "user_1",
            "type": "user"
          },
          {
            "name": "user_2",
            "type": "user"
          }
        ]
      }
    ],
    "identifier": 68747325
  },
  {
    "context": [
      "for s in $(echo $values | jq -r \"to_entries|map(\\\"\\(.key)=\\(.value|tostring)\\\")|.[]\" $1); do",
      "for line in $(jq -r \"to_entries|map(\\\"\\(.key)=\\(.value|tostring)\\\")|.[]\" \"$1\"); do"
    ],
    "utterance": "Extract each key and its value as 'key=value' pairs from the top-level object as strings.",
    "expressions": [
      "to_entries|map(\"\\(.key)=\\(.value|tostring)\")|.[]"
    ],
    "data": [
      {
        "input": {
          "PASSPHRASE": "$(cat /home/x/secret)"
        },
        "output": [
          "PASSPHRASE=$(cat /home/x/secret)"
        ]
      }
    ],
    "identifier": 68647601
  },
  {
    "context": [
      "This is an example input:\r\n\r\n```json\r\n{\r\n  \"key1\": \"value\",      \r\n  \"key2\": [\r\n    {\"key3\": 5, \"key4\": \"value1\"},  \r\n    {\"key3\": null, \"key4\": \"value2\"},  \r\n    {\"key3\": 9, \"key4\": \"value3\"}\r\n  ]\r\n}\r\n```",
      "Example output:\r\n\r\n```json\r\n{\r\n  \"key1\": \"value\",\r\n  \"value1\": 5,\r\n  \"value2\": null,\r\n  \"value3\": 9\r\n}\r\n```",
      "I'd say that what's missing is how to \"merge\" keys in the object with the top-level. How can I do that?",
      "With your input JSON fixed to take keys/values in double-quotes, your expression could be written as\r\n\r\n```none\r\n[ {key1}, (.key2[] | { (.key4): .key3} ) ] | add\r\n```"
    ],
    "utterance": "Flatten an object's key2 array entries such that each object's key4 becomes a new top-level property with the value from key3, alongside the original key1 property.",
    "expressions": [
      "[ {key1}, (.key2[] | { (.key4): .key3} ) ] | add"
    ],
    "data": [
      {
        "input": {
          "key1": "value",
          "key2": [
            {
              "key3": 5,
              "key4": "value1"
            },
            {
              "key3": null,
              "key4": "value2"
            },
            {
              "key3": 9,
              "key4": "value3"
            }
          ]
        },
        "output": {
          "key1": "value",
          "value1": 5,
          "value2": null,
          "value3": 9
        }
      }
    ],
    "identifier": 68627056
  },
  {
    "context": [
      "Which returns a json like this:",
      "{ \"TagList\": [{ \"Key\": \"owner\", \"Value\": \"me\" },{ \"Key\": \"Project\", \"Value\": \"my_project\" }]}",
      "cluster_tags=$(aws rds list-tags-for-resource --resource-name $cluster_arn | jq -r '.TagList')",
      "How can I solve this problem *without creating a JSON file* ?"
    ],
    "utterance": "Output the value of the TagList array without extra formatting or escaping, suitable for direct parameter usage.",
    "expressions": [
      ".TagList"
    ],
    "data": [
      {
        "input": {
          "TagList": [
            {
              "Key": "owner",
              "Value": "me"
            },
            {
              "Key": "Project",
              "Value": "my_project"
            }
          ]
        },
        "output": [
          {
            "Key": "owner",
            "Value": "me"
          },
          {
            "Key": "Project",
            "Value": "my_project"
          }
        ]
      }
    ],
    "identifier": 68379064
  },
  {
    "context": [
      "I need output of 'host1' and 'host3'",
      "with command ` |jq .host1`, I can only get one",
      "If you can use a *hardcoded* list of `keys`, you can use the following JQ command to get only `host1` and `host3`:",
      "{ host1, host3 }"
    ],
    "utterance": "Select only the top-level entries named host1 and host3, preserving their keys and values.",
    "expressions": [
      "{ host1, host3 }"
    ],
    "data": [
      {
        "input": {
          "host1": {
            "ip": "10.1.2.3"
          },
          "host2": {
            "ip": "10.1.2.2"
          },
          "host3": {
            "ip": "10.1.18.1"
          }
        },
        "output": {
          "host1": {
            "ip": "10.1.2.3"
          },
          "host3": {
            "ip": "10.1.18.1"
          }
        }
      }
    ],
    "identifier": 68544053
  },
  {
    "context": [
      "How do I substitute a certain matching node in a tree by the path to that node from the root node using jq?",
      "The desired result is:\r\n{\r\n  \"a\": {\r\n    \"b\": 1,\r\n    \"c\": {\r\n      \"d\": [\"a\", \"c\"]\r\n    }\r\n  },\r\n  \"e\": {\r\n    \"d\": [\"e\"]\r\n  }\r\n}",
      "( inputs | paths | select(.[-1] == \"d\")) as $f | setpath($f; $f[:-1])"
    ],
    "utterance": "Replace every value of key \"d\" in the tree with an array containing the path from the root to that key within the structure.",
    "expressions": [
      "(inputs | paths | select(.[-1] == \"d\")) as $f | setpath($f; $f[:-1])"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": 1,
            "c": {
              "d": 2
            }
          },
          "e": {
            "d": 3
          }
        },
        "output": {
          "a": {
            "b": 1,
            "c": {
              "d": [
                "a",
                "c"
              ]
            }
          },
          "e": {
            "d": [
              "e"
            ]
          }
        }
      }
    ],
    "identifier": 68371453
  },
  {
    "context": [
      "I have to remove the \"data\" tags whose value is \"attribute 0\" in \"obj\" array in the objects whose \"id\" is 1.",
      "I used the below command and I got the output as expected.",
      "jq 'del(.resources[] | select(.id== 1) | .obj[] | select(.data== \"attribute 0\") )'"
    ],
    "utterance": "Remove any entry with \"data\" equal to \"attribute 0\" from the \"obj\" array for objects where \"id\" is 1.",
    "expressions": [
      "del(.resources[] | select(.id==1) | .obj[] | select(.data==\"attribute 0\"))"
    ],
    "data": [
      {
        "input": {
          "name": "This is a sample",
          "resources": [
            {
              "id": 0,
              "obj": [
                {
                  "data": "attribute 0 \\u003e"
                },
                {
                  "data": "attribute 1"
                },
                {
                  "data": "attribute 2"
                }
              ]
            },
            {
              "id": 1,
              "obj": [
                {
                  "data": "attribute 0"
                },
                {
                  "data": "attribute 1"
                },
                {
                  "data": "attribute 2"
                }
              ]
            },
            {
              "id": 1,
              "obj": [
                {
                  "data": "attribute 0"
                },
                {
                  "data": "attribute 1"
                },
                {
                  "data": "attribute 2"
                }
              ]
            }
          ]
        },
        "output": {
          "name": "This is a sample",
          "resources": [
            {
              "id": 0,
              "obj": [
                {
                  "data": "attribute 0 \\u003e"
                },
                {
                  "data": "attribute 1"
                },
                {
                  "data": "attribute 2"
                }
              ]
            },
            {
              "id": 1,
              "obj": [
                {
                  "data": "attribute 1"
                },
                {
                  "data": "attribute 2"
                }
              ]
            },
            {
              "id": 1,
              "obj": [
                {
                  "data": "attribute 1"
                },
                {
                  "data": "attribute 2"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 68544684
  },
  {
    "context": [
      "I currently do this:\r\n\r\n```\r\ncat test.log  | jq -rR 'fromjson? | \"[\\(.level)] \\(.msg)\"'\r\n```\r\n\r\nWhich gives this:\r\n\r\n```\r\n[20] Debug message\r\n[30] Info message\r\n[30] Info message\r\n[40] Warn message\r\n[20] Debug message\r\n```\r\n\r\nDesired output, after some transforming etc:\r\n\r\n```\r\n[debug] Debug message\r\n[info] Info message\r\n[info] Info message\r\n[warn] Warn message\r\n[debug] Debug message\r\n```\r\n\r\nIs it possible to in JQ transform \"enum\" values like this?",
      "You could do a mapping of log levels, you could do\r\n\r\n```none\r\njq -nr --argjson levelMap '{\"20\": \"debug\", \"30\": \"info\", \"40\": \"warn\"}' 'inputs \r\n     | \"[\\($levelMap[.level | tostring])] \\(.msg)\"'\r\n```",
      "Sure, you can just use `as` to declare a mapping object up front, and use it later:\r\n\r\n    jq -rR '{\"20\": \"debug\", \"30\": \"info\", \"40\": \"warn\"} as $levelmap\r\n        | fromjson? | \"[\\($levelmap[.level | tostring])] \\(.msg)\"'"
    ],
    "utterance": "Replace the numeric value of the 'level' property in each object with a mapped string label and print the formatted output including the message.",
    "expressions": [
      "jq -nr --argjson levelMap '{\"20\": \"debug\", \"30\": \"info\", \"40\": \"warn\"}' 'inputs | \"[\\($levelMap[.level | tostring])] \\(.msg)\"'",
      "jq -rR '{\"20\": \"debug\", \"30\": \"info\", \"40\": \"warn\"} as $levelmap | fromjson? | \"[\\($levelmap[.level | tostring])] \\(.msg)\"'"
    ],
    "data": [
      {
        "input": [
          {
            "level": 20,
            "msg": "Debug message"
          },
          {
            "level": 30,
            "msg": "Info message"
          },
          {
            "level": 30,
            "msg": "Info message"
          },
          {
            "level": 40,
            "msg": "Warn message"
          },
          {
            "level": 20,
            "msg": "Debug message"
          }
        ],
        "output": [
          "[debug] Debug message",
          "[info] Info message",
          "[info] Info message",
          "[warn] Warn message",
          "[debug] Debug message"
        ]
      }
    ],
    "identifier": 68848457
  },
  {
    "context": [
      "my json.file looks like\r\n\r\n    {\r\n      \"price1\" : \"120.10\",\r\n      \"price2\" : \"110.30\",\r\n      \"price3\" : \"244.45\"\r\n    }\r\n\r\nI am looking for my array values to include the key name as well (`key:value`). \r\nmy desired output should be `key:value` format \r\n\r\n    price1:120.10 price2:110.10 price3:244.45",
      "array=($(jq -r 'to_entries[] | ( \"\\(.key):\\(.value)\" )' <<< \"$json\"))\necho ${array[@]}\nprice1:120.10 price2:110.30 price3:244.45"
    ],
    "utterance": "Extract all key-value pairs as strings in the format key:value from the object, in order.",
    "expressions": [
      "to_entries[] | \"\\(.key):\\(.value)\""
    ],
    "data": [
      {
        "input": {
          "price1": "120.10",
          "price2": "110.30",
          "price3": "244.45"
        },
        "output": [
          "price1:120.10",
          "price2:110.30",
          "price3:244.45"
        ]
      }
    ],
    "identifier": 68486144
  },
  {
    "context": [
      "I want to add prefix and suffix in the existing value of JSON file.",
      "Here is expected output -\n         \"directory\": [\n            {\n              \"start_datetime\": \"1990-07-20 07:45:58\",\n              \"end_datetime\": \"1990-07-20 07:45:58\",\n              \"file_name\": \"AWS_sample_N11_output.json\",\n            },\n            {\n              \"start_datetime\": \"1990-07-20 07:45:58\",\n              \"end_datetime\": \"1990-07-20 07:45:58\",\n              \"file_name\": \"AWS_sample_N12_output.json\",\n            }\n    ]",
      "Variables aren't expanded in double quotes. Use the `+` operator to concatenate strings:\n\n    '(.directory[].file_name |= \"AWS_\" + $prefix + \"_\\(.)_output.json\")'",
      "or use the string interpolation `\\(...)`:\n\n    '(.directory[].file_name |= \"AWS_\\($prefix)_\\(.)_output.json\")'"
    ],
    "utterance": "Add a given prefix and suffix to the value of each file_name in the directory array so that each becomes AWS_<prefix>_<file_name>_output.json, using a variable prefix.",
    "expressions": [
      "(.directory[].file_name |= \"AWS_\" + $prefix + \"_\\(.)_output.json\")",
      "(.directory[].file_name |= \"AWS_\\($prefix)_\\(.)_output.json\")"
    ],
    "data": [
      {
        "input": {
          "directory": [
            {
              "start_datetime": "1990-07-20 07:45:58",
              "end_datetime": "1990-07-20 07:45:58",
              "file_name": "N11"
            },
            {
              "start_datetime": "1990-07-20 07:45:58",
              "end_datetime": "1990-07-20 07:45:58",
              "file_name": "N12"
            }
          ]
        },
        "output": {
          "directory": [
            {
              "start_datetime": "1990-07-20 07:45:58",
              "end_datetime": "1990-07-20 07:45:58",
              "file_name": "AWS_sample_N11_output.json"
            },
            {
              "start_datetime": "1990-07-20 07:45:58",
              "end_datetime": "1990-07-20 07:45:58",
              "file_name": "AWS_sample_N12_output.json"
            }
          ]
        }
      }
    ],
    "identifier": 68898407
  },
  {
    "context": [
      "What I need is to select either `Option1` or `Option2` based on whether or not it contains user input.",
      "If the user provides `inner1`, return the `Option1` object",
      "If the user provides `innerY` return the `Option2` object",
      "the jq `filter` you\u2019d need is `getpath`:",
      "getpath(paths | select(.[-1] == \"inner1\") | .[0:-2])",
      "you could also use `..`, e.g. perhaps:",
      ".. | objects | map_values( select(has(\"inner1\"))) | select(length>0)"
    ],
    "utterance": "Return the Option object that contains a key matching a given user-supplied name such as 'inner1' or 'innerY'.",
    "expressions": [
      "getpath(paths | select(.[-1] == \"inner1\") | .[0:-2])",
      ".. | objects | map_values( select(has(\"inner1\"))) | select(length>0)"
    ],
    "data": [
      {
        "input": {
          "A": {
            "Option1": {
              "contains": {
                "inner1": {
                  "foo": 123
                },
                "inner2": {
                  "bar": 456
                }
              }
            },
            "Option2": {
              "innerX": {
                "baz": 42
              },
              "innerY": {
                "bat": 43
              }
            }
          }
        },
        "output": {
          "contains": {
            "inner1": {
              "foo": 123
            },
            "inner2": {
              "bar": 456
            }
          }
        }
      }
    ],
    "identifier": 68472959
  },
  {
    "context": [
      "I want to pull both ***array_within_array*** element and upper array element(***event_array***) to root level using **jq**.",
      "So after conversion there should be 4 events(1 from ***meal_selection***, 1 from ***login*** and 2 from ***placed_order***). these all should be on the same level.",
      "Here's a straightforward solution that keeps things simple by using two steps:",
      "```\n{ region, user_id} + (.event_array[] )\n| if .event_attributes|has(\"array_within_array\")\n  then .event_attributes.array_within_array as $a\n  | .event_attributes = $a[]\n  else .\n  end\n``` "
    ],
    "utterance": "Flatten nested event arrays so each sub-event under 'array_within_array' becomes its own top-level event, preserving region and user_id for each.",
    "expressions": [
      "{ region, user_id} + (.event_array[] ) | if .event_attributes|has(\"array_within_array\") then .event_attributes.array_within_array as $a | .event_attributes = $a[] else . end"
    ],
    "data": [
      {
        "input": {
          "region": "USA",
          "user_id": "123",
          "event_array": [
            {
              "event_attributes": {
                "date": "2021-08-17",
                "category": "lunch",
                "location": "office"
              },
              "event_name": "meal_selection",
              "created_at": "2021-08-13 01:28:57"
            },
            {
              "event_name": "login",
              "created_at": "2021-08-13 01:29:02"
            },
            {
              "event_attributes": {
                "array_within_array": [
                  {
                    "date": "2021-08-17",
                    "category": "lunch",
                    "location": "office"
                  },
                  {
                    "date": "2021-08-18",
                    "category": "dinner",
                    "location": "home"
                  }
                ]
              },
              "event_name": "placed_order",
              "created_at": "2021-08-13 01:28:08"
            }
          ]
        },
        "output": [
          {
            "region": "USA",
            "user_id": "123",
            "event_attributes": {
              "date": "2021-08-17",
              "category": "lunch",
              "location": "office"
            },
            "event_name": "meal_selection",
            "created_at": "2021-08-13 01:28:57"
          },
          {
            "region": "USA",
            "user_id": "123",
            "event_name": "login",
            "created_at": "2021-08-13 01:29:02"
          },
          {
            "region": "USA",
            "user_id": "123",
            "event_attributes": {
              "date": "2021-08-17",
              "category": "lunch",
              "location": "office"
            },
            "event_name": "placed_order",
            "created_at": "2021-08-13 01:28:08"
          },
          {
            "region": "USA",
            "user_id": "123",
            "event_attributes": {
              "date": "2021-08-18",
              "category": "dinner",
              "location": "home"
            },
            "event_name": "placed_order",
            "created_at": "2021-08-13 01:28:08"
          }
        ]
      }
    ],
    "identifier": 68828666
  },
  {
    "context": [
      "I'd like to use `jq` to iterate over these objects and return the number of `brown fox`'s  jumping UNTIL a match is not found.",
      "How do I exclude the matches after a mismatch and count the number of matches so that `jq` returns only `4`?",
      "reduce .[] as $i ([0, true]; if .[1] and ($i.message | contains(\"brown fox\")) then .[0] += 1 else .[1] = false end) | .[0]",
      "until(\n   (.[1] | .[0] | .message | test(\"brown fox\")| not);\n   [ .[0]+ 1 , (.[1] | .[1:]) ]) \n| .[0]",
      "count(while (inputs | .message|test(\"brown fox\"); true) )",
      "count( select_while(inputs; .message|test(\"brown fox\") ) )"
    ],
    "utterance": "Count the consecutive objects at the beginning of the data where the message contains 'brown fox', stopping at the first non-match.",
    "expressions": [
      "reduce .[] as $i ([0, true]; if .[1] and ($i.message | contains(\"brown fox\")) then .[0] += 1 else .[1] = false end) | .[0]",
      "[0,.] | until((.[1] | .[0] | .message | test(\"brown fox\")| not); [ .[0]+ 1 , (.[1] | .[1:]) ]) | .[0]",
      "def count(s): reduce s as $x (0; .+1);\ncount(while (inputs | .message|test(\"brown fox\"); true) )",
      "def count(s): reduce s as $x (0; .+1);\ndef select_while(s; cond): label $out | s | if cond then . else break $out end;\ncount( select_while(inputs; .message|test(\"brown fox\") ) )"
    ],
    "data": [
      {
        "input": [
          {
            "id": "da1234563",
            "message": "brown fox jump over a red log"
          },
          {
            "id": "da1234564",
            "message": "brown fox jump over a red log"
          },
          {
            "id": "da1234565",
            "message": "brown fox jump over a red log"
          },
          {
            "id": "da1234566",
            "message": "brown fox jump over a red log"
          },
          {
            "id": "da1234567",
            "message": "red fox jump over a brown log"
          },
          {
            "id": "da1234568",
            "message": "another random string"
          },
          {
            "id": "da1234569",
            "message": "brown fox jump over a red log"
          }
        ],
        "output": 4
      }
    ],
    "identifier": 68499385
  },
  {
    "context": [
      "This input needs to be converted like this using jq",
      "Expected output:",
      "The path will contain the array index as path, and sometimes the keys will be combined in the path as well",
      "You need to convert each `.path` to a form [`setpath`](https://stedolan.github.io/jq/manual/v1.6/#setpath(PATHS;VALUE)) can understand. The rest is straightforward.",
      "reduce .[] as {$path, $value} (null;\n  setpath($path / \"/\" | map(tonumber? // .); $value)\n)"
    ],
    "utterance": "Transform an array where each entry has a 'path' and a 'value' into a nested key/object structure where intermediate array indices and object keys are taken from the path and the leaf value is set appropriately.",
    "expressions": [
      "reduce .[] as {$path, $value} (null; setpath($path / \"/\" | map(tonumber? // .); $value))"
    ],
    "data": [
      {
        "input": [
          {
            "label": "test1",
            "value": 1,
            "path": "data/testData/testDataLevel3/testDataLevel3_1/0/testDataLevel3_1_a2"
          },
          {
            "label": "test2",
            "value": 2,
            "path": "data/testData/testDataLevel1/testDataLevel1_1"
          }
        ],
        "output": {
          "data": {
            "testData": {
              "testDataLevel1": {
                "testDataLevel1_1": 2
              },
              "testDataLevel3": {
                "testDataLevel3_1": [
                  {
                    "testDataLevel3_1_a2": 1
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 68684696
  },
  {
    "context": [
      "I am trying to find out the first tag where the key is `env`.",
      "You could wrap the results of your query in an array and then pick the first one",
      "`[.tags[] | select(.key==\"env\")] | .[0]`",
      "Use `first(expr)` to provide an expression that satisfies your usecase.",
      "first(.tags[]? | select(.key == \"env\") .value)",
      "jq -r 'first( .tags[] | select(.key==\"env\") ).value'",
      "'.tags[]' flattens the array into a stream of values. You're applying '.[0]' to each of the values, not a filtered array. To filter an array, you'd use",
      "'.tags | map(select(...)) | .[0]'",
      "'.tags | map(select(...)) | first'",
      "'.tags | [ .[] | select(...) ] | first'",
      "'[ .tags[] | select(...) ] | first'",
      "Finally, '[ ... ] | first' can be written as 'first(...)'.",
      "first( .tags[] | select(...) )"
    ],
    "utterance": "Retrieve the first object in the 'tags' array where key equals 'env'.",
    "expressions": [
      "[.tags[] | select(.key==\"env\")] | .[0]",
      "first(.tags[] | select(.key==\"env\"))",
      ".tags | map(select(.key==\"env\")) | .[0]",
      ".tags | map(select(.key==\"env\")) | first",
      ".tags | [ .[] | select(.key==\"env\") ] | first",
      "[ .tags[] | select(.key==\"env\") ] | first"
    ],
    "data": [
      {
        "input": {
          "tags": [
            {
              "key": "env",
              "value": "foo"
            },
            {
              "key": "env",
              "value": "bar"
            }
          ]
        },
        "output": {
          "key": "env",
          "value": "foo"
        }
      }
    ],
    "identifier": 68569705
  },
  {
    "context": [
      "However, in our environment, some instances do not have any tags associated with them, so when I run my script I get an error, at which point jq stops processing before iterating over the remainding elements of the array:",
      "Is there a way I can filter for non-existent Tags and substitute a placeholder value for Name (like '-')",
      "One way to add placeholder values would be to use an `if ... then ... else ... end` construction, e.g.",
      "jq -r '\n.Reservations[].Instances[]\n  | (if .Tags then (.Tags | from_entries).Name else \"-\" end) as $name\n  | \"\\(.InstanceId)  \\(.PrivateIpAddress)  \\($name)\"'"
    ],
    "utterance": "Output a table of instance ID, private IP address, and the Name tag (or '-' if Name is missing), handling cases where Tags or Name are not present.",
    "expressions": [
      ".Reservations[].Instances[] | (if .Tags then (.Tags | from_entries).Name else \"-\" end) as $name | \"\u001b[34m\\(.InstanceId)  \\(.PrivateIpAddress)  \\($name)\"",
      ".Reservations[].Instances[] | ((.Tags // empty) | from_entries) as $tags | \"\\(.InstanceId)  \\(.PrivateIpAddress)  \\($tags.Name)\""
    ],
    "identifier": 68493809
  },
  {
    "context": [
      "I have a jq query to get two values from the JSON file:",
      "`jq -r '.[] | [.name, .size] | join(\",\")' file.json`",
      "What I want is to sort them by number.",
      "I've tried to pipe the query by `| sort_by(.size | tonumber)` but it always fail on `Cannot iterate over string (\"name1,1024\")`",
      "jq -r '[.[] | {name, size}] | sort_by(.size) | [.[][]] | join(\",\")'"
    ],
    "utterance": "Output name and size pairs, sorted by size in ascending order.",
    "expressions": [
      ".[] | {name, size} | sort_by(.size) | [.[] | \"\u001b[32m\"+.name+\",\"+(.size|tostring)]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "name1",
            "size": 1024
          },
          {
            "name": "name2",
            "size": 300
          },
          {
            "name": "name3",
            "size": 512
          }
        ],
        "output": [
          "name2,300",
          "name3,512",
          "name1,1024"
        ]
      }
    ],
    "identifier": 68829796
  },
  {
    "context": [
      "I need to filter out those two (last) arrays which have 'AWS: KEY1', leaving only the first two (which have 'AWS: [arnX]'.",
      "But I can't figure out how to do this! The 'AWS' is *either* a string *or* an array in the same JSON! No idea how to deal with both at the same time..",
      "Try:\n```\n.Statement|=map(select([.Principal.AWS]|flatten|all(.!=\"KEY1\")))\n```",
      "The `[.Principal.AWS]|flatten` bit does what you want to ensure you have a list of strings and not a single string. `all(.!=\"KEY1\")` tests to make sure \"KEY1\" is not in the list. `map(select(...))` keeps only the statements that match the test."
    ],
    "utterance": "Filter out all policy statements where the Principal AWS value is 'KEY1', regardless of whether it is a string or an array, and keep only those statements where AWS is not 'KEY1'.",
    "expressions": [
      ".Statement|=map(select([.Principal.AWS]|flatten|all(.!=\"KEY1\")))"
    ],
    "data": [
      {
        "input": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn1",
                  "arn2",
                  "arn3"
                ]
              },
              "Action": [
                "access1",
                "access2",
                "access3"
              ],
              "Resource": "arn:aws:s3:::bucket1/*"
            },
            {
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn1",
                  "arn2",
                  "arn3"
                ]
              },
              "Action": "access4",
              "Resource": "arn:aws:s3:::bucket1"
            },
            {
              "Effect": "Allow",
              "Principal": {
                "AWS": "KEY1"
              },
              "Action": [
                "access5",
                "access4"
              ],
              "Resource": "arn:aws:s3:::bucket1"
            },
            {
              "Effect": "Allow",
              "Principal": {
                "AWS": "KEY1"
              },
              "Action": [
                "access2",
                "access3",
                "access1"
              ],
              "Resource": "arn:aws:s3:::bucket1/directory/*"
            }
          ]
        },
        "output": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn1",
                  "arn2",
                  "arn3"
                ]
              },
              "Action": [
                "access1",
                "access2",
                "access3"
              ],
              "Resource": "arn:aws:s3:::bucket1/*"
            },
            {
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn1",
                  "arn2",
                  "arn3"
                ]
              },
              "Action": "access4",
              "Resource": "arn:aws:s3:::bucket1"
            }
          ]
        }
      }
    ],
    "identifier": 68833834
  },
  {
    "context": [
      "I only want the first matching tag (key+value) copied up onto the parent object.",
      "it gives me multiple outputs if the given tag appears more than once in the child array ... I only want the first one.",
      "Try using `first(<expression>)` to get only the first matching value.",
      "`jq -r '.[] | .tags[].key |= ascii_downcase | .env = first((.tags[] | select(.key == \"env\").values[0]),null)|[.accountid,.name,.env] | @csv' test.json`",
      "Alternatively, ... extract them all into one object ... I'm using `reverse` to meet your requirement of keeping the first match for any given key, otherwise the last match would win.",
      "`jq -r '.[] | .tags |= ( map({(.key|ascii_downcase): .values[0]}) | reverse | add ) | [.accountid, .name, .tags.env] | @csv'`"
    ],
    "utterance": "Copy the first tag with key 'env' (case-insensitive) from the tags array to the parent object.",
    "expressions": [
      ".[] | .tags[].key |= ascii_downcase | .env = first((.tags[] | select(.key == \"env\").values[0]),null) | [ .accountid, .name, .env ] | @csv",
      ".[] | .tags |= ( map({(.key|ascii_downcase): .values[0]}) | reverse | add ) | [ .accountid, .name, .tags.env ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "integration1",
            "accountid": 111,
            "tags": [
              {
                "key": "env",
                "values": [
                  "prod"
                ]
              },
              {
                "key": "team",
                "values": [
                  "cougar"
                ]
              }
            ]
          },
          {
            "name": "integration2",
            "accountid": 222,
            "tags": [
              {
                "key": "env",
                "values": [
                  "prod"
                ]
              },
              {
                "key": "team",
                "values": [
                  "bear"
                ]
              }
            ]
          },
          {
            "name": "integration3",
            "accountid": 333,
            "tags": [
              {
                "key": "env",
                "values": [
                  "test"
                ]
              },
              {
                "key": "team",
                "values": [
                  "lemur"
                ]
              },
              {
                "key": "Env",
                "values": [
                  "qa"
                ]
              }
            ]
          }
        ],
        "output": [
          "111,\"integration1\",\"prod\"",
          "222,\"integration2\",\"prod\"",
          "333,\"integration3\",\"test\""
        ]
      }
    ],
    "identifier": 68681462
  },
  {
    "context": [
      "I need to extract both the value of subfield a of tags 035 and 999 when 035.subfields[].ind1 and 035.subfields[].ind2 are both \"0\".",
      "My desired output is \n\n    ocm00000001projmusemuse13792     020d182f-ba5d-4bbe-a2eb-e4390aa0736c",
      "With the -r command-line option, the filter:\n\n```\n[.fields[]\n | (select(.\"035\".ind1 == \"0\" and .\"035\".ind2 == \"0\")\n    | (.\"035\".subfields[] | select(.a) | .a) ),\n   (select(.\"999\")\n    | (.\"999\".subfields[] | select(.s) | .s) ) ]\n| join(\" \")\n```",
      "yields:\n```\nocm00000001projmusemuse13792 020d182f-ba5d-4bbe-a2eb-e4390aa0736c\n```"
    ],
    "utterance": "Output the value of subfield a from tag 035 where ind1 and ind2 are both \"0\", and the value of subfield s from tag 999, separated by a space.",
    "expressions": [
      "[.fields[]\n | (select(.\"035\".ind1 == \"0\" and .\"035\".ind2 == \"0\")\n    | (.\"035\".subfields[] | select(.a) | .a) ),\n   (select(.\"999\")\n    | (.\"999\".subfields[] | select(.s) | .s) ) ]\n| join(\" \")"
    ],
    "data": [
      {
        "input": {
          "leader": "01815cam a22004934a 4500",
          "fields": [
            {
              "001": "mig00005597434"
            },
            {
              "035": {
                "subfields": [
                  {
                    "a": "(OCoLC)67764532"
                  }
                ],
                "ind1": " ",
                "ind2": " "
              }
            },
            {
              "035": {
                "subfields": [
                  {
                    "a": "ocm00000001projmusemuse13792"
                  }
                ],
                "ind1": "0",
                "ind2": "0"
              }
            },
            {
              "245": {
                "subfields": [
                  {
                    "a": "The Sins of the Father"
                  },
                  {
                    "b": "A Romance of the South /"
                  },
                  {
                    "c": "by Thomas Dixon ; with an introduction by Steven Weisenburger."
                  }
                ],
                "ind1": "1",
                "ind2": "4"
              }
            },
            {
              "999": {
                "subfields": [
                  {
                    "i": "a1b7fa7e-9e2e-4973-96d0-3939235c8b80"
                  },
                  {
                    "s": "020d182f-ba5d-4bbe-a2eb-e4390aa0736c"
                  }
                ],
                "ind1": "f",
                "ind2": "f"
              }
            }
          ]
        },
        "output": "ocm00000001projmusemuse13792 020d182f-ba5d-4bbe-a2eb-e4390aa0736c"
      }
    ],
    "identifier": 68506318
  },
  {
    "context": [
      "I am reformatting the \"fillDate\" field from a string date, to something with the following structure:  fillDate\": { \"$date\" : \"2021-01-02T00:00:00Z\"},",
      "This is so it can be correctly imported into a MongoDB database.",
      "The following code works correctly for an array; but it eliminates out all of the other fields in the json document.",
      "When I need it to look like this:",
      "{\n  \"fieldA\": \"123\",\n  \"fillDate\": { \"$date\" : \"2021-01-01T00:00:00Z\"},\n  \"fieldB\": \"foo\"\n},",
      ".[] | .fillDate = { \"$date\":   .fillDate |( .[0:4] + \"-\" + .[5:7] + .[6:9] + \"T00:00:00Z\")"
    ],
    "utterance": "Replace the fillDate field in each object with an object {\"$date\": formatted date string in the form YYYY-MM-DDT00:00:00Z}, preserving all other fields and processing every array element.",
    "expressions": [
      "map(.fillDate = { \"$date\": (.fillDate[0:4] + \"-\" + .fillDate[4:6] + \"-\" + .fillDate[6:8] + \"T00:00:00Z\") })"
    ],
    "data": [
      {
        "input": [
          {
            "fieldA": "123",
            "fillDate": "20210101",
            "fieldB": "foo"
          },
          {
            "fieldA": "456",
            "fillDate": "20210102",
            "fieldB": "bar"
          }
        ],
        "output": [
          {
            "fieldA": "123",
            "fillDate": {
              "$date": "2021-01-01T00:00:00Z"
            },
            "fieldB": "foo"
          },
          {
            "fieldA": "456",
            "fillDate": {
              "$date": "2021-01-02T00:00:00Z"
            },
            "fieldB": "bar"
          }
        ]
      }
    ],
    "identifier": 68552823
  },
  {
    "context": [
      "Having a list of strings (one per line) like",
      "how do I convert these into the JSON list `[\"str1\", \"str2\", ...]`?",
      "Assuming that the input is given on stdin, the following command solves the problem:",
      "jq -Rn '[inputs]'",
      "Any empty lines (like a trailing newline) may be skipped by adding a little filter:",
      "jq -Rn '[inputs|select(length>0)]'"
    ],
    "utterance": "Convert a list of lines, each containing a string, into an array of those strings.",
    "expressions": [
      "jq -Rn '[inputs]'",
      "jq -Rn '[inputs|select(length>0)]'"
    ],
    "data": [
      {
        "input": "str1\nstr2\nstr3\n",
        "output": [
          "str1",
          "str2",
          "str3"
        ]
      }
    ],
    "identifier": 68859957
  },
  {
    "context": [
      "I am trying to strip a substring from an array of strings; this array is obtained as a key set from a map.",
      "First I'm extracting the key set and making lower case which works:",
      "$ jq -r 'with_entries( .key |= ascii_downcase) | keys' example.json",
      "and then I'm attempting to strip the `version` part of each element with `sub(\"version$\"; \"\")` however I'm not quite understanding how to make it iterate over the array instead of `sub` trying to operate on the array as a whole:",
      "It looks like `map` would do the trick, and you might also consider `keys_unsorted`:",
      "with_entries( .key |= ascii_downcase ) | keys_unsorted | map(sub(\"version$\"; \"\"))"
    ],
    "utterance": "Remove the 'version' suffix from each lowercased key in an object and return the modified keys as an array.",
    "expressions": [
      "with_entries( .key |= ascii_downcase ) | keys_unsorted | map(sub(\"version$\"; \"\"))"
    ],
    "data": [
      {
        "input": {
          "appOneVersion": "1.0",
          "appTwoVersion": "1.0",
          "appThreeVersion": "1.0"
        },
        "output": [
          "appone",
          "apptwo",
          "appthree"
        ]
      }
    ],
    "identifier": 68825303
  },
  {
    "context": [
      "When testing $TAGS using a hardcoded value the filter returns `true`, as expected.",
      "However, after introducing `clusterName` as a JQ argument, the filter now returns `false`.",
      "\"I've tried the following in the filter, all of which also yield the same result.\"",
      "You can use string interpolation (`\\()`) ... to concat that variable to the rest like so:",
      "' .\"kubernetes.io/cluster/\\($clusterName)\" == \"owned\" '",
      "Shows `true` when testing with the supplied variables."
    ],
    "utterance": "Test if the key named \"kubernetes.io/cluster/\" concatenated with the supplied clusterName variable has the value \"owned\".",
    "expressions": [
      ".\"kubernetes.io/cluster/\\($clusterName)\" == \"owned\""
    ],
    "data": [
      {
        "input": {
          "kubernetes.io/cluster/my-cluster": "owned"
        },
        "output": true
      }
    ],
    "identifier": 68680455
  },
  {
    "context": [
      "I need to add a top level property `collection`  like this, which still contains the same nested items within it. This is my desired result:",
      "jq '&#39;{\"collection\": .}&#39;' <in.json >out.json"
    ],
    "utterance": "Wrap the entire object as the value of a new top-level property named collection.",
    "expressions": [
      "{\"collection\": .}"
    ],
    "data": [
      {
        "input": {
          "item": [
            {
              "id": "123",
              "name": "Customer",
              "item": [
                {
                  "id": "456",
                  "name": "Retrieve a customer"
                }
              ]
            }
          ]
        },
        "output": {
          "collection": {
            "item": [
              {
                "id": "123",
                "name": "Customer",
                "item": [
                  {
                    "id": "456",
                    "name": "Retrieve a customer"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 68415620
  },
  {
    "context": [
      "create the second list of array from .value",
      "readarray -t record2 < <(echo \"${json_data}\" | jq -r \".records[].value\")"
    ],
    "utterance": "Extract all values from records[].value, including those containing spaces, preserving line integrity.",
    "expressions": [
      ".records[].value"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "name": "record1",
              "value": "\"1.this-is-string-value-of-record-1-with-no-spaces\""
            },
            {
              "name": "record2",
              "value": "\"2. this is string value of record 2 with spaces\""
            },
            {
              "name": "record3",
              "value": "\"3. this is string value of record 3 with spaces\""
            }
          ]
        },
        "output": [
          "\"1.this-is-string-value-of-record-1-with-no-spaces\"",
          "\"2. this is string value of record 2 with spaces\"",
          "\"3. this is string value of record 3 with spaces\""
        ]
      }
    ],
    "identifier": 68887539
  },
  {
    "context": [
      "I try to replace placeholders in array JSON with IDs from the input file and create new array of objects.",
      "I need to have the same structure as the array.json only with values.",
      "$ jq -n '[ inputs ] | transpose | map(.[0] + {DataId: .[1].Id})' array.json input.json",
      "jq -n '\n (input| map(.Id)) as $ids\n | input\n | reduce range(0; length) as $i (.;\n    .[$i].DataId = $ids[$i] )\n' input.json array.json"
    ],
    "utterance": "Replace the DataId property in each object of one array with the Id value from the corresponding object in a second array, preserving other fields.",
    "expressions": [
      "[ inputs ] | transpose | map(.[0] + {DataId: .[1].Id})",
      "(input| map(.Id)) as $ids | input | reduce range(0; length) as $i (.; .[$i].DataId = $ids[$i] )"
    ],
    "data": [
      {
        "input": [
          [
            {
              "DataId": "{{ID}}"
            },
            {
              "DataId": "{{ID}}"
            }
          ],
          [
            {
              "Id": "123456"
            },
            {
              "Id": "7890123"
            }
          ]
        ],
        "output": [
          {
            "DataId": "123456"
          },
          {
            "DataId": "7890123"
          }
        ]
      }
    ],
    "identifier": 68853258
  },
  {
    "context": [
      "I want to be able (let's say search(id) is a function). if I call search(1) it needs to return the list of objects from (id=1) and all the ref objects that follow until one of the object has \"ref\": \"none\" or the `id` it references does not exist in the list of objects.",
      "\"ref\": \"id:2\", references the object with (id=2). I want to get all those objects until the `ref` field of one object is none or makes reference to a non-existing `id` in the list like \"ref:101\" (id=101 is not in the list)",
      "Desired output for search(1)\n\n```\n{\n  \"id\": 1,\n  \"ref\": \"id:2\",\n  \"msg\": \"1\"\n}\n{\n  \"id\": 2,\n  \"ref\": \"none\",\n  \"msg\": \"2\"\n}\n```",
      "You need to aggregate your inputs into an object where you can easily navigate first. Then the rest is going to be plain recursion.",
      "Like, with **-n/--null-input** specified, something like this should work just fine:\n```\ndef prepare:\n  reduce inputs as $in ({};\n    . + ($in | {\"id:\\(.id)\": .})\n  );\ndef search($id):\n  def follow($ref):\n    if has($ref) then .[$ref], follow(.[$ref].ref) else empty end;\n  follow(\"id:\\($id)\");\nprepare | search(1)\n```"
    ],
    "utterance": "Given a sequence of objects each with an id and a ref field, retrieve an object with the specified id and recursively follow its ref, yielding all linked objects until ref is \"none\" or references a non-existent id.",
    "expressions": [
      "def prepare:\n  reduce inputs as $in ({};\n    . + ($in | {\"id:\\(.id)\": .})\n  );\ndef search($id):\n  def follow($ref):\n    if has($ref) then .[$ref], follow(.[$ref].ref) else empty end;\n  follow(\"id:\\($id)\");\nprepare | search(1)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "ref": "id:2",
            "msg": "1"
          },
          {
            "id": 2,
            "ref": "none",
            "msg": "2"
          },
          {
            "id": 3,
            "ref": "none",
            "msg": "3"
          }
        ],
        "output": [
          {
            "id": 1,
            "ref": "id:2",
            "msg": "1"
          },
          {
            "id": 2,
            "ref": "none",
            "msg": "2"
          }
        ]
      }
    ],
    "identifier": 68430853
  },
  {
    "context": [
      "I have this json that i want to convert.",
      "I have tried this, which is pretty close:",
      "jq '. | group_by(.externalGroup)[] | {(.[0].externalGroup): map(.groupId)}'",
      "But this doesn't convert properly with yq. It would need to look something like this instead:",
      "{\n  \"another group admins\": [\n    \"da2e42c8-6423-4d32-99b5-5fc58f9f80b8\"\n  ],\n  \"another group users\": [\n    \"7c69cac1-4a70-4170-8251-cde3762fe498\"\n  ],\n  \"my group admin\": [\n    \"e08a1d9d-f108-4e87-bdb3-ee4f10c6752a\"\n  ],\n  \"my group users\": [\n    \"8370821e-edfa-4615-ac2e-47815b740f40\"\n  ],\n  \"some group\": [\n    \"e08a1d9d-f108-4e87-bdb3-ee4f10c6752a\",\n    \"8370821e-edfa-4615-ac2e-47815b740f40\",\n    \"7c69cac1-4a70-4170-8251-cde3762fe498\"\n  ]\n}",
      "Try:",
      "jq 'group_by(.externalGroup) | map({key:.[0].externalGroup, value:map(.groupId)}) | from_entries'",
      "jq 'group_by(.externalGroup) | map({(.[0].externalGroup):map(.groupId)}) | add'"
    ],
    "utterance": "Group objects by their externalGroup field, collecting the groupId values for each group into a list, and output as a single object mapping each group name to its groupIds.",
    "expressions": [
      "group_by(.externalGroup) | map({key:.[0].externalGroup, value:map(.groupId)}) | from_entries",
      "group_by(.externalGroup) | map({(.[0].externalGroup):map(.groupId)}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "externalGroup": "another group admins",
            "groupId": "da2e42c8-6423-4d32-99b5-5fc58f9f80b8"
          },
          {
            "externalGroup": "another group users",
            "groupId": "7c69cac1-4a70-4170-8251-cde3762fe498"
          },
          {
            "externalGroup": "my group admin",
            "groupId": "e08a1d9d-f108-4e87-bdb3-ee4f10c6752a"
          },
          {
            "externalGroup": "my group users",
            "groupId": "8370821e-edfa-4615-ac2e-47815b740f40"
          },
          {
            "externalGroup": "some group",
            "groupId": "e08a1d9d-f108-4e87-bdb3-ee4f10c6752a"
          },
          {
            "externalGroup": "some group",
            "groupId": "8370821e-edfa-4615-ac2e-47815b740f40"
          },
          {
            "externalGroup": "some group",
            "groupId": "7c69cac1-4a70-4170-8251-cde3762fe498"
          }
        ],
        "output": {
          "another group admins": [
            "da2e42c8-6423-4d32-99b5-5fc58f9f80b8"
          ],
          "another group users": [
            "7c69cac1-4a70-4170-8251-cde3762fe498"
          ],
          "my group admin": [
            "e08a1d9d-f108-4e87-bdb3-ee4f10c6752a"
          ],
          "my group users": [
            "8370821e-edfa-4615-ac2e-47815b740f40"
          ],
          "some group": [
            "e08a1d9d-f108-4e87-bdb3-ee4f10c6752a",
            "8370821e-edfa-4615-ac2e-47815b740f40",
            "7c69cac1-4a70-4170-8251-cde3762fe498"
          ]
        }
      }
    ],
    "identifier": 68674042
  },
  {
    "context": [
      "I have a test.json file that looks like this: \r\n\r\n    [\r\n      {\r\n        \"array\": [\r\n          \"string1\",\r\n          \"string2\"\r\n        ]\r\n      },\r\n      {\r\n        \"object1\": {\r\n          \"subobject1\": {},\r\n          \"subobject2\": {}\r\n        }\r\n      },\r\n      {\r\n        \"object2\": {}\r\n      }\r\n    ]",
      "I expect is this, `string3` only being appended to `array`: \r\n\r\n    {\r\n      \"array\": [\r\n        \"string1\",\r\n        \"string2\",\r\n        \"string3\"\r\n      ]\r\n    }\r\n    {\r\n      \"object1\": {\r\n        \"subobject1\": {},\r\n        \"subobject2\": {}\r\n      },\r\n    }\r\n    {\r\n      \"object2\": {},\r\n    }",
      "How can I append to the one array `array` without affecting any other objects in the file?",
      "Well, does something like this work for you?\r\n\r\n    jq '.[0].array += [\"string3\"]' test.json",
      "I like the more general solutions provided by @peak particularly the first one:\r\n\r\n    map( if .array then .array += [\"string3\"] else . end)",
      "Depending on your requirements, you may wish to consider:\r\n\r\n    map( if .array then .array += [\"string3\"] else . end)",
      "You can try this to find object by key `array` and append there\r\n```\r\njq '.[] | select(has(\"array\")).array += [\"string3\"]' test.json\r\n```"
    ],
    "utterance": "Append 'string3' to the array named 'array' in the first object of a top-level array, without modifying other objects.",
    "expressions": [
      ".[0].array += [\"string3\"]",
      "map( if .array then .array += [\"string3\"] else . end)",
      ".[] | select(has(\"array\")).array += [\"string3\"]"
    ],
    "data": [
      {
        "input": [
          {
            "array": [
              "string1",
              "string2"
            ]
          },
          {
            "object1": {
              "subobject1": {},
              "subobject2": {}
            }
          },
          {
            "object2": {}
          }
        ],
        "output": [
          {
            "array": [
              "string1",
              "string2",
              "string3"
            ]
          },
          {
            "object1": {
              "subobject1": {},
              "subobject2": {}
            }
          },
          {
            "object2": {}
          }
        ]
      }
    ],
    "identifier": 68504374
  },
  {
    "context": [
      "I need to filter the array elements to only those that have a \"key\" value that is found in the list of values.",
      "The list of values is a text file containing a single item per-line.",
      "You can use the following:\n\n```sh\njq --rawfile to_keep_file to_keep.txt '\n   ( [ $to_keep_file | match(\".+\"; \"g\").string | { (.): true } ] | add ) as $to_keep_lkup |\n   map(select($to_keep_lkup[.key]))\n' to_filter.json\n```",
      "or\n\n```sh\n(\n   jq -sR . to_keep.txt\n   cat to_filter.json\n) | jq -n '\n   ( [ input | match(\".+\"; \"g\").string | { (.): true } ] | add ) as $to_keep_lkup |\n   inputs | map(select($to_keep_lkup[.key]))\n'\n```"
    ],
    "utterance": "Filter an array to only include objects whose \"key\" field matches a value from a list of strings loaded from an external file.",
    "expressions": [
      "( [ $to_keep_file | match(\".+\"; \"g\").string | { (.): true } ] | add ) as $to_keep_lkup | map(select($to_keep_lkup[.key]))",
      "( [ input | match(\".+\"; \"g\").string | { (.): true } ] | add ) as $to_keep_lkup | inputs | map(select($to_keep_lkup[.key]))"
    ],
    "data": [
      {
        "input": [
          {
            "key": "foo",
            "detail": "bar"
          },
          {
            "key": "qux",
            "detail": "baz"
          }
        ],
        "output": [
          {
            "key": "foo",
            "detail": "bar"
          }
        ]
      }
    ],
    "identifier": 68644504
  },
  {
    "context": [
      "I want to shove the json object from file 2 into \"b\" from file 1",
      "jq '.b = input' file1 file2",
      "Otherwise you'd use the following to retain the original value of `.b` when file #2 is empty.\njq '.b = first(inputs, .b)' file1 file2"
    ],
    "utterance": "Replace the value of key 'b' in the first object with the entire object from another file.",
    "expressions": [
      ".b = input",
      ".b = first(inputs, .b)"
    ],
    "data": [
      {
        "input": {
          "a": "aval",
          "b": {},
          "c": "cval"
        },
        "output": {
          "a": "aval",
          "b": {
            "b1": "b1val",
            "b2": "b2val"
          },
          "c": "cval"
        }
      }
    ],
    "identifier": 68876023
  },
  {
    "context": [
      "I am trying to find the elements with same `keys` but different `values` using `jq`.",
      "**Expected output:**\n{\n  \"COMMON-VAR\": \"ABC\",\n  \"LASTNAME\": \"D\",\n}",
      "Iterate over keys of the first object and check whether they exist in the second and have the same value in both objects. Delete those that do, and leave the rest intact.",
      "jq -n '\n  input as $f1 | input as $f2\n  | reduce ($f1|keys_unsorted[]) as $k ({};\n      if $f2 | has($k) and $f1[$k] != $f2[$k] then .[$k]=$f1[$k] else . end)\n' file1.json file2.json"
    ],
    "utterance": "Select all key-value pairs from the first file whose keys exist in the second file and have different values.",
    "expressions": [
      "inputs as $a\n| reduce keys_unsorted[] as $k (.;\n  if ($k | in($a)) and (.[$k] == $a[$k]) then del(.[$k]) else . end\n)",
      "input as $f1 | input as $f2\n| reduce ($f1|keys_unsorted[]) as $k ({};\n    if $f2 | has($k) and $f1[$k] != $f2[$k] then .[$k]=$f1[$k] else . end)"
    ],
    "data": [
      {
        "input": {
          "file1": {
            "COMMON-VAR": "ABC",
            "LASTNAME": "D",
            "FIRSTNAME": "JOHN"
          },
          "file2": {
            "COMMON-VAR": "DEF",
            "LASTNAME": "S",
            "FIRSTNAME": "JOHN",
            "ADDRESS": "SanJose, CA",
            "ZIP": "09817"
          }
        },
        "output": {
          "COMMON-VAR": "ABC",
          "LASTNAME": "D"
        }
      }
    ],
    "identifier": 68684609
  },
  {
    "context": [
      "I want entire objects removed based on duplicate values of the \"run\" key, while keeping the object with the largest \"startTime\" number:",
      "I was trying to use `unique` because I want to keep only 1 of each \"run:\" ids where in a larger list I might have three `x`, two `y`, and four `z`.  I'd want to keep one `x`, `y`, and `z` in this case based on the largest \"startTime\".",
      "Here's a straightforward jq solution:\n```\n.data.results |=\n  (group_by(.event.biking.run)\n   | map(max_by(.event.biking.startTime)))\n```\nIt uses `group_by` to group by \"run\", and then `max_by` to select the desired event."
    ],
    "utterance": "Remove all but the object with the highest startTime for each unique value of the event.biking.run key in the results array.",
    "expressions": [
      ".data.results |= (group_by(.event.biking.run) | map(max_by(.event.biking.startTime)))"
    ],
    "data": [
      {
        "input": {
          "data": {
            "results": [
              {
                "event": {
                  "biking": {
                    "startTime": 12,
                    "id": "a",
                    "run": "x"
                  }
                },
                "displayName": "Alex"
              },
              {
                "event": {
                  "biking": {
                    "startTime": 10,
                    "id": "b",
                    "run": "x"
                  }
                },
                "displayName": "Adam"
              },
              {
                "event": {
                  "biking": {
                    "startTime": 11,
                    "id": "c",
                    "run": "y"
                  }
                },
                "displayName": "Aaron"
              }
            ]
          }
        },
        "output": {
          "data": {
            "results": [
              {
                "event": {
                  "biking": {
                    "startTime": 12,
                    "id": "a",
                    "run": "x"
                  }
                },
                "displayName": "Alex"
              },
              {
                "event": {
                  "biking": {
                    "startTime": 11,
                    "id": "c",
                    "run": "y"
                  }
                },
                "displayName": "Aaron"
              }
            ]
          }
        }
      }
    ],
    "identifier": 68387526
  },
  {
    "context": [
      "But what I want is to update the keys of `file1` with the values of matching keys in `file2`, and the new keys in `file2` will be ignored. So it would return:\r\n\r\n```\r\n{\r\n  \"error\": {\r\n    \"200\": \"200 error code\",\r\n    \"500\": \"500 error\"\r\n  }\r\n}\r\n```\r\nNotice that the key `200` was updated with the value from `file2` while the key `400` was ignored.",
      "Here is one solution to the problem as I understand it:\r\n```\r\njq -n '\n input.error as $file1\n | input.error as $file2\n | (($file2|keys_unsorted) - ($file1|keys_unsorted)) as $k1\n | ($file1 + $file2) | delpaths($k1 | map([.]))\n | {error: .}\n' file1.json file2.json\n```\nThere are many other alternatives....",
      "```sh\njq -n '\n   input.error as $overrides |\n   input | .error |= (\n      keys_unsorted[] as $key |\n      .[$key] = ( $overrides[$key] // .[$key] )\n   )\n' file2.json file1.json\n```"
    ],
    "utterance": "Update the 'error' object in the first file with values from the second file, but only for keys that already exist in the first file, ignoring new keys from the second file.",
    "expressions": [
      "jq -n 'input.error as $file1 | input.error as $file2 | (($file2|keys_unsorted) - ($file1|keys_unsorted)) as $k1 | ($file1 + $file2) | delpaths($k1 | map([.])) | {error: .}' file1.json file2.json",
      "jq -n 'input.error as $overrides | input | .error |= (keys_unsorted[] as $key | .[$key] = ( $overrides[$key] // .[$key] ))' file2.json file1.json"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "error": {
              "200": "200 error",
              "500": "500 error"
            }
          },
          "file2.json": {
            "error": {
              "200": "200 error code",
              "400": "400 error code"
            }
          }
        },
        "output": {
          "error": {
            "200": "200 error code",
            "500": "500 error"
          }
        }
      }
    ],
    "identifier": 68504668
  },
  {
    "context": [
      "During shell script run time additionally `$PORT` & `$u` variable values need to be added in output of each `json` file.",
      "**Expected json output:-**\n{\n  ...\n  \"port\": \"2728\",\n  \"userid\": \"daniel\"\n},",
      "By using --arg with jq you can pass paremeter and use as a variables",
      "by using `map` and `+`  you can iterate over the array and add a new property for each associative  array",
      "curl --user $USERID:$PASSWORD http://198.98.99.12:46567/$PORT/protects/$u  \\\n   | jq --arg a_port $PORT  --arg $u  $USER 'map(.+{\"userid\":$a_userid}+{\"port\":$a_port|tonumber})'  > m4-$u.json"
    ],
    "utterance": "Add shell variables for user and port as fields in every object of the data retrieved for each user.",
    "expressions": [
      "map(. + {userid: $a_userid} + {port: ($a_port|tonumber)})"
    ],
    "data": [
      {
        "input": [
          {
            "depotFile": "//ABND/JJEB/...",
            "host": "*",
            "isgroup": "",
            "line": "16",
            "perm": "open",
            "user": "5G_USER_GROUP"
          },
          {
            "depotFile": "//LIB/...",
            "host": "*",
            "isgroup": "",
            "line": "19",
            "perm": "write",
            "user": "6G_USER_GROUP"
          }
        ],
        "output": [
          {
            "depotFile": "//ABND/JJEB/...",
            "host": "*",
            "isgroup": "",
            "line": "16",
            "perm": "open",
            "user": "5G_USER_GROUP",
            "userid": "daniel",
            "port": 2728
          },
          {
            "depotFile": "//LIB/...",
            "host": "*",
            "isgroup": "",
            "line": "19",
            "perm": "write",
            "user": "6G_USER_GROUP",
            "userid": "daniel",
            "port": 2728
          }
        ]
      }
    ],
    "identifier": 68664722
  },
  {
    "context": [
      "What I want to achieve is to get \"generator\" and \"payload\" values. The tricky thing is that some items contain two results and some generators have two items too. In that case, I am only interested on payload value of the one with metadata info.",
      "Desired output:\n```\nagentinfo, 3p95ouql5QgiZ2M7MBBQH5\nlog-audit, dWdVpfCCm44ax4KCyTEmhL\nconfig, 1gi1QRjxme267adKl7Kqzn\n```",
      "Also tried select and unique_by but I didn\u2019t manage to get what I want.",
      "```\njq -r '\n  reduce(.audits[] | {generator} * .results[]) as $item ({}; \n    (.[$item.generator]?) as $left\n    | . * {($item.generator):\n             (if ($left | has(\"metadata\"))\n              then $left else $item end) })\n  | .[]\n  | \"\\(.generator),\\(.payload)\"'\n```\nOutput:\n```\nagentinfo,3p95ouql5QgiZ2M7MBBQH5\nlog-audit,dWdVpfCCm44ax4KCyTEmhL\nconfig,1gi1QRjxme267adKl7Kqzn\n```",
      "Here's a straightforward approach using `group_by`:\n```\njq -r '\n  [ .audits[]\n    | .generator as $generator\n    | .results\n    | (map(select(.payload)) | length) as $npayloads\n    | (if $npayloads == 1 then (.[] | select(.payload).payload)\n       else first(.[] | select(.metadata).payload)\n       end)  as $payload\n    | {$generator, $payload} ]\n  | group_by(.generator)\n  | map(.[0])[]\n  | \"\\(.generator),\\(.payload)\"\n'\n```\nThis produces the desired output."
    ],
    "utterance": "Extract for each generator the payload value, preferring the result with metadata when multiple results exist for the same generator.",
    "expressions": [
      "jq -r '\n  reduce(.audits[] | {generator} * .results[]) as $item ({}; \n    (.[$item.generator]?) as $left\n    | . * {($item.generator):\n             (if ($left | has(\"metadata\"))\n              then $left else $item end) })\n  | .[]\n  | \"\\(.generator),\\(.payload)\"'",
      "jq -r '\n  [ .audits[]\n    | .generator as $generator\n    | .results\n    | (map(select(.payload)) | length) as $npayloads\n    | (if $npayloads == 1 then (.[] | select(.payload).payload)\n       else first(.[] | select(.metadata).payload)\n       end)  as $payload\n    | {$generator, $payload} ]\n  | group_by(.generator)\n  | map(.[0])[]\n  | \"\\(.generator),\\(.payload)\"\n'"
    ],
    "data": [
      {
        "input": {
          "type": "audit_manifest",
          "version": "1.0",
          "audits": [
            {
              "id": "",
              "generator": "agentinfo",
              "generatorVersion": "1.0.0.0",
              "results": [
                {
                  "payload": "3p95ouql5QgiZ2M7MBBQH5",
                  "type": "application/json"
                }
              ]
            },
            {
              "id": "",
              "generator": "log-audit",
              "generatorVersion": "1.0.0.0",
              "results": [
                {
                  "payload": "m3q1IVhgNk59VySdnvEXgk",
                  "type": "application/json"
                },
                {
                  "payload": "dWdVpfCCm44ax4KCyTEmhL",
                  "type": "application/octet-stream",
                  "metadata": [
                    {
                      "name": "name",
                      "value": "agent.log"
                    }
                  ]
                }
              ]
            },
            {
              "id": "",
              "generator": "log-audit",
              "generatorVersion": "1.0.0.0",
              "results": [
                {
                  "payload": "80iINCJwFFjcLp3BUf9Tec",
                  "type": "application/json"
                }
              ]
            },
            {
              "id": "",
              "generator": "config",
              "generatorVersion": "1.0.0.0",
              "results": [
                {
                  "payload": "hRUiHto5JpcjnbD3tJQMx1",
                  "type": "application/json"
                },
                {
                  "payload": "1gi1QRjxme267adKl7Kqzn",
                  "type": "application/octet-stream",
                  "metadata": [
                    {
                      "name": "name",
                      "value": "config.json"
                    }
                  ]
                }
              ]
            },
            {
              "id": "",
              "generator": "config",
              "generatorVersion": "1.0.0.0",
              "results": [
                {
                  "payload": "SGf26By1b174bCLD0YYx01",
                  "type": "application/json"
                }
              ]
            }
          ]
        },
        "output": "agentinfo,3p95ouql5QgiZ2M7MBBQH5\nlog-audit,dWdVpfCCm44ax4KCyTEmhL\nconfig,1gi1QRjxme267adKl7Kqzn"
      }
    ],
    "identifier": 68649725
  },
  {
    "context": [
      "aws s3api list-objects-v2 --bucket \"$LOGGING_BUCKET\" | jq '.Contents' >> entries.json &&",
      "keys=$(jq '.[].Key' entries.json )",
      "for key in $keys;do",
      "aws s3api get-object --bucket \"$LOGGING_BUCKET\" --key \"$key\" ouput_file_\"$key\"",
      "The variable `$key` will be a quoted string, so you&#39;re basically double quoting the string, and S3 is failing to find `\"key_name\"` with the quotes.",
      "You could remove the quotes before passing them along:"
    ],
    "utterance": "Extract the value of the Key field for each item in the Contents array.",
    "expressions": [
      ".Contents[].Key"
    ],
    "identifier": 68728763
  },
  {
    "context": [
      "Given this doc , I would like to transform into a different doc, with this structure:",
      "[{\"key\": \"val1\",\"mnt\": \" /-rootFS\",\"key3\": {\"key4\": \"val4\"}}, ...]",
      "Not sure how to do it , I have tried in many different ways, mostly getting a \"Cannot index array with string \\\"mount\\\"\" error.",
      "Here's one way:",
      "map( (.mount \n      | if . == \"/\" then \"root\" \n        elif . == \"/opt\" then \"opt\" \n        else \"tmp\" end) as $type\n      | {key: \"val1\",\n         mnt:  \"\\(.mount)-\\($type)FS\",\n         key3: {key4: \"val4\"}} )"
    ],
    "utterance": "Transform an array into objects with key 'val1', 'mnt' equal to mount plus a suffix based on specific mount values, and key3.key4 equal to 'val4'.",
    "expressions": [
      "map((.mount | if . == \"/\" then \"root\" elif . == \"/opt\" then \"opt\" else \"tmp\" end) as $type | {key: \"val1\", mnt: \"\\(.mount)-\\($type)FS\", key3: {key4: \"val4\"}})"
    ],
    "data": [
      {
        "input": [
          {
            "mount": "/",
            "size": "45G",
            "usedperc": "26"
          },
          {
            "mount": "/opt",
            "size": "197G",
            "usedperc": "20"
          },
          {
            "mount": "/tmp",
            "size": "5.0G",
            "usedperc": "8"
          }
        ],
        "output": [
          {
            "key": "val1",
            "mnt": "/-rootFS",
            "key3": {
              "key4": "val4"
            }
          },
          {
            "key": "val1",
            "mnt": "/opt-optFS",
            "key3": {
              "key4": "val4"
            }
          },
          {
            "key": "val1",
            "mnt": "/tmp-tmpFS",
            "key3": {
              "key4": "val4"
            }
          }
        ]
      }
    ],
    "identifier": 68643008
  },
  {
    "context": [
      "I have this:",
      "{ \"service\" : { \"category\" : \"managed-object\", \"resource\" : \"attribute\", \"action\" : \"delete\", \"options\" : { \"uuid\" : \"#VALUE\", \"attributes\" : { \"name\" : { \"value\" : \"#VALUE\" }, \"contactInfo\" : \"\", \"activationDate\" : \"\", \"deactivationDate\" : \"\", \"protectStopDate\" : \"\", \"processStartDate\" : \"\" } } } }",
      "I need this:",
      "{ \"service\" : { \"category\" : \"managed-object\", \"resource\" : \"attribute\", \"action\" : \"delete\", \"options\" : { \"uuid\" : \"#VALUE\", \"attributes\" : { \"name\" : { \"value\" : \"#VALUE\" } } } } }",
      "'.service.options.attributes |= {name}'"
    ],
    "utterance": "Remove all keys from the 'attributes' object inside 'service.options' except 'name', preserving all other structure and values.",
    "expressions": [
      ".service.options.attributes |= {name}"
    ],
    "data": [
      {
        "input": {
          "service": {
            "category": "managed-object",
            "resource": "attribute",
            "action": "delete",
            "options": {
              "uuid": "#VALUE",
              "attributes": {
                "name": {
                  "value": "#VALUE"
                },
                "contactInfo": "",
                "activationDate": "",
                "deactivationDate": "",
                "protectStopDate": "",
                "processStartDate": ""
              }
            }
          }
        },
        "output": {
          "service": {
            "category": "managed-object",
            "resource": "attribute",
            "action": "delete",
            "options": {
              "uuid": "#VALUE",
              "attributes": {
                "name": {
                  "value": "#VALUE"
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 68914275
  },
  {
    "context": [
      "You also want to add the -r option to jq in the variables you are going to pass in curl, like so:",
      "ruleId=$($whitelist | jq -r '.[].ruleId')",
      "alert=$($whitelist | jq -r '.[].alertName')",
      "jq -r 'MYFILTER' \"$whitelist\"",
      "Although jq is fairly light-weight, it is worth noting that all those calls to jq could be reduced to one, though of course your shell script would then have to be modified as well."
    ],
    "utterance": "Extract each object's fields as raw strings for ruleId, alertName, newLevel, url, urlIsRegex, enabled, parameter, and evidence from an array at the top level.",
    "expressions": [
      ".[].ruleId",
      ".[].alertName",
      ".[].newLevel",
      ".[].url",
      ".[].urlIsRegex",
      ".[].enabled",
      ".[].parameter",
      ".[].evidence",
      ".[] | [.ruleId, .alertName, .newLevel, .url, .urlIsRegex, .enabled, .parameter, .evidence] | @tsv",
      "[.[].ruleId]",
      "[.[].alertName]",
      "[.[].newLevel]",
      "[.[].url]",
      "[.[].urlIsRegex]",
      "[.[].enabled]",
      "[.[].parameter]",
      "[.[].evidence]"
    ],
    "identifier": 68712132
  },
  {
    "context": [
      "I am trying to capture some fields with the array index",
      "Expected output",
      "1.test1~id1",
      "2.test2~id2",
      "to_entries[] | \"\\(.key + 1).\\(.value.name)~\\(.value.id)\"",
      "jq --raw-output 'to_entries[] | \"\\(.key + 1).\\(.value.name)~\\(.value.id)\"'"
    ],
    "utterance": "For each object in the array, output the 1-based index, followed by a dot, the name, a tilde, and the id in the format: N.name~id.",
    "expressions": [
      "to_entries[] | \"\\(.key + 1).\\(.value.name)~\\(.value.id)\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "test1",
            "id": "id1",
            "ip": "10.0.0.0"
          },
          {
            "name": "test2",
            "id": "id2",
            "ip": "10.1.0.0"
          }
        ],
        "output": [
          "1.test1~id1",
          "2.test2~id2"
        ]
      }
    ],
    "identifier": 68913642
  },
  {
    "context": [
      "echo \"$foo\" | jq -r '.[] | .name, .failed_step.name, .failed_step.number' | while \\\n    read -r job && read -r step && read -r number; do\n        echo \"job = $job\";\n        echo \"step = $step\";\n        echo \"number = $number\";\ndone",
      "You don't need a `while` loop. Just format it with the jq command:",
      "echo \"$foo\" | jq -j '.[] | \"job = \", .name, \"\\nstep = \", .failed_step.name, \"\\nnumber = \", .failed_step.number, \"\\n\"'",
      "jq -r '.[] | .name + \"\\t\" + .failed_step.name + \"\\t\" + (.failed_step.number | tostring)'"
    ],
    "utterance": "Extract name, failed_step.name, and failed_step.number for each object, separating the values by tabs on each line.",
    "expressions": [
      ".[] | .name + \"\\t\" + .failed_step.name + \"\\t\" + (.failed_step.number | tostring)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "e2e (control-plane, true, true, true, ipv4, IPv4, true, false)",
            "failed_step": {
              "name": "Run Tests",
              "conclusion": "failure",
              "number": 11
            }
          },
          {
            "name": "e2e (control-plane, true, true, true, ipv4, IPv4, true, false)",
            "failed_step": {
              "name": "Generate Test Report",
              "conclusion": "failure",
              "number": 13
            }
          }
        ],
        "output": "e2e (control-plane, true, true, true, ipv4, IPv4, true, false)\tRun Tests\t11\ne2e (control-plane, true, true, true, ipv4, IPv4, true, false)\tGenerate Test Report\t13"
      }
    ],
    "identifier": 68582317
  },
  {
    "context": [
      "I have an array of Objects in the following form:",
      "{\n    \"alpha\": {\n        \"beta\": \"gamma\",\n        \"delta\": \"epsilon\"\n    },\n    \"zeta\": {\n        \"eta\": \"theta\",\n        \"iota\": \"kappa\"\n    }\n}",
      "I would like to transform this Object to be in the following form:",
      "{\n    \"alpha\": {\n        \"beta\": \"gamma\",\n        \"delta\": \"epsilon\",\n        \"zeta\": {\n            \"eta\": \"theta\",\n            \"iota\": \"kappa\"\n        }\n    },\n}",
      "jq '.alpha.zeta=.zeta|del(.zeta)' input.json",
      "$ jq '{alpha: (.alpha + {zeta})}' tmp.json",
      "`{zeta}` is shorthand for `{zeta: .zeta}`."
    ],
    "utterance": "Nest the object under the property 'zeta' inside the object under 'alpha', removing 'zeta' from the top level.",
    "expressions": [
      ".alpha.zeta = .zeta | del(.zeta)",
      "{alpha: (.alpha + {zeta})}"
    ],
    "data": [
      {
        "input": {
          "alpha": {
            "beta": "gamma",
            "delta": "epsilon"
          },
          "zeta": {
            "eta": "theta",
            "iota": "kappa"
          }
        },
        "output": {
          "alpha": {
            "beta": "gamma",
            "delta": "epsilon",
            "zeta": {
              "eta": "theta",
              "iota": "kappa"
            }
          }
        }
      }
    ],
    "identifier": 68394005
  },
  {
    "context": [
      "cat testfile.txt | jq 'fromjson | select(.kubernetes.pod.memory.usage.bytes != null) .kubernetes.pod.memory.usage.bytes, .\"@timestamp\"'",
      "How to delete excess dates?",
      "You just need to add a pipe after select :",
      "cat testfile.txt | jq 'fromjson | select(.kubernetes.pod.memory.usage.bytes != null) | .kubernetes.pod.memory.usage.bytes, .\"@timestamp\"'"
    ],
    "utterance": "Output only records where .kubernetes.pod.memory.usage.bytes is not null, displaying the bytes value followed by the @timestamp.",
    "expressions": [
      "fromjson | select(.kubernetes.pod.memory.usage.bytes != null) | .kubernetes.pod.memory.usage.bytes, .\"@timestamp\""
    ],
    "identifier": 68693551
  },
  {
    "context": [
      "How I can create like this json using my variables and set to new var:\r\n\r\n    [\r\n      {\r\n        \"name\": \"server-1\",\r\n        \"url\": \"http://server-1.net\"\r\n      },\r\n      {\r\n        \"name\": \"server-2\",\r\n        \"url\": \"http://server-2.net\"\r\n      }\r\n    ]",
      "Pass your strings using `--arg`, then you can create the JSON as expected:",
      "result=$(jq -n \\\r\n    --arg name1 \"$server1_name\" \\\r\n    --arg url1 \"$server1_url\" \\\r\n    --arg name2 \"$server2_name\" \\\r\n    --arg url2 \"$server2_url\" \\\r\n    '[ { \"name\": $name1, \"url\": $url1 }, { \"name\": $name2, \"url\": $url2 } ]')",
      "You can construct two arrays of names and urls, then adapt [this answer](https://stackoverflow.com/a/57283652/1126841) to \"zip\" the two arrays together into the desired array of objects.",
      "jq -n \\\r\n    --arg name1 \"$server1_name\" \\\r\n    --arg url1 \"$server1_url\" \\\r\n    --arg name2 \"$server2_name\" \\\r\n    --arg url2 \"$server2_url\" \\\r\n'[$name1, $name2] as $names |\r\n [$url1, $url2] as $urls |\r\n  [([$names, $urls] | transpose[]) as [$name, $url] |{$name, $url}]'"
    ],
    "utterance": "Produce an array of objects containing name and url fields, using Bash variables server1_name, server1_url, server2_name, and server2_url as values.",
    "expressions": [
      "[ { \"name\": $name1, \"url\": $url1 }, { \"name\": $name2, \"url\": $url2 } ]",
      "[$name1, $name2] as $names | [$url1, $url2] as $urls | [([$names, $urls] | transpose[]) as [$name, $url] | {\"name\": $name, \"url\": $url}]"
    ],
    "data": [
      {
        "input": {
          "server1_name": "server-1",
          "server1_url": "http://server-1.net",
          "server2_name": "server-2",
          "server2_url": "http://server-2.net"
        },
        "output": [
          {
            "name": "server-1",
            "url": "http://server-1.net"
          },
          {
            "name": "server-2",
            "url": "http://server-2.net"
          }
        ]
      }
    ],
    "identifier": 68940509
  },
  {
    "context": [
      "I want to the exact same output with a slightly different input: my \"realnames\" is an array of objects:",
      "{\n\"posts\": [{\"title\": \"Frist psot\", \"author\": \"anon\"},\n           {\"title\": \"A well-written article\", \"author\": \"person1\"}],\n \"realnames\": [{id: \"anon\", name: \"Anonymous Coward\"},\n               {id: \"person1\", name: \"Person McPherson\"}]}\n\nHow would I get the exact same output from this input?",
      ".realnames[] as $names | .posts[] | {title, author: (select(.author == $names.id) | $names.name)}",
      "This could be accomplished via:\n\n    .realnames |= (map({(.id): .name}) | add)"
    ],
    "utterance": "For each post, replace the author field with the name from realnames, where the author's value matches a realnames entry's id.",
    "expressions": [
      ".realnames[] as $names | .posts[] | {title, author: (select(.author == $names.id) | $names.name)}",
      ".realnames |= (map({(.id): .name}) | add) | .posts[] | {title, author: .realnames[.author]}"
    ],
    "data": [
      {
        "input": {
          "posts": [
            {
              "title": "Frist psot",
              "author": "anon"
            },
            {
              "title": "A well-written article",
              "author": "person1"
            }
          ],
          "realnames": [
            {
              "id": "anon",
              "name": "Anonymous Coward"
            },
            {
              "id": "person1",
              "name": "Person McPherson"
            }
          ]
        },
        "output": [
          {
            "title": "Frist psot",
            "author": "Anonymous Coward"
          },
          {
            "title": "A well-written article",
            "author": "Person McPherson"
          }
        ]
      }
    ],
    "identifier": 68877871
  },
  {
    "context": [
      "On running the following command:\r\n\r\n```jq -r '(.features[0] | keys_unsorted), (.features[] | to_entries | map(.value[]))|@csv' temp.json```\r\n\r\nIt throws up this error\r\n```jq: error (at gcc.geojson:1892525): Cannot iterate over string (\"Feature\").```",
      "We need the columns: \"coordinates\", \"properties\" and properties's sub nests as columns in the .csv file. Sample content is as given below for your information",
      "The expected output is as given below:\r\n\r\n```\"54.4249414,24.5382557\", \"Abu Dhabi\",\"St. Regis Saadiyat Island\",\"St. Regis Saadiyat\",\"contact:email\":\"spnstregis@spinneysauh.com\",etc```",
      "In brief, each \"feature\" is not a flat object, and so, since you want to use `@csv`, you're\r\ngoing to have to specify how to represent each \"feature\" as a flat array.",
      "This could be done in one of the following ways, but in each case, your headers are not going to match:\r\n\r\n    .features[] | [.. | scalars]\r\n\r\nor\r\n\r\n    .features[] | [.geometry.coordinates[], .properties[]]"
    ],
    "utterance": "Output a table where each row contains the coordinates and all property values for each feature.",
    "expressions": [
      ".features[] | [.geometry.coordinates[], .properties[]] | @csv"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "Point",
                "coordinates": [
                  54.4249414,
                  24.5382557
                ]
              },
              "properties": {
                "addr:city": "Abu Dhabi",
                "addr:neighbourhood": "St. Regis Saadiyat Island",
                "addr:street": "St. Regis Saadiyat",
                "contact:email": "spnstregis@spinneysauh.com",
                "shop": "alcohol"
              }
            }
          ]
        },
        "output": "\"54.4249414\", \"24.5382557\", \"Abu Dhabi\", \"St. Regis Saadiyat Island\", \"St. Regis Saadiyat\", \"spnstregis@spinneysauh.com\", \"alcohol\""
      }
    ],
    "identifier": 68594397
  },
  {
    "context": [
      "Using that JSON data, I'm trying to extract the values listed in the `assignedValue` field. When I use the jq tool and filter by `.[]|.assignedValue` it returns the values I want...",
      "But when I run that script, all it does is return null values...",
      "We can change the syntax to as the structure was slightly different compared to the one OP run it on the site",
      "> capture_jq %>% jq('.\"assignedValue\"')",
      "[ \"Male\", \"Caucasian\", \"31\" ]"
    ],
    "utterance": "Extract all values of assignedValue from the current array.",
    "expressions": [
      ".[] | .assignedValue",
      ".\"assignedValue\""
    ],
    "data": [
      {
        "input": [
          {
            "customField": {
              "customFieldId": 83
            },
            "customFieldId": 83,
            "customFieldGroupId": 36,
            "assignedValue": "Male"
          },
          {
            "customField": {
              "customFieldId": 84
            },
            "customFieldId": 84,
            "customFieldGroupId": 36,
            "assignedValue": "Caucasian"
          },
          {
            "customField": {
              "customFieldId": 85
            },
            "customFieldId": 85,
            "customFieldGroupId": 36,
            "assignedValue": "31"
          }
        ],
        "output": [
          "Male",
          "Caucasian",
          "31"
        ]
      }
    ],
    "identifier": 68686847
  },
  {
    "context": [
      "ruleId=$($whitelist | jq -r '.[].ruleId')",
      "gives: \n\n10055\n10098\n\nThis can not be interpreted correctly from CURL.",
      "how can I pass variables in a proper manner, in a sort of iteration, using JQ?",
      "you can use bash arrays to store your values:",
      "ruleId=($($whitelist | jq -r '.[].ruleId'))",
      "and then iterate over them.",
      "mapfile -t rule      < <(jq -r '.[].ruleId'      \"${whitelist}\")",
      "for ((i=0; i<${listlength}; i++))\n    do\n        curl ... \"${rule[$i]}\" ... \"${alert[$i]}\" ...\n    done"
    ],
    "utterance": "Extract each ruleId field from an array so that each value can be used individually in a loop.",
    "expressions": [
      ".[].ruleId"
    ],
    "identifier": 68728292
  },
  {
    "context": [
      "I have a JSON array like this:",
      "And I want to print it in the following \"human-readable\" format:",
      "Note that the number of elements of the array and the number of key/value pairs for each element is variable and not known in advance.",
      "If you don't mind an empty line at the end of the output, this should work fine:",
      "jq -r '.[] | (to_entries[] | \"\\(.key) : \\(.value)\"), \"\"'",
      "One way to avoid the extra newline is to use join twice:",
      "[.[]\n     | [ (to_entries[] | \"\\(.key) : \\(.value)}\") ]\n       | join(\"\\n\")]\n    | join(\"\\n\\n\")"
    ],
    "utterance": "Print each object's keys and values with the format '<key> : <value>', separated by blank lines between objects, for all items in an array where both the objects and their keys are variable.",
    "expressions": [
      ".[] | (to_entries[] | \"\\(.key) : \\(.value)\"), \"\"",
      "[.[] | [ (to_entries[] | \"\\(.key) : \\(.value)\") ] | join(\"\\n\")] | join(\"\\n\\n\")"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value1a",
            "key2": "value2a",
            "key3": "value3a",
            "keyn": "valuena"
          },
          {
            "key1": "value1b",
            "key2": "value2b",
            "key3": "value3b",
            "keyn": "valuenb"
          },
          {
            "key1": "value1z",
            "key2": "value2z",
            "key3": "value3z",
            "keyn": "valuenz"
          }
        ],
        "output": "key1 : value1a\nkey2 : value2a\nkey3 : value3a\nkeyn : valuena\n\nkey1 : value1b\nkey2 : value2b\nkey3 : value3b\nkeyn : valuenb\n\nkey1 : value1z\nkey2 : value2z\nkey3 : value3z\nkeyn : valuenz"
      }
    ],
    "identifier": 68892871
  },
  {
    "context": [
      "Basically, the only fields I really need is the data that is contained within FieldId: 83, FieldId: 84, and FieldId: 85. All the other fields are basically irrelevant for the purposes of this exercise. So just the data from those three fields.  \r\n\r\nHow would I do that?",
      "jq '.[] | select(.Field.FieldId | IN(83,84,85))' input.json",
      "< input.json jq -n --stream '\n  fromstream(1|truncate_stream(inputs)) | select(.Field.FieldId | IN(83,84,85))'"
    ],
    "utterance": "Select all objects where Field.FieldId is 83, 84, or 85.",
    "expressions": [
      ".[] | select(.Field.FieldId | IN(83,84,85))"
    ],
    "data": [
      {
        "input": [
          {
            "Field": {
              "FieldId": 54,
              "FieldParentId": null,
              "FieldName": "What school did you attend?",
              "FieldGroupId": 12,
              "FieldGroupName": "College",
              "FieldGroupType": "Contacts",
              "FieldTypeId": "T",
              "isEditable": true,
              "maxTextboxCharacters": 75,
              "availableValues": null,
              "isExportable": true
            },
            "FieldId": 54,
            "FieldGroupId": 12,
            "assignedValue": null
          },
          {
            "Field": {
              "FieldId": 83,
              "FieldParentId": null,
              "FieldName": "Gender",
              "FieldGroupId": 36,
              "FieldGroupName": "Demographics",
              "FieldGroupType": "Contacts",
              "FieldTypeId": "T",
              "isEditable": true,
              "maxTextboxCharacters": 75,
              "availableValues": null,
              "isExportable": true
            },
            "FieldId": 83,
            "FieldGroupId": 36,
            "assignedValue": "Male"
          },
          {
            "Field": {
              "FieldId": 84,
              "FieldParentId": null,
              "FieldName": "Race",
              "FieldGroupId": 36,
              "FieldGroupName": "Demographics",
              "FieldGroupType": "Contacts",
              "FieldTypeId": "T",
              "isEditable": true,
              "maxTextboxCharacters": 75,
              "availableValues": null,
              "isExportable": true
            },
            "FieldId": 84,
            "FieldGroupId": 36,
            "assignedValue": "Caucasian"
          },
          {
            "Field": {
              "FieldId": 85,
              "FieldParentId": null,
              "FieldName": "Age",
              "FieldGroupId": 36,
              "FieldGroupName": "Demographics",
              "FieldGroupType": "Contacts",
              "FieldTypeId": "T",
              "isEditable": true,
              "maxTextboxCharacters": 75,
              "availableValues": null,
              "isExportable": true
            },
            "FieldId": 85,
            "FieldGroupId": 36,
            "assignedValue": "31"
          }
        ],
        "output": [
          {
            "Field": {
              "FieldId": 83,
              "FieldParentId": null,
              "FieldName": "Gender",
              "FieldGroupId": 36,
              "FieldGroupName": "Demographics",
              "FieldGroupType": "Contacts",
              "FieldTypeId": "T",
              "isEditable": true,
              "maxTextboxCharacters": 75,
              "availableValues": null,
              "isExportable": true
            },
            "FieldId": 83,
            "FieldGroupId": 36,
            "assignedValue": "Male"
          },
          {
            "Field": {
              "FieldId": 84,
              "FieldParentId": null,
              "FieldName": "Race",
              "FieldGroupId": 36,
              "FieldGroupName": "Demographics",
              "FieldGroupType": "Contacts",
              "FieldTypeId": "T",
              "isEditable": true,
              "maxTextboxCharacters": 75,
              "availableValues": null,
              "isExportable": true
            },
            "FieldId": 84,
            "FieldGroupId": 36,
            "assignedValue": "Caucasian"
          },
          {
            "Field": {
              "FieldId": 85,
              "FieldParentId": null,
              "FieldName": "Age",
              "FieldGroupId": 36,
              "FieldGroupName": "Demographics",
              "FieldGroupType": "Contacts",
              "FieldTypeId": "T",
              "isEditable": true,
              "maxTextboxCharacters": 75,
              "availableValues": null,
              "isExportable": true
            },
            "FieldId": 85,
            "FieldGroupId": 36,
            "assignedValue": "31"
          }
        ]
      }
    ],
    "identifier": 68685806
  },
  {
    "context": [
      "but only the keys with regex `[a-z]-` in `B` should be updated in `A`",
      "Discard keys that don't match `^[a-z]-$` in **B** and add **A** and the resulting object together.",
      "jq -n '\n  input as $A\n| input as $B\n| $A + ($B | with_entries(select(.key | test(\"^[a-z]-$\"))))\n' fileA fileB"
    ],
    "utterance": "Update an object by replacing values for keys from another object if those keys match the regular expression '^[a-z]-$'.",
    "expressions": [
      "input as $A | input as $B | $A + ($B | with_entries(select(.key | test(\"^[a-z]-$\"))))"
    ],
    "data": [
      {
        "input": [
          {
            "a-": {
              "v": 1
            },
            "b-": {
              "v": 2
            },
            "c": {
              "v": 3
            }
          },
          {
            "a-": {
              "v": 9
            },
            "b-": {
              "v": 9
            },
            "d": {
              "v": 9
            }
          }
        ],
        "output": {
          "a-": {
            "v": 9
          },
          "b-": {
            "v": 9
          },
          "c": {
            "v": 3
          }
        }
      }
    ],
    "identifier": 68954456
  },
  {
    "context": [
      "I have a file with JSON like:",
      "NUTS_PATH=\"NUTS|/nuts/2010\" #Storing in shell variable",
      "RESULT=($(jq -r --arg NUTS_PATH_ALIAS \"$NUTS_PATH\" '.[$NUTS_PATH_ALIAS]' $INPUT_FILE))",
      "For me, this jq query works:",
      "$ jq '.[\"NUTS|/nuts/2010\"]' test.json",
      "because you've got pipes and slashes in your string, the variable quoting gets a bit funny.",
      "RESULT=\"$(jq -r --arg NUTS_PATH_ALIAS \"$NUTS_PATH\" '.[$NUTS_PATH_ALIAS]' \"$INPUT_FILE\")\""
    ],
    "utterance": "Extract the object value for a key stored in a shell variable, where the key contains special characters such as pipe (|) and slash (/), using the key as a variable.",
    "expressions": [
      "jq --arg NUTS_PATH_ALIAS \"$NUTS_PATH\" '.[$NUTS_PATH_ALIAS]' \"$INPUT_FILE\"",
      "jq '.[\"NUTS|/nuts/2010\"]' test.json"
    ],
    "data": [
      {
        "input": {
          "NUTS|/nuts/2010": {
            "type": "small",
            "mfg": "TSQQ",
            "colors": []
          }
        },
        "output": {
          "type": "small",
          "mfg": "TSQQ",
          "colors": []
        }
      }
    ],
    "identifier": 68837705
  },
  {
    "context": [
      "I'm using `journalctl` to grab system journal entries and output as JSON. `journalctl` outputs as JSON objects separated by a newline.",
      "I'm trying to find a way to stop at a specific cursor and search the JSON objects between the `first` and `last` cursor.",
      "At the moment I'm using the following snippet (sloppy by my own admission) to search the journal after a cursor and count the objects where a match is found.",
      "journalctl -u my-service --after-cursor=\"$FIRST_CURSOR\" -o json | jq -n 'inputs|select(.MESSAGE|test(\".*My search string .*\")) | jq length | wc -l",
      "1. A jq-only solution would be:",
      "[inputs|select(.MESSAGE|test(\"My search string\")) | length] | length",
      "2. Notice there is no need for the initial or final `.*` in the regex"
    ],
    "utterance": "Count the number of entries where the MESSAGE field contains the string 'My search string'.",
    "expressions": [
      "[inputs | select(.MESSAGE | test(\"My search string\"))] | length"
    ],
    "data": [
      {
        "input": [
          {
            "MESSAGE": "Listening on port."
          },
          {
            "MESSAGE": "My search string is present here."
          },
          {
            "MESSAGE": "This doesn't match."
          },
          {
            "MESSAGE": "My search string again!"
          }
        ],
        "output": 2
      }
    ],
    "identifier": 68471082
  },
  {
    "context": [
      "\"I'm typing: `cat myfile.txt | jq fromjson.timestamp`\"",
      "\"The pipeline you're looking for is",
      "```\njq 'fromjson | .[\"@timestamp\"]'\n```",
      "\"You cannot use the `.foo` syntax to access fields with special characters such as \"@\".\""
    ],
    "utterance": "Extract the value of the '@timestamp' key after parsing each line as an object.",
    "expressions": [
      "fromjson | .[\"@timestamp\"]"
    ],
    "identifier": 68621762
  },
  {
    "context": [
      "But to make it flexible if I replace it with a variable then it throws error.",
      "for key in $keys\n    do\n      value=$(echo $data | jq --arg k \"$key\" '.$k.value')\n      final_value=\"${final_value}${key}: ${value}\"\n    done",
      "jq: error: try .[\"field\"] instead of .field for unusually named fields at <top-level>, line 1:\n    .$k.value",
      "to_entries[] | \"\\(.key): \\(.value.value)\"",
      "This will produce the following output:\nmy_db_instance_class: db.t3.medium\nmy_db_instance_test: db.t4.medium"
    ],
    "utterance": "Extract each top-level key and its nested value field, outputting them as key: value pairs.",
    "expressions": [
      "to_entries[] | \"\\(.key): \\(.value.value)\""
    ],
    "data": [
      {
        "input": {
          "my_db_instance_class": {
            "sensitive": false,
            "type": "string",
            "value": "db.t3.medium"
          },
          "my_db_instance_test": {
            "sensitive": false,
            "type": "string",
            "value": "db.t4.medium"
          }
        },
        "output": [
          "my_db_instance_class: db.t3.medium",
          "my_db_instance_test: db.t4.medium"
        ]
      }
    ],
    "identifier": 68652292
  },
  {
    "context": [
      "I have a sequence of objects, each with a single key. The values are themselves objects and the keys in the sequence may repeat. I would like to group said objects by their key and merge the values for repeated keys with something like jq's `add`.",
      "Here is my input:",
      "# jq '.' /tmp/json.json ",
      "{",
      "  \"cmsa-x-41100001\": {",
      "    \"fqdn\": \"cmsa-x-41100001.example.com\",",
      "    \"fqdn_ip4\": [",
      "      \"100.64.40.10\"",
      "    ]",
      "  }",
      "}",
      "{",
      "  \"cmsa-x-41100002\": {",
      "    \"fqdn\": \"cmsa-x-41100002.example.com\",",
      "    \"fqdn_ip4\": [",
      "      \"100.64.40.5\"",
      "    ]",
      "  }",
      "}",
      "{",
      "  \"cmsa-x-41100000\": {",
      "    \"fqdn\": \"cmsa-x-41100000.example.com\",",
      "    \"fqdn_ip4\": [",
      "      \"100.64.40.13\"",
      "    ]",
      "  }",
      "}",
      "{",
      "  \"cmsa-x-41100001\": {",
      "    \"k8s_salt:cluster_domain\": \"cluster4.csip\"",
      "  }",
      "}",
      "{",
      "  \"cmsa-x-41100002\": {",
      "    \"k8s_salt:cluster_domain\": \"cluster4.csip\"",
      "  }",
      "}",
      "{",
      "  \"cmsa-x-41100000\": {",
      "    \"k8s_salt:cluster_domain\": \"cluster4.csip\"",
      "  }",
      "}",
      "Here is my desired output:",
      "{",
      "  \"cmsa-x-41100000\": {",
      "    \"fqdn\": \"cmsa-x-41100000.example.com\",",
      "    \"fqdn_ip4\": [",
      "      \"100.64.40.13\"",
      "    ],",
      "    \"k8s_salt:cluster_domain\": \"cluster4.csip\"",
      "  },",
      "  \"cmsa-x-41100001\": {",
      "    \"fqdn\": \"cmsa-x-41100001.example.com\",",
      "    \"fqdn_ip4\": [",
      "      \"100.64.40.10\"",
      "    ],",
      "    \"k8s_salt:cluster_domain\": \"cluster4.csip\"",
      "  },",
      "  \"cmsa-x-41100002\": {",
      "    \"fqdn\": \"cmsa-x-41100002.example.com\",",
      "    \"fqdn_ip4\": [",
      "      \"100.64.40.5\"",
      "    ],",
      "    \"k8s_salt:cluster_domain\": \"cluster4.csip\"",
      "  }",
      "}",
      "Use `reduce` to fold all the objects together, and merge their contents with the `*` operator:",
      "",
      "reduce .[] as $item ({}; . * $item)"
    ],
    "utterance": "Combine a sequence of single-key objects, merging values of objects with the same key into one object containing all their key-value pairs.",
    "expressions": [
      "reduce .[] as $item ({}; . * $item)"
    ],
    "data": [
      {
        "input": [
          {
            "cmsa-x-41100001": {
              "fqdn": "cmsa-x-41100001.example.com",
              "fqdn_ip4": [
                "100.64.40.10"
              ]
            }
          },
          {
            "cmsa-x-41100002": {
              "fqdn": "cmsa-x-41100002.example.com",
              "fqdn_ip4": [
                "100.64.40.5"
              ]
            }
          },
          {
            "cmsa-x-41100000": {
              "fqdn": "cmsa-x-41100000.example.com",
              "fqdn_ip4": [
                "100.64.40.13"
              ]
            }
          },
          {
            "cmsa-x-41100001": {
              "k8s_salt:cluster_domain": "cluster4.csip"
            }
          },
          {
            "cmsa-x-41100002": {
              "k8s_salt:cluster_domain": "cluster4.csip"
            }
          },
          {
            "cmsa-x-41100000": {
              "k8s_salt:cluster_domain": "cluster4.csip"
            }
          }
        ],
        "output": {
          "cmsa-x-41100000": {
            "fqdn": "cmsa-x-41100000.example.com",
            "fqdn_ip4": [
              "100.64.40.13"
            ],
            "k8s_salt:cluster_domain": "cluster4.csip"
          },
          "cmsa-x-41100001": {
            "fqdn": "cmsa-x-41100001.example.com",
            "fqdn_ip4": [
              "100.64.40.10"
            ],
            "k8s_salt:cluster_domain": "cluster4.csip"
          },
          "cmsa-x-41100002": {
            "fqdn": "cmsa-x-41100002.example.com",
            "fqdn_ip4": [
              "100.64.40.5"
            ],
            "k8s_salt:cluster_domain": "cluster4.csip"
          }
        }
      }
    ],
    "identifier": 68411696
  },
  {
    "context": [
      "I want to convert the above string to local time.",
      "But fromdateiso8601 does not work on this format.",
      "EDIT: I tried the following but the part of `23:55:12` does not change when the timezone is changed. I'd expect that this should be changed as TZ is changed.",
      "jq's built-ins do not recognize timezone offsets.",
      "for the time being, the following solution to the stated problem assumes the use of `gojq` rather than stedolan/jq. It has two main steps: 1. Use the generic filter `datetime_to_seconds` to convert the timestamp with an offset to \"seconds since the epoch\"; 2. Use `strflocaltime`, which recognizes the environment variable TZ.",
      "def datetime_to_seconds: \n  if test(\"[-+]\")\n  then\n    sub(\"(?<s>[-+])(?<d1>[0-9]{2})(?<d2>[0-9]{2})$\"; \"\\(.s)\\(.d1):\\(.d2)\")\n    | capture(\"(?<datetime>^.*T[0-9:]+)(?<s>[-+])(?<hh>[0-9]+):?(?<mm>[0-9]*)\")\n    | (.datetime +\"Z\" | fromdateiso8601) as $seconds\n    | (if .s == \"+\" then -1 else 1 end) as $plusminus\n    | (.mm | if . == \"\" then 0 else . end) as $mm\n    | ([.hh,$mm] | map(tonumber) |.[0] *= 60 | add * 60 * $plusminus) as $offset\n    | ($seconds + $offset)\n  else . + (if test(\"Z\") then \"\" else \"Z\" end) | fromdateiso8601\n       end;\n\ndatetime_to_seconds\n| strflocaltime(\"%Y-%m-%dT%H:%M:%S %Z\")"
    ],
    "utterance": "Convert an ISO8601 date string with a numeric timezone offset (e.g., '+0000') to local time, respecting the TZ environment variable so the hour and day adjust correctly.",
    "expressions": [
      "def datetime_to_seconds: \n  if test(\"[-+]\")\n  then\n    sub(\"(?<s>[-+])(?<d1>[0-9]{2})(?<d2>[0-9]{2})$\"; \"\\(.s)\\(.d1):\\(.d2)\")\n    | capture(\"(?<datetime>^.*T[0-9:]+)(?<s>[-+])(?<hh>[0-9]+):?(?<mm>[0-9]*)\")\n    | (.datetime +\"Z\" | fromdateiso8601) as $seconds\n    | (if .s == \"+\" then -1 else 1 end) as $plusminus\n    | (.mm | if . == \"\" then 0 else . end) as $mm\n    | ([.hh,$mm] | map(tonumber) |.[0] *= 60 | add * 60 * $plusminus) as $offset\n    | ($seconds + $offset)\n  else . + (if test(\"Z\") then \"\" else \"Z\" end) | fromdateiso8601\n       end;\n\ndatetime_to_seconds\n| strflocaltime(\"%Y-%m-%dT%H:%M:%S %Z\")"
    ],
    "data": [
      {
        "input": {
          "x": "2021-08-04T22:55:12+0000"
        },
        "output": "2021-08-04T18:55:12 EDT"
      }
    ],
    "identifier": 68660343
  },
  {
    "context": [
      "But this seems pretty wasteful.  Is there a more advanced way to use JQ, and perhaps:\n - Filter for `.data.Item_*_Foo.value, .data.Item_*_Bar.value`\n - OR chain these rows in a single `jq` expression (reasonably readable, compact)",
      "And the goal is:\n\n```\nunknown, swing # data.Item_A_Foo.value, data.Item_A_Bar.value\nmedium, hit # data.Item_B_Foo.value, data.Item_B_Bar.value\nwhatever, etc. # data.Item_C_Foo.value, data.Item_C_Bar.value\n```",
      "you could proceed along the lines suggested by this jq filter:\n\n```\n  .data\n  | (keys_unsorted|map(select(test(\"^Item_[^_]*_Foo$\")))) as $foos\n  | ($foos | map(sub(\"_Foo$\"; \"_Bar\"))) as $bars\n  | [ .[$foos[]].value, .[$bars[]].value]\n  | @tsv\n```",
      "The idea is to determine dynamically which keys to select."
    ],
    "utterance": "Extract pairs of values for all items where both Foo and corresponding Bar keys exist, outputting each as a separate row of two fields.",
    "expressions": [
      ".data\n| (keys_unsorted|map(select(test(\"^Item_[^_]*_Foo$\")))) as $foos\n| ($foos | map(sub(\"_Foo$\"; \"_Bar\"))) as $bars\n| [ .[$foos[]].value, .[$bars[]].value]\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "data": {
            "Item_A_Foo": {
              "adj": "wild",
              "adv": "unruly",
              "value": "unknown"
            },
            "Item_A_Bar": {
              "adj": "rotund",
              "quality": "mighty",
              "value": "swing"
            },
            "Item_B_Foo": {
              "adj": "nice",
              "adv": "heroically",
              "value": "medium"
            },
            "Item_B_Bar": {
              "adj": "flat",
              "quality": "brave",
              "value": "hit"
            },
            "Item_C_Foo": {
              "adj": "odd",
              "value": "whatever"
            },
            "Item_C_Bar": {
              "value": "etc"
            },
            "Not_an_Item": {
              "value": "doesn't matter"
            }
          }
        },
        "output": "unknown\tswing\nmedium\thit\nwhatever\tetc"
      }
    ],
    "identifier": 68746172
  },
  {
    "context": [
      "jq -s . whitelist.json > whitelist_tmp.json",
      "The -s command-line option changes the JSON (essentially, it wraps the original JSON in an array), and is likely the source of your problem. Try omitting it."
    ],
    "utterance": "Read a file named whitelist.json in the local directory and output its content unchanged.",
    "expressions": [
      "jq . whitelist.json"
    ],
    "data": [
      {
        "input": [
          {
            "ruleId": 1,
            "alertName": "suspicious"
          }
        ],
        "output": [
          {
            "ruleId": 1,
            "alertName": "suspicious"
          }
        ]
      }
    ],
    "identifier": 68737973
  },
  {
    "context": [
      "how to make request to output coantainer name and how much memory and cpu usage.",
      "Now it's easy to write the queries to get the details you want, e.g.",
      "< kubernetes.txt jq fromjson.container.memory.request"
    ],
    "utterance": "Extract the container's name, memory requested in bytes, and CPU requested in cores from the data.",
    "expressions": [
      ".container | {name, memory_bytes: .memory.request.bytes, cpu_cores: .cpu.request.cores}",
      "{name: .container.name, memory_bytes: .container.memory.request.bytes, cpu_cores: .container.cpu.request.cores}"
    ],
    "data": [
      {
        "input": {
          "container": {
            "memory": {
              "request": {
                "bytes": 614251535.4
              }
            },
            "name": "testcontainer",
            "cpu": {
              "request": {
                "cores": 0.3
              }
            }
          }
        },
        "output": {
          "name": "testcontainer",
          "memory_bytes": 614251535.4,
          "cpu_cores": 0.3
        }
      }
    ],
    "identifier": 68521246
  },
  {
    "context": [
      "I want to specify the `ENV` in the command and use it to fetch the key `\"development\"` from the json.",
      "ENV=development cat dbconfig.json | jq '.database.$ENV'",
      "Using a shell variable may not be the best idea, but if that's what you want, this should give you the hint you're looking for:",
      "ENV=development jq -n 'env.ENV'"
    ],
    "utterance": "Retrieve the value associated with a key determined by an environment variable (e.g., ENV=development) under the 'database' object.",
    "expressions": [
      ".database[env.ENV]"
    ],
    "data": [
      {
        "input": {
          "database": {
            "development": {
              "name": "example",
              "user": "user",
              "password": "asdfasdf"
            }
          }
        },
        "output": {
          "name": "example",
          "user": "user",
          "password": "asdfasdf"
        }
      }
    ],
    "identifier": 68404857
  },
  {
    "context": [
      "I'm trying to convert objects that look like this:",
      "To CSV that looks like this:",
      "\"metric1\",\"queue1\",1626286800000,1",
      "\"metric1\",\"queue1\",1626286800000,2",
      "\"metric2\",\"queue1\",1626286800000,11",
      "\"metric2\",\"queue1\",1626286800000,22",
      "Command: jq -r '. | {id:.metricId, queue: .data[].dimensionMap.Queue, time: .data[].timestamps[0], value: .data[].values[0]} | [.id, .queue, .time, .value] | @csv'",
      "Output:",
      "I've looked over the documentation and several blog posts/videos but I haven't been able to find a solution so far.",
      "One way to tackle the problem is to use jq \"$-variables\":",
      ".metricId as $metricId\n| .data[]\n| .dimensionMap.Queue as $q\n| [.timestamps, .values] | transpose[]\n| [$metricId, $q, .[]]\n| @csv"
    ],
    "utterance": "Convert objects containing metricId, a data array with dimensionMap.Queue, timestamps, and values fields into CSV rows with fields: metricId, queue, timestamp, and value, such that each combination of metricId, queue, timestamp, and value becomes a row.",
    "expressions": [
      ".metricId as $metricId | .data[] | .dimensionMap.Queue as $q | [.timestamps, .values] | transpose[] | [$metricId, $q, .[]] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "metricId": "metric1",
            "data": [
              {
                "dimensions": [
                  "DEVICE-a1b2c3",
                  "queue1"
                ],
                "dimensionMap": {
                  "Queue": "queue1",
                  "enitity": "DEVICE-a1b2c3"
                },
                "timestamps": [
                  1626286800000
                ],
                "values": [
                  1
                ]
              },
              {
                "dimensions": [
                  "DEVICE-a1b2c3",
                  "queue2"
                ],
                "dimensionMap": {
                  "Queue": "queue2",
                  "entity": "DEVICE-a1b2c3"
                },
                "timestamps": [
                  1626286800000
                ],
                "values": [
                  2
                ]
              }
            ]
          },
          {
            "metricId": "metric2",
            "data": [
              {
                "dimensions": [
                  "DEVICE-a1b2c3",
                  "queue1"
                ],
                "dimensionMap": {
                  "Queue": "queue1",
                  "entity": "DEVICE-a1b2c3"
                },
                "timestamps": [
                  1626286800000
                ],
                "values": [
                  11
                ]
              },
              {
                "dimensions": [
                  "DEVICE-a1b2c3",
                  "queue2"
                ],
                "dimensionMap": {
                  "Queue": "queue2",
                  "entity": "DEVICE-a1b2c3"
                },
                "timestamps": [
                  1626286800000
                ],
                "values": [
                  22
                ]
              }
            ]
          }
        ],
        "output": [
          "\"metric1\",\"queue1\",1626286800000,1",
          "\"metric1\",\"queue2\",1626286800000,2",
          "\"metric2\",\"queue1\",1626286800000,11",
          "\"metric2\",\"queue2\",1626286800000,22"
        ]
      }
    ],
    "identifier": 68398296
  },
  {
    "context": [
      "I would like to extract **id value** only where **from = mail2@mail.com**",
      "jq '.filter[] | select(.criteria.from | test(\"mail2@mail.com\"; \"i\")) | .id'",
      "solution:\n\n    select(.criteria.from == \"mail2@mail.com\")"
    ],
    "utterance": "Extract the id value where the from field equals mail2@mail.com.",
    "expressions": [
      ".filter[] | select(.criteria.from == \"mail2@mail.com\") | .id"
    ],
    "data": [
      {
        "input": {
          "filter": [
            {
              "id": "id_1",
              "criteria": {
                "from": "mail1@mail.com"
              },
              "action": {
                "addLabelIds": [
                  "Label_1"
                ],
                "removeLabelIds": [
                  "IMPORTANT",
                  "SPAM"
                ]
              }
            },
            {
              "id": "id_2",
              "criteria": {
                "from": "mail2@mail.com"
              },
              "action": {
                "addLabelIds": [
                  "Label_2"
                ],
                "removeLabelIds": [
                  "IMPORTANT",
                  "SPAM"
                ]
              }
            }
          ]
        },
        "output": "id_2"
      }
    ],
    "identifier": 68734540
  },
  {
    "context": [
      "I\u2019m looking to concatenate multiple JSON files in a directory using jq.",
      "This seems work okay and I get the expected concatenated output until it encounters a JSON file that just has null written in it, and when I try to concatenate this with the others I get an error.",
      "Is there a way to exclude this null JSON file while concatenating through the directory?",
      "Just select array inputs.",
      "jq -n '[inputs | arrays[]]' *.json",
      "Use `select(. != null)` instead of `arrays` if you don't want to exclude all non-arrays but only `null`."
    ],
    "utterance": "Concatenate multiple files, ignoring any input files that contain only null.",
    "expressions": [
      "jq -n '[inputs | arrays[]]' *.json",
      "jq -n '[inputs | select(. != null)[]]' *.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "a": 12,
              "b": 22,
              "c": []
            }
          ],
          null
        ],
        "output": [
          {
            "a": 12,
            "b": 22,
            "c": []
          }
        ]
      }
    ],
    "identifier": 68404038
  },
  {
    "context": [
      "I want to delete entries that don't match this condition `startDateTime >= 3` and the expected output is",
      "The following produces the desired result, and is hopefully clear enough to help you formulate the precise solution to your problem:",
      "map_values(\n  map(\n    if has(\"previous\")\n    then select( .previous.startDateTime >= 3 and .current.startDateTime >= 3)\n    else .\n    end\n  )\n)",
      "Here's an illustrative program that produces the desired result using `walk`:",
      "walk (if type == \"array\"\n      then map(select(\n         if type == \"object\" and (.previous and .previous.startDateTime<3 or .current.startDateTime<3)\n         then empty\n\t else . end) )\n      else .\n      end)"
    ],
    "utterance": "Remove all objects from every array where either previous.startDateTime or current.startDateTime is less than 3.",
    "expressions": [
      "map_values(map(if has(\"previous\") then select(.previous.startDateTime >= 3 and .current.startDateTime >= 3) else . end))",
      "walk(if type == \"array\" then map(select(if type == \"object\" and (.previous and .previous.startDateTime<3 or .current.startDateTime<3) then empty else . end)) else . end)"
    ],
    "data": [
      {
        "input": {
          "a6acc79a-1776-1719-a400-e78e2cda4dd1": [
            {
              "previous": {
                "id": "cf091d81-d0cb-3b31-ae15-451c551cf2fb",
                "startDateTime": 1,
                "endDateTime": 2
              },
              "current": {
                "id": "2c05d2ad-ba36-3f61-9c12-5d2294aa4e3a",
                "startDateTime": 1,
                "endDateTime": 3
              }
            },
            {
              "previous": {
                "id": "f255daf7-b8fc-3b73-99bf-ec7d26b37748",
                "startDateTime": 3,
                "endDateTime": 3
              },
              "current": {
                "id": "9e0f131c-3043-3262-8d26-9c8b3bd0f516",
                "startDateTime": 3,
                "endDateTime": 3
              }
            }
          ]
        },
        "output": {
          "a6acc79a-1776-1719-a400-e78e2cda4dd1": [
            {
              "previous": {
                "id": "f255daf7-b8fc-3b73-99bf-ec7d26b37748",
                "startDateTime": 3,
                "endDateTime": 3
              },
              "current": {
                "id": "9e0f131c-3043-3262-8d26-9c8b3bd0f516",
                "startDateTime": 3,
                "endDateTime": 3
              }
            }
          ]
        }
      }
    ],
    "identifier": 68734190
  },
  {
    "context": [
      "I have this json object like this :\r\n\r\n     [ {\r\n        \"name\": \"ACCOUNT-V1\",\r\n        \"version\": \"1.3.0\"\r\n      },\r\n      {\r\n        \"name\": \"IDENTIFIER-V1\",\r\n        \"version\": \"1.1.0\"\r\n      },\r\n      {\r\n        \"name\": \"LOCATION-V1\",\r\n        \"version\": \"1.6.0\"\r\n      }\r\n    ]\r\n\r\n\r\n\r\nI'd like to parse and print like this\r\n```\r\nACCOUNT-V1 1.3.0\r\nIDENTIFIER-V1 1.1.0\r\nLOCATION-V1 1.6.0\r\n```",
      "jq --raw-output '.[] | \"\\(.name) \\(.version)\"'"
    ],
    "utterance": "Output each object's name and version properties, separated by a space, for all elements in the top-level array.",
    "expressions": [
      ".[] | \"\u0001(.name) \u0001(.version)\"",
      "-r '.[] | \"\\(.name) \\(.version)\"'",
      "--raw-output '.[] | \"\\(.name) \\(.version)\"'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "ACCOUNT-V1",
            "version": "1.3.0"
          },
          {
            "name": "IDENTIFIER-V1",
            "version": "1.1.0"
          },
          {
            "name": "LOCATION-V1",
            "version": "1.6.0"
          }
        ],
        "output": [
          "ACCOUNT-V1 1.3.0",
          "IDENTIFIER-V1 1.1.0",
          "LOCATION-V1 1.6.0"
        ]
      }
    ],
    "identifier": 68745002
  },
  {
    "context": [
      "How to output only strings with values",
      "You can leverage the `select` function for this:",
      "cat kubernetes.txt | jq 'fromjson.kubernetes.pod | select(.cpu.usage.nanocores != null) | .name, .cpu.usage.nanocores'"
    ],
    "utterance": "Output only pod names and nanocore usage where nanocore usage is not null.",
    "expressions": [
      "fromjson.kubernetes.pod | select(.cpu.usage.nanocores != null) | .name, .cpu.usage.nanocores"
    ],
    "identifier": 68610117
  },
  {
    "context": [
      "I want to make a list of all the names of files which are last modified more that 30 minutes ago.",
      "How can I use jq to filter for lastModified more than 30 minutes ago based on the timestamp in the properties so I only get the relevant file names?",
      "jq --join-output '(now - 1800) as $date | .[] | select((.properties.lastModified | .[:18] + \"Z\" | fromdate) < $date) | .name + \"\\u0000\"' input_file.json"
    ],
    "utterance": "Return the names of files where the lastModified property is more than 30 minutes before the current time.",
    "expressions": [
      "(now - 1800) as $date | .[] | select((.properties.lastModified | .[:18] + \"Z\" | fromdate) < $date) | .name"
    ],
    "data": [
      {
        "input": [
          {
            "name": "page/page1.html",
            "properties": {
              "lastModified": "2021-08-10T18:00:45+00:00"
            }
          },
          {
            "name": "page/page2.html",
            "properties": {
              "lastModified": "2021-08-10T19:24:23+00:00"
            }
          },
          {
            "name": "page/page3.html",
            "properties": {
              "lastModified": "2021-08-10T20:36:21+00:00"
            }
          }
        ]
      }
    ],
    "identifier": 68732327
  },
  {
    "context": [
      "I would like to add the orders[].packages[].status field to the orders[].contents[] with the matching packagenumber.",
      "How can the input transformed to the desired output format?  Using pyjq or jqplay.org?",
      "You're looking for something like this:",
      ".orders[] |= (\n  ( .packages | INDEX(.packagenumber) ) as $r\n  | .contents[] |= . + ($r[.packagenumber | tostring] | {status})\n  | del(.packages)\n)"
    ],
    "utterance": "For each order, add the status value from the corresponding package to each content item where packagenumber matches, and remove the packages field from the result.",
    "expressions": [
      ".orders[] |= ( ( .packages | INDEX(.packagenumber) ) as $r | .contents[] |= . + ($r[.packagenumber | tostring] | {status}) | del(.packages) )"
    ],
    "data": [
      {
        "input": {
          "orders": [
            {
              "code": 2389,
              "packages": [
                {
                  "packagenumber": 3929,
                  "status": 100
                },
                {
                  "packagenumber": 3930,
                  "status": 110
                }
              ],
              "contents": [
                {
                  "contentid": 398,
                  "description": "closet",
                  "packagenumber": 3929
                },
                {
                  "contentid": 399,
                  "description": "rice",
                  "packagenumber": 3929
                },
                {
                  "contentid": 400,
                  "description": "foo",
                  "packagenumber": 3930
                }
              ]
            },
            {
              "code": 2390,
              "packages": [
                {
                  "packagenumber": 3930,
                  "status": 110
                },
                {
                  "packagenumber": 3931,
                  "status": 150
                }
              ],
              "contents": [
                {
                  "contentid": 500,
                  "description": "bar",
                  "packagenumber": 3931
                },
                {
                  "contentid": 501,
                  "description": "snicker",
                  "packagenumber": 3931
                },
                {
                  "contentid": 502,
                  "description": "mars",
                  "packagenumber": 3930
                }
              ]
            }
          ]
        },
        "output": {
          "orders": [
            {
              "code": 2389,
              "contents": [
                {
                  "contentid": 398,
                  "description": "closet",
                  "packagenumber": 3929,
                  "status": 100
                },
                {
                  "contentid": 399,
                  "description": "rice",
                  "packagenumber": 3929,
                  "status": 100
                },
                {
                  "contentid": 400,
                  "description": "foo",
                  "packagenumber": 3930,
                  "status": 110
                }
              ]
            },
            {
              "code": 2390,
              "contents": [
                {
                  "contentid": 500,
                  "description": "bar",
                  "packagenumber": 3931,
                  "status": 150
                },
                {
                  "contentid": 501,
                  "description": "snicker",
                  "packagenumber": 3931,
                  "status": 150
                },
                {
                  "contentid": 502,
                  "description": "mars",
                  "packagenumber": 3930,
                  "status": 110
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 68407091
  },
  {
    "context": [
      "I would like to get output that looks something like:\n\n    ABCD12345 recipient1@example.com\n    ABCD12345 recipient2@example.com\n    ABCD12345 recipient3@example.com",
      "EDIT: more data\n\n    {\n      \"queue_id\": \"ABCD12345\",\n      \"sender\": \"sender@example.com\",\n      \"recipients\": [\n        {\n          \"address\": \"recipient1@example.com\",\n          \"something\": \"output1\"\n        },\n        {\n          \"address\": \"recipient2@example.com\",\n          \"something\": \"output2\"\n        },\n        {\n          \"address\": \"recipient3@example.com\",\n          \"something\": \"output3\"\n        },\n        {\n          \"address\": \"recipient3@example.com\",\n          \"something\": \"output4\"\n        }\n      ]\n    }\nDesired output:\n\n    ABCD12345 sender@example.com recipient1@example.com output1\n    ABCD12345 sender@example.com recipient2@example.com output2\n    ABCD12345 sender@example.com recipient3@example.com output3\n    ABCD12345 sender@example.com recipient4@example.com output4",
      "Looks like you're looking for something like this:\n```\n\"\\(.queue_id) \\(.recipients[].address)\"\n```"
    ],
    "utterance": "Output each recipient's address and 'something' value in a line along with the queue_id and sender address, for each recipient in the recipients array.",
    "expressions": [
      "\"\\(.queue_id) \\(.sender) \\(.recipients[].address) \\(.recipients[].something)\"",
      ".recipients[] | \"\u001b[\\(.queue_id) \\(.sender) \\(.address) \\(.something)\""
    ],
    "data": [
      {
        "input": {
          "queue_id": "ABCD12345",
          "sender": "sender@example.com",
          "recipients": [
            {
              "address": "recipient1@example.com",
              "something": "output1"
            },
            {
              "address": "recipient2@example.com",
              "something": "output2"
            },
            {
              "address": "recipient3@example.com",
              "something": "output3"
            },
            {
              "address": "recipient4@example.com",
              "something": "output4"
            }
          ]
        },
        "output": [
          "ABCD12345 sender@example.com recipient1@example.com output1",
          "ABCD12345 sender@example.com recipient2@example.com output2",
          "ABCD12345 sender@example.com recipient3@example.com output3",
          "ABCD12345 sender@example.com recipient4@example.com output4"
        ]
      }
    ],
    "identifier": 68619636
  },
  {
    "context": [
      "Let\u2019s say I have the following GeoJSON file:",
      "I\u2019d like to find a way of erasing only the arrays containing a specific `algorithm` key. Let\u2019s say I want to erase all arrays which `algorithm` is equal to `parameterA`, so I\u2019d get the following result:",
      "But I don\u2019t know how to use a condition in it that will erase only array blocks that have a specific property. How can I do it using `jq`?",
      "jq 'del( .features[] | select(.properties.algorithm == \"parameterA\") )'"
    ],
    "utterance": "Remove all elements from the features array where the properties.algorithm value is parameterA.",
    "expressions": [
      "del( .features[] | select(.properties.algorithm == \"parameterA\") )"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "algorithm": "parameterA"
              },
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": []
              }
            },
            {
              "type": "Feature",
              "properties": {
                "algorithm": "parameterB"
              },
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": []
              }
            },
            {
              "type": "Feature",
              "properties": {
                "algorithm": "parameterB"
              },
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": []
              }
            },
            {
              "type": "Feature",
              "properties": {
                "algorithm": "parameterA"
              },
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": []
              }
            }
          ],
          "properties": {
            "name": "myGeoJSON"
          }
        },
        "output": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "algorithm": "parameterB"
              },
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": []
              }
            },
            {
              "type": "Feature",
              "properties": {
                "algorithm": "parameterB"
              },
              "geometry": {
                "type": "MultiPolygon",
                "coordinates": []
              }
            }
          ],
          "properties": {
            "name": "myGeoJSON"
          }
        }
      }
    ],
    "identifier": 68568375
  },
  {
    "context": [
      "I need to be able to produce the following but without having to explicit array's indexes, so that I don't need to know input array's lenght",
      "echo '[{\"name\":\"John\", \"age\":30, \"car\":null},{\"name\":\"Marc\", \"age\":32, \"car\":null}]' | jq -r '{(.[0].name):.[0].age,(.[1].name):.[1].age}'",
      "Use `add` to merge the objects.",
      "jq '[ .[] | { (.name) : .age } ] | add'"
    ],
    "utterance": "Produce an object mapping each person's name to their age, for each element in an array of objects containing name and age fields.",
    "expressions": [
      "[ .[] | { (.name) : .age } ] | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "John",
            "age": 30,
            "car": null
          },
          {
            "name": "Marc",
            "age": 32,
            "car": null
          }
        ],
        "output": {
          "John": 30,
          "Marc": 32
        }
      }
    ],
    "identifier": 68521557
  },
  {
    "context": [
      "From .httpRequest I need to REMOVE:\n\n.httpRequest.headers\n.httpRequest.keepAlive\n.httpRequest.secure\n.httpRequest.body.rawBytes",
      "From .httpResponse I need to PICK:\n\n.httpResponse.statusCode\n.httpResponse.reasonPhrase\n.httpResponse.headers.Content-Type\n.httpResponse.headers.content-lenght",
      "From .httpResponse I need to REMOVE:\n\n.httpResponse.body.rawBytes",
      "Create a fresh object (using `{}`) when you want to pick, and use `del` when you want to remove.",
      "map({\n   \"httpRequest\": (\n      .httpRequest |\n      del(.headers, .keepAlive, .secure, .body.rawBytes)\n   ),\n   \"httpResponse\": (\n      .httpResponse |\n      del(.body.rawBytes) |\n      {\n         statusCode,\n         reasonPhrase,\n         \"headers\": {\n            \"Content-Type\":   .headers.\"Content-Type\",\n            \"Content-Length\": .headers.\"content-length\"\n         },\n         body\n      }\n   )\n})"
    ],
    "utterance": "For each array element, keep httpRequest with headers, keepAlive, secure, and body.rawBytes removed; include httpResponse with only statusCode, reasonPhrase, headers (Content-Type and content-length), and body, removing body.rawBytes.",
    "expressions": [
      "map({\n   \"httpRequest\": (\n      .httpRequest |\n      del(.headers, .keepAlive, .secure, .body.rawBytes)\n   ),\n   \"httpResponse\": (\n      .httpResponse |\n      del(.body.rawBytes) |\n      {\n         statusCode,\n         reasonPhrase,\n         \"headers\": {\n            \"Content-Type\":   .headers.\"Content-Type\",\n            \"Content-Length\": .headers.\"content-length\"\n         },\n         body\n      }\n   )\n})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "7250078e-5fbf-43d7-9c67-94b88fbf44d8",
            "priority": 0,
            "httpRequest": {
              "method": "POST",
              "path": "/catalog-data-rest/oid/search.xml",
              "headers": {
                "Host": [
                  "preproduccio.gcatalegs.isisscat.intranet.gencat.cat:8443"
                ],
                "Authorization": [
                  "Basic VVNVTVBJVFNUOkJ4c2w3MjU5"
                ],
                "User-Agent": [
                  "curl/7.58.0"
                ],
                "Accept": [
                  "*/*"
                ],
                "Content-Type": [
                  "text/html; charset=utf-8"
                ],
                "Content-Length": [
                  "94"
                ]
              },
              "keepAlive": true,
              "secure": true,
              "body": {
                "type": "STRING",
                "string": "<request><oid>2.16.724.4.402</oid><startIndex>1</startIndex><pageSize>100</pageSize></request>",
                "rawBytes": "PHJlcXVlc3Q+PG9pZD4yLjE2LjcyNC40LjQwMjwvb2lkPjxzdGFydEluZGV4PjE8L3N0YXJ0SW5kZXg+PHBhZ2VTaXplPjEwMDwvcGFnZVNpemU+PC9yZXF1ZXN0Pg==",
                "contentType": "text/html; charset=utf-8"
              }
            },
            "httpResponse": {
              "statusCode": 200,
              "reasonPhrase": "OK",
              "headers": {
                "Date": [
                  "Tue, 20 Jul 2021 11:07:40 GMT"
                ],
                "X-Powered-By": [
                  "Servlet/3.0"
                ],
                "X-Content-Type-Options": [
                  "nosniff"
                ],
                "X-XSS-Protection": [
                  "1; mode=block"
                ],
                "Cache-Control": [
                  "no-cache, no-store, max-age=0, must-revalidate"
                ],
                "Pragma": [
                  "no-cache"
                ],
                "Expires": [
                  "0"
                ],
                "Strict-Transport-Security": [
                  "max-age=31536000 ; includeSubDomains"
                ],
                "X-Frame-Options": [
                  "DENY"
                ],
                "Set-Cookie": [
                  "JSESSIONID=0000r6GgpYaB7bQiXRaS8zB8qw8:19pp48tgo; Path=/; HttpOnly"
                ],
                "Keep-Alive": [
                  "timeout=10, max=100"
                ],
                "Connection": [
                  "Keep-Alive"
                ],
                "Content-Type": [
                  "application/xml"
                ],
                "Content-Language": [
                  "en-US"
                ],
                "content-length": [
                  "29089"
                ]
              },
              "cookies": {
                "JSESSIONID": "0000r6GgpYaB7bQiXRaS8zB8qw8:19pp48tgo"
              },
              "body": {
                "type": "XML",
                "xml": "string-value",
                "rawBytes": "string-value",
                "contentType": "application/xml"
              }
            },
            "times": {
              "remainingTimes": 1
            },
            "timeToLive": {
              "unlimited": true
            }
          }
        ],
        "output": [
          {
            "httpRequest": {
              "method": "POST",
              "path": "/catalog-data-rest/oid/search.xml",
              "body": {
                "type": "STRING",
                "string": "<request><oid>2.16.724.4.402</oid><startIndex>1</startIndex><pageSize>100</pageSize></request>",
                "contentType": "text/html; charset=utf-8"
              }
            },
            "httpResponse": {
              "statusCode": 200,
              "reasonPhrase": "OK",
              "headers": {
                "Content-Type": [
                  "application/xml"
                ],
                "Content-Length": [
                  "29089"
                ]
              },
              "body": {
                "type": "XML",
                "xml": "string-value",
                "contentType": "application/xml"
              }
            }
          }
        ]
      }
    ],
    "identifier": 68455813
  },
  {
    "context": [
      "I have thin JSON input:",
      "[{\"x\": [\"2020-02-24T00:00:00\",\"2020-02-25T00:00:00\",\"2020-02-26T00:00:00\"], \"y\": [3,2,6]}]",
      "And I would like to obtain:",
      "[{\"a\": \"2020-02-24T00:00:00\", \"b\": 3}, {\"a\": \"2020-02-25T00:00:00\", \"b\": 2}, {\"a\": \"2020-02-26T00:00:00\", \"b\": 6}]",
      "If I apply `.[]|{a:.x[],b:.y[]}` I obtain the cartesian product (9 items).",
      "How to change the structure of this JSON avoiding cartesian product?",
      "Introducing a single \"$-variable\" keeps things brief and straightforward:",
      "map(range(0; .x|length) as $i | {a: .x[$i], b: .y[$i]})",
      "but a $-variable free solution only requires one more line:",
      "map([.x, .y] | transpose[] | {a: .[0], b: .[1]})"
    ],
    "utterance": "Convert each pair of elements with the same index from the 'x' and 'y' arrays inside an object to a new object with keys 'a' and 'b', respectively.",
    "expressions": [
      "map(range(0; .x|length) as $i | {a: .x[$i], b: .y[$i]})",
      "map([.x, .y] | transpose[] | {a: .[0], b: .[1]})"
    ],
    "data": [
      {
        "input": [
          {
            "x": [
              "2020-02-24T00:00:00",
              "2020-02-25T00:00:00",
              "2020-02-26T00:00:00"
            ],
            "y": [
              3,
              2,
              6
            ]
          }
        ],
        "output": [
          {
            "a": "2020-02-24T00:00:00",
            "b": 3
          },
          {
            "a": "2020-02-25T00:00:00",
            "b": 2
          },
          {
            "a": "2020-02-26T00:00:00",
            "b": 6
          }
        ]
      }
    ],
    "identifier": 68447475
  },
  {
    "context": [
      "I need to loop through the JSON below in bash",
      "The loop needs to read all the fields, so I can pass them to variables and check their values."
    ],
    "utterance": "Iterate over each object in the data array and access all of its key-value pairs.",
    "expressions": [
      ".data[]"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "seen": true,
              "id": "2079a988-f856-4adb-bd3d-49ddf775ba16-1629277814281",
              "tinyId": "17290",
              "status": "closed",
              "acknowledged": false,
              "isSeen": true
            },
            {
              "seen": false,
              "id": "0a6e6024-9e80-42d2-ae4f-4b4af4a25fd2-1629277649193",
              "tinyId": "17289",
              "status": "open",
              "acknowledged": false,
              "isSeen": false
            },
            {
              "seen": false,
              "id": "108370f4-f54e-443d-9b7c-eec9d641c69a-1629277622211",
              "tinyId": "17288",
              "status": "open",
              "acknowledged": false,
              "isSeen": false
            }
          ]
        },
        "output": {
          "seen": true,
          "id": "2079a988-f856-4adb-bd3d-49ddf775ba16-1629277814281",
          "tinyId": "17290",
          "status": "closed",
          "acknowledged": false,
          "isSeen": true
        }
      }
    ],
    "identifier": 68829823
  },
  {
    "context": [
      "I am trying to find a clean way to assign 2 json string values to 2 variables within a while loop.",
      "echo \"$foo\" | jq \".[].name,.[].nested_name.name\" | while read -r foo bar; do",
      "In iteration 1, I want:",
      "foo = \"name string (more info)\" \nbar = \"my name\"",
      "You can generate a similar \"CSV output\" with the following `jq` command:",
      "jq --raw-output '.[] | \"\\(.name),\\(.nested_name.name)\"'",
      "So I think it'd look something like this:",
      "echo \"$foo\" | jq --raw-output '.[] | \"\\(.name),\\(.nested_name.name)\"' | while IFS=, read -r foo bar; do",
      "jq -r '.[] | \"foo=\\\"\" + .name + \"\\\"\",\"bar=\\\"\" + .nested_name.name + \"\\\"\"' foobar.json"
    ],
    "utterance": "Extract for each object both the top-level 'name' and the nested 'nested_name.name' as pairs for assignment in a loop.",
    "expressions": [
      ".[] | \"\u001b[31m\\(.name),\\(.nested_name.name)\u001b[0m\"",
      "--raw-output '.[] | \"\\(.name),\\(.nested_name.name)\"'",
      "-r '.[] | \"foo=\\\"\" + .name + \"\\\"\",\"bar=\\\"\" + .nested_name.name + \"\\\"\"'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "name string (more info)",
            "nested_name": {
              "name": "my name",
              "conclusion": "failure",
              "number": 11
            }
          },
          {
            "name": "name string (more info)",
            "nested_name": {
              "name": "my other name",
              "conclusion": "failure",
              "number": 13
            }
          }
        ],
        "output": [
          "name string (more info),my name",
          "name string (more info),my other name"
        ]
      }
    ],
    "identifier": 68552491
  },
  {
    "context": [
      "I would like to add 2 extra newlines after each json.",
      "Is that possible with `jq` somehow?",
      "So long as none of the incoming JSON texts is a string, you could write:",
      "jq -r '., \"\", \"\"' file.json"
    ],
    "utterance": "Output each object followed by two extra empty lines between objects.",
    "expressions": [
      "jq -r '., \"\", \"\"' file.json"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "bar",
            "say": "what"
          },
          {
            "foo2": "bar2",
            "say2": "what2"
          }
        ],
        "output": "{\n  \"foo\": \"bar\",\n  \"say\": \"what\"\n}\n\n\n{\n  \"foo2\": \"bar2\",\n  \"say2\": \"what2\"\n}\n"
      }
    ],
    "identifier": 68545850
  },
  {
    "context": [
      "I need to convert JSON objects to a very specific format called `zmp`, which looks like this:\n\n```\nselectMailbox     user.one@domain.com\nmodifyFolderFlags /Inbox       \"\"\nmodifyFolderFlags /Inbox/teste \"\"\n\nselectMailbox     user.two@domain.com.br\nmodifyFolderFlags /Inbox \"\"\nmodifyFolderFlags /Sent  \"\"\n```",
      "it's missing the block separator (blank line).",
      "jq  -r '{\"email\":input_filename} + . | \n        \"selectMailbox \\(.email)\",\n          (..|objects | select(.flags == \"i\" or .flags == \"#i\") |\n                          \"modifyFolderFlags \\(.path) \\\"\\\" \" \n          ),\"\" ' *"
    ],
    "utterance": "Output each mailbox's header once, followed by all its matching folder modification lines, with a blank line separating each block.",
    "expressions": [
      "jq  -r '{\"email\":input_filename} + . | \"selectMailbox \\(.email)\", (..|objects | select(.flags == \"i\" or .flags == \"#i\") | \"modifyFolderFlags \\(.path) \\\"\\\" \"), \"\" ' *"
    ],
    "data": [
      {
        "input": {
          "user.one@domain.com": {
            "path": "/",
            "subFolders": [
              {
                "flags": "#",
                "path": "/Drafts",
                "subFolders": []
              },
              {
                "flags": "#i",
                "path": "/Inbox",
                "subFolders": [
                  {
                    "flags": "i",
                    "path": "/Inbox/teste",
                    "subFolders": []
                  }
                ],
                "unreadCount": 0
              },
              {
                "path": "/Sent",
                "subFolders": []
              }
            ],
            "unreadCount": 0
          },
          "user.two@domain.com.br": {
            "path": "/",
            "subFolders": [
              {
                "flags": "#i",
                "path": "/Inbox",
                "subFolders": []
              },
              {
                "flags": "#i",
                "path": "/Sent",
                "subFolders": []
              },
              {
                "flags": "#",
                "path": "/Trash",
                "subFolders": []
              }
            ],
            "unreadCount": 0
          }
        },
        "output": "selectMailbox     user.one@domain.com\nmodifyFolderFlags /Inbox       \"\"\nmodifyFolderFlags /Inbox/teste \"\"\n\nselectMailbox     user.two@domain.com.br\nmodifyFolderFlags /Inbox \"\"\nmodifyFolderFlags /Sent  \"\"\n"
      }
    ],
    "identifier": 68402950
  },
  {
    "context": [
      "how to get \"created\" value if \"toString\" value is Code Review from below json code.",
      "| select(has(\"created\") and any(.items[]; .toString == \"Code Review\"))\n| .created"
    ],
    "utterance": "Extract the 'created' field from any object whose 'items' array contains an object where 'toString' equals 'Code Review'.",
    "expressions": [
      ".. | objects | select(has(\"created\") and any(.items[]; .toString == \"Code Review\")) | .created"
    ],
    "data": [
      {
        "input": {
          "expand": "renderedFields,names,schema,operations,editmeta,changelog,versionedRepresentations",
          "id": "562940",
          "fields": {},
          "changelog": {
            "histories": [
              {
                "id": "3818773",
                "created": "2021-06-28T16:34:02.000+0530",
                "items": [
                  {
                    "field": "status",
                    "toString": "Coding"
                  }
                ]
              },
              {
                "id": "3818870",
                "created": "2021-06-28T17:23:44.000+0530",
                "items": [
                  {
                    "field": "status",
                    "toString": "Code Review"
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "2021-06-28T17:23:44.000+0530"
        ]
      }
    ],
    "identifier": 68395321
  },
  {
    "context": [
      "The condition I have been trying to match on is when `href` from index-of-pages.json includes the string in `url` in key.json.",
      "Objects in **index-of-files.json** that do not match anything in the key would still be included in the desired output.",
      "sort_by(.url | -length) as $c | inputs | map(. + (.href as $s | first($c[] | select(.url as $ss | $s | index($ss))) // {}))"
    ],
    "utterance": "Augment each object with fields from another array element if its href contains a url as a substring, otherwise leave the object unchanged.",
    "expressions": [
      "sort_by(.url | -length) as $c | inputs | map(. + (.href as $s | first($c[] | select(.url as $ss | $s | index($ss))) // {}))"
    ],
    "data": [
      {
        "input": {
          "key.json": [
            {
              "url": "/guide1/",
              "guide": "Guide 1",
              "tag": "how-to"
            },
            {
              "url": "/guide2/",
              "guide": "Guide 2",
              "tag": "how-to"
            },
            {
              "url": "/apiguide1/subguide1/",
              "guide": "API Guide 1",
              "subguide": "Subguide 1",
              "tag": "api"
            },
            {
              "url": "/guide1/about",
              "guide": "Guide 1",
              "tag": "about"
            }
          ],
          "index-of-pages.json": [
            {
              "href": "articles/guide1/page1.html",
              "name": "Page 1",
              "views": "204"
            },
            {
              "href": "articles/guide2/page2.html",
              "name": "Page 2",
              "views": "180"
            },
            {
              "href": "articles/guide2/page3.html",
              "name": "Page 3",
              "views": "121"
            },
            {
              "href": "apis/apiguide1/subguide1/page4.html",
              "name": "Page 4",
              "views": "101"
            },
            {
              "href": "apis/apiguide2/subguide2/page5.html",
              "name": "Page 5",
              "views": "103"
            },
            {
              "href": "articles/guide1/about.html",
              "name": "Page 6",
              "views": "103"
            },
            {
              "href": "index.html",
              "name": "Page 7",
              "views": "400"
            }
          ]
        },
        "output": [
          {
            "href": "articles/guide1/page1.html",
            "name": "Page 1",
            "views": "204",
            "url": "/guide1/",
            "guide": "Guide 1",
            "tag": "how-to"
          },
          {
            "href": "articles/guide2/page2.html",
            "name": "Page 2",
            "views": "180",
            "url": "/guide2/",
            "guide": "Guide 2",
            "tag": "how-to"
          },
          {
            "href": "articles/guide2/page3.html",
            "name": "Page 3",
            "views": "121"
          },
          {
            "href": "apis/apiguide1/subguide1/page4.html",
            "name": "Page 4",
            "views": "101",
            "url": "/apiguide1/subguide1/",
            "guide": "API Guide 1",
            "subguide": "Subguide 1",
            "tag": "api"
          },
          {
            "href": "apis/apiguide2/subguide2/page5.html",
            "name": "Page 5",
            "views": "103"
          },
          {
            "href": "articles/guide1/about.html",
            "name": "Page 6",
            "views": "103",
            "url": "/guide1/about",
            "guide": "Guide 1",
            "tag": "about"
          },
          {
            "href": "index.html",
            "name": "Page 7",
            "views": "400"
          }
        ]
      }
    ],
    "identifier": 68553586
  },
  {
    "context": [
      "How to delete many and keep few objects in big JSON file?",
      "What jq command deletes everything but:\n    \n    {\n      \"service\" : {\n        \"category\" : \"managed-object\",\n        \"resource\" : \"object\",\n        \"action\" : \"locate\",\n        \"options\" : {\n          \"attributes\" : {\n            \"name\" : {\n              \"value\" : \"#VALUE\"\n            },\n          },\n          \"customAttributes\" : [ {\n            \"name\" : \"#VALUE\",\n            \"value\" : \"#VALUE\",\n            \"type\" : \"#TEXT|NUMBER\"\n          } ]\n        }\n      }\n    }",
      "For removing all fields but `name` from `service.options.attributes` it's easiest to specify just what you're keeping:",
      "You can combine these together:",
      "And you can simplify the repetition a fair bit:",
      "jq '.service.options|=(del(.max,.objectGroupMember)|.attributes|={name})'"
    ],
    "utterance": "Remove all keys except 'name' from 'service.options.attributes' and keep only 'attributes' and 'customAttributes' in 'service.options', retaining the overall object structure.",
    "expressions": [
      ".service.options|={attributes,customAttributes}",
      ".service.options.attributes|={name}",
      ".service.options|=(del(.max,.objectGroupMember)|.attributes|={name})"
    ],
    "data": [
      {
        "input": {
          "service": {
            "category": "managed-object",
            "resource": "object",
            "action": "locate",
            "options": {
              "max": "#VALUE",
              "objectGroupMember": "#FRESH|DEFAULT",
              "attributes": {
                "name": {
                  "value": "#VALUE"
                },
                "state": "#PREACTIVE|ACTIVE|DEACTIVATED|COMPROMISED|DESTROYED|DESTROYED_COMPROMISED",
                "objectType": "#VALUE",
                "fresh": "#YES|NO"
              },
              "customAttributes": [
                {
                  "name": "#VALUE",
                  "value": "#VALUE",
                  "type": "#TEXT|NUMBER"
                }
              ]
            }
          }
        },
        "output": {
          "service": {
            "category": "managed-object",
            "resource": "object",
            "action": "locate",
            "options": {
              "attributes": {
                "name": {
                  "value": "#VALUE"
                }
              },
              "customAttributes": [
                {
                  "name": "#VALUE",
                  "value": "#VALUE",
                  "type": "#TEXT|NUMBER"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 68412090
  },
  {
    "context": [
      "I would like to get the return object of `\"x\" == 2`.",
      "Is there a way to have jq return me like this instead?",
      "{ \"B\": { \"x\": 2 } }",
      "with_entries(select(.value.x == 2))",
      "You can also use map_values :",
      "map_values(select(.x == 2))"
    ],
    "utterance": "Return an object containing only those entries whose nested 'x' value equals 2.",
    "expressions": [
      "with_entries(select(.value.x == 2))",
      "map_values(select(.x == 2))"
    ],
    "data": [
      {
        "input": {
          "A": {
            "x": 1
          },
          "B": {
            "x": 2
          },
          "C": {
            "x": 3
          }
        },
        "output": {
          "B": {
            "x": 2
          }
        }
      }
    ],
    "identifier": 68889789
  },
  {
    "context": [
      "What I want is:\r\n\r\n```json\r\n{\r\n  \"dog\": [\r\n    {\r\n      \"name\": \"sam\",\r\n      \"age\": \"2\"\r\n    }\r\n  ]\r\n}\r\n```",
      "Instead of an integer index, use a slice. (Also, the array is 0-indexed, not 1-indexed.)\r\n\r\n    $ jq --argjson i 0 '{dog: .dog[$i:$i+1]}' < tmp.json\r\n    {\r\n      \"dog\": [\r\n        {\r\n          \"name\": \"sam\",\r\n          \"age\": \"2\"\r\n        }\r\n      ]\r\n    }",
      "Try\r\n\r\n```\r\njq --argjson i 2 '.dog|=[.[$i-1]]'\r\n```\r\n\r\nThe `.dog|=[.[$index]]` part modifies just the array `dog` and replaces it with an array of just the item at position `$index`. This has the benefit of preserving anything else that might be in the top-level object. We use `$i-1` since you indicate you want to provide 1-based indices as input. "
    ],
    "utterance": "Extract a specific object from the 'dog' array by index, and wrap it in a new object with the same key, resulting in an array containing only that object.",
    "expressions": [
      "{dog: .dog[$i:$i+1]}",
      ".dog|=[.[$i-1]]"
    ],
    "data": [
      {
        "input": {
          "dog": [
            {
              "name": "sam",
              "age": "2"
            },
            {
              "name": "billy",
              "age": "5"
            }
          ]
        },
        "output": {
          "dog": [
            {
              "name": "sam",
              "age": "2"
            }
          ]
        }
      }
    ],
    "identifier": 68909597
  }
]