[
  {
    "context": [
      "jq 'query.....' $srcJson > $destinationJson",
      "the file output redirection operation (`>`) in Windows PowerShell defaults to UTF16LE (or in Windows-speak \"Unicode\") encoding.",
      "try piping the output from `jq` to a cmdlet that allows you to explicitly set the output encoding, like `Out-File`:",
      "jq 'query...' $srcJson |Out-File $destinationJson -Encoding UTF8"
    ],
    "utterance": "Save the output so the resulting file matches the original's encoding and binary content without changing file size.",
    "expressions": [
      "jq 'query...' $srcJson | Out-File $destinationJson -Encoding UTF8"
    ],
    "identifier": 67506478
  },
  {
    "context": [
      "How can I read `id`, `val2` and `date` from list using `jq`?",
      "Use `fromjson` to unescape a string.",
      "jq '.response.array[]\n    | {Result:[{x_date, array: .list\n                | join(\",\")\n                | fromjson}]}'"
    ],
    "utterance": "Extract id, val2, and date fields from the inner array stored as an escaped JSON string within .response.array[].list.",
    "expressions": [
      ".response.array[] | {Result:[{x_date, array: (.list | join(\",\") | fromjson)}]}"
    ],
    "data": [
      {
        "input": {
          "response": {
            "resNum": 222222,
            "start": 0,
            "array": [
              {
                "tr_id": "xx33fg",
                "user_id": "6678",
                "x_date": "2021-04-27",
                "list": [
                  "[{\"id\":\"123\",\"val2\":\"RX\",\"date\":\"2020-11-13\"}",
                  "{\"id\":\"456\",\"val2\":\"DB\",\"date\":\"2020-09-20\"}]"
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 67491312
  },
  {
    "context": [
      "I would like to use `jq` to produce a list of IPs of the `nodes` hosts by looking up the names in `._meta.hostvars`. In the example, the output should be:\n```\n10.0.0.1\n10.0.0.2\n```",
      "Note that `10.0.0.3` should not be included because `name_3` is not in the `.nodes.hosts` list. So just doing `jq -r '._meta.hostvars[].ansible_host'` doesn't work.",
      "I've tried `jq '.nodes.hosts[] | ._meta.hostvars[.].ansible_host' but that fails because `._meta` doesn't scan from the root after the pipe.",
      "You can store the root in a variable before changing the context:\n\n```\njq -r '. as $root | .nodes.hosts[] | $root._meta.hostvars[.].ansible_host'\n```",
      "But a better solution is to just inline the \"hosts\" query:\n```\njq -r '._meta.hostvars[.nodes.hosts[]].ansible_host'\n```"
    ],
    "utterance": "Output the ansible_host values corresponding to each host listed in nodes.hosts, excluding any hostvars entries not present in nodes.hosts.",
    "expressions": [
      ". as $root | .nodes.hosts[] | $root._meta.hostvars[.].ansible_host",
      "._meta.hostvars[.nodes.hosts[]].ansible_host"
    ],
    "data": [
      {
        "input": {
          "_meta": {
            "hostvars": {
              "name_1": {
                "ansible_host": "10.0.0.1"
              },
              "name_2": {
                "ansible_host": "10.0.0.2"
              },
              "name_3": {
                "ansible_host": "10.0.0.3"
              }
            }
          },
          "nodes": {
            "hosts": [
              "name_1",
              "name_2"
            ]
          }
        },
        "output": [
          "10.0.0.1",
          "10.0.0.2"
        ]
      }
    ],
    "identifier": 67465825
  },
  {
    "context": [
      "Assuming the .csv file is valid CSV and that `percentage.txt` and the .csv file are properly matched w.r.t. headers, you could use `jq` ...",
      "paste -d, dels_20210508.csv <(jq -Rr '[.]|@csv' percent.txt)"
    ],
    "utterance": "Append the first column from percent.txt as the third column to each row of an existing two-column CSV file, aligning rows by order.",
    "expressions": [
      "[.]|@csv"
    ],
    "data": [
      {
        "input": [
          "dels_20210508.csv contents:",
          "col1-data1,col2-data1",
          "col1-data2,col2-data2",
          "col1-data3,col2-data3",
          "",
          "percent.txt contents:",
          "col3-data1",
          "col3-data2",
          "col3-data3"
        ],
        "output": [
          "col1-data1,col2-data1,col3-data1",
          "col1-data2,col2-data2,col3-data2",
          "col1-data3,col2-data3,col3-data3"
        ]
      }
    ],
    "identifier": 67475323
  },
  {
    "context": [
      "I have a bash associative array containing dynamic data like:\n\n    declare -A assoc_array=([cluster_name]=\"cpod1\" [site_name]=\"ppod1\" [alarm_name]=\"alarm1\")\nI have to create the JSON data accordingly.",
      "for key in \"${!assoc_array[@]}\"; do\n  printf '%s\\x1e%s\\n' \"$key\" \"${assoc_array[$key]}\"\ndone | jq -Rn '[\n  inputs |\n  split(\"\\u001e\") | .[0] as $key | .[1] as $value |\n  {\"name\": $key, \"value\": $value, \"regex\": false}\n]'",
      "alarmjsonarray=$(echo \"${alarmjsonarray:-[]}\" |\n                   jq --arg name \"$i\" \\\n                      --arg value \"${assoc_array[$i]}\" \\\n                      --arg isRegex \"False\" \\\n                      '. + [{(\"name\"):$name,(\"value\"):$value,(\"isRegex\"):$isRegex}]')"
    ],
    "utterance": "Produce an array where each element is an object with keys 'name', 'value', and 'regex', using all key-value pairs from an associative array, setting 'regex' to false for every object.",
    "expressions": [
      "[\n  inputs |\n  split(\"\\u001e\") | .[0] as $key | .[1] as $value |\n  {\"name\": $key, \"value\": $value, \"regex\": false}\n]",
      ". + [{(\"name\"):$name,(\"value\"):$value,(\"isRegex\"):$isRegex}]"
    ],
    "data": [
      {
        "input": [
          "cluster_name\u001ecpod1",
          "site_name\u001eppod1",
          "alarm_name\u001ealarm1"
        ],
        "output": [
          {
            "name": "cluster_name",
            "value": "cpod1",
            "regex": false
          },
          {
            "name": "site_name",
            "value": "ppod1",
            "regex": false
          },
          {
            "name": "alarm_name",
            "value": "alarm1",
            "regex": false
          }
        ]
      }
    ],
    "identifier": 67490269
  },
  {
    "context": [
      "I'm trying to extract value of a branch from the below json/test.json file using jq",
      "Below is jq command I'm using ```jq -r '.pipeline.stages.actions.configuration.Branch' test.json```which returns **jq: error (at test.json:76): Cannot index array with string \"actions\".** I'n I missing something here",
      "Your json key address should be `.pipeline.stages[0].actions[0].configuration.Branch` so that would make your command look like this:",
      "jq -r '.pipeline.stages[0].actions[0].configuration.Branch' test.json",
      "That's because both `stages` and `actions` are arrays with both only a single item in them.",
      "and finally to configuration and Branch\n\n```\n$ jq -r '.pipeline.stages[0].actions[0].configuration.Branch' test.json\nexperiment\n```"
    ],
    "utterance": "Extract the value of the Branch field from the first action in the first stage of the pipeline.",
    "expressions": [
      ".pipeline.stages[0].actions[0].configuration.Branch"
    ],
    "data": [
      {
        "input": {
          "pipeline": {
            "name": "test",
            "roleArn": "arn:aws:iam::1234:role/service-role/AWSCodePipelineServiceRole-us-west-2-test",
            "artifactStore": {
              "type": "S3"
            },
            "stages": [
              {
                "name": "Source",
                "actions": [
                  {
                    "name": "Source",
                    "actionTypeId": {
                      "category": "Source",
                      "version": "1"
                    },
                    "runOrder": 1,
                    "configuration": {
                      "Branch": "experiment"
                    }
                  }
                ]
              }
            ],
            "version": 1
          }
        },
        "output": "experiment"
      }
    ],
    "identifier": 67478211
  },
  {
    "context": [
      "I have data like this:",
      "{ \"s1\": [{\"answer\": 1, \"count\": 90}, {\"answer\": 0, \"count\": 10}] }",
      "{ \"s2\": [{\"answer\": 1, \"count\": 85}, {\"answer\": 0, \"count\": 15}] }",
      "I'm trying to use `jq` to extract the count of the `1` answer for each key, with this desired result:",
      "{ \"s1\": 90, \"s2\": 85 }",
      "Update -- this result would be equally useful:",
      "{ \"s1\": 90 }",
      "{ \"s2\": 85 }",
      "Looks like this solution works:",
      "jq -c 'with_entries(.value = (.value[] | select(.answer==1) | .count))' foo.json",
      "{ \"s1\":90 }",
      "{ \"s2\":85 }",
      "This gives the originally requested result:",
      "jq -s '[ .[] | .[] = (.[][]) | select(.[].answer == 1) | .[] = .[].count ] | add' foo.json"
    ],
    "utterance": "Extract the count value where answer equals 1 for each top-level key.",
    "expressions": [
      "with_entries(.value = (.value[] | select(.answer==1) | .count))",
      "-s '[ .[] | .[] = (.[][]) | select(.[].answer == 1) | .[] = .[].count ] | add'"
    ],
    "data": [
      {
        "input": {
          "s1": [
            {
              "answer": 1,
              "count": 90
            },
            {
              "answer": 0,
              "count": 10
            }
          ]
        },
        "output": {
          "s1": 90
        }
      },
      {
        "input": {
          "s2": [
            {
              "answer": 1,
              "count": 85
            },
            {
              "answer": 0,
              "count": 15
            }
          ]
        },
        "output": {
          "s2": 85
        }
      }
    ],
    "identifier": 67495457
  },
  {
    "context": [
      "I am trying to get a value in second line of msg_values after colon:",
      "What I want is just a:\n`+somestring12345=`",
      ".txt|.msg_values[1]| index(\":\") as $ix | .[1+$ix:]"
    ],
    "utterance": "Extract everything after the colon (:) from the second element of msg_values inside the txt object.",
    "expressions": [
      ".txt.msg_values[1] | (index(\":\") as $ix | .[1+$ix:])",
      ".txt.msg_values[1] | (index(\":\") // empty) as $ix | .[1+$ix:]"
    ],
    "data": [
      {
        "input": {
          "txt": {
            "new": false,
            "msg": "Generating 'value'\nGenerated new value: +somestring12345=\n",
            "msg_values": [
              "Generating 'value'",
              "Generated new value: +somestring12345=",
              ""
            ]
          }
        },
        "output": "+somestring12345="
      }
    ],
    "identifier": 67535834
  },
  {
    "context": [
      "How would you add \"text_id\" field to every object inside .[].remote[] array so it would become ...",
      "jq 'map( .text_id as $t\n             | .remote |= map( . + {text_id : $t} )\n             | del(.text_id)\n        )'",
      ".[] |= (.remote[] += {text_id} | del(.text_id))"
    ],
    "utterance": "For each object, add its text_id value as a text_id field to every object in its remote array, and remove text_id from the parent object.",
    "expressions": [
      "map( .text_id as $t | .remote |= map( . + {text_id : $t} ) | del(.text_id) )",
      ".[] |= (.remote[] += {text_id} | del(.text_id))"
    ],
    "data": [
      {
        "input": [
          {
            "remote": [
              {
                "id": 1
              },
              {
                "id": 2
              },
              {
                "id": 3
              }
            ],
            "text_id": 1
          },
          {
            "remote": [
              {
                "id": 4
              },
              {
                "id": 5
              },
              {
                "id": 6
              }
            ],
            "text_id": 2
          }
        ],
        "output": [
          {
            "remote": [
              {
                "id": 1,
                "text_id": 1
              },
              {
                "id": 2,
                "text_id": 1
              },
              {
                "id": 3,
                "text_id": 1
              }
            ]
          },
          {
            "remote": [
              {
                "id": 4,
                "text_id": 2
              },
              {
                "id": 5,
                "text_id": 2
              },
              {
                "id": 6,
                "text_id": 2
              }
            ]
          }
        ]
      }
    ],
    "identifier": 67515543
  },
  {
    "context": [
      "It is inserting the full contents of the file including opening and closing [] into the existing array, I was aiming for something more like this:",
      "jq --argjson envVars \"$(&lt;input.json)\" '.containerDefinitions[0].environment += [$envVars]' task.json > new-task.json",
      "jq '.containerDefinitions[0].environment += $inputs' task.json --slurpfile inputs input.json",
      "Using --slurpfile has the effect of wrapping the contents of the file in an array, so your second try would have to involve `$inputs[0]`.",
      "In the end peak suggested the correct way using $inputs[0] with --slurpfile did the trick."
    ],
    "utterance": "Append all objects from an external array file to the environment array in the first container definition",
    "expressions": [
      "jq '.containerDefinitions[0].environment += $inputs[0]' task.json --slurpfile inputs input.json"
    ],
    "data": [
      {
        "input": {
          "task.json": {
            "family": "test-container",
            "networkMode": "awsvpc",
            "containerDefinitions": [
              {
                "cpu": 0,
                "image": "test-image",
                "name": "test-container",
                "environment": [
                  {
                    "name": "CRON",
                    "value": "no"
                  },
                  {
                    "name": "LOG_CHANNEL",
                    "value": "stack"
                  }
                ]
              }
            ],
            "requiresCompatibilities": [
              "FARGATE"
            ],
            "cpu": "512",
            "memory": "1024"
          },
          "input.json": [
            {
              "name": "MINIMUM_NOTICE_PERIOD",
              "value": "3"
            },
            {
              "name": "SERVER_TIMEZONE",
              "value": "Europe/London"
            }
          ]
        },
        "output": {
          "family": "test-container",
          "networkMode": "awsvpc",
          "containerDefinitions": [
            {
              "cpu": 0,
              "image": "test-image",
              "name": "test-container",
              "environment": [
                {
                  "name": "CRON",
                  "value": "no"
                },
                {
                  "name": "LOG_CHANNEL",
                  "value": "stack"
                },
                {
                  "name": "MINIMUM_NOTICE_PERIOD",
                  "value": "3"
                },
                {
                  "name": "SERVER_TIMEZONE",
                  "value": "Europe/London"
                }
              ]
            }
          ],
          "requiresCompatibilities": [
            "FARGATE"
          ],
          "cpu": "512",
          "memory": "1024"
        }
      }
    ],
    "identifier": 67507028
  },
  {
    "context": [
      "I'm new to jq, and hoping to convert JSON below so that, for each object in  the records array , the  \"Account\" object is deleted and replaced with an \"AccountID\" field which has a the value of Account.Id.",
      "Assuming I don't know what the name of the field (eg. Account ) is prior to executing, so it Has to be dynamically included as an argument to --arg.",
      "Adapting [peak's answer](https://stackoverflow.com/a/67541950/14122) to use the dynamic field name:",
      "jq -c --arg field \"Account\" \\\n      --arg field_name_id \"AccountID\" '\n.records |= map(.[$field].Id as $x\n                  | del(.[$field])\n                  | . + {($field_name_id): $x})\n'"
    ],
    "utterance": "For each object in the records array, remove the object specified by a dynamic field name and instead add a field (with a dynamic name) whose value is the Id property of the removed object.",
    "expressions": [
      ".records |= map(.[$field].Id as $x | del(.[$field]) | . + {($field_name_id): $x})"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "attributes": {
                "type": "Contact",
                "referenceId": "ContactRef1"
              },
              "Account": {
                "attributes": {
                  "type": "Account",
                  "url": "/services/data/v51.0/sobjects/Account/asdf"
                },
                "Id": "asdf"
              }
            },
            {
              "attributes": {
                "type": "Contact",
                "referenceId": "ContactRef2"
              },
              "Account": {
                "attributes": {
                  "type": "Account",
                  "url": "/services/data/v51.0/sobjects/Account/qwer"
                },
                "Id": "qwer"
              }
            }
          ]
        },
        "output": {
          "records": [
            {
              "attributes": {
                "type": "Contact",
                "referenceId": "ContactRef1"
              },
              "AccountID": "asdf"
            },
            {
              "attributes": {
                "type": "Contact",
                "referenceId": "ContactRef2"
              },
              "AccountID": "qwer"
            }
          ]
        }
      }
    ],
    "identifier": 67541549
  },
  {
    "context": [
      "The har snippet that is causing issues in the response, is multiple entries for \"Cache-Control\", Like below:",
      "{ \"name\": \"Cache-Control\", \"value\": \"public\" }, { \"name\": \"Cache-Control\", \"value\": \"max-age=31536000\" },",
      "they are split as 2 columns.",
      "\"xx.js\",\"2021-05-06T06:14:10.505Z\",\"public\",\"max-age=31536000\",\"gzip\"...",
      "I need to get this as:",
      "\"public;max-age=31536000\"",
      "([.response.headers[] | select(.name | ascii_downcase == \"cache-control\").value] | join(\";\"))"
    ],
    "utterance": "Combine all values from response headers with name case-insensitively equal to 'cache-control' into a single string separated by semicolons.",
    "expressions": [
      "([.response.headers[] | select(.name | ascii_downcase == \"cache-control\").value] | join(\";\"))"
    ],
    "data": [
      {
        "input": {
          "response": {
            "headers": [
              {
                "name": "Cache-Control",
                "value": "public"
              },
              {
                "name": "Cache-Control",
                "value": "max-age=31536000"
              },
              {
                "name": "Other-Header",
                "value": "value"
              }
            ]
          }
        },
        "output": "public;max-age=31536000"
      }
    ],
    "identifier": 67524181
  },
  {
    "context": [
      "I want to collect the data from all embedded arrays and to get an array of all objects with \"a\" and \"b\" values. For the JSON above the result should be:",
      "[ {\"a\": 1, \"b\": \"z\"}, {\"a\": 1, \"b\": \"x\"}, {\"a\": 2, \"b\": \"c\"} ]",
      "You can use `.l[]` within the expression in order to return each element of the array returned in the response. So, use this one below",
      "map({a} + .l[])"
    ],
    "utterance": "Extract a flat array of objects containing both the value of 'a' and each 'b' value from all elements and their embedded arrays in the data.",
    "expressions": [
      "map({a} + .l[])"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "l": [
              {
                "b": "z"
              },
              {
                "b": "x"
              }
            ]
          },
          {
            "a": 2,
            "l": [
              {
                "b": "c"
              }
            ]
          }
        ],
        "output": [
          {
            "a": 1,
            "b": "z"
          },
          {
            "a": 1,
            "b": "x"
          },
          {
            "a": 2,
            "b": "c"
          }
        ]
      }
    ],
    "identifier": 67566274
  },
  {
    "context": [
      "And I need to convert it to this result. That is, union the inner level with the outer level, for each object in the array:",
      "The part I'm having trouble with is how to get `timestamp` to be in the same object as `cnt`.",
      "Just add them?\n```\nmap({timestamp} + .event)\n```"
    ],
    "utterance": "For each object, merge the 'timestamp' and 'cnt' fields from the outer and inner levels into a new object containing only these two keys.",
    "expressions": [
      "map({timestamp} + .event)"
    ],
    "data": [
      {
        "input": [
          {
            "version": "v1",
            "timestamp": "2020-01-01T00:00:00.000Z",
            "event": {
              "cnt": 45543336
            }
          },
          {
            "version": "v1",
            "timestamp": "2020-01-02T00:00:00.000Z",
            "event": {
              "cnt": 59389530
            }
          },
          {
            "version": "v1",
            "timestamp": "2020-01-03T00:00:00.000Z",
            "event": {
              "cnt": 58390082
            }
          }
        ],
        "output": [
          {
            "timestamp": "2020-01-01T00:00:00.000Z",
            "cnt": 45543336
          },
          {
            "timestamp": "2020-01-02T00:00:00.000Z",
            "cnt": 59389530
          },
          {
            "timestamp": "2020-01-03T00:00:00.000Z",
            "cnt": 58390082
          }
        ]
      }
    ],
    "identifier": 67564684
  },
  {
    "context": [
      "I need to get values for:\n\n- \"DeviceName\"\n- \"KmsKeyId\"\n- \"VolumeSize\"",
      "jq -r '\n  .LaunchTemplateVersions[].LaunchTemplateData.BlockDeviceMappings[]\n  | (.DeviceName, .Ebs.KmsKeyId,.Ebs.VolumeSize)' input.json"
    ],
    "utterance": "Extract DeviceName, KmsKeyId, and VolumeSize for every BlockDeviceMapping from all launch template versions.",
    "expressions": [
      ".LaunchTemplateVersions[].LaunchTemplateData.BlockDeviceMappings[] | (.DeviceName, .Ebs.KmsKeyId, .Ebs.VolumeSize)"
    ],
    "data": [
      {
        "input": {
          "LaunchTemplateVersions": [
            {
              "LaunchTemplateId": "lt-xxxxxx",
              "LaunchTemplateName": "dev-xxxxxx",
              "VersionNumber": 1,
              "VersionDescription": "dev-xxxxx",
              "CreateTime": "2021-04-28T06:12:15+00:00",
              "CreatedBy": "arn:aws:sts::xxxxx",
              "DefaultVersion": true,
              "LaunchTemplateData": {
                "BlockDeviceMappings": [
                  {
                    "DeviceName": "/dev/xvda",
                    "Ebs": {
                      "Encrypted": true,
                      "DeleteOnTermination": true,
                      "KmsKeyId": "arn:aws:kms:xxxx",
                      "SnapshotId": "snap-xxxx",
                      "VolumeSize": 800,
                      "VolumeType": "gp2"
                    }
                  }
                ]
              }
            }
          ]
        },
        "output": [
          "/dev/xvda",
          "arn:aws:kms:xxxx",
          800
        ]
      }
    ],
    "identifier": 67577689
  },
  {
    "context": [
      "any way I can use jq and combine the objects and arrays without having duplicates?",
      "file1.json ... file2.json ... combined.json ...",
      "So, assuming an invocation along the lines of\n\n    jq -s -f program.jq file1.json file2.json",
      ".[0] as $file1 | .[1] as $file2\n| (INDEX($file1.skins[]; .[\"Item Shortname\"]) | map_values(.skins)) as $dict\n\n| $file2\n| .skins |= map( .[\"Item Shortname\"] as $name\n                 | .skins += $dict[$name]\n                 | .skins |= [uniques(.[])] )",
      "One way to avoid slurping the two files would be to use `input` in conjunction with the -n command line option instead of -s.  The \"main\" part of the jq program would then be as follows:\n(INDEX(input.skins[]; .[\"Item Shortname\"]) | map_values(.skins)) as $dict\n| input\n| .skins |= map( .[\"Item Shortname\"] as $name\n                 | .skins += $dict[$name]\n                 | .skins |= [uniques(.[])] )"
    ],
    "utterance": "Combine two files so that skin objects with the same Item Shortname are merged and their skins arrays are concatenated with duplicates removed.",
    "expressions": [
      "def uniques(stream): foreach stream as $s ({};\n  ($s|type) as $t\n  | (if $t == \"string\" then $s else ($s|tostring) end) as $y\n  | if .[$t][$y] then .emit = false else .emit = true | (.item = $s) | (.[$t][$y] = true) end;\n  if .emit then .item else empty end );\n\n.[0] as $file1 | .[1] as $file2\n| (INDEX($file1.skins[]; .[\"Item Shortname\"]) | map_values(.skins)) as $dict\n| $file2\n| .skins |= map( .[\"Item Shortname\"] as $name\n                 | .skins += $dict[$name]\n                 | .skins |= [uniques(.[])] )",
      "def uniques(stream): foreach stream as $s ({};\n  ($s|type) as $t\n  | (if $t == \"string\" then $s else ($s|tostring) end) as $y\n  | if .[$t][$y] then .emit = false else .emit = true | (.item = $s) | (.[$t][$y] = true) end;\n  if .emit then .item else empty end );\n\n(INDEX(input.skins[]; .[\"Item Shortname\"]) | map_values(.skins)) as $dict\n| input\n| .skins |= map( .[\"Item Shortname\"] as $name\n                 | .skins += $dict[$name]\n                 | .skins |= [uniques(.[])] )"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "skins": [
              {
                "Item Shortname": "boots.name",
                "skins": [
                  2,
                  25,
                  41
                ]
              },
              {
                "Item Shortname": "fun.name",
                "skins": [
                  12,
                  8
                ]
              }
            ]
          },
          "file2.json": {
            "skins": [
              {
                "Item Shortname": "boots.name",
                "skins": [
                  2,
                  20
                ]
              },
              {
                "Item Shortname": "fun.name",
                "skins": [
                  90,
                  6,
                  82
                ]
              }
            ]
          }
        },
        "output": {
          "skins": [
            {
              "Item Shortname": "boots.name",
              "skins": [
                2,
                20,
                25,
                41
              ]
            },
            {
              "Item Shortname": "fun.name",
              "skins": [
                90,
                6,
                82,
                12,
                8
              ]
            }
          ]
        }
      }
    ],
    "identifier": 67556396
  },
  {
    "context": [
      "The following filters for computing the elapsed clock time might also be helpful:",
      "def time(f):\n  now as $start | f as $out | (now - $start | stderr) | \"\", $out;",
      "def time(f; $msg):\n  now as $start | f as $out | (\"\\(now - $start): \\($msg)\" | stderr) | \"\", $out;",
      "time( ack(3;7) | debug)"
    ],
    "utterance": "Measure and print how long a specific query or function takes to execute.",
    "expressions": [
      "def time(f): now as $start | f as $out | (now - $start | stderr) | \"\", $out;",
      "def time(f; $msg): now as $start | f as $out | (\"\\(now - $start): \\($msg)\" | stderr) | \"\", $out;"
    ],
    "identifier": 67595507
  },
  {
    "context": [
      "I need to iterate over every element of an list (upper_one), and replace it with other value.",
      "Is it possible to iterate over list with jq, replace values with value from another function (like $id in the code), and print the whole final json with substituted values?",
      "I need this kind of output:\r\n{\r\n  \"name\": \"market\",\r\n  \"type\": \"grocery\",\r\n  \"shelves\": {\r\n    \"upper_one\": [\r\n      \"1\",\r\n      \"10\",\r\n      \"7\"\r\n    ]\r\n  }\r\n}\r\nnot just elements of \"upper_one\" list thrice.",
      "$ jq '.shelves.upper_one[] |= (sub(\"23423565\";\"1\") | sub(\"23552352\";\"10\") | sub(\"08789089\";\"7\"))' your.json"
    ],
    "utterance": "Replace every string in the shelves.upper_one list with specific new values based on a mapping, resulting in a final JSON with the updated list.",
    "expressions": [
      ".shelves.upper_one[] |= (sub(\"23423565\";\"1\") | sub(\"23552352\";\"10\") | sub(\"08789089\";\"7\"))"
    ],
    "data": [
      {
        "input": {
          "name": "market",
          "type": "grocery",
          "shelves": {
            "upper_one": [
              "23423565",
              "23552352",
              "08789089"
            ]
          }
        },
        "output": {
          "name": "market",
          "type": "grocery",
          "shelves": {
            "upper_one": [
              "1",
              "10",
              "7"
            ]
          }
        }
      }
    ],
    "identifier": 67581063
  },
  {
    "context": [
      "Is there  a simple way to combine two json variables?",
      "Given `$a {a:1,b:1}` and `$b {c:1,d:1}`",
      "How do I produce a result of `{a:1,b:1,c:1,d:1}`",
      "Yes, e.g.\n\n    $a + $b",
      "or\n\n     [$a,$b]|add",
      "Try the following:\n\njq --slurp 'add' <(echo \"$a\") <(echo \"$b\")",
      "Output:\n\n{\n  \"a\": 1,\n  \"b\": 1,\n  \"c\": 1,\n  \"d\": 1\n}"
    ],
    "utterance": "Combine two objects so that the resulting object contains all key-value pairs from both.",
    "expressions": [
      "$a + $b",
      "[$a,$b]|add"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 1
          },
          {
            "c": 1,
            "d": 1
          }
        ],
        "output": {
          "a": 1,
          "b": 1,
          "c": 1,
          "d": 1
        }
      }
    ],
    "identifier": 67596741
  },
  {
    "context": [
      "one of the instances requires a ```sentinelPassword``` value.",
      "I can fetch the password using ```kubectl get secret``` but I&#39;m trying to figure out how to insert that password into the config file for the particular instance that requires it.",
      "# Find instance by their host value which is unique. (Can&#39;t figure out how to do this bit)",
      "if $JSON host name contains \"Redis2.development.svc.cluster.local\"",
      "you could run:\n```\npassword=mypassword\n< local.json jq --arg password \"$password\" '\n  .connections[] |= if any(.sentinels[].host; index(\"Redis2.development.svc.cluster.local\"))\n                    then .sentinelPassword = $password else . end'\n```"
    ],
    "utterance": "Set sentinelPassword to a specified value for the connection whose sentinels[].host matches 'Redis2.development.svc.cluster.local'.",
    "expressions": [
      ".connections[] |= if any(.sentinels[].host; index(\"Redis2.development.svc.cluster.local\")) then .sentinelPassword = $password else . end"
    ],
    "data": [
      {
        "input": {
          "connections": [
            {
              "label": "Redis1",
              "sentinels": [
                {
                  "host": "Redis1.default.svc.cluster.local",
                  "port": 26379
                }
              ],
              "sentinelName": "mymaster",
              "sentinelPassword": "",
              "dbIndex": 0
            },
            {
              "label": "Redis2",
              "sentinels": [
                {
                  "host": "Redis2.development.svc.cluster.local",
                  "port": 26379
                }
              ],
              "sentinelName": "mymaster",
              "sentinelPassword": "",
              "dbIndex": 0
            }
          ]
        },
        "output": {
          "connections": [
            {
              "label": "Redis1",
              "sentinels": [
                {
                  "host": "Redis1.default.svc.cluster.local",
                  "port": 26379
                }
              ],
              "sentinelName": "mymaster",
              "sentinelPassword": "",
              "dbIndex": 0
            },
            {
              "label": "Redis2",
              "sentinels": [
                {
                  "host": "Redis2.development.svc.cluster.local",
                  "port": 26379
                }
              ],
              "sentinelName": "mymaster",
              "sentinelPassword": "mypassword",
              "dbIndex": 0
            }
          ]
        }
      }
    ],
    "identifier": 67589467
  },
  {
    "context": [
      "I want to have an output like:\r\n\r\n```77d07cfb-484c-4b49-856c-354310ea8f66 job-name-1```",
      "Is there anyway to get these both in same command?",
      ".taskchain_id + \" \" +.kubernetes.labels.\"job-name\"\r\n\r\nhttps://jqplay.org/s/n7-LguIZtu"
    ],
    "utterance": "Output the value of taskchain_id followed by the value of kubernetes.labels.job-name, separated by a space.",
    "expressions": [
      ".taskchain_id + \" \" + .kubernetes.labels.\"job-name\""
    ],
    "data": [
      {
        "input": {
          "kubernetes": {
            "container_name": "test",
            "container_hash": "test",
            "host": "host1",
            "docker_id": "faaf",
            "pod_id": "222-44f0-8ff0-87faf2bf1f9c",
            "labels": {
              "job-name": "job-name-1"
            }
          },
          "taskchain_id": "77d07cfb-484c-4b49-856c-354310ea8f66"
        },
        "output": "77d07cfb-484c-4b49-856c-354310ea8f66 job-name-1"
      }
    ],
    "identifier": 67599618
  },
  {
    "context": [
      "And I need to add this key/value to **rule1 only**:\r\n\r\n    \"EnableContinuousBackup\": true",
      "So, how can I make it work so my json looks like this in the end?",
      "You need to enclose the right hand side of the assignment operator (`=`, not `+=`) in parentheses.",
      "(.Rules[] | select(.RuleName == \"rule1\") .EnableContinuousBackup) = true"
    ],
    "utterance": "Add the key EnableContinuousBackup with value true to the object in Rules where RuleName equals \"rule1\".",
    "expressions": [
      "(.Rules[] | select(.RuleName == \"rule1\") .EnableContinuousBackup) = true"
    ],
    "data": [
      {
        "input": {
          "BackupPlanName": "backup-plan",
          "Rules": [
            {
              "RuleName": "rule1",
              "Lifecycle": {
                "DeleteAfterDays": 35
              },
              "RuleId": "3e5ae513"
            },
            {
              "RuleName": "rule2",
              "Lifecycle": {
                "DeleteAfterDays": 365
              },
              "RuleId": "82c660c9"
            }
          ]
        },
        "output": {
          "BackupPlanName": "backup-plan",
          "Rules": [
            {
              "RuleName": "rule1",
              "Lifecycle": {
                "DeleteAfterDays": 35
              },
              "RuleId": "3e5ae513",
              "EnableContinuousBackup": true
            },
            {
              "RuleName": "rule2",
              "Lifecycle": {
                "DeleteAfterDays": 365
              },
              "RuleId": "82c660c9"
            }
          ]
        }
      }
    ],
    "identifier": 67601107
  },
  {
    "context": [
      "I\u2019d like to have it be an array, and have tried recommendations like piping it into `jq -s '. '`. These attempts only yield a single-element array. What would be the best way to format this? I highly suspect `from_entries` and `to_entries` have to be incorporated somehow.",
      "EXPECTED OUTPUT",
      "[",
      "  {",
      "    \"key\": \"adaway\",",
      "    ...",
      "  },",
      "  {",
      "    \"key\": \"adguard\",",
      "    ...",
      "  },",
      "  ...",
      "]",
      "the first of these is the one corresponding to the shown expected output. `{$key}` is shorthand for `{\"key\": $key}`.",
      "| [keys_unsorted[] as $key | {\"key\": $key} + .[$key] ]"
    ],
    "utterance": "Convert an object with specific keys to an array of objects, each having a 'key' field set to the original key, plus all its properties.",
    "expressions": [
      "[keys_unsorted[] as $key | {\"key\": $key} + .[$key] ]"
    ],
    "data": [
      {
        "input": {
          "adaway": {
            "url": "https://raw.githubusercontent.com/AdAway/adaway.github.io/master/hosts.txt",
            "rule": "/^127\\.0\\.0\\.1[[:space:]]+([[:alnum:]_-]{1,63}\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($2)}",
            "size": "S",
            "focus": "mobile",
            "descurl": "https://github.com/AdAway/adaway.github.io"
          },
          "adguard": {
            "url": "https://adguardteam.github.io/AdGuardSDNSFilter/Filters/filter.txt",
            "rule": "BEGIN{FS=\\\"[/|^|\\r]\\\"}/^\\|\\|([[:alnum:]_-]{1,63}\\.)+[[:alpha:]]+[\\/\\^\\r]+$/{print tolower($3)}",
            "size": "L",
            "focus": "general",
            "descurl": "https://adguard.com"
          },
          "disconnect": {
            "url": "https://s3.amazonaws.com/lists.disconnect.me/simple_malvertising.txt",
            "rule": "/^([[:alnum:]_-]{1,63}\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($1)}",
            "size": "S",
            "focus": "general",
            "descurl": "https://disconnect.me"
          },
          "yoyo": {
            "url": "https://pgl.yoyo.org/adservers/serverlist.php?hostformat=nohtml&showintro=0&mimetype=plaintext",
            "rule": "/^([[:alnum:]_-]{1,63}\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($1)}",
            "size": "S",
            "focus": "general",
            "descurl": "https://pgl.yoyo.org"
          }
        },
        "output": [
          {
            "key": "adaway",
            "url": "https://raw.githubusercontent.com/AdAway/adaway.github.io/master/hosts.txt",
            "rule": "/^127\\.0\\.0\\.1[[:space:]]+([[:alnum:]_-]{1,63}\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($2)}",
            "size": "S",
            "focus": "mobile",
            "descurl": "https://github.com/AdAway/adaway.github.io"
          },
          {
            "key": "adguard",
            "url": "https://adguardteam.github.io/AdGuardSDNSFilter/Filters/filter.txt",
            "rule": "BEGIN{FS=\\\"[/|^|\\r]\\\"}/^\\|\\|([[:alnum:]_-]{1,63}\\.)+[[:alpha:]]+[\\/\\^\\r]+$/{print tolower($3)}",
            "size": "L",
            "focus": "general",
            "descurl": "https://adguard.com"
          },
          {
            "key": "disconnect",
            "url": "https://s3.amazonaws.com/lists.disconnect.me/simple_malvertising.txt",
            "rule": "/^([[:alnum:]_-]{1,63}\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($1)}",
            "size": "S",
            "focus": "general",
            "descurl": "https://disconnect.me"
          },
          {
            "key": "yoyo",
            "url": "https://pgl.yoyo.org/adservers/serverlist.php?hostformat=nohtml&showintro=0&mimetype=plaintext",
            "rule": "/^([[:alnum:]_-]{1,63}\\.)+[[:alpha:]]+([[:space:]]|$)/{print tolower($1)}",
            "size": "S",
            "focus": "general",
            "descurl": "https://pgl.yoyo.org"
          }
        ]
      }
    ],
    "identifier": 67577852
  },
  {
    "context": [
      "I\u2019d like to create a csv file with the value within the Name key and all of the \"c7n:MatchedFilters\" in the array.",
      "for each object, we find the name and bind it to $name, we concatenate the filters and bind them to $filters, then we construct an array containing both, then we convert the array to a CSV string.",
      "jq --raw-output '\n    .[]|\n\n    first(\n        .Tags[]|\n        select(.Key==\"Name\")\n    ).Value as $name|\n\n    (\n        .\"c7n:MatchedFilters\"|\n        join(\" \")\n    ) as $filters|\n\n    [$name, $filters]|\n\n    @csv"
    ],
    "utterance": "Output the value of the Name tag and all c7n:MatchedFilters fields for each object as CSV rows, concatenating filters with spaces.",
    "expressions": [
      ".[] | first(.Tags[] | select(.Key==\"Name\")).Value as $name | (.\"c7n:MatchedFilters\" | join(\" \")) as $filters | [$name, $filters] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "Tags": [
              {
                "Key": "Name",
                "Value": "example1"
              },
              {
                "Key": "Irrelevant",
                "Value": "irrelevant"
              }
            ],
            "c7n:MatchedFilters": [
              "tag: example_tag_rule"
            ],
            "another_key": "another_value_I_dont_want"
          },
          {
            "Tags": [
              {
                "Key": "Name",
                "Value": "example2"
              }
            ],
            "c7n:MatchedFilters": [
              "tag:example_tag_rule",
              "tag: example_tag_rule2"
            ]
          }
        ],
        "output": "\"example1\",\"tag: example_tag_rule\"\n\"example2\",\"tag:example_tag_rule tag: example_tag_rule2\""
      }
    ],
    "identifier": 67601395
  },
  {
    "context": [
      "So I have this input to jq:\n\n[\n  \"foo\",\n  {\n    \"a\": 1,\n    \"b\": 2\n  },\n  {\n    \"a\": 1,\n    \"b\": 3\n  },\n  {\n    \"a\": 2,\n    \"b\": 2\n  }\n]\n\nand I want to select all objects where b is 2 ideally as an array:",
      "But the string in the list makes that difficult.",
      "If I try:\n\n.[]| select(.b == 2)\n\nThen I get the error:\n\njq: error (at /tmp/data.json:14): Cannot index string with string \"b\"",
      "You can just add a `?`: `.[]| select(.b? == 2)`.",
      "As of the second question, I'd use [`map()`][2] so the result is an array as requested:\n\nmap(select(.b? == 2))",
      "Another way is to use the built-in `objects` filter which discards an input if it is not an object:\n\nmap(objects | select(.b == 2))",
      "Check the value's type in your select filter:\n\nmap(select(type == \"object\" and .b == 2))"
    ],
    "utterance": "Return all elements with a field b equal to 2 as an array, excluding non-objects from the result.",
    "expressions": [
      "map(select(.b? == 2))",
      "map(objects | select(.b == 2))",
      "map(select(type == \"object\" and .b == 2))"
    ],
    "data": [
      {
        "input": [
          "foo",
          {
            "a": 1,
            "b": 2
          },
          {
            "a": 1,
            "b": 3
          },
          {
            "a": 2,
            "b": 2
          }
        ],
        "output": [
          {
            "a": 1,
            "b": 2
          },
          {
            "a": 2,
            "b": 2
          }
        ]
      }
    ],
    "identifier": 67624282
  },
  {
    "context": [
      "I want to delete any JSON entry in `schemas`, which is not found in `paths` values recursively.",
      "For example, `Duration` is found in the values at `paths`, but not for `Apple`.",
      "So `Apple` entry should be deleted from the JSON file.",
      "You're right about the relevance of the `with_entries(select(...))` idiom:",
      "[.paths[].summary] as $texts\n| .components.schemas |=\n    with_entries( select( .key as $key | any($texts[]; index($key) )))"
    ],
    "utterance": "Remove entries from components.schemas whose key is not referenced in any summary value under paths.",
    "expressions": [
      "[.paths[].summary] as $texts | .components.schemas |= with_entries( select( .key as $key | any($texts[]; index($key)) ))"
    ],
    "data": [
      {
        "input": {
          "openapi": "3.0.1",
          "paths": {
            "/api/car": {
              "summary": "Something about Duration"
            },
            "/api/plane": {
              "summary": "Something about Duration"
            }
          },
          "components": {
            "schemas": {
              "Duration": {
                "enum": [
                  "OneMonth",
                  "ThreeMonth"
                ]
              },
              "Apple": {
                "type": "object",
                "properties": {
                  "flaggedDataCount": {
                    "type": "integer",
                    "description": "someting",
                    "format": "int32"
                  }
                }
              }
            }
          }
        },
        "output": {
          "openapi": "3.0.1",
          "paths": {
            "/api/car": {
              "summary": "Something about Duration"
            },
            "/api/plane": {
              "summary": "Something about Duration"
            }
          },
          "components": {
            "schemas": {
              "Duration": {
                "enum": [
                  "OneMonth",
                  "ThreeMonth"
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 67624677
  },
  {
    "context": [
      "An example of my desired output can be found below.",
      "How can I modify the query to get my desired output?",
      "You can use the [group_by] function.",
      "group_by(.metadata.namespace)[]|",
      "{ name: .[0].metadata.namespace, pods: [ .[] | { name: .metadata.name, containers: [ .spec.containers[] | { name, image } ] } ] }"
    ],
    "utterance": "Group the items by namespace, and output each namespace with its name and a list of pods, each containing its name and its list of containers including name and image.",
    "expressions": [
      ".items |\n{\n    namespaceCount: ([ .[].metadata.namespace ] | unique | length),\n    podCount: (. | length),\n    containerCount: ([ .[].spec.containers[].image ] | length),\n    namespaces: [\n        group_by(.metadata.namespace)[]|\n        {\n            name: .[0].metadata.namespace,\n            pods: [\n                .[] |\n                {\n                    name: .metadata.name,\n                    containers: [ .spec.containers[] | { name, image } ]\n                }\n            ]\n        }\n    ]\n}"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "pod-in-namespace-1-a",
                "namespace": "namespace-1"
              },
              "spec": {
                "containers": [
                  {
                    "image": "some/image:1.2.3",
                    "name": "container1"
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "pod-in-namespace-1-b",
                "namespace": "namespace-1"
              },
              "spec": {
                "containers": [
                  {
                    "image": "another/image:9.8.7",
                    "name": "container2"
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "namespaceCount": 1,
          "podCount": 2,
          "containerCount": 2,
          "namespaces": [
            {
              "name": "namespace-1",
              "pods": [
                {
                  "name": "pod-in-namespace-1-a",
                  "containers": [
                    {
                      "name": "container1",
                      "image": "some/image:1.2.3"
                    }
                  ]
                },
                {
                  "name": "pod-in-namespace-1-b",
                  "containers": [
                    {
                      "name": "container2",
                      "image": "another/image:9.8.7"
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 67633961
  },
  {
    "context": [
      "Here is the `jq` command like below: `jq &#39;.. |.&quot;$ref&quot;? | select(. != null)&#39;`",
      "How do I run this command in Powershell?",
      "`jq &#39;.. |.\\&quot;$ref\\&quot;? | select(. != null)&#39;` works with PowerShell version 5.1.1941.1682 on Windows 10. Note the single quotes around the argument and the backslashes before the double quotes.",
      "NB: `select(. != null)` can be written more succinctly as `select(values)`"
    ],
    "utterance": "Return all values of keys named \"$ref\" from any depth in the data structure.",
    "expressions": [
      ".. | .[\"$ref\"]? | select(. != null)",
      ".. | .[\"$ref\"]? | select(values)"
    ],
    "identifier": 67635182
  },
  {
    "context": [
      "I would like to get group of 4 words in one line, then break the line, and sort it by first column.",
      "I would like to have:\n\n    \"Office-1\", \"work-1\", \"11xxx111\", \"hp\"    \n    \"Office-1\" \"work-3\", \"22xxx222\", \"dell\"    \n    \"Office-2\", \"work-2\", \"33xxx333\", \"lenovo\"",
      "To sort by `.location` only, without an external sort:\n```\nmap( [ .location, .host_name, .serial_number, .model] )\n| sort_by(.[0])[]\n| map(\"\\\"\\(.)\\\"\") | join(\", \")\n```",
      "You can ask `jq` to produce arbitrary formatted strings.\n\n```sh\ncurl -L 'http://mylink/ |\njq -r '.[]| \"\\\"\\(.location)\\\" , \\\"\\(.host_name)\\\" , \\\"\\(.serial_number)\\\" , \\\"\\(.model)\\\"\"' |\nsort\n```",
      "If you want the output as CSV, simply replace the last line in the jq program above by `@csv`."
    ],
    "utterance": "List each record's location, host_name, serial_number, and model as quoted strings on one line, one group per line, sorted by location.",
    "expressions": [
      "map([.location, .host_name, .serial_number, .model])\n| sort_by(.[0])[]\n| map(\"\\\"\\(.)\\\"\") | join(\", \")",
      ".[] | \"\\\"\\(.location)\\\" , \\\"\\(.host_name)\\\" , \\\"\\(.serial_number)\\\" , \\\"\\(.model)\\\"\"",
      "group_by(.location) | .[] | .[] | map(values) | \"\\\"\" + join (\"\\\", \\\"\") + \"\\\"\""
    ],
    "data": [
      {
        "input": [
          {
            "location": "Office-1",
            "host_name": "work-1",
            "serial_number": "11xxx111",
            "model": "hp"
          },
          {
            "location": "Office-2",
            "host_name": "work-2",
            "serial_number": "33xxx333",
            "model": "lenovo"
          },
          {
            "location": "Office-1",
            "host_name": "work-3",
            "serial_number": "22xxx222",
            "model": "dell"
          }
        ],
        "output": [
          "\"Office-1\", \"work-1\", \"11xxx111\", \"hp\"",
          "\"Office-1\", \"work-3\", \"22xxx222\", \"dell\"",
          "\"Office-2\", \"work-2\", \"33xxx333\", \"lenovo\""
        ]
      }
    ],
    "identifier": 67607713
  },
  {
    "context": [
      "I need them transformed to the format below, with the predefined constant keys pulled out to the top level and the variable keys staying in the searchResult array.",
      "You could use `IN/1` as follows:",
      "(.searchResult | (from_entries | {common1, common2})) + { searchResult }\n| .searchResult |= map(select(.key | IN(\"common1\", \"common2\") | not))"
    ],
    "utterance": "Promote the entries whose key is 'common1' or 'common2' to the top level, leaving the other entries in the searchResult array.",
    "expressions": [
      "(.searchResult | (from_entries | {common1, common2})) + { searchResult } | .searchResult |= map(select(.key | IN(\"common1\", \"common2\") | not))"
    ],
    "data": [
      {
        "input": {
          "searchResult": [
            {
              "key": "common1",
              "value": "A string"
            },
            {
              "key": "common2",
              "value": "2149944"
            },
            {
              "key": "varying1",
              "value": "604516"
            },
            {
              "key": "varying73",
              "value": "58.92"
            }
          ]
        },
        "output": {
          "common1": "A string",
          "common2": "2149944",
          "searchResult": [
            {
              "key": "varying1",
              "value": "604516"
            },
            {
              "key": "varying73",
              "value": "58.92"
            }
          ]
        }
      }
    ],
    "identifier": 67635168
  },
  {
    "context": [
      "I'm trying to split an array of nested json objects using **jq**.",
      "Expecting output as:",
      "{\n    \"storeId\": \"1412\",\n    \"templateCheck\": [ ... ]\n}",
      "jq '.storeId as $storeId | .templateCheck[] | { $storeId, templateCheck: [ . ] }'",
      "jq '(. | del(.templateCheck)) as $o | .templateCheck[] | $o + { templateCheck: [.] }'"
    ],
    "utterance": "For each object in the 'templateCheck' array, emit a new object with the same 'storeId' and a 'templateCheck' array containing only that object.",
    "expressions": [
      ".storeId as $storeId | .templateCheck[] | { $storeId, templateCheck: [ . ] }",
      "(. | del(.templateCheck)) as $o | .templateCheck[] | $o + { templateCheck: [.] }"
    ],
    "data": [
      {
        "input": {
          "storeId": "1412",
          "templateCheck": [
            {
              "rom": 37,
              "updateDate": "2021-05-09 07:53:17",
              "lhb": "2021-05-09 06:32:41",
              "templateCode": "REGULAR",
              "lId": "50-19-78-5C",
              "sk": "830066",
              "skUpdateDate": "2020-07-21 05:37:07",
              "battery": 30,
              "status": 1
            },
            {
              "rom": 37,
              "updateDate": "2021-05-09 07:54:02",
              "lhb": "2021-05-09 06:32:41",
              "templateCode": "REGULAR",
              "lId": "50-1B-FE-6E",
              "sk": "740541",
              "skUpdateDate": "2021-03-22 05:59:00",
              "battery": 30,
              "status": 1
            },
            {
              "rom": 37,
              "updateDate": "2021-05-09 07:52:05",
              "lhb": "2021-05-09 06:32:41",
              "templateCode": "REGULAR",
              "lId": "50-1C-22-6E",
              "sk": "846760",
              "skUpdateDate": "2021-05-08 03:34:22",
              "battery": 29,
              "status": 1
            }
          ]
        },
        "output": [
          {
            "storeId": "1412",
            "templateCheck": [
              {
                "rom": 37,
                "updateDate": "2021-05-09 07:53:17",
                "lhb": "2021-05-09 06:32:41",
                "templateCode": "REGULAR",
                "lId": "50-19-78-5C",
                "sk": "830066",
                "skUpdateDate": "2020-07-21 05:37:07",
                "battery": 30,
                "status": 1
              }
            ]
          },
          {
            "storeId": "1412",
            "templateCheck": [
              {
                "rom": 37,
                "updateDate": "2021-05-09 07:54:02",
                "lhb": "2021-05-09 06:32:41",
                "templateCode": "REGULAR",
                "lId": "50-1B-FE-6E",
                "sk": "740541",
                "skUpdateDate": "2021-03-22 05:59:00",
                "battery": 30,
                "status": 1
              }
            ]
          },
          {
            "storeId": "1412",
            "templateCheck": [
              {
                "rom": 37,
                "updateDate": "2021-05-09 07:52:05",
                "lhb": "2021-05-09 06:32:41",
                "templateCode": "REGULAR",
                "lId": "50-1C-22-6E",
                "sk": "846760",
                "skUpdateDate": "2021-05-08 03:34:22",
                "battery": 29,
                "status": 1
              }
            ]
          }
        ]
      }
    ],
    "identifier": 67607384
  },
  {
    "context": [
      "I actually use jq associated with a curl command.",
      "I'd like to filter rows, with something like this :",
      "curl <curl expression> | jq | grep myfilter",
      "jq util do not accept to be grepped.",
      "If you really want to use grep, try `jq .` instead of just `jq`.",
      "something like this should work:",
      "`curl <curl expression> | jq -r --ubuffered | grep myfilter`"
    ],
    "utterance": "Output the entire input in a format suitable for searching with grep for a specific value.",
    "expressions": [
      "jq .",
      "jq -r --unbuffered"
    ],
    "identifier": 67638475
  },
  {
    "context": [
      "I want to delete any JSON entry from `components.schemas` if it is not found in the `$paths`",
      "Here is my Powershell script with `jq`:\r\n\r\n    $paths = jq &#39;.. |.\\&quot;$ref\\&quot;? | select(. != null)&#39; $srcJson\r\n    jq &#39;.components.schemas |= with_entries( select( .key as $key | any(${paths}[]; index($key) )))&#39; $srcJson | Out-File $destinationJson -Encoding UTF8",
      "Notice that the `BadSchemas` is removed from the `components.schemas`",
      "you should be able to do something like this:\r\n\r\n```\r\n$paths = jq &#39;.. |.\\&quot;$ref\\&quot;? | select(. != null)&#39; $srcJson | ConvertTo-Json\r\njq --argjson paths &quot;$paths&quot; &#39;.components.schemas |= with_entries( select( .key as $key | any($paths[]; index($key) )))&#39; $srcJson | Out-File $destinationJson -Encoding UTF8\r\n```"
    ],
    "utterance": "Remove all entries from components.schemas whose keys are not referenced by any $ref field in the document.",
    "expressions": [
      ".components.schemas |= with_entries( select( .key as $key | any($paths[]; index($key)) ))"
    ],
    "identifier": 67636275
  },
  {
    "context": [
      "I want to search for `SearchString` key (you can see that we can't use a fixed index for it) and when the key appears decrypt its value from base64 (perhaps using `@base64d` filter). Is this possible with JQ? If so, how?",
      "getpath(paths | select(.[-1] == \"SearchString\")) |= @base64d",
      "walk(if type == \"object\" and .SearchString \n     then .SearchString |= @base64d else . end)",
      "walk(if type == \"object\" and (.SearchString|type) == \"string\" \n     then .SearchString |= @base64d else . end)"
    ],
    "utterance": "Decode every value for the key SearchString from base64 anywhere it appears, regardless of nesting level.",
    "expressions": [
      "getpath(paths | select(.[-1] == \"SearchString\")) |= @base64d",
      "walk(if type == \"object\" and .SearchString then .SearchString |= @base64d else . end)",
      "walk(if type == \"object\" and (.SearchString|type) == \"string\" then .SearchString |= @base64d else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "searchblock",
            "Priority": 3,
            "Statement": {
              "RateBasedStatement": {
                "Limit": 100,
                "AggregateKeyType": "IP",
                "ScopeDownStatement": {
                  "ByteMatchStatement": {
                    "SearchString": "Y2F0YWxvZ3NlYXJjaA==",
                    "FieldToMatch": {
                      "UriPath": {}
                    },
                    "TextTransformations": [
                      {
                        "Priority": 0,
                        "Type": "LOWERCASE"
                      }
                    ],
                    "PositionalConstraint": "CONTAINS"
                  }
                }
              }
            },
            "Action": {
              "Block": {}
            },
            "VisibilityConfig": {
              "SampledRequestsEnabled": true,
              "CloudWatchMetricsEnabled": true,
              "MetricName": "searchblock"
            }
          },
          {
            "Name": "bot-block",
            "Priority": 4,
            "Statement": {
              "ByteMatchStatement": {
                "SearchString": "Ym90",
                "FieldToMatch": {
                  "SingleHeader": {
                    "Name": "user-agent"
                  }
                },
                "TextTransformations": [
                  {
                    "Priority": 0,
                    "Type": "LOWERCASE"
                  }
                ],
                "PositionalConstraint": "CONTAINS"
              }
            },
            "Action": {
              "Allow": {}
            },
            "VisibilityConfig": {
              "SampledRequestsEnabled": true,
              "CloudWatchMetricsEnabled": true,
              "MetricName": "user-agent"
            }
          }
        ],
        "output": [
          {
            "Name": "searchblock",
            "Priority": 3,
            "Statement": {
              "RateBasedStatement": {
                "Limit": 100,
                "AggregateKeyType": "IP",
                "ScopeDownStatement": {
                  "ByteMatchStatement": {
                    "SearchString": "catalogsearch",
                    "FieldToMatch": {
                      "UriPath": {}
                    },
                    "TextTransformations": [
                      {
                        "Priority": 0,
                        "Type": "LOWERCASE"
                      }
                    ],
                    "PositionalConstraint": "CONTAINS"
                  }
                }
              }
            },
            "Action": {
              "Block": {}
            },
            "VisibilityConfig": {
              "SampledRequestsEnabled": true,
              "CloudWatchMetricsEnabled": true,
              "MetricName": "searchblock"
            }
          },
          {
            "Name": "bot-block",
            "Priority": 4,
            "Statement": {
              "ByteMatchStatement": {
                "SearchString": "bot",
                "FieldToMatch": {
                  "SingleHeader": {
                    "Name": "user-agent"
                  }
                },
                "TextTransformations": [
                  {
                    "Priority": 0,
                    "Type": "LOWERCASE"
                  }
                ],
                "PositionalConstraint": "CONTAINS"
              }
            },
            "Action": {
              "Allow": {}
            },
            "VisibilityConfig": {
              "SampledRequestsEnabled": true,
              "CloudWatchMetricsEnabled": true,
              "MetricName": "user-agent"
            }
          }
        ]
      }
    ],
    "identifier": 67631286
  },
  {
    "context": [
      "what I wanted to achieve is a json document with below contents:\n\n{\"index\":{}}\n{\"LAST_MODIFIED_BY\":\"david\",\"LAST_MODIFIED_DATE\":\"2018-06-26 12:02:03.0\",\"CLASS_NAME\":\"/SC/Trade/HTS_CA/1234abcd\",\"DECISION\":\"AGREE\",\"TASK_TYPE_ID\":\"abcd1234-832b-43b6-afa6-361253ffe1d5\",\"NAME\":\"something\"}\n{\"index\":{}}\n{\"LAST_MODIFIED_BY\":\"sarah\",\"LAST_MODIFIED_DATE\":\"2018-08-26 12:02:03.0\",\"CLASS_NAME\":\"/SC/Import/HTS_US/9876abcd\",\"DECISION\":\"DISAGREE\",\"TASK_TYPE_ID\":\"abcd1234-832b-43b6-afa6-361253ffe1d5\",\"NAME\":\"nicename\"}\n... more rows to follow",
      "jq -nc 'inputs | {\"index\":{}}, .'"
    ],
    "utterance": "Add a line with {\"index\":{}} before each existing line in the file.",
    "expressions": [
      "jq -nc 'inputs | {\"index\":{}}, .'"
    ],
    "data": [
      {
        "input": [
          "{\"LAST_MODIFIED_BY\":\"david\",\"LAST_MODIFIED_DATE\":\"2018-06-26 12:02:03.0\",\"CLASS_NAME\":\"/SC/Trade/HTS_CA/1234abcd\",\"DECISION\":\"AGREE\",\"TASK_TYPE_ID\":\"abcd1234-832b-43b6-afa6-361253ffe1d5\",\"NAME\":\"something\"}",
          "{\"LAST_MODIFIED_BY\":\"sarah\",\"LAST_MODIFIED_DATE\":\"2018-08-26 12:02:03.0\",\"CLASS_NAME\":\"/SC/Import/HTS_US/9876abcd\",\"DECISION\":\"DISAGREE\",\"TASK_TYPE_ID\":\"abcd1234-832b-43b6-afa6-361253ffe1d5\",\"NAME\":\"nicename\"}"
        ],
        "output": [
          "{\"index\":{}}",
          "{\"LAST_MODIFIED_BY\":\"david\",\"LAST_MODIFIED_DATE\":\"2018-06-26 12:02:03.0\",\"CLASS_NAME\":\"/SC/Trade/HTS_CA/1234abcd\",\"DECISION\":\"AGREE\",\"TASK_TYPE_ID\":\"abcd1234-832b-43b6-afa6-361253ffe1d5\",\"NAME\":\"something\"}",
          "{\"index\":{}}",
          "{\"LAST_MODIFIED_BY\":\"sarah\",\"LAST_MODIFIED_DATE\":\"2018-08-26 12:02:03.0\",\"CLASS_NAME\":\"/SC/Import/HTS_US/9876abcd\",\"DECISION\":\"DISAGREE\",\"TASK_TYPE_ID\":\"abcd1234-832b-43b6-afa6-361253ffe1d5\",\"NAME\":\"nicename\"}"
        ]
      }
    ],
    "identifier": 67650620
  },
  {
    "context": [
      "I have a JSON in the below format, I want to create an HTML file from it in the given format. Unfortunately I can only use 'jq' to achieve this due to some limitations.",
      "the table should be populated in the desired format.",
      "Here's a meat-and-potatoes solution that begins with some generic JSON-to-html filters:",
      "def p($p): \"<p>\\($p)</p>\";",
      "# input: array of arrays\ndef row2html:\n  reduce .[] as $value (\"<tr>\"; . + \"<td>\\($value)</td>\") + \"</tr>\";",
      "# with style\ndef row2html($style):\n  reduce .[] as $value (\"<tr>\";\n     . + \"<td style=\\($style)><strong>\\($value)</strong></td>\") + \"</tr>\";",
      "# input: an array of arrays, the first being treated as a header row\ndef table2html($tablestyle; $headerstyle):\n  \"<table style=\\($tablestyle)>\",\n  \"<tbody>\",\n   (.[0] | row2html($headerstyle)),\n   (.[1:][] | row2html),\n  \"</tbody>\",\n  \"</table>\" ;",
      "# Input: an array of conformal objects\n# Output: header array followed by arrays of values\ndef atomicKeys2arrays:\n  # emit an array of atomic keys\n  def atomicKeys: to_entries | map( select(.value|scalars) | .key);\n  (.[0] | atomicKeys) as $keys\n  | $keys,\n    (.[] | [ .[$keys[]]]);",
      "def tableStyle: \"\\\"border-collapse: collapse; width: 100%;\\\" border=\\\"1\\\"\" ;\ndef headerStyle: \"\\\"text-align: center;\\\"\" ;",
      "def table2html: table2html(tableStyle; headerStyle);",
      "def task:\n  p(\"Summary of JSON\"),\n  ( [atomicKeys2arrays]|table2html ),\n  p(\"Details of value1\"),\n  ([.[0].key4 | atomicKeys2arrays] | table2html ), \n  p(\"Details of value11\"),\n  ([.[1].key4 | atomicKeys2arrays] | table2html ) ;",
      "task"
    ],
    "utterance": "Output nested data as an HTML summary table of key1, key2, key3 for all objects, plus for each object a detailed table for key4 using jq only.",
    "expressions": [
      "def p($p): \"<p>\\($p)</p>\";\n\ndef row2html:\n  reduce .[] as $value (\"<tr>\"; . + \"<td>\\($value)</td>\") + \"</tr>\";\n\ndef row2html($style):\n  reduce .[] as $value (\"<tr>\";\n     . + \"<td style=\\($style)><strong>\\($value)</strong></td>\") + \"</tr>\";\n\ndef table2html($tablestyle; $headerstyle):\n  \"<table style=\\($tablestyle)>\",\n  \"<tbody>\",\n   (.[0] | row2html($headerstyle)),\n   (.[1:][] | row2html),\n  \"</tbody>\",\n  \"</table>\";\n\ndef atomicKeys2arrays:\n  def atomicKeys: to_entries | map( select(.value|scalars) | .key);\n  (.[0] | atomicKeys) as $keys\n  | $keys,\n    (.[] | [ .[$keys[]]]);\n\ndef tableStyle: \"\\\"border-collapse: collapse; width: 100%;\\\" border=\\\"1\\\"\";\ndef headerStyle: \"\\\"text-align: center;\\\"\";\ndef table2html: table2html(tableStyle; headerStyle);\n\ndef task:\n  p(\"Summary of JSON\"),\n  ( [atomicKeys2arrays]|table2html ),\n  p(\"Details of value1\"),\n  ([.[0].key4 | atomicKeys2arrays] | table2html ),\n  p(\"Details of value11\"),\n  ([.[1].key4 | atomicKeys2arrays] | table2html );\n\ntask"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3",
            "key4": [
              {
                "key5": "value5",
                "key6": "value6"
              },
              {
                "key5": "value7",
                "key6": "value8"
              }
            ]
          },
          {
            "key1": "value11",
            "key2": "value12",
            "key3": "value13",
            "key4": [
              {
                "key5": "value15",
                "key6": "value16"
              },
              {
                "key5": "value17",
                "key6": "value18"
              }
            ]
          }
        ],
        "output": [
          "<p>Summary of JSON</p>",
          "<table style=\"border-collapse: collapse; width: 100%;\" border=\"1\">",
          "<tbody>",
          "<tr><td style=\"text-align: center;\"><strong>key1</strong></td><td style=\"text-align: center;\"><strong>key2</strong></td><td style=\"text-align: center;\"><strong>key3</strong></td></tr>",
          "<tr><td>value1</td><td>value2</td><td>value3</td></tr>",
          "<tr><td>value11</td><td>value12</td><td>value13</td></tr>",
          "</tbody>",
          "</table>",
          "<p>Details of value1</p>",
          "<table style=\"border-collapse: collapse; width: 100%;\" border=\"1\">",
          "<tbody>",
          "<tr><td style=\"text-align: center;\"><strong>key5</strong></td><td style=\"text-align: center;\"><strong>key6</strong></td></tr>",
          "<tr><td>value5</td><td>value6</td></tr>",
          "<tr><td>value7</td><td>value8</td></tr>",
          "</tbody>",
          "</table>",
          "<p>Details of value11</p>",
          "<table style=\"border-collapse: collapse; width: 100%;\" border=\"1\">",
          "<tbody>",
          "<tr><td style=\"text-align: center;\"><strong>key5</strong></td><td style=\"text-align: center;\"><strong>key6</strong></td></tr>",
          "<tr><td>value15</td><td>value16</td></tr>",
          "<tr><td>value17</td><td>value18</td></tr>",
          "</tbody>",
          "</table>"
        ]
      }
    ],
    "identifier": 67544203
  },
  {
    "context": [
      "i want select if  \"Name\": \"bot-block\" then  update it's \u200b\"Action\": to \"Block\": {} from  \"Allow\": {}",
      "my current command ``` jq  '.[] | select(.Name==\"bot-block\") | .Action |= . + { \"Block\" : {} } ' input.json ```",
      "but it filters my json and only returns the item with .Name=bot-block,i want updation in json not filtering",
      "You can directly \"assign\" to the `Action` element of the selected array item. `|=` only affects the selected item, but the output of the filter is still the entire input.",
      "jq  'map(select(.Name==\"bot-block\").Action |= {Block: {}})' input.json",
      "should be\n\n```jq\n( .[] | select(.Name==\"bot-block\") | .Action ) |= . + { \"Block\" : {} }\n```"
    ],
    "utterance": "Update the item where Name is \"bot-block\" by changing its Action key to have Block: {} instead of Allow: {}, without filtering out other items.",
    "expressions": [
      "map(select(.Name==\"bot-block\").Action |= {Block: {}})",
      "( .[] | select(.Name==\"bot-block\") | .Action ) |= . + { \"Block\" : {} }"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "searchblock",
            "Priority": 3,
            "Action": {
              "Block": {}
            },
            "VisibilityConfig": {
              "SampledRequestsEnabled": true,
              "CloudWatchMetricsEnabled": true,
              "MetricName": "searchblock"
            }
          },
          {
            "Name": "bot-block",
            "Priority": 4,
            "Action": {
              "Allow": {}
            },
            "VisibilityConfig": {
              "SampledRequestsEnabled": true,
              "CloudWatchMetricsEnabled": true,
              "MetricName": "user-agent"
            }
          }
        ],
        "output": [
          {
            "Name": "searchblock",
            "Priority": 3,
            "Action": {
              "Block": {}
            },
            "VisibilityConfig": {
              "SampledRequestsEnabled": true,
              "CloudWatchMetricsEnabled": true,
              "MetricName": "searchblock"
            }
          },
          {
            "Name": "bot-block",
            "Priority": 4,
            "Action": {
              "Block": {}
            },
            "VisibilityConfig": {
              "SampledRequestsEnabled": true,
              "CloudWatchMetricsEnabled": true,
              "MetricName": "user-agent"
            }
          }
        ]
      }
    ],
    "identifier": 67650215
  },
  {
    "context": [
      "I want to get a list of objects that have only the keys and their values that i specifiy.",
      ".Results | .[] |  with_entries(select([.key] | inside([\"key\",\"key2\", \"key3\"])))",
      "[.Results[]|with_entries(select(.key|IN(\"KeyIwant\",\"etc\")))]",
      "If you want the whitelist to be presented as a JSON array, say $w, then write IN($w[])"
    ],
    "utterance": "Extract an array of objects from Results, each containing only specified keys and their values, such as KeyIwant.",
    "expressions": [
      "[.Results[] | with_entries(select(.key|IN(\"KeyIwant\",\"etc\")))]",
      "[.Results[] | with_entries(select(.key|IN($w[])))]"
    ],
    "data": [
      {
        "input": {
          "Key": "value",
          "Results": [
            {
              "KeyIwant": "value1",
              "OtherKey": "blah"
            },
            {
              "KeyIwant": "value2",
              "OtherKey": "blub"
            }
          ]
        },
        "output": [
          {
            "KeyIwant": "value1"
          },
          {
            "KeyIwant": "value2"
          }
        ]
      }
    ],
    "identifier": 67683574
  },
  {
    "context": [
      "How can I do a split on single quotes?",
      "echo \"{\\\"username\\\": \\\"hu'lk\\\"}\" | jq -r '.username|split(\"\\'\")|join(\"\")'",
      "You could use `split(\"'\")` or",
      "Consider also `gsub(\"'\";\"\")`"
    ],
    "utterance": "Remove all single quote characters from the value of the username field.",
    "expressions": [
      ".username | split(\"'\") | join(\"\")",
      ".username | gsub(\"'\";\"\")"
    ],
    "data": [
      {
        "input": {
          "username": "hu'lk"
        },
        "output": "hulk"
      }
    ],
    "identifier": 67689961
  },
  {
    "context": [
      "I have a Bash script that uses jq and a for loop to iterate through an array, grab a directory that I need to be monitored by Amazon CloudWatch, and stick it into the latter's JSON configuration file.",
      "However, for some reason, only the last item in the array is actually being written.",
      "Using `jq --args` allows the `logPaths` array to be passed in as a set of positional arguments, and referred to from within the relevant jq code as `$ARGS.positional`.",
      "($ARGS.positional | [\n    .[] | { \"file_path\": .,\n            \"log_group_name\": \"/aws-account/aws/ec2/syslogs\",\n            \"log_stream_name\": $definedElsewhere,\n            \"timestamp_format\": \"%b %d %H:%M:%S\"\n          }]) as $newLogSinks |\n    .logs.logs_collected.files.collect_list += $newLogSinks"
    ],
    "utterance": "Append multiple new file configuration objects with specified file paths, log group name '/aws-account/aws/ec2/syslogs', a given log stream name, and a timestamp format, to the logs.logs_collected.files.collect_list array.",
    "expressions": [
      "($ARGS.positional | [\n    .[] | { \"file_path\": ., \"log_group_name\": \"/aws-account/aws/ec2/syslogs\", \"log_stream_name\": $definedElsewhere, \"timestamp_format\": \"%b %d %H:%M:%S\" }\n]) as $newLogSinks | .logs.logs_collected.files.collect_list += $newLogSinks"
    ],
    "data": [
      {
        "input": {
          "logs": {
            "logs_collected": {
              "files": {
                "collect_list": [
                  {
                    "test": "make sure this old data is retained"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "logs": {
            "logs_collected": {
              "files": {
                "collect_list": [
                  {
                    "test": "make sure this old data is retained"
                  },
                  {
                    "file_path": "/shared/logs/application/application1",
                    "log_group_name": "/aws-account/aws/ec2/syslogs",
                    "log_stream_name": "Other Value",
                    "timestamp_format": "%b %d %H:%M:%S"
                  },
                  {
                    "file_path": "/shared/logs/application/application2",
                    "log_group_name": "/aws-account/aws/ec2/syslogs",
                    "log_stream_name": "Other Value",
                    "timestamp_format": "%b %d %H:%M:%S"
                  },
                  {
                    "file_path": "/shared/logs/application/application3",
                    "log_group_name": "/aws-account/aws/ec2/syslogs",
                    "log_stream_name": "Other Value",
                    "timestamp_format": "%b %d %H:%M:%S"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 67676812
  },
  {
    "context": [
      "I\u2019d like to change the value for all **UIDs** inside of the **notifications** array to another value.",
      "You\u2019re overcomplicating:\r\n\r\n    jq '.panels[].panels[].alert.notifications[].uid |= \"newvalue\"'",
      "An alternative ... where we use `walk()` to change literally all the `.uid` values so we don\u2019t have to define the full path:\r\n\nwalk(if type == \"object\" and has(\"uid\") then .uid = \"NEW VALUE\" else . end)"
    ],
    "utterance": "Replace all UID values inside notifications arrays in all nested panels with the value 'newvalue'.",
    "expressions": [
      ".panels[].panels[].alert.notifications[].uid |= \"newvalue\"",
      "walk(if type == \"object\" and has(\"uid\") then .uid = \"newvalue\" else . end)"
    ],
    "data": [
      {
        "input": {
          "panels": [
            {
              "panels": [
                {
                  "alert": {
                    "notifications": [
                      {
                        "uid": "dmRej73Gz"
                      }
                    ]
                  }
                }
              ]
            }
          ]
        },
        "output": {
          "panels": [
            {
              "panels": [
                {
                  "alert": {
                    "notifications": [
                      {
                        "uid": "newvalue"
                      }
                    ]
                  }
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 67693604
  },
  {
    "context": [
      "All i want to do is to fill \"students\" with a variable and i use `jq` for that, but i get this error:",
      "Actually, want to do modify JSON and get:\nHere is my config:\n{\n  \"students\": \"Andrei\"\n}",
      "jq with variable for key and value:\n\n    jq --arg KEY \"students\" --arg VALUE \"Andrei\" '{($KEY):$VALUE}' file"
    ],
    "utterance": "Set the value of the 'students' key to 'Andrei', using variables for the key and value.",
    "expressions": [
      "{($KEY):$VALUE}"
    ],
    "data": [
      {
        "input": {
          "students": ""
        },
        "output": {
          "students": "Andrei"
        }
      }
    ],
    "identifier": 67710843
  },
  {
    "context": [
      "I have an JSON array as below : ",
      "[ { \"key\" : \"Name\", \"value\" : \"John\" }, { \"key\" : \"City\", \"value\" : \"New York\" }, { \"key\" : \"Country\", \"value\" : \"USA\" } ]",
      "I need to convert it to a String like below :",
      "--metadata \"key\": \"Name\", \"value\" : \"John\" --metadata \"key\": \"City\", \"value\" : \"New York\" --metadata \"key\": \"Country\", \"value\" : \"USA\"",
      "EDIT: see below for how to do this without `awk`",
      "EDIT: I just saw @oguz ismail's comment; using `map` and `join` gets rid of the need for `awk`:",
      "jq -r 'map(\"--metadata \\\"key\\\": \\\"\\(.key)\\\", \\\"value\\\": \\\"\\(.value)\\\"\") | join(\" \")' so8247.json",
      "EDIT: Using Charles Duffy's suggestion of using from the comment of using '-j' to eliminate the `map`, `join`, and `awk`:",
      "jq -j '.[] | \"--metadata \\\"key\\\": \\\"\\(.key)\\\", \\\"value\\\": \\\"\\(.value)\\\"\"' so8247.json"
    ],
    "utterance": "Produce a single string where each object is formatted as --metadata \"key\": \"value\", \"value\": \"value\" and all are separated by spaces.",
    "expressions": [
      "map(\"--metadata \\\"key\\\": \\\"\\(.key)\\\", \\\"value\\\": \\\"\\(.value)\\\"\") | join(\" \")",
      ".[] | \"--metadata \\\"key\\\": \\\"\\(.key)\\\", \\\"value\\\": \\\"\\(.value)\\\"\""
    ],
    "data": [
      {
        "input": [
          {
            "key": "Name",
            "value": "John"
          },
          {
            "key": "City",
            "value": "New York"
          },
          {
            "key": "Country",
            "value": "USA"
          }
        ],
        "output": "--metadata \"key\": \"Name\", \"value\": \"John\" --metadata \"key\": \"City\", \"value\": \"New York\" --metadata \"key\": \"Country\", \"value\": \"USA\""
      }
    ],
    "identifier": 67648247
  },
  {
    "context": [
      "Using jq, i want to test if an element exist in an array, if yes being able to mofify this element, if not adding this element to that array",
      "Elem.CHAINLIST exist in Obj.COPY [] ?\n\n yes : add Elem.ELEMENT to Obj.ELEMENT[] with unique to qvoid duplicates \n\n no : add Elem to Obj.COPY[]",
      "The following solution uses the built-in function `INDEX/2` to create convenient and efficient representations\nof the collections of CHAINLIST-ELEMENT objects, together with a bespoke function, `augment/1`, for combining elements.",
      "Use `unique` to combine the .ELEMENT fields",
      "reduce ($b|keys_unsorted[]) as $key (.; \n   .[$key].ELEMENT = (.[$key].ELEMENT + $b[$key].ELEMENT | unique));"
    ],
    "utterance": "For each update object: if an object in COPY has the same CHAINLIST value, append its ELEMENT array to the existing object's ELEMENT array (ensuring unique values); if not, add it as a new object.",
    "expressions": [
      "def augment($b): reduce ($b|keys_unsorted[]) as $key (.; .[$key].ELEMENT = (.[$key].ELEMENT + $b[$key].ELEMENT | unique));\n(INDEX($edits[];.CHAINLIST) | map_values(del(.CHAINLIST))) as $edits\n| (INDEX(.COPY[]; .CHAINLIST) | map_values(del(.CHAINLIST))) as $COPY\n| .COPY |= ($COPY | augment($edits) | to_entries | map( { CHAINLIST: .key, ELEMENT: .value.ELEMENT} ))"
    ],
    "data": [
      {
        "input": {
          "LOGIN": "user",
          "COPY": [
            {
              "CHAINLIST": "chain1",
              "ELEMENT": [
                "element1-1",
                "element1-2"
              ]
            },
            {
              "CHAINLIST": "chain2",
              "ELEMENT": [
                "element2-1",
                "element2-2"
              ]
            }
          ]
        },
        "output": {
          "LOGIN": "user",
          "COPY": [
            {
              "CHAINLIST": "chain1",
              "ELEMENT": [
                "element1-1",
                "element1-2"
              ]
            },
            {
              "CHAINLIST": "chain2",
              "ELEMENT": [
                "element2-1",
                "element2-2",
                "element2-3"
              ]
            },
            {
              "CHAINLIST": "chain3",
              "ELEMENT": [
                "element3-1"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 67708288
  },
  {
    "context": [
      "cat VIAC.json | jq '.underlyingPrice - (.callExpDateMap[][][] | select(.putCall == \"CALL\").bid)'",
      "41.540000000000006",
      "Expected values",
      "41.54",
      "I know I can use awk and other functions to get what I need, but would like to understand why this is happening."
    ],
    "utterance": "Subtract all .bid values where .putCall is \"CALL\" from .underlyingPrice and display the result with two decimal places.",
    "expressions": [
      ".as({p: .underlyingPrice}) | .callExpDateMap[][][] | select(.putCall == \"CALL\") | (.p - .bid) | tostring | tonumber | . as $n | ( ($n * 100 | round) / 100 )",
      ".as({p: .underlyingPrice}) | .callExpDateMap[][][] | select(.putCall == \"CALL\") | (.p - .bid) | @sprintf(\"%.2f\", .)"
    ],
    "data": [
      {
        "input": {
          "underlyingPrice": 42.34,
          "callExpDateMap": {
            "2022-01-21:1": [
              [
                {
                  "putCall": "CALL",
                  "bid": 0.8
                },
                {
                  "putCall": "CALL",
                  "bid": 0.55
                }
              ]
            ]
          }
        },
        "output": [
          "41.54",
          "41.79"
        ]
      }
    ],
    "identifier": 67711148
  },
  {
    "context": [
      "Let&#39;s say I have a JSON map like so:\r\n\r\n```\r\n{\r\n  &quot;a&quot;: &quot;1&quot;,\r\n  &quot;b&quot;: &quot;3&quot;,\r\n  &quot;c&quot;: &quot;2&quot;,\r\n  &quot;d&quot;: &quot;1&quot;\r\n}\r\n```\r\n\r\nHow can I invert it and create lists for duplicates. So end up with this:\r\n\r\n```\r\n{\r\n &quot;1&quot;: [ &quot;a&quot;, &quot;d&quot;],\r\n &quot;2&quot;: &quot;c&quot;,\r\n &quot;3&quot;: &quot;b&quot; \r\n}\r\n```\r\n\r\nor\r\n\r\n\r\n```\r\n{\r\n &quot;1&quot;: [ &quot;a&quot;, &quot;d&quot;],\r\n &quot;2&quot;: [&quot;c&quot;],\r\n &quot;3&quot;: [&quot;b&quot;] \r\n}\r\n```",
      "The following implementation avoids the sorting entailed by `group_by`:\r\n\r\n```\r\n# Input: a JSON object, $in, viewed as a mapping of keys to strings;\r\n# Output: a JSON object, all values of which are arrays.\r\n# The output represents the inverse relation defined\r\n# by $in|map_values(tostring)\r\ndef inverseMapping: \r\n  reduce to_entries[] as $pair ({};\r\n    .[$pair.value|tostring] += [$pair.key]);\r\n```",
      "Example: Using the JSON data in the question, the output would be:\r\n\r\n    {&quot;1&quot;:[&quot;a&quot;,&quot;d&quot;],&quot;3&quot;:[&quot;b&quot;],&quot;2&quot;:[&quot;c&quot;]}",
      "The following function implements the transformation envisioned by the first possibility mentioned in the question:\r\n```\r\ndef quasiInverseMapping:\r\n  reduce to_entries[] as $pair ({};\r\n    ($pair.value|tostring) as $v\r\n     | if (.[$v]|type) == &quot;array&quot; then .[$v] += [$pair.key]\r\n       elif .[$v] then .[$v] = [.[$v], $pair.key]\r\n       else .[$v] = $pair.key\r\n       end) ;\r\n```",
      "Example: Using the JSON data in the question, the output would be:\r\n\r\n    {&quot;1&quot;:[&quot;a&quot;,&quot;d&quot;],&quot;3&quot;:&quot;b&quot;,&quot;2&quot;:&quot;c&quot;}"
    ],
    "utterance": "Invert a map so each value maps to the list of its original keys, grouping duplicates together.",
    "expressions": [
      "reduce to_entries[] as $pair ({}; .[$pair.value|tostring] += [$pair.key])",
      "def inverseMapping: reduce to_entries[] as $pair ({}; .[$pair.value|tostring] += [$pair.key]);",
      "def quasiInverseMapping: reduce to_entries[] as $pair ({};\n  ($pair.value|tostring) as $v\n   | if (.[$v]|type) == \"array\" then .[$v] += [$pair.key]\n     elif .[$v] then .[$v] = [.[$v], $pair.key]\n     else .[$v] = $pair.key\n     end);"
    ],
    "data": [
      {
        "input": {
          "a": "1",
          "b": "3",
          "c": "2",
          "d": "1"
        },
        "output": {
          "1": [
            "a",
            "d"
          ],
          "2": [
            "c"
          ],
          "3": [
            "b"
          ]
        }
      },
      {
        "input": {
          "a": "1",
          "b": "3",
          "c": "2",
          "d": "1"
        },
        "output": {
          "1": [
            "a",
            "d"
          ],
          "2": "c",
          "3": "b"
        }
      }
    ],
    "identifier": 67696478
  },
  {
    "context": [
      "The algorithm should look **for each user** having **the most recent date** which has the **status Done**.",
      "In case the most recent entry is of status Rejected (even if there are Done statuses before it), do not count it.",
      "For the above JSON, the algorithm should return 3.",
      "group_by(.user) | map(select(max_by(.date) .status == \"Done\")) | length"
    ],
    "utterance": "Count how many users have their most recent entry with status Done.",
    "expressions": [
      "group_by(.user) | map(select(max_by(.date) .status == \"Done\")) | length"
    ],
    "data": [
      {
        "input": [
          {
            "user": "PersonA",
            "status": "Done",
            "date": "2021-05-10T12:38:09Z"
          },
          {
            "user": "PersonA",
            "status": "Rejected",
            "date": "2021-05-15T11:08:41Z"
          },
          {
            "user": "PersonB",
            "status": "Rejected",
            "date": "2021-05-15T15:23:49Z"
          },
          {
            "user": "PersonA",
            "status": "Rejected",
            "date": "2021-05-15T18:51:04Z"
          },
          {
            "user": "PersonC",
            "status": "Done",
            "date": "2021-05-19T14:43:12Z"
          },
          {
            "user": "PersonB",
            "status": "Done",
            "date": "2021-05-19T19:29:10Z"
          },
          {
            "user": "PersonA",
            "status": "Done",
            "date": "2021-05-22T10:40:31Z"
          }
        ],
        "output": 3
      }
    ],
    "identifier": 67721185
  },
  {
    "context": [
      "How would I go about returning each document from a list of dictionaries based on whether or not a list contained within each dictionary does or does not contain a specific key name, and find those whose list is empty?",
      "For the distinct items, you could of course use `unique`:",
      "    map(select(.members[] | has(\"subPath\")).name ) | unique[]",
      "Similarly for #2.",
      "For #3, you need to check `.members|length`:",
      "    .[] | select(.members | length == 0)"
    ],
    "utterance": "Return all objects in the input array where the 'members' list contains at least one object with the key 'subPath', or where 'members' does not contain any object with the key 'subPath', or where 'members' is empty.",
    "expressions": [
      "map(select(.members[] | has(\"subPath\"))).name | unique[]",
      "map(select(.members[] | has(\"subPath\") | not)).name | unique[]",
      ".[] | select(.members | length == 0)"
    ],
    "data": [
      {
        "input": [
          {
            "alternate_mode": "global-availability",
            "dynamic_ratio": "no",
            "enabled": "yes",
            "fallback_mode": "return-to-dns",
            "full_path": "/Common/a2ws-test.ree.se.net_pool",
            "load_balancing_mode": "global-availability",
            "manual_resume": "no",
            "max_answers_returned": 1,
            "members": [
              {
                "name": "a2ws-test.ree.se.net-443-vs",
                "partition": "Common",
                "subPath": "f5-tstltm-dmz-dc1-pair:/Common",
                "enabled": "yes",
                "limitMaxBps": 0,
                "limitMaxBpsStatus": "disabled",
                "limitMaxConnections": 0,
                "limitMaxConnectionsStatus": "disabled",
                "limitMaxPps": 0,
                "limitMaxPpsStatus": "disabled",
                "monitor": "default",
                "ratio": 1,
                "disabled": "no",
                "member_order": 0
              },
              {
                "name": "dc2-a2ws-test.ree.se.net-443-vs",
                "partition": "Common",
                "subPath": "f5-tstltm-dmz-dc2-pair:/Common",
                "enabled": "yes",
                "limitMaxBps": 0,
                "limitMaxBpsStatus": "disabled",
                "limitMaxConnections": 0,
                "limitMaxConnectionsStatus": "disabled",
                "limitMaxPps": 0,
                "limitMaxPpsStatus": "disabled",
                "monitor": "default",
                "ratio": 1,
                "disabled": "no",
                "member_order": 1
              }
            ],
            "name": "a2ws-test.ree.se.net_pool",
            "partition": "Common",
            "qos_hit_ratio": 5,
            "qos_hops": 0,
            "qos_kilobytes_second": 3,
            "qos_lcs": 30,
            "qos_packet_rate": 1,
            "qos_rtt": 50,
            "qos_topology": 0,
            "qos_vs_capacity": 0,
            "qos_vs_score": 0,
            "ttl": 30,
            "verify_member_availability": "yes"
          },
          {
            "alternate_mode": "round-robin",
            "dynamic_ratio": "no",
            "enabled": "yes",
            "fallback_mode": "return-to-dns",
            "full_path": "/Common/aci-apic.ree.se.net_pool",
            "load_balancing_mode": "round-robin",
            "manual_resume": "no",
            "max_answers_returned": 1,
            "members": [
              {
                "name": "prd_dc1_servers:aci-apic01.ree.se.net",
                "partition": "Common",
                "enabled": "yes",
                "limitMaxBps": 0,
                "limitMaxBpsStatus": "disabled",
                "limitMaxConnections": 0,
                "limitMaxConnectionsStatus": "disabled",
                "limitMaxPps": 0,
                "limitMaxPpsStatus": "disabled",
                "monitor": "default",
                "ratio": 1,
                "disabled": "no",
                "member_order": 0
              },
              {
                "name": "prd_dc1_servers:aci-apic02.ree.se.net",
                "partition": "Common",
                "enabled": "yes",
                "limitMaxBps": 0,
                "limitMaxBpsStatus": "disabled",
                "limitMaxConnections": 0,
                "limitMaxConnectionsStatus": "disabled",
                "limitMaxPps": 0,
                "limitMaxPpsStatus": "disabled",
                "monitor": "default",
                "ratio": 1,
                "disabled": "no",
                "member_order": 1
              },
              {
                "name": "prd_dc2_servers:aci-apic03.ree.se.net",
                "partition": "Common",
                "enabled": "yes",
                "limitMaxBps": 0,
                "limitMaxBpsStatus": "disabled",
                "limitMaxConnections": 0,
                "limitMaxConnectionsStatus": "disabled",
                "limitMaxPps": 0,
                "limitMaxPpsStatus": "disabled",
                "monitor": "default",
                "ratio": 1,
                "disabled": "no",
                "member_order": 2
              }
            ],
            "name": "aci-apic.ree.se.net_pool",
            "partition": "Common",
            "qos_hit_ratio": 5,
            "qos_hops": 0,
            "qos_kilobytes_second": 3,
            "qos_lcs": 30,
            "qos_packet_rate": 1,
            "qos_rtt": 50,
            "qos_topology": 0,
            "qos_vs_capacity": 0,
            "qos_vs_score": 0,
            "ttl": 30,
            "verify_member_availability": "yes"
          },
          {
            "alternate_mode": "global-availability",
            "dynamic_ratio": "no",
            "enabled": "yes",
            "fallback_mode": "return-to-dns",
            "full_path": "/Common/b2b.ree.se.net_pool",
            "load_balancing_mode": "global-availability",
            "manual_resume": "no",
            "max_answers_returned": 1,
            "members": [],
            "name": "b2b.ree.se.net_pool",
            "partition": "Common",
            "qos_hit_ratio": 5,
            "qos_hops": 0,
            "qos_kilobytes_second": 3,
            "qos_lcs": 30,
            "qos_packet_rate": 1,
            "qos_rtt": 50,
            "qos_topology": 0,
            "qos_vs_capacity": 0,
            "qos_vs_score": 0,
            "ttl": 30,
            "verify_member_availability": "yes"
          }
        ],
        "output": null
      }
    ],
    "identifier": 67443057
  },
  {
    "context": [
      "I\u2019d like to only see the key-value-pairs as output, something like this:\n{\n  \"server.port\": 9110,\n  \"management.port\": 9350,  \n  \"oak\": \"true\",\n  ...\n}",
      "You can simply add `properties` objects, though in order go get that output in return you need to take `value` fields out too.\n.propertySources | map(.properties) | add | map_values(.value)"
    ],
    "utterance": "Combine all properties objects and extract each key with its value field.",
    "expressions": [
      ".propertySources | map(.properties) | add | map_values(.value)"
    ],
    "data": [
      {
        "input": {
          "propertySources": [
            {
              "name": "ports",
              "properties": {
                "server.port": {
                  "value": 9110
                },
                "management.port": {
                  "value": 9350
                }
              }
            },
            {
              "name": "trees",
              "properties": {
                "oak": {
                  "value": "true"
                }
              }
            },
            {
              "name": "elephants",
              "properties": {}
            }
          ]
        },
        "output": {
          "server.port": 9110,
          "management.port": 9350,
          "oak": "true"
        }
      }
    ],
    "identifier": 67722229
  },
  {
    "context": [
      "I want to remove pairs where key name `(VAR-A)` in value `{{a.b.VAR-A}}` (after `a.b.`) matches and If I have more than one `{{a.b.VAR-A}}` in values separated by `-` , I want to keep them.",
      "This question works if I have all strings, but it fails when I have `boolean` value in `yaml`.",
      "del(.[] | select( ( type == \"string\" and test(\"^{{a[.]b[.][^}]*}}$\" ))))",
      "map_values( select( ( type == \"string\" and test(\"^{{a[.]b[.][^}]*}}$\" )) | not))",
      "jq  'del(.[] | select(( type == \"string\" and test(\"^{{a[.]b[.][^}]*}}$\" ))))'",
      "map_values( select( type == \"string\" and test(\"^{{a[.]b[.][^}]*}}$\" | not)"
    ],
    "utterance": "Remove all pairs where the value is a string matching the pattern '{{a.b.<KEY>}}', retaining entries where the value includes additional content (such as concatenation) or where the value is a boolean.",
    "expressions": [
      "del(.[] | select(( type == \"string\" and test(\"^{{a[.]b[.][^}]*}}$\" ))))",
      "map_values(select(( type == \"string\" and test(\"^{{a[.]b[.][^}]*}}$\" )) | not))"
    ],
    "data": [
      {
        "input": {
          "VAR-A": "{{a.b.VAR-A}}",
          "VAR-B": "{{a.b.VAR-B}}",
          "VAR-C": "v0.0",
          "VAR-D": "{{a.b.VAR-D}}-{{a.b.VAR-A}}",
          "VAR-E": "{{a.b.VAR-C}}-{{a.b.VAR-B}}-{{a.b.VAR-A}}",
          "VAR-F": true
        },
        "output": {
          "VAR-C": "v0.0",
          "VAR-D": "{{a.b.VAR-D}}-{{a.b.VAR-A}}",
          "VAR-E": "{{a.b.VAR-C}}-{{a.b.VAR-B}}-{{a.b.VAR-A}}",
          "VAR-F": true
        }
      }
    ],
    "identifier": 67714130
  },
  {
    "context": [
      "I need output in two formats:",
      "1. Repeat the output from first code for every row in the 2nd output to get a \"long format data\".",
      "\"321321\",\"01APR2021\",\"01APR2021\",\"25MAY2021\",0,\"Success\",\"val1\",\"v1.1\",122,\"this is another text\",\"\",\"\",\"\",\"\",\"this is a text\"",
      "2. Concatenate the 4 rows from 2nd output into one row in a fixed order to get a \"wide format data\".",
      "\"321321\",\"01APR2021\",\"01APR2021\",\"25MAY2021\",0,\"Success\",\"val1\",\"v1.1\",122,\"this is another text\",\"\",\"\",\"\",\"\",\"this is a text\",\"val2\",\"v1.1\",-789,\"\",\"\",\"\",\"\",\"\",\"\",\"val3\",\"v1.1\",123,\"\",\"\",\"\",\"\",\"\",\"\",\"val4\",\"v1.1\",234,\"\",\"\",\"\",\"\",\"\",\"and yet another text\"",
      "Assuming all the objects in .listField are conformal:",
      "### First task",
      "[ .id, .date1, .date2, .date3, .numField1, .Status, .strField1 ]\n+ (.listField[] | [.[]] )\n| @csv",
      "### Second task",
      "[ .id, .date1, .date2, .date3, .numField1, .Status, .strField1 ]\n+ [.listField[] | .[] ]\n| @csv"
    ],
    "utterance": "For each object, output a row with the top-level fields followed by the fields of each .listField element (long format); and also output a row with the top-level fields followed by all inner fields of all .listField elements concatenated in fixed order (wide format).",
    "expressions": [
      "[ .id, .date1, .date2, .date3, .numField1, .Status, .strField1 ] + (.listField[] | [.[]] ) | @csv",
      "[ .id, .date1, .date2, .date3, .numField1, .Status, .strField1 ] + [.listField[] | .[] ] | @csv"
    ],
    "data": [
      {
        "input": {
          "id": "321321",
          "date1": "01APR2021",
          "date2": "01APR2021",
          "date3": "25MAY2021",
          "numField1": 0,
          "Status": "Success",
          "strField1": null,
          "listField": [
            {
              "name": "val1",
              "version": "v1.1",
              "value": 122,
              "str1": "this is another text",
              "str2": "",
              "str3": "",
              "str4": "",
              "str5": "",
              "str6": "this is a text"
            },
            {
              "name": "val2",
              "version": "v1.1",
              "value": -789,
              "str1": "",
              "str2": "",
              "str3": "",
              "str4": "",
              "str5": "",
              "str6": ""
            },
            {
              "name": "val3",
              "version": "v1.1",
              "value": 123,
              "str1": "",
              "str2": "",
              "str3": "",
              "str4": "",
              "str5": "",
              "str6": ""
            },
            {
              "name": "val4",
              "version": "v1.1",
              "value": 234,
              "str1": "",
              "str2": "",
              "str3": "",
              "str4": "",
              "str5": "",
              "str6": "and yet another text"
            }
          ]
        },
        "output": [
          "\"321321\",\"01APR2021\",\"01APR2021\",\"25MAY2021\",0,\"Success\",null,\"val1\",\"v1.1\",122,\"this is another text\",\"\",\"\",\"\",\"\",\"this is a text\"",
          "\"321321\",\"01APR2021\",\"01APR2021\",\"25MAY2021\",0,\"Success\",null,\"val2\",\"v1.1\",-789,\"\",\"\",\"\",\"\",\"\",\"\"",
          "\"321321\",\"01APR2021\",\"01APR2021\",\"25MAY2021\",0,\"Success\",null,\"val3\",\"v1.1\",123,\"\",\"\",\"\",\"\",\"\",\"\"",
          "\"321321\",\"01APR2021\",\"01APR2021\",\"25MAY2021\",0,\"Success\",null,\"val4\",\"v1.1\",234,\"\",\"\",\"\",\"\",\"and yet another text\""
        ]
      },
      {
        "input": {
          "id": "321321",
          "date1": "01APR2021",
          "date2": "01APR2021",
          "date3": "25MAY2021",
          "numField1": 0,
          "Status": "Success",
          "strField1": null,
          "listField": [
            {
              "name": "val1",
              "version": "v1.1",
              "value": 122,
              "str1": "this is another text",
              "str2": "",
              "str3": "",
              "str4": "",
              "str5": "",
              "str6": "this is a text"
            },
            {
              "name": "val2",
              "version": "v1.1",
              "value": -789,
              "str1": "",
              "str2": "",
              "str3": "",
              "str4": "",
              "str5": "",
              "str6": ""
            },
            {
              "name": "val3",
              "version": "v1.1",
              "value": 123,
              "str1": "",
              "str2": "",
              "str3": "",
              "str4": "",
              "str5": "",
              "str6": ""
            },
            {
              "name": "val4",
              "version": "v1.1",
              "value": 234,
              "str1": "",
              "str2": "",
              "str3": "",
              "str4": "",
              "str5": "",
              "str6": "and yet another text"
            }
          ]
        },
        "output": "\"321321\",\"01APR2021\",\"01APR2021\",\"25MAY2021\",0,\"Success\",null,\"val1\",\"v1.1\",122,\"this is another text\",\"\",\"\",\"\",\"\",\"this is a text\",\"val2\",\"v1.1\",-789,\"\",\"\",\"\",\"\",\"\",\"\",\"val3\",\"v1.1\",123,\"\",\"\",\"\",\"\",\"\",\"\",\"val4\",\"v1.1\",234,\"\",\"\",\"\",\"\",\"\",\"and yet another text\""
      }
    ],
    "identifier": 67691103
  },
  {
    "context": [
      "But, is there a way to use the key filter with case unsensitive and make this command works :\r\n\r\n    jq '.KeY2=\"123\"' test.json\r\nAnd also... to do nothing if the key was not found in the JSON file. The default behavior is to append the searched key.",
      "`test(regex; \"i\")` can be used to perform a case-insensitive regular expression match in jq. Thus:",
      "An alternative is to convert both versions to lowercase for the comparison only:",
      "You can use `ascii_downcase` to get the lowercase version of the key:\r\n\r\n    jq --arg k Key1 '(.[$k | ascii_downcase] // empty) = \"123\"'\r\n\r\nThe `// empty` part prevents the creation of the key."
    ],
    "utterance": "Update the value of a key, matching the key case-insensitively, and do nothing if the key does not exist.",
    "expressions": [
      "jq --arg key KeY2 --arg newValue 123 '[to_entries[] | if .key | test($key; \"i\") then .value = $newValue else . end ] | from_entries' <test.json",
      "jq --arg key KeY2 --arg newValue 123 '($key | ascii_downcase) as $lower_key | [to_entries[] | if (.key | ascii_downcase) == $lower_key then .value = $newValue else . end ] | from_entries' <test.json",
      "jq --arg k Key1 '(.[$k | ascii_downcase] // empty) = \"123\"'"
    ],
    "data": [
      {
        "input": {
          "key1": "abc",
          "key2": "def",
          "key3": "ghi"
        },
        "output": {
          "key1": "abc",
          "key2": "123",
          "key3": "ghi"
        }
      }
    ],
    "identifier": 67725386
  },
  {
    "context": [
      "Here convert json to csv.",
      "curl -s https://www.githubstatus.com/api/v2/status.json | jq -r '.page | [.id, .name] | @csv'",
      "And here is the result:",
      "\"kctbh9vrtdwd\",\"GitHub\"",
      "But why not print csv headers?",
      "1) Manually add the headers",
      "[\"id\", \"name\"],\n(.page | [.id, .name])\n| @csv",
      "2) Include the headers based on the specification of the relevant columns",
      "[\"id\", \"name\"] as $headers\n| $headers, (.page | [.[$headers[]]])\n| @csv"
    ],
    "utterance": "Produce CSV output that includes the column headers 'id' and 'name', followed by the corresponding values from the 'page' object.",
    "expressions": [
      "[\"id\", \"name\"], (.page | [.id, .name]) | @csv",
      "[\"id\", \"name\"] as $headers | $headers, (.page | [.[$headers[]]]) | @csv"
    ],
    "data": [
      {
        "input": {
          "page": {
            "id": "kctbh9vrtdwd",
            "name": "GitHub",
            "url": "https://www.githubstatus.com",
            "time_zone": "Etc/UTC",
            "updated_at": "2021-05-27T16:56:02.461Z"
          },
          "status": {
            "indicator": "none",
            "description": "All Systems Operational"
          }
        },
        "output": "\"id\",\"name\"\n\"kctbh9vrtdwd\",\"GitHub\""
      }
    ],
    "identifier": 67728663
  },
  {
    "context": [
      "need to get only of id key",
      "output expected is\n```none\n/application1/4b693882-ffba-4c93-a0f2-cccafcb4d7dd\n/application2/4b693882-ffba-4c93-a0f2-cccafcb4d7dd\n```",
      "After fixing the errors in your JSON, we can use the following [tag:JQ] filter to get the desired output:\n```\n.apps[] | .id\n```",
      "Result `jq -r '.apps[] | .id'`:\n```none\n/application1/4b693882-ffba-4c93-a0f2-cccafcb4d7dd\n/application2/4b693882-ffba-4c93-a0f2-cccafcb4d7dd\n```"
    ],
    "utterance": "List only the values of the 'id' keys from all objects in the 'apps' array.",
    "expressions": [
      ".apps[] | .id",
      ".apps[].id"
    ],
    "data": [
      {
        "input": {
          "apps": [
            {
              "id": "/application1/4b693882-ffba-4c93-a0f2-cccafcb4d7dd",
              "cmd": null,
              "args": null,
              "user": null,
              "env": {},
              "constraints": [
                [
                  "hostname",
                  "GROUP_BY",
                  "5"
                ]
              ]
            },
            {
              "id": "/application2/4b693882-ffba-4c93-a0f2-cccafcb4d7dd",
              "cmd": null,
              "args": null,
              "user": null,
              "env": {},
              "constraints": [
                [
                  "hostname",
                  "GROUP_BY",
                  "5"
                ]
              ]
            }
          ]
        },
        "output": [
          "/application1/4b693882-ffba-4c93-a0f2-cccafcb4d7dd",
          "/application2/4b693882-ffba-4c93-a0f2-cccafcb4d7dd"
        ]
      }
    ],
    "identifier": 67739619
  },
  {
    "context": [
      "I need to extract only the servers whose status is online (in this case server2, server 4) from the below json. Can anyone help me with this? I need solution in jq with 1.5 version",
      "If you want to include servers if *any* instance of it is online,",
      "jq -r '[ .[].machines[] | select(.status == \"online\") | .name ] | unique[]'"
    ],
    "utterance": "List the names of all servers that have any instance with status equal to \"online\".",
    "expressions": [
      "[ .[].machines[] | select(.status == \"online\") | .name ] | unique[]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "core.vm",
            "machines": [
              {
                "name": "server1",
                "max_load": 220,
                "status": "offline"
              },
              {
                "name": "server2",
                "max_load": 220,
                "status": "online"
              }
            ]
          },
          {
            "name": "cust.vm",
            "machines": [
              {
                "name": "server1",
                "max_load": 20,
                "status": "offline"
              },
              {
                "name": "server2",
                "max_load": 20,
                "status": "online"
              }
            ]
          },
          {
            "name": "intl.vm",
            "machines": [
              {
                "name": "server3",
                "max_load": 20,
                "status": "offline"
              },
              {
                "name": "server4",
                "max_load": 20,
                "status": "online"
              }
            ]
          }
        ],
        "output": [
          "server2",
          "server4"
        ]
      }
    ],
    "identifier": 67748815
  },
  {
    "context": [
      "I have multiline string like\r\n\r\n    a=aValue\r\n    b=bValue\r\n    c=cValue\r\n    a=dValue\r\n    b=eValue\r\n    c=fValue\r\n\r\nHow using jq get json like this?\r\n\r\n    [\r\n      {\"a\": \"aValue\", \"b\": \"bValue\", \"c\": \"cValue\"},\r\n      {\"a\": \"dValue\", \"b\": \"eValue\", \"c\": \"fValue\"}\r\n    ]",
      "jq -R -s '[ split(\"\\n\") | map(split(\"=\") | {(.[0]): .[1]}) | _nwise(3) | add ]'",
      "If values may contain equals signs, use .[1:] | join(\"=\") instead of .[1].",
      "Here's an answer that is not tied to the number of distinct keys, and avoids slurping the lines (i.e., has minimal memory requirements):",
      "jq -Rn 'foreach (inputs, null) as $in ({};\n    if $in == null then .emit = .object\n    else ($in | capture(\"(?<key>[^=]*)=(?<value>.*)\") // null) as $kv\n    | if $kv == null \n      then .\n      elif (.object | . and has($kv.key)) \n      then .emit = .object | .object  = ([$kv]|from_entries)\n      else .emit = null    | .object += ([$kv]|from_entries)\n      end\n    end ;\n    select(.emit).emit )'",
      "Note that the above produces a stream, so if you want all the objects in an array, simply enclose the entire jq program in square brackets:"
    ],
    "utterance": "Convert a multiline string where each group of consecutive lines in the format key=value should become an object in an array, grouping every set of lines with the same keys together.",
    "expressions": [
      "split(\"\\n\") | map(split(\"=\") | {(.[0]): .[1]}) | _nwise(3) | add",
      "foreach (inputs, null) as $in ({};\n    if $in == null then .emit = .object\n    else ($in | capture(\"(?<key>[^=]*)=(?<value>.*)\") // null) as $kv\n    | if $kv == null \n      then .\n      elif (.object | . and has($kv.key)) \n      then .emit = .object | .object  = ([$kv]|from_entries)\n      else .emit = null    | .object += ([$kv]|from_entries)\n      end\n    end ;\n    select(.emit).emit )"
    ],
    "data": [
      {
        "input": "a=aValue\nb=bValue\nc=cValue\na=dValue\nb=eValue\nc=fValue",
        "output": [
          {
            "a": "aValue",
            "b": "bValue",
            "c": "cValue"
          },
          {
            "a": "dValue",
            "b": "eValue",
            "c": "fValue"
          }
        ]
      }
    ],
    "identifier": 67734002
  },
  {
    "context": [
      "I need output as : \n\"my-created-lb\"\n\"10.45.78.9:80\",\"enabled\"\n\"10.45.78.10:80\",\"enabled\"\n\"10.45.78.11:80\",\"enabled\"\n\"10.45.78.12:80\",\"enabled\"",
      "Because you want the key's name, you could use `to_entries` like this:",
      "To get the exact output listed in the original post, modify the `jq` script to be:\n```\njq -r '.[] | [.fqdn], ( .members | to_entries | .[] | [ .key, .value.state ] ) | @csv'\n```",
      "To get precisely your desired output:\n```bash\njq -r '.[] | ([.fqdn]|@csv), (.members | keys[] as $k | [$k, .[$k].state] | @csv)' file.json\n```"
    ],
    "utterance": "Display the fqdn, followed by each member's key and its state as separate CSV lines, matching the given output format.",
    "expressions": [
      ".[] | [.fqdn], ( .members | to_entries | .[] | [ .key, .value.state ] ) | @csv",
      ".[] | ([.fqdn]|@csv), (.members | keys[] as $k | [$k, .[$k].state] | @csv)"
    ],
    "data": [
      {
        "input": [
          {
            "fqdn": "my-created-lb",
            "status": "Active",
            "members": {
              "10.45.78.9:80": {
                "dc": "NA",
                "state": "enabled",
                "port": 80
              },
              "10.45.78.10:80": {
                "dc": "NA",
                "state": "enabled",
                "port": 80
              },
              "10.45.78.11:80": {
                "dc": "NA",
                "state": "enabled",
                "port": 80
              },
              "10.45.78.12:80": {
                "dc": "NA",
                "state": "enabled",
                "port": 80
              }
            }
          }
        ],
        "output": [
          "\"my-created-lb\"",
          "\"10.45.78.9:80\",\"enabled\"",
          "\"10.45.78.10:80\",\"enabled\"",
          "\"10.45.78.11:80\",\"enabled\"",
          "\"10.45.78.12:80\",\"enabled\""
        ]
      }
    ],
    "identifier": 67741660
  },
  {
    "context": [
      "How can I get the size of the list of each key using `jq`, so that it outputs:\r\n\r\n    {\"a\": 3, \"b\": 4, \"c\": 1}",
      "Use `map_values`, it is like `map`, but works on objects too.",
      "map_values(length)"
    ],
    "utterance": "Count the number of elements in each top-level array by key, returning an object with the same keys and counts.",
    "expressions": [
      "map_values(length)"
    ],
    "data": [
      {
        "input": {
          "a": [
            "2",
            "33",
            "ff"
          ],
          "b": [
            "4",
            "aa",
            "555",
            "4445"
          ],
          "c": [
            "a"
          ]
        },
        "output": {
          "a": 3,
          "b": 4,
          "c": 1
        }
      }
    ],
    "identifier": 67790535
  },
  {
    "context": [
      "I have a json response in a variable called %VM% defined by ... Echoing %VM% shows a json string like: {\"notes\":\"SVR Pro 123263\",\"osType\":\"Windows\",\"size\":\"Std\",\"environment\":\"someTxtHere\"}",
      "for /F \"delims=\" %%a in (\"%VM% | jq .environment\") Do Set environment=%%a",
      "Looks like the following fixed it [\u2026]. `For /F \"Delims=\" %%G in ('\"echo %VM%\" ^| jq .environment') Do Set \"environment=%%G\"`"
    ],
    "utterance": "Extract the value associated with the environment key from a variable containing an object where environment is set to someTxtHere.",
    "expressions": [
      ".environment"
    ],
    "data": [
      {
        "input": {
          "notes": "SVR Pro 123263",
          "osType": "Windows",
          "size": "Std",
          "environment": "someTxtHere"
        },
        "output": "someTxtHere"
      }
    ],
    "identifier": 67788464
  },
  {
    "context": [
      "category_ids=`jq '.categories | keys[]' $dictionary_location`",
      "For some reason I have to turn it into an array to iterate properly."
    ],
    "utterance": "Extract all keys from the object under the 'categories' property.",
    "expressions": [
      ".categories | keys[]"
    ],
    "identifier": 67795602
  },
  {
    "context": [
      "i would like to select all objects with \"foo\" key equal to \"aaa\" or \"bbb\".",
      "i would like to enhance it and replace that `x=y or x=z` to sql'ish styled `x in (y,z)`.",
      "hmm, i managed to do it with this:",
      "```.[] | select(.foo as $tmpvar | [\"aaa\", \"bbb\"] | index ($tmpvar ) )```",
      "in versions above 1.5 there is a new `IN` operator that makes life a bit easier:",
      ".[] | select(.foo|IN(\"aaa\",\"bbb\"))",
      "my recommendation is to use a simple regex test:",
      "map(select(.foo | test(\"aaa|bbb\")))"
    ],
    "utterance": "Select all objects where the field 'foo' is either 'aaa' or 'bbb'.",
    "expressions": [
      ".[] | select(.foo == \"aaa\" or .foo == \"bbb\")",
      ".[] | select(.foo as $tmpvar | [\"aaa\", \"bbb\"] | index($tmpvar))",
      ".[] | select(.foo|IN(\"aaa\",\"bbb\"))",
      "map(select(.foo | test(\"aaa|bbb\")))"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "aaa",
            "bar": 111
          },
          {
            "foo": "bbb",
            "bar": 111
          },
          {
            "foo": "ccc",
            "bar": 222
          },
          {
            "foo": "aaa",
            "bar": 333
          },
          {
            "foo": "ddd",
            "bar": 444
          }
        ],
        "output": [
          {
            "foo": "aaa",
            "bar": 111
          },
          {
            "foo": "bbb",
            "bar": 111
          },
          {
            "foo": "aaa",
            "bar": 333
          }
        ]
      }
    ],
    "identifier": 67774229
  },
  {
    "context": [
      "I want to determine which top level keys have a sub-object K/V .type=\"generic\".",
      "in this case, I use the following:",
      "jq 'to_entries[] | select (.value.type == \"generic\") | .key' vault.json",
      "which produces:",
      "\"somekey1/\"",
      "\"somekey3/\"",
      "Which is exactly what I am looking for."
    ],
    "utterance": "Find all top-level keys whose child object has a type field equal to \"generic\".",
    "expressions": [
      "to_entries[] | select(.value.type == \"generic\") | .key"
    ],
    "data": [
      {
        "input": {
          "somekey1/": {
            "accessor": "generic_123456",
            "config": {
              "default_lease_ttl": 0,
              "force_no_cache": false,
              "max_lease_ttl": 0
            },
            "description": "",
            "external_entropy_access": false,
            "local": false,
            "options": {},
            "seal_wrap": false,
            "type": "generic",
            "uuid": "1111111-2222-3333-4444-55555555555"
          },
          "somekey2/": {
            "accessor": "aws_123456",
            "config": {
              "default_lease_ttl": 3600,
              "force_no_cache": false,
              "max_lease_ttl": 86400
            },
            "description": "",
            "external_entropy_access": false,
            "local": false,
            "options": null,
            "seal_wrap": false,
            "type": "aws",
            "uuid": "1111111-2222-3333-4444-55555555555"
          },
          "somekey3/": {
            "accessor": "generic_1234567",
            "config": {
              "default_lease_ttl": 0,
              "force_no_cache": false,
              "max_lease_ttl": 0
            },
            "description": "",
            "external_entropy_access": false,
            "local": false,
            "options": {},
            "seal_wrap": false,
            "type": "generic",
            "uuid": "1111111-2222-3333-4444-55555555555"
          }
        },
        "output": [
          "somekey1/",
          "somekey3/"
        ]
      }
    ],
    "identifier": 67794752
  },
  {
    "context": [
      "My list of values is something like `a b c`. This list is stored as a scalar variable in bash (not hardcoded). How can I select the corresponding objects from the JSON from this list of values?",
      "Pass the list of ids to JQ using the `--arg` directive, split it into an array there and keep that in a variable, and test whether an object's `id` field holds a value that resides in that array using the IN built-in.",
      "`jq --arg ids \"$var\" '($ids / \" \") as $ids | .[] | select(.id | IN($ids[]))' file`"
    ],
    "utterance": "Select all objects whose id field matches any value provided in a space-separated string variable.",
    "expressions": [
      "($ids / \" \") as $ids | .[] | select(.id | IN($ids[]))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "a"
          },
          {
            "id": "b"
          },
          {
            "id": "z"
          }
        ],
        "output": [
          {
            "id": "a"
          },
          {
            "id": "b"
          }
        ]
      }
    ],
    "identifier": 67806267
  },
  {
    "context": [
      "I have tried multiple jq filters to try to get to a result that looks like\r\n**interfaceId,vendor,addresses**",
      "I want the output to be:\r\n\r\n`interfaceId,vendor,addresses`        for each record returned by curl/json",
      "jq -r '.macTable[] | [.interfaceId, .vendor, .addresses[]] | @csv' x.json",
      "output is something like\n\n\"eth1\",\"Apple\",\"192.168.5.101\"\n\"eth1\",\"BB Technologies (Limited)\",\"192.xxx.x.1\"\n\"eth1\",,\"192.xxx.x.100\""
    ],
    "utterance": "Produce each record's interfaceId, vendor, and addresses as comma-separated values on a single line for every entry in macTable.",
    "expressions": [
      ".macTable[] | [.interfaceId, .vendor, .addresses[]] | @csv"
    ],
    "data": [
      {
        "input": {
          "deviceId": "75c2fde3-4b5a-4faf-a24d-d8019e8911e1",
          "macTable": [
            {
              "interfaceId": "eth1",
              "addresses": [
                "192.168.5.101"
              ],
              "mac": "3c:15:c2:c3:f0:e0",
              "vendor": "Apple",
              "vlan": null,
              "hostname": null,
              "device": {
                "id": null,
                "connected": null,
                "enabled": null,
                "authorized": null,
                "ipAddress": null,
                "identification": {
                  "id": null,
                  "type": null
                },
                "overview": {
                  "status": "unknown"
                }
              },
              "site": null
            },
            {
              "interfaceId": "eth1",
              "addresses": [
                "192.xxx.x.1"
              ],
              "mac": "xx:83:c4:01:ac:5d",
              "vendor": "BB Technologies (Limited)",
              "vlan": null,
              "hostname": null,
              "device": {
                "id": null,
                "connected": null,
                "enabled": null,
                "authorized": null,
                "ipAddress": null,
                "identification": {
                  "id": null,
                  "type": null
                },
                "overview": {
                  "status": "unknown"
                }
              },
              "site": null
            },
            {
              "interfaceId": "eth1",
              "addresses": [
                "192.xxx.x.100"
              ],
              "mac": "9f:25:0b:4b:32:73",
              "vendor": null,
              "vlan": null,
              "hostname": null,
              "device": {
                "id": null,
                "connected": null,
                "enabled": null,
                "authorized": null,
                "ipAddress": null,
                "identification": {
                  "id": null,
                  "type": null
                },
                "overview": {
                  "status": "unknown"
                }
              },
              "site": null
            }
          ],
          "pagination": {
            "total": 3,
            "count": 20,
            "page": 1,
            "pages": 1
          }
        },
        "output": [
          "\"eth1\",\"Apple\",\"192.168.5.101\"",
          "\"eth1\",\"BB Technologies (Limited)\",\"192.xxx.x.1\"",
          "\"eth1\",,\"192.xxx.x.100\""
        ]
      }
    ],
    "identifier": 67796591
  },
  {
    "context": [
      "How would you get a list of all the hashes? They seem to be the name of objects, but I can't list them.",
      "Also, I wonder how would you filter to get the dates (in seconds, ex. 1622459402) in the objects?",
      "My json does not contain any keys except \"t\" and \"cid\", they are not what I am after."
    ],
    "utterance": "Extract all hash values present as field names under the \"t\" key and retrieve the date values (in seconds) from their associated arrays.",
    "expressions": [
      ".t | keys",
      ".t | to_entries[] | .value[20]",
      ".t | to_entries[] | {hash: .key, date: .value[20]}"
    ],
    "data": [
      {
        "input": {
          "t": {
            "2C3D7D91DFD0A57CFCA8B7092347B311088D3B6E": [
              "1",
              "0",
              "1",
              "1",
              "Young.Sheldon.S04.1080p.x265-ZMNT",
              "4764367221",
              "1136",
              "1136",
              "4764367221",
              "5201425130",
              "1091",
              "0",
              "0",
              "4194304",
              "",
              "0",
              "0",
              "0",
              "0",
              "0",
              "2",
              "1622459402",
              "0",
              "0",
              "1136",
              "/home/xxxxxxxx/files/Young.Sheldon.S04.1080p.x265-ZMNT",
              "1622421479",
              "2",
              "1",
              "",
              "",
              "4436465131520",
              "1",
              "1"
            ],
            "FAC73275BC376C4C26DFDA41D991D021838DB778": [
              "1",
              "0",
              "1",
              "1",
              "Joshy.2016.NORDIC.1080p.BluRay.REMUX.AVC.DTS-HD.MA.5.1-Danishbits",
              "21160180253",
              "5045",
              "5045",
              "21160180253",
              "4470554624",
              "211",
              "114688",
              "0",
              "4194304",
              "",
              "1",
              "0",
              "1",
              "0",
              "0",
              "2",
              "1622459402",
              "0",
              "0",
              "5045",
              "/home/xxxxxxxx/files/Joshy.2016.NORDIC.1080p.BluRay.REMUX.AVC.DTS-HD.MA.5.1-Danishbits",
              "1622413504",
              "2",
              "1",
              "",
              "",
              "4436465131520",
              "1",
              "1"
            ],
            "671CA27A76DC35E8E9F46723F1F6596A8BC75DA0": [
              "1",
              "0",
              "1",
              "1",
              "Working.Girl.1988.1080p.Bluray.REMUX.AVC.DTS-HD.MA.5.1-4K4U",
              "29680778067",
              "14153",
              "14153",
              "29680778067",
              "12426936320",
              "418",
              "0",
              "0",
              "2097152",
              "",
              "1",
              "0",
              "1",
              "0",
              "0",
              "2",
              "1622459402",
              "0",
              "0",
              "14153",
              "/home/xxxxxxxx/files/Working.Girl.1988.1080p.Bluray.REMUX.AVC.DTS-HD.MA.5.1-4K4U",
              "1622440882",
              "2",
              "1",
              "",
              "",
              "4436465131520",
              "1",
              "1"
            ]
          },
          "cid": 1423760010
        },
        "output": {
          "hashes": [
            "2C3D7D91DFD0A57CFCA8B7092347B311088D3B6E",
            "FAC73275BC376C4C26DFDA41D991D021838DB778",
            "671CA27A76DC35E8E9F46723F1F6596A8BC75DA0"
          ],
          "dates": [
            "1622459402",
            "1622459402",
            "1622459402"
          ],
          "hashes_with_dates": [
            {
              "hash": "2C3D7D91DFD0A57CFCA8B7092347B311088D3B6E",
              "date": "1622459402"
            },
            {
              "hash": "FAC73275BC376C4C26DFDA41D991D021838DB778",
              "date": "1622459402"
            },
            {
              "hash": "671CA27A76DC35E8E9F46723F1F6596A8BC75DA0",
              "date": "1622459402"
            }
          ]
        }
      }
    ],
    "identifier": 67774970
  },
  {
    "context": [
      "i am trying to read commands from the json file using jq.",
      "only issue currently facing is that after getting values from json array each string value is automatically getting split a space which is dividing content of string into n no of values instead of one.",
      "query+= '.files[] | .service_commands[] |.command[]'",
      "The last executed \"singleline\", But it was supposed to be  \"singleline command\".",
      "Replace these lines:\r\n\r\n      local outputCommands=($(jq -cr \"$query\" \"$patchConfFile\"))\r\n    \r\n      local result=${PIPESTATUS[0]}\r\n\r\nwith these lines:\r\n\r\n      outputCommands=()\r\n      while IFS='' read -r line || ! result=$line; do outputCommands+=(\"$line\"); done < <(jq -r \"$query\" \"$patchConfFile\"; echo -n $?)",
      "In the JQ command, I'm ditching the `-c` option so that the results print one per line."
    ],
    "utterance": "Extract all values from the 'command' arrays within 'service_commands', ensuring each value is output as a complete string including spaces.",
    "expressions": [
      ".patches[] | .files[] | .service_commands[] | .command[]"
    ],
    "data": [
      {
        "input": {
          "baseVersion": "abc",
          "patches": [
            {
              "version": "122",
              "description": "This patch contains fixes blah blah blah ",
              "iBuild": "60",
              "files": [
                {
                  "fullPath": "20.6.I60.jar",
                  "nodeTypes": [
                    "a",
                    "b"
                  ],
                  "productTypes": [
                    "a",
                    "b"
                  ],
                  "restart": "true",
                  "service_commands": [
                    {
                      "node_name": [
                        "a"
                      ],
                      "command": [
                        "ls",
                        "date",
                        "demo"
                      ]
                    },
                    {
                      "node_name": [
                        "b"
                      ],
                      "command": [
                        "singleline command00"
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "ls",
          "date",
          "demo",
          "singleline command00"
        ]
      }
    ],
    "identifier": 67803428
  },
  {
    "context": [
      "RP_SHA=$( jq -re  '.sha' <<< $JSON_DATA)",
      "RP_ID=$(jq -re .id <<< $JSON_DATA)",
      "syntax error: unexpected redirection",
      "How I can correctly parse and set to my var json data using `jq` in my case?"
    ],
    "utterance": "Extract the value of the 'sha' property and assign it to a shell variable.",
    "expressions": [
      "jq -r '.sha'"
    ],
    "data": [
      {
        "input": {
          "id": 546,
          "sha": "fh456h8"
        },
        "output": "fh456h8"
      }
    ],
    "identifier": 67819988
  },
  {
    "context": [
      "This is my command:\r\n```\r\ncurl \"http://artifactory.xxx.xxx.com:8080/artifactory/api/storage/generic-tools/xxx-xxx/?lastModified\" | jq .uri | xargs curl\r\n```",
      "Curl downloads the json file and [jq](https://stedolan.github.io/jq/) extract the url for the json file containing with the library information.",
      "the `xargs` binary from MSys2 might expect Unix convention for EOLs which is just LF. So `curl` sees an additional stray CR character which it assumes to be part of the URL.",
      "Check that theory by using something like this and check for stray CR (0x0d) characters **between** two URLs:\r\n\r\n    jq '.uri' input.json  |xargs  echo | hexdump -C"
    ],
    "utterance": "Extract the value at the key 'uri' from the input.",
    "expressions": [
      ".uri"
    ],
    "data": [
      {
        "input": {
          "uri": "http://example.com/download/file.txt",
          "otherField": "value"
        },
        "output": "http://example.com/download/file.txt"
      }
    ],
    "identifier": 67821958
  },
  {
    "context": [
      "I have like this json data in my case:",
      "echo \"{\\\"id\\\":\\\"$PRODUCT_ID\\\",\\\"user\\\":\\\"$USER_DATA\\\"}\" | jq -re > ~/user.json",
      "When I tried save this json to file get error with message:",
      "> parse error: Unmatched '}' at line 1, column 21",
      "How I can save correctly my json data to file?",
      "You should use `jq` to create your json. Try something like this :",
      "jq --arg id \"$PRODUCT_ID\" -n '{$id}' | \\",
      "jq --arg id \"$USER_ID\" \\",
      "   --arg sha \"$USER_SHA\" \\",
      "   --arg user \"user\" \\",
      "   '.[$user]={$id, $sha}' > ~/user.json"
    ],
    "utterance": "Create an object with a top-level id field set to PRODUCT_ID and a nested user object with id set to USER_ID and sha set to USER_SHA, and save it to a file.",
    "expressions": [
      "jq --arg id \"$PRODUCT_ID\" -n '{$id}' | jq --arg id \"$USER_ID\" --arg sha \"$USER_SHA\" --arg user \"user\" '.[$user]={$id, $sha}'"
    ],
    "identifier": 67821411
  },
  {
    "context": [
      "I need to convert it to shell variables, the keys should be uppercase, and also \"-\" should be converted \"_\", and finally all key names should be put in shell list to generate the output which you can see below.",
      "Using the jq command-line options -n and -r, the following produces the output as required (that is, without the superfluous __INDEX keys):",
      "def q: if type==\"string\" then @sh else tojson|@sh end;",
      "foreach inputs as $in (-1;.+1;\n  . as $n\n  | $in\n  | to_entries[]\n  | \"\\(.key|gsub(\"-\";\"_\")|ascii_upcase + ($n|tostring) )=\\(.value|q)\"\n  )"
    ],
    "utterance": "Convert object keys to uppercase, replace hyphens with underscores, append an integer suffix per object, and output as shell assignment lines.",
    "expressions": [
      "def q: if type==\"string\" then @sh else tojson|@sh end; foreach inputs as $in (-1; .+1; . as $n | $in | to_entries[] | \"\\(.key|gsub(\"-\";\"_\")|ascii_upcase + ($n|tostring) )=\\(.value|q)\")"
    ],
    "data": [
      {
        "input": [
          {
            "msg-version": "1.0",
            "msg-type": "app-config",
            "content": "aaa"
          },
          {
            "msg-version": "1.0",
            "msg-type": "app-config",
            "content": "bbb"
          },
          {
            "msg-version": "1.0",
            "msg-type": "app-config",
            "content": "ddd",
            "breakit": {
              "a": "b"
            }
          }
        ],
        "output": [
          "MSG_VERSION0='1.0'",
          "MSG_TYPE0='app-config'",
          "CONTENT0='aaa'",
          "MSG_VERSION1='1.0'",
          "MSG_TYPE1='app-config'",
          "CONTENT1='bbb'",
          "MSG_VERSION2='1.0'",
          "MSG_TYPE2='app-config'",
          "CONTENT2='ddd'",
          "BREAKIT2='{\"a\":\"b\"}'"
        ]
      }
    ],
    "identifier": 67811860
  },
  {
    "context": [
      "Hi guys,\r\nI have above code, i want to display the below values as follows\r\n\r\n\r\nSchedule, Yes\r\n\r\nSchedule, No",
      "Given the input shown above, you&#39;d use this command:\r\n\r\n    jq --slurp --raw-output 'map(select(.Key == \"Schedule\") | \"\\(.Key), \\(.Value)\") | .[]'"
    ],
    "utterance": "Display all entries where Key is Schedule, in the format 'Schedule, Value'.",
    "expressions": [
      "jq --slurp --raw-output 'map(select(.Key == \"Schedule\") | \"\\(.Key), \\(.Value)\") | .[]'"
    ],
    "data": [
      {
        "input": [
          {
            "Value": "test-CDB-CCP-CONSUL_ACL",
            "Key": "Name"
          },
          {
            "Value": "yes",
            "Key": "Schedule"
          },
          {
            "Value": "ENGINEERING-PLATFORM",
            "Key": "Department"
          },
          {
            "Value": "clustr.dev@tallysolutions.com",
            "Key": "Owner"
          },
          {
            "Value": "kalyan.g@tallysolutions.com",
            "Key": "Owner"
          },
          {
            "Value": "No",
            "Key": "Schedule"
          }
        ],
        "output": [
          "Schedule, yes",
          "Schedule, No"
        ]
      }
    ],
    "identifier": 67823112
  },
  {
    "context": [
      "I want to exclude anything that has **directory** or **other-directory** in the string",
      "I then want to split the array into 4 arrays but I want to evenly split anything that has **integration** in the string i.e I don't want all the integrations in one array. Any other string can then be split across the 4 arrays.",
      "map(select(test(\"(other-)?directory\")|not))",
      "| roundrobin( (.[] | select(index(\"integration\"))), (.[] | select(index(\"integration\")|not));  4)",
      "# get rid of everything with directory or other-directory\n[ .[] | select(test(\"directory|other-directory\") | not) ]\n\n# grab all lines with \"integration\" in an array\n | [ ([ .[] | select(test(\"integration\")) ]),\n# grab all lines without \"integration\" into a second array\n     ([ .[] | select(test(\"integration\") | not) ]) ]\n# flatten and divide into buckets (arg passed in)\n | flatten | bucket_shift($num_buckets|tonumber)"
    ],
    "utterance": "Exclude entries containing 'directory' or 'other-directory' and split the remaining entries into 4 evenly sized arrays so that entries containing 'integration' are distributed as evenly as possible across all arrays.",
    "expressions": [
      "map(select(test(\"(other-)?directory\")|not)) | roundrobin( (.[] | select(index(\"integration\"))), (.[] | select(index(\"integration\")|not));  4)",
      "[ .[] | select(test(\"directory|other-directory\") | not) ]\n| [ ([ .[] | select(test(\"integration\")) ]), ([ .[] | select(test(\"integration\") | not) ]) ] | flatten | bucket_shift($num_buckets|tonumber)"
    ],
    "data": [
      {
        "input": [
          "/home/test-spa/src/components/modals/super-admin/tests/integration/index.test.tsx",
          "/home/test-spa/src/components/modals/delete-user/tests/index.test.tsx",
          "/home/test-spa/src/components/modals/edit-admin/tests/integration/index.test.tsx",
          "/home/test-spa/src/components/modals/delete-admin/tests/index.test.tsx",
          "/home/test-spa/src/components/modals/add-user/tests/integration/index.test.tsx",
          "/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx",
          "/home/test-spa/src/components/modals/edit-user/tests/index.test.tsx",
          "/home/test-spa/src/components/modals/change-user/tests/index.test.tsx",
          "/home/test-spa/src/other-directory/modals/tests/index.test.ts",
          "/home/test-spa/src/directory/modals/tests/index.test.ts"
        ],
        "output": [
          [
            "/home/test-spa/src/components/modals/super-admin/tests/integration/index.test.tsx",
            "/home/test-spa/src/components/modals/delete-user/tests/index.test.tsx"
          ],
          [
            "/home/test-spa/src/components/modals/edit-admin/tests/integration/index.test.tsx",
            "/home/test-spa/src/components/modals/delete-admin/tests/index.test.tsx"
          ],
          [
            "/home/test-spa/src/components/modals/add-admin/tests/integration/index.test.tsx",
            "/home/test-spa/src/components/modals/edit-user/tests/index.test.tsx"
          ],
          [
            "/home/test-spa/src/components/modals/add-user/tests/integration/index.test.tsx",
            "/home/test-spa/src/components/modals/change-user/tests/index.test.tsx"
          ]
        ]
      }
    ],
    "identifier": 67755535
  },
  {
    "context": [
      "I want to remove this particular block of code from the above json file - , \"time\": { \"metrics\": 83 }",
      "Note: number 83 can be any number in general.",
      "Maybe you can try something like this: jq 'del(.time)' temp.json > temp2.json."
    ],
    "utterance": "Remove the key named 'time' (with any metrics value) from the top-level object.",
    "expressions": [
      "del(.time)"
    ],
    "data": [
      {
        "input": {
          "data": {
            "stuff": [
              "....."
            ]
          },
          "time": {
            "metrics": 83
          }
        },
        "output": {
          "data": {
            "stuff": [
              "....."
            ]
          }
        }
      }
    ],
    "identifier": 67830480
  },
  {
    "context": [
      "I need to loop through the IDs and find any IDs that contain a letter.",
      "I have:\n\ncat results.json | jq '.array|map(select( (.id|contains(\"a\")) or (.id|contains(\"b\")) ))' etc. etc.",
      "How can I write a more efficient query/regex to do this in one `contains()` function",
      "will produce the following output:\n\n    [\n      \"foo\",\n      \"bar\",\n      \"a99\"\n    ]",
      "To check whether a string contains a letter of the alphabet, you could use `test(\"[A-Za-z]\")`.",
      "you\u2019ll probably also want to select or check for strings, e.g. using the form:\n\n    select( .id | strings | test(...) )"
    ],
    "utterance": "Find all elements with an id that contains any letter of the English alphabet.",
    "expressions": [
      ".array | map(select(.id | strings | test(\"[A-Za-z]\")))",
      ".array | map(select(.id | strings | test(\"\\\\p{Alpha}\")))",
      ".array | map(select(.id | strings | test(\"\\\\p{L}\")))"
    ],
    "identifier": 67825049
  },
  {
    "context": [
      "Just getting ARN and Name is easy: `.SecretList[] | {ARN, Name}`.",
      "Querying the tags is tricky but I figured out this: `.SecretList[].Tags[] | select(.Key == \"company-mnemonic\") | {\"company-mnemonic\": .Value}`.",
      "Is there a way I can combine these 2 ideas into one so that I get something that looks like this:\n\n    {\n        \"ARN\": \"arn:aws:secretsmanager....\",\n        \"Name\": \"some-name\",\n        \"company-mnemonic\": \"whatever\"\n    }",
      "It's not tricky at all. `Tags` can be converted to a proper object using `from_entries`, and then it's simple addition.\n```\n.SecretList[] | {ARN, Name} + (.Tags | from_entries | {\"company-mnemonic\"})\n```"
    ],
    "utterance": "Extract ARN, Name, and the value of the company-mnemonic tag from each element in the SecretList array, returning them together in a single object.",
    "expressions": [
      ".SecretList[] | {ARN, Name} + (.Tags | from_entries | {\"company-mnemonic\"})"
    ],
    "data": [
      {
        "input": {
          "SecretList": [
            {
              "ARN": "arn:aws:secretsmanager....",
              "Name": "some-name",
              "Description": "",
              "LastChangedDate": "2021-06-03T20:43:35.059000-05:00",
              "LastAccessedDate": "2021-05-31T19:00:00-05:00",
              "Tags": [
                {
                  "Key": "company-mnemonic",
                  "Value": "whatever"
                },
                {
                  "Key": "usage",
                  "Value": "something"
                }
              ]
            }
          ]
        },
        "output": {
          "ARN": "arn:aws:secretsmanager....",
          "Name": "some-name",
          "company-mnemonic": "whatever"
        }
      }
    ],
    "identifier": 67831232
  },
  {
    "context": [
      "if the Name tag is empty or tag itself not there for particular instances I want to display the instance IDs.",
      "For all EC2 instances, if Schedule tag has the below values only. any value apart from that it should show instance IDs.",
      "Allowed values:\r\n- Yes\r\n- yes\r\n- No\r\n- no"
    ],
    "utterance": "Show instance IDs where the Name tag is missing or empty, or where the Schedule tag exists but its value is not Yes, yes, No, or no.",
    "expressions": [
      ".Reservations[].Instances[] | select((.Tags | map(select(.Key==\"Name\"))[0].Value // \"\") == \"\" or (.Tags | map(select(.Key==\"Schedule\"))[0].Value? // empty | select(. | test(\"^(?i:yes|no)$\") | not))) | .InstanceId"
    ],
    "identifier": 67832111
  },
  {
    "context": [
      "I want to add a new pair of values to an array that's nested within a couple of objects.",
      "I need to add an Id-Label pair: `{\"Id\": 642587, \"Label\": \"S8\"}` in the `Value` array",
      "The simplest solution, I believe, would be:\r\n\r\n    .FieldValues[0].Value += [{Id: 8511657, \"Label\": \"S8\"}]"
    ],
    "utterance": "Append {\"Id\": 8511657, \"Label\": \"S8\"} to the Value array inside the first object of the FieldValues array.",
    "expressions": [
      ".FieldValues[0].Value += [{Id: 8511657, \"Label\": \"S8\"}]"
    ],
    "data": [
      {
        "input": {
          "FieldValues": [
            {
              "FieldName": "Groups",
              "Value": [
                {
                  "Id": 641254,
                  "Label": "S4"
                },
                {
                  "Id": 642587,
                  "Label": "S8"
                },
                {
                  "Id": 641247,
                  "Label": "S7"
                }
              ],
              "SystemCode": "Groups"
            }
          ],
          "Id": 33034883
        },
        "output": {
          "FieldValues": [
            {
              "FieldName": "Groups",
              "Value": [
                {
                  "Id": 641254,
                  "Label": "S4"
                },
                {
                  "Id": 642587,
                  "Label": "S8"
                },
                {
                  "Id": 641247,
                  "Label": "S7"
                },
                {
                  "Id": 8511657,
                  "Label": "S8"
                }
              ],
              "SystemCode": "Groups"
            }
          ],
          "Id": 33034883
        }
      }
    ],
    "identifier": 67875810
  },
  {
    "context": [
      "i need to insert ~400 values  i.e  `\"a\",\"b\"` from bash variable *$a* into *template.json*",
      "My command:\n    `jq --arg value \"$a\"  '.trials |= . + [$value]' data/template.json > new_file.json`\n\ngives result :\n{\n  \"trials\": [\n    \"\\\"a\\\",\\\"b\\\"\"\n  ],\n  \"targetState\": \"RELEASE\",\n  \"force\": false\n}",
      "However i need : [\"a\",\"b\"]",
      "jq --argjson new_trials \"[$a]\" \\\n   '.trials |= . + $new_trials' template.json",
      "printf %s \"[$a]\" |\n   jq --argfile tmpl template.json -n \\\n      '$tmpl | .trials |= . + input'",
      "printf %s \"$a\" |\n   jq --argfile tmpl template.json -Rn \\\n      '$tmpl | .trials |= . + ( input | \"[\\(.)]\" | fromjson )'"
    ],
    "utterance": "Insert multiple comma-separated string values from a shell variable into the trials array.",
    "expressions": [
      "jq --argjson new_trials \"[$a]\" '.trials |= . + $new_trials' template.json",
      "printf %s \"[$a]\" | jq --argfile tmpl template.json -n '$tmpl | .trials |= . + input'",
      "printf %s \"$a\" | jq --argfile tmpl template.json -Rn '$tmpl | .trials |= . + ( input | \"[\\(.)]\" | fromjson )'"
    ],
    "data": [
      {
        "input": {
          "trials": [],
          "targetState": "EDIT",
          "force": false
        },
        "output": {
          "trials": [
            "a",
            "b"
          ],
          "targetState": "EDIT",
          "force": false
        }
      }
    ],
    "identifier": 67860621
  },
  {
    "context": [
      "For each element in `files[]` ending in `.txt` I want to set the corresponding element in `download[]` to `1`. How do I do that in JQ?",
      ".download = (.files | map(if endswith(\".txt\") then 1 else 0 end))",
      ".download = reduce (.files | path(.[] | select(endswith(\".txt\")))) as $p (.download; setpath($p; 1))"
    ],
    "utterance": "Set each element in the download array to 1 if the corresponding element in the files array ends with .txt; otherwise, leave it as 0.",
    "expressions": [
      ".download = (.files | map(if endswith(\".txt\") then 1 else 0 end))",
      ".download = reduce (.files | path(.[] | select(endswith(\".txt\")))) as $p (.download; setpath($p; 1))"
    ],
    "data": [
      {
        "input": {
          "download": [
            0,
            0,
            0,
            0
          ],
          "files": [
            "file1.txt",
            "file1.iso",
            "file2.txt",
            "file2.iso"
          ]
        },
        "output": {
          "download": [
            1,
            0,
            1,
            0
          ],
          "files": [
            "file1.txt",
            "file1.iso",
            "file2.txt",
            "file2.iso"
          ]
        }
      }
    ],
    "identifier": 67881098
  },
  {
    "context": [
      "The JSON object in each INSTALL_RECEIPT.json has a .time key, which would presumably be more reliable than a file or directory time stamp, so you might like to consider something like this bash script:",
      "jq -nr --arg cellar \"$CELLAR\" '\n  [inputs | {time, file: (input_filename|sub($cellar;\"\") | sub(\"/INSTALL_RECEIPT.json\";\"\"))}]\n  | sort_by(.time)[-40:][]\n  | .file\n' $CELLAR/*/*/INSTALL_RECEIPT.json"
    ],
    "utterance": "Show the names of the last 40 formulas installed, based on the 'time' field in their INSTALL_RECEIPT.json files.",
    "expressions": [
      "jq -nr --arg cellar \"$CELLAR\" '[inputs | {time, file: (input_filename|sub($cellar;\"\") | sub(\"/INSTALL_RECEIPT.json\";\"\"))}] | sort_by(.time)[-40:][] | .file' $CELLAR/*/*/INSTALL_RECEIPT.json"
    ],
    "identifier": 67845539
  },
  {
    "context": [
      "I want to retrive only de tguid in history array, and if exist a way to do this, use de index of the array to acomplish that.",
      "jq  &#39;.[].history.events.tguid[1]&#39; /tmp/teste.json",
      "try this\n```\njq  '.history.events | .[1].tguid' /tmp/teste.json\n```",
      "jq  '.[].history.events | .[0].tguid' /tmp/teste1.json"
    ],
    "utterance": "Return the tguid value from the events array inside history using a specified index.",
    "expressions": [
      ".history.events | .[1].tguid",
      ".[].history.events | .[0].tguid"
    ],
    "data": [
      {
        "input": {
          "pguid": "4EA979A2-E578-4DA3-89DB-24082F3092AA",
          "lastEnrollTguid": "EA98B161-04D3-4F0A-920A-58DBFF3C2274",
          "timestamp": 1016086888000,
          "keys": [
            {
              "id": "gr",
              "value": "1907971"
            }
          ],
          "biographics": [
            {
              "id": "localNascimento",
              "value": "JOINVILLE SC"
            },
            {
              "id": "dataNascimento",
              "value": "1859-03-08"
            },
            {
              "id": "mae",
              "value": "ANTA MARCIA PINHEAD"
            },
            {
              "id": "nome",
              "value": "MIR PINHEAD"
            }
          ],
          "biometric": [
            {
              "source": "ORIGINAL",
              "type": "FACE",
              "format": "JPEG",
              "properties": {
                "width": 0,
                "height": 0,
                "resolution": 500,
                "ratio": 0,
                "matcherId": 0,
                "extractorId": 0
              },
              "index": 10,
              "content": "5215421547"
            }
          ],
          "labels": [
            "SC",
            "CIVIL",
            "MASCULINO",
            "JOINVILLE"
          ],
          "history": {
            "events": [
              {
                "type": "ENROLL",
                "tguid": "3C1B0D1F-9143-4C24-A351-E88A19317AC9",
                "timestamp": 1014086658288
              },
              {
                "type": "UPDATE",
                "tguid": "EA98B161-04D3-4F0A-920A-58DBFF3C2274",
                "timestamp": 1016786888028
              }
            ]
          }
        },
        "output": "EA98B161-04D3-4F0A-920A-58DBFF3C2274"
      }
    ],
    "identifier": 67888913
  },
  {
    "context": [
      "DATA=$(curl -s 'https://api.coinmarketcap.com/v2/ticker/' | jq -r '.data .\"1\" .quotes .USD .price')",
      "With a valid API KEY, the following curl invocation:",
      "curl -H \"X-CMC_PRO_API_KEY:$KEY\" -H \"Accept: application/json\" \\",
      "-d \"start=1&limit=5000&convert=USD\" \\",
      "-G https://pro-api.coinmarketcap.com/v1/cryptocurrency/listings/latest",
      "yields valid JSON, for which the jq query:",
      "jq '.data[0].quote.USD.price'",
      "yields",
      "32884.18011827609",
      "arrays are indexed by integers, not strings;"
    ],
    "utterance": "Select the USD price of the first cryptocurrency in the data array from the API response.",
    "expressions": [
      ".data[0].quote.USD.price"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": 1,
              "name": "Bitcoin",
              "symbol": "BTC",
              "quote": {
                "USD": {
                  "price": 32884.18011827609
                }
              }
            }
          ]
        },
        "output": 32884.18011827609
      }
    ],
    "identifier": 67889924
  },
  {
    "context": [
      "echo '{\"pre-destinations\": {\"results\": [{\"sessions\": \"16903\"}]}}' | jq '.pre-destinations'",
      "jq: error: destinations/0 is not defined at <top-level>, line 1:",
      ".pre-destinations",
      "The root cause is I was using a **'-'** in the key value, but why it fails ?",
      "you would have to quote the key name, e.g.",
      "jq '\".pre-destinations\"'",
      "or more robustly (with respect to variations between different versions of jq):",
      "jq '[\"pre-destinations\"]'",
      "This is the only way I could get it to work:",
      "jq '. | to_entries | .[] | select (.key == \"pre-destinations\") | .value'"
    ],
    "utterance": "Extract the value associated with the key 'pre-destinations', where the key contains a hyphen.",
    "expressions": [
      ".[\"pre-destinations\"]",
      ". | to_entries | .[] | select (.key == \"pre-destinations\") | .value"
    ],
    "data": [
      {
        "input": {
          "pre-destinations": {
            "results": [
              {
                "sessions": "16903"
              }
            ]
          }
        },
        "output": {
          "results": [
            {
              "sessions": "16903"
            }
          ]
        }
      }
    ],
    "identifier": 67895271
  },
  {
    "context": [
      "I want to create a CSV that has \"id\", \"name\" and \"magic\". If an element doesn't exist, an empty string should be set:",
      "\"id\",\"name\",\"magic\"\n\"1\",\"Luxor\",\"\"\n\"2\",\"Farflame\",\"30\"",
      "As you can see, the row with id \"1\" has only two cells, because there isn't a \"magic\" element inside of \"tag\". I tried all kinds of `if` statements, but wasn't able to find one that does what I want.",
      "Instead, I would write a function similar to `from_entries` for converting `tag` arrays to objects, and use it like this:",
      "def f: map({(.k): .v}) | add;\n.[] | [.id] + (.tag | f | [.name, .magic]) | @csv"
    ],
    "utterance": "Produce a table with columns id, name, and magic, filling in an empty string when name or magic is missing in an item's tags.",
    "expressions": [
      "def f: map({(.k): .v}) | add; .[] | [.id] + (.tag | f | [.name, .magic]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "tag": [
              {
                "k": "name",
                "v": "Luxor"
              }
            ]
          },
          {
            "id": "2",
            "tag": [
              {
                "k": "name",
                "v": "Farflame"
              },
              {
                "k": "magic",
                "v": "30"
              }
            ]
          }
        ],
        "output": [
          "\"1\",\"Luxor\",\"\"",
          "\"2\",\"Farflame\",\"30\""
        ]
      }
    ],
    "identifier": 67891343
  },
  {
    "context": [
      "wanted result (note the quotation marks):",
      "PD_TOKEN=\"Token y_NbAkKc66ryYTWUXYEu\"",
      "You can use [`@sh`][1] instead of `tostring` to escape shell-safely:",
      "$ jq -r 'to_entries | map(\"\\(.key)=\\(.value|@sh)\")[]' infile.json",
      "Additionally, without `map`:",
      "jq -r 'to_entries[] | \"\\(.key)=\\(.value|@sh)\"' infile.json",
      "jq -r 'keys[] as $key | \"\\($key)=\\(.[$key]|@sh)\"' infile.json"
    ],
    "utterance": "For each key-value pair, output KEY=\"value\" where values with spaces are quoted.",
    "expressions": [
      "to_entries | map(\"\\(.key)=\\(.value|@sh)\")[]",
      "to_entries[] | \"\\(.key)=\\(.value|@sh)\"",
      "keys[] as $key | \"\\($key)=\\(.[$key]|@sh)\""
    ],
    "data": [
      {
        "input": {
          "PD_TOKEN": "Token y_NbAkKc66ryYTWUXYEu",
          "API": "http://cool.api/",
          "HELP_URL": "https://help.com"
        },
        "output": [
          "PD_TOKEN='Token y_NbAkKc66ryYTWUXYEu'",
          "API='http://cool.api/'",
          "HELP_URL='https://help.com'"
        ]
      }
    ],
    "identifier": 67897266
  },
  {
    "context": [
      "I want to filter the output with only those 2 tags with its values",
      "Expected Results:",
      "{\r\n \"ResourceARN\": ...\r\n \"Tags\": [\r\n  {\r\n   \"Key\": \"Name\",\r\n   \"Value\": \"eks-efs-non-prod\"\r\n  },\r\n  {\r\n   \"Key\": \"Name in Resolve\",\r\n   \"Value\": \"True\"\r\n  }\r\n ]\r\n}",
      "the relevant jq filter would be:",
      ".Tags |= map(select(.Key | IN(\"Name\", \"Name in Resolve\")))"
    ],
    "utterance": "Filter each resource so that only tags with Key equal to \"Name\" or \"Name in Resolve\" and their values are retained.",
    "expressions": [
      ".Tags |= map(select(.Key | IN(\"Name\", \"Name in Resolve\")))",
      "def IN(s): first((s == .) // empty) // false; .Tags |= map(select(.Key | IN(\"Name\", \"Name in Resolve\")))"
    ],
    "data": [
      {
        "input": {
          "ResourceARN": "arn:aws:backup:$Region:$AccountId:recovery-point:xxxxxxxx",
          "Tags": [
            {
              "Key": "Name",
              "Value": "eks-efs-non-prod"
            },
            {
              "Key": "Deptt",
              "Value": "XXX"
            },
            {
              "Key": "BusinessUnit",
              "Value": "XXX"
            },
            {
              "Key": "Name in Resolve",
              "Value": "True"
            },
            {
              "Key": "SysOwner",
              "Value": "XXX"
            },
            {
              "Key": "IT Director",
              "Value": "Ankur K"
            }
          ]
        },
        "output": {
          "ResourceARN": "arn:aws:backup:$Region:$AccountId:recovery-point:xxxxxxxx",
          "Tags": [
            {
              "Key": "Name",
              "Value": "eks-efs-non-prod"
            },
            {
              "Key": "Name in Resolve",
              "Value": "True"
            }
          ]
        }
      }
    ],
    "identifier": 67905970
  },
  {
    "context": [
      "Input is a document . I will get names in a String preceded by number",
      "\"cNames\": \" 1 MANJSY JOAU 2 CHAFANH BINO\"",
      "The expected output is a name array sometime like shown below",
      "\"cNameArray\": [\n    \"MANJSY JOAU\",\n    \"CHAFANH BINO\"\n]",
      ".doc[0] |= (.cNames |= [splits(\" *[0-9] *\")][1:])",
      ".doc[0] |= (.cNames |= [splits(\" *[0-9] *\")][1:] | with_entries(if .key == \"cNames\" then .key = \"cNameArray\" else . end) )"
    ],
    "utterance": "Extract name strings that follow numbers in the 'cNames' field and create a new 'cNameArray' key with those names as an array.",
    "expressions": [
      ".doc[0] |= (.cNames |= [splits(\" *[0-9] *\")][1:])",
      ".doc[0] |= (.cNames |= [splits(\" *[0-9] *\")][1:] | with_entries(if .key == \"cNames\" then .key = \"cNameArray\" else . end) )"
    ],
    "data": [
      {
        "input": {
          "doc": [
            {
              "cNo": "6222332 22450 32",
              "cNames": " 1 MANJSY JOAU 2 CHAFANH BINO",
              "cExpiry": "04/2025"
            },
            {
              "fields": 3,
              "documents": 1
            }
          ]
        },
        "output": {
          "doc": [
            {
              "cNo": "6222332 22450 32",
              "cNameArray": [
                "MANJSY JOAU",
                "CHAFANH BINO"
              ],
              "cExpiry": "04/2025"
            },
            {
              "fields": 3,
              "documents": 1
            }
          ]
        }
      }
    ],
    "identifier": 67922169
  },
  {
    "context": [
      "I want to apply them a jq filter to remove all keys who have an empty value. By empty I mean empty string, empty object and arrays with just one empty string inside.",
      "input\r\n\r\n    {\r\n      \"foo\": {\r\n        \"keep\": \"me\",\r\n        \"remove\": \"\",\r\n        \"nest\": {\r\n          \"keep\": \"me\",\r\n          \"remove\": \"\"\r\n        },\r\n        \"remove-me\": {},\r\n        \"remove-me-to\": [\"\"]\r\n      }\r\n    }",
      "output\r\n\r\n    {\r\n      \"foo\": {\r\n        \"keep\": \"me\",\r\n        \"nest\": {\r\n          \"keep\": \"me\"\r\n        }\r\n      }\r\n    }",
      "walk(if type == \"object\" then with_entries(select(.value | (. != {} and . != [\"\"] and . != \"\"))) else . end)",
      "jq '. |= walk(if type == \"object\" then with_entries(select(.value | (. != {} and . != [\"\"] and . != \"\"))) else . end)' test.json"
    ],
    "utterance": "Remove all object keys whose value is an empty string, an empty object, or an array containing only an empty string (recursively, at any nesting level).",
    "expressions": [
      "walk(if type == \"object\" then with_entries(select(.value | (. != {} and . != [\"\"] and . != \"\"))) else . end)"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "keep": "me",
            "remove": "",
            "nest": {
              "keep": "me",
              "remove": ""
            },
            "remove-me": {},
            "remove-me-to": [
              ""
            ]
          }
        },
        "output": {
          "foo": {
            "keep": "me",
            "nest": {
              "keep": "me"
            }
          }
        }
      }
    ],
    "identifier": 67917803
  },
  {
    "context": [
      "the json looks like {\"id\":\"12345\",\"name\":\"myname\"}",
      "ID=$(curl --header \"PRIVATE-TOKEN:<token>\" \"<api_endpoint>\" | jq -r --arg NAMES \"$NAME\" '.[] | select(.name==$NAMES) | .id')",
      "If I take the curl command and run it on the command line it works as expected.",
      "Use without `.[]` and apply `select` to your object directly:",
      "Filter: `select(.name==\"myname\") | .id`",
      "Output: `12345`"
    ],
    "utterance": "Extract the value of the field 'id' where the field 'name' matches a given value, from an object with 'id' and 'name' fields.",
    "expressions": [
      "select(.name==$NAMES) | .id"
    ],
    "data": [
      {
        "input": {
          "id": "12345",
          "name": "myname"
        },
        "output": "12345"
      }
    ],
    "identifier": 67931022
  },
  {
    "context": [
      "I also wanted to get the second last AMI ID using AWS CLI. Could someone help me out on this?",
      "You can use indices, like in python (`[-2]`):",
      "jq -r '.Images | sort_by(.CreationDate)[-2].ImageId'"
    ],
    "utterance": "Fetch the second most recent AMI ID by sorting images by their CreationDate.",
    "expressions": [
      ".Images | sort_by(.CreationDate)[-2].ImageId"
    ],
    "identifier": 67931552
  },
  {
    "context": [
      "I am looking for and variable definition with the \"name\" property of \"Environment\".  Then I want to change its value to \"dev\".",
      "I would like the entire JSON payload returned with the new query value of: dev",
      "You were almost there:\r\n\r\n    (.templating.list[] | select(.name == \"Environment\" ) | .query) |= \"dev\"",
      "walk (if type == \"object\" and .name == \"Environment\" and has(\"query\") \r\n      then .query = \"dev\" else . end)",
      "(.. | objects | select(.name == \"Environment\" and has(\"query\"))).query |= \"dev\""
    ],
    "utterance": "Update the value of the query field to \"dev\" in the variable definition object where name is \"Environment\", and return the full structure with this change.",
    "expressions": [
      "(.templating.list[] | select(.name == \"Environment\") | .query) |= \"dev\"",
      "walk (if type == \"object\" and .name == \"Environment\" and has(\"query\") then .query = \"dev\" else . end)",
      "(.. | objects | select(.name == \"Environment\" and has(\"query\"))).query |= \"dev\""
    ],
    "data": [
      {
        "input": {
          "annotations": {
            "list": [
              {
                "builtIn": 1,
                "datasource": "-- Grafana --",
                "enable": true,
                "hide": true,
                "iconColor": "rgba(0, 211, 255, 1)",
                "name": "Annotations & Alerts",
                "type": "dashboard"
              }
            ]
          },
          "editable": true,
          "gnetId": null,
          "graphTooltip": 0,
          "id": 5,
          "iteration": 1622058997292,
          "links": [],
          "panels": [
            {
              "aliasColors": {},
              "bars": false,
              "dashLength": 10,
              "dashes": false,
              "datasource": null,
              "fieldConfig": {
                "defaults": {},
                "overrides": []
              },
              "fill": 1,
              "fillGradient": 0,
              "gridPos": {
                "h": 9,
                "w": 12,
                "x": 0,
                "y": 0
              },
              "hiddenSeries": false,
              "id": 2,
              "legend": {
                "avg": false,
                "current": false,
                "max": false,
                "min": false,
                "show": true,
                "total": false,
                "values": false
              },
              "lines": true,
              "linewidth": 1,
              "nullPointMode": "null",
              "options": {
                "alertThreshold": true
              },
              "percentage": false,
              "pluginVersion": "7.5.4",
              "pointradius": 2,
              "points": false,
              "renderer": "flot",
              "seriesOverrides": [],
              "spaceLength": 10,
              "stack": false,
              "steppedLine": false,
              "targets": [
                {
                  "alias": "",
                  "dimensions": {},
                  "expression": "",
                  "id": "",
                  "matchExact": true,
                  "metricName": "",
                  "namespace": "",
                  "period": "",
                  "refId": "A",
                  "region": "default",
                  "statistics": [
                    "Average"
                  ]
                }
              ],
              "thresholds": [],
              "timeFrom": null,
              "timeRegions": [],
              "timeShift": null,
              "title": "Panel Title",
              "tooltip": {
                "shared": true,
                "sort": 0,
                "value_type": "individual"
              },
              "type": "graph",
              "xaxis": {
                "buckets": null,
                "mode": "time",
                "name": null,
                "show": true,
                "values": []
              },
              "yaxes": [
                {
                  "format": "short",
                  "label": null,
                  "logBase": 1,
                  "max": null,
                  "min": null,
                  "show": true
                },
                {
                  "format": "short",
                  "label": null,
                  "logBase": 1,
                  "max": null,
                  "min": null,
                  "show": true
                }
              ],
              "yaxis": {
                "align": false,
                "alignLevel": null
              }
            }
          ],
          "schemaVersion": 27,
          "style": "dark",
          "tags": [],
          "templating": {
            "list": [
              {
                "description": null,
                "error": null,
                "hide": 2,
                "label": null,
                "name": "Environment",
                "query": "prod",
                "skipUrlSync": false,
                "type": "constant"
              }
            ]
          },
          "time": {
            "from": "now-6h",
            "to": "now"
          },
          "timepicker": {},
          "timezone": "",
          "title": "test",
          "uid": "Op2N9sqGk",
          "version": 1
        },
        "output": {
          "annotations": {
            "list": [
              {
                "builtIn": 1,
                "datasource": "-- Grafana --",
                "enable": true,
                "hide": true,
                "iconColor": "rgba(0, 211, 255, 1)",
                "name": "Annotations & Alerts",
                "type": "dashboard"
              }
            ]
          },
          "editable": true,
          "gnetId": null,
          "graphTooltip": 0,
          "id": 5,
          "iteration": 1622058997292,
          "links": [],
          "panels": [
            {
              "aliasColors": {},
              "bars": false,
              "dashLength": 10,
              "dashes": false,
              "datasource": null,
              "fieldConfig": {
                "defaults": {},
                "overrides": []
              },
              "fill": 1,
              "fillGradient": 0,
              "gridPos": {
                "h": 9,
                "w": 12,
                "x": 0,
                "y": 0
              },
              "hiddenSeries": false,
              "id": 2,
              "legend": {
                "avg": false,
                "current": false,
                "max": false,
                "min": false,
                "show": true,
                "total": false,
                "values": false
              },
              "lines": true,
              "linewidth": 1,
              "nullPointMode": "null",
              "options": {
                "alertThreshold": true
              },
              "percentage": false,
              "pluginVersion": "7.5.4",
              "pointradius": 2,
              "points": false,
              "renderer": "flot",
              "seriesOverrides": [],
              "spaceLength": 10,
              "stack": false,
              "steppedLine": false,
              "targets": [
                {
                  "alias": "",
                  "dimensions": {},
                  "expression": "",
                  "id": "",
                  "matchExact": true,
                  "metricName": "",
                  "namespace": "",
                  "period": "",
                  "refId": "A",
                  "region": "default",
                  "statistics": [
                    "Average"
                  ]
                }
              ],
              "thresholds": [],
              "timeFrom": null,
              "timeRegions": [],
              "timeShift": null,
              "title": "Panel Title",
              "tooltip": {
                "shared": true,
                "sort": 0,
                "value_type": "individual"
              },
              "type": "graph",
              "xaxis": {
                "buckets": null,
                "mode": "time",
                "name": null,
                "show": true,
                "values": []
              },
              "yaxes": [
                {
                  "format": "short",
                  "label": null,
                  "logBase": 1,
                  "max": null,
                  "min": null,
                  "show": true
                },
                {
                  "format": "short",
                  "label": null,
                  "logBase": 1,
                  "max": null,
                  "min": null,
                  "show": true
                }
              ],
              "yaxis": {
                "align": false,
                "alignLevel": null
              }
            }
          ],
          "schemaVersion": 27,
          "style": "dark",
          "tags": [],
          "templating": {
            "list": [
              {
                "description": null,
                "error": null,
                "hide": 2,
                "label": null,
                "name": "Environment",
                "query": "dev",
                "skipUrlSync": false,
                "type": "constant"
              }
            ]
          },
          "time": {
            "from": "now-6h",
            "to": "now"
          },
          "timepicker": {},
          "timezone": "",
          "title": "test",
          "uid": "Op2N9sqGk",
          "version": 1
        }
      }
    ],
    "identifier": 67712138
  },
  {
    "context": [
      "I have an array of objects, and want to filter the arrays in the `b` property to only have elements matching the `a` property of the object.",
      "produces",
      "[\n  {\n    \"a\": 3,\n    \"b\": [\n      3\n    ]\n  },\n  {\n    \"a\": 5,\n    \"b\": [\n      5,\n      5\n    ]\n  }\n]",
      "map(.a as $a | .b |= map(select(. == $a)))",
      "del(.[] | .a as $a | .b[] | select(. != $a))"
    ],
    "utterance": "Keep only the elements in each object's b array that are equal to that object's a property.",
    "expressions": [
      "[.[] | (.a as $a | .b |= [.[] | select(. == $a)])]",
      "map(.a as $a | .b |= map(select(. == $a)))",
      "del(.[] | .a as $a | .b[] | select(. != $a))"
    ],
    "data": [
      {
        "input": [
          {
            "a": 3,
            "b": [
              1,
              2,
              3
            ]
          },
          {
            "a": 5,
            "b": [
              3,
              5,
              4,
              3,
              5
            ]
          }
        ],
        "output": [
          {
            "a": 3,
            "b": [
              3
            ]
          },
          {
            "a": 5,
            "b": [
              5,
              5
            ]
          }
        ]
      }
    ],
    "identifier": 67940124
  },
  {
    "context": [
      "jq works quite nicely as a template engine, but there are choices to be made, e.g. depending on whether the \"template\" itself is valid JSON.",
      "In the example you gave, the template is not valid JSON, but it is potentially valid jq, so the strategy using jq \"$-variables\" would make sense, e.g. along the lines of:",
      "jq -n --arg value \"someValue\" -f template.jq",
      "where `template.jq` is your template.",
      "Three different strategies for using jq as a template engine are explained at some length in the jq Cookbook:"
    ],
    "utterance": "Substitute a variable in a template with a string value, ensuring proper escaping for special characters.",
    "expressions": [
      "jq -n --arg value \"someValue\" -f template.jq"
    ],
    "data": [
      {
        "input": "{ \"x\": $value }",
        "output": {
          "x": "someValue"
        }
      }
    ],
    "identifier": 67944912
  },
  {
    "context": [
      "$ jq_expr='.value | .[] | [.x] | @tsv'",
      "$ jq -e -r \"$jq_expr\" <<< '{\"value\": []}' || echo \"$?\" # I just want this one to exit with 0 instead of 4.",
      "To handle the case in which .value is the empty array specially, you could use an `if ... then ... else ... end` statement, a `try ... catch ...` expression, or some equivalent.",
      "jq_expr='.value | if length > 0 then map(.x) else empty end | @tsv'"
    ],
    "utterance": "Return .x from each object in .value as TSV, but exit with status 0 and no output if .value is empty.",
    "expressions": [
      ".value | if length > 0 then map(.x) else empty end | @tsv"
    ],
    "data": [
      {
        "input": {
          "value": []
        },
        "output": ""
      },
      {
        "input": {
          "value": [
            {
              "x": 42
            }
          ]
        },
        "output": "42"
      }
    ],
    "identifier": 67949284
  },
  {
    "context": [
      "I want to use `jq` to return with an exit status of 0 (print nothing) for the second case, and print `no such element: xxx` to stderr and return an exit status of 1 for the first case.",
      ".value | if . then .error | halt_error(1) else null | halt_error(0) end",
      "jq -n 'inputs | .value | if .error then \"\\(.message)\\n\" | halt_error(1) else halt end' < file.json"
    ],
    "utterance": "Return exit status 1 and print the message field if the value contains an error; otherwise exit successfully and print nothing.",
    "expressions": [
      ".value | if . then .error | halt_error(1) else null | halt_error(0) end",
      "inputs | .value | if .error then \"\\(.message)\\n\" | halt_error(1) else halt end"
    ],
    "data": [
      {
        "input": {
          "value": {
            "error": "no such element",
            "message": "no such element: xxx"
          }
        },
        "output": "no such element: xxx\n"
      },
      {
        "input": {
          "value": null
        },
        "output": ""
      }
    ],
    "identifier": 67945051
  },
  {
    "context": [
      "How do I query and replace the value for SMT_PORT_3306_TCP_ADDR.",
      "the output I get ... I do not get the full json",
      "Input Json : ...",
      "Expected output without the top level **taskDefinition** value:",
      "Use `|=` with `if`.",
      "jq '.taskDefinition.containerDefinitions[0].environment[] |= if   .name == \"SMT_PORT_3306_TCP_ADDR\" then .value = \"myvalue\" else . end'"
    ],
    "utterance": "Replace the value of the environment variable whose name is SMT_PORT_3306_TCP_ADDR with myvalue inside the first container definition, and output the full task definition object (without the enclosing taskDefinition key).",
    "expressions": [
      ".taskDefinition | .containerDefinitions[0].environment |= map(if .name == \"SMT_PORT_3306_TCP_ADDR\" then .value = \"myvalue\" else . end)"
    ],
    "data": [
      {
        "input": {
          "taskDefinition": {
            "taskDefinitionArn": "some value",
            "containerDefinitions": [
              {
                "name": "common-api-img",
                "environment": [
                  {
                    "name": "SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST",
                    "value": "false"
                  },
                  {
                    "name": "SMT_PORT_3306_TCP_ADDR",
                    "value": "valueToReplace"
                  }
                ],
                "mountPoints": [],
                "volumesFrom": []
              }
            ],
            "revision": 65,
            "volumes": [],
            "status": "ACTIVE"
          }
        },
        "output": {
          "taskDefinitionArn": "some value",
          "containerDefinitions": [
            {
              "name": "common-api-img",
              "environment": [
                {
                  "name": "SERVER_API_TIMEOUT_SUBSCRIPTIONS_CANCEL_REQUEST",
                  "value": "false"
                },
                {
                  "name": "SMT_PORT_3306_TCP_ADDR",
                  "value": "myvalue"
                }
              ],
              "mountPoints": [],
              "volumesFrom": []
            }
          ],
          "revision": 65,
          "volumes": [],
          "status": "ACTIVE"
        }
      }
    ],
    "identifier": 67938918
  },
  {
    "context": [
      "I can't figure out how to sort based on a value in the array, and then print the key of the array.",
      "The date is in `.[26]`.",
      "Here is my desired output:\n\n    FAC73275BC376C4C26DFDA41D991D021838DB778\n    2C3D7D91DFD0A57CFCA8B7092347B311088D3B6E\n    671CA27A76DC35E8E9F46723F1F6596A8BC75DA0\n\nOr even better just the single\n\n    671CA27A76DC35E8E9F46723F1F6596A8BC75DA0",
      "[ \n  .t | \n  (keys_unsorted[]) as $k | \n  { key: $k, value: .[$k][26] } \n] | sort_by(.value)[].key",
      "Or to get the last element alone replace sort in above with `sort_by(.value) | last.key`",
      ".t | to_entries | sort_by(.value[26])[].key",
      ".t | to_entries | max_by(.value[26]) .key"
    ],
    "utterance": "Sort the keys of the top-level object t by the value at index 26 of their array value, and return either all keys in sorted order or just the one with the largest value at index 26.",
    "expressions": [
      "[ .t | (keys_unsorted[]) as $k | { key: $k, value: .[$k][26] } ] | sort_by(.value)[].key",
      "[ .t | (keys_unsorted[]) as $k | { key: $k, value: .[$k][26] } ] | sort_by(.value) | last.key",
      ".t | to_entries | sort_by(.value[26])[].key",
      ".t | to_entries | max_by(.value[26]) .key"
    ],
    "data": [
      {
        "input": {
          "t": {
            "2C3D7D91DFD0A57CFCA8B7092347B311088D3B6E": [
              "1",
              "0",
              "1",
              "1",
              "Young.Sheldon.S04.1080p.x265-ZMNT",
              "4764367221",
              "1136",
              "1136",
              "4764367221",
              "5201425130",
              "1091",
              "0",
              "0",
              "4194304",
              "",
              "0",
              "0",
              "0",
              "0",
              "0",
              "2",
              "1622459402",
              "0",
              "0",
              "1136",
              "/home/xxxxxxxx/files/Young.Sheldon.S04.1080p.x265-ZMNT",
              "1622421479",
              "2",
              "1",
              "",
              "",
              "4436465131520",
              "1",
              "1"
            ],
            "FAC73275BC376C4C26DFDA41D991D021838DB778": [
              "1",
              "0",
              "1",
              "1",
              "Joshy.2016.NORDIC.1080p.BluRay.REMUX.AVC.DTS-HD.MA.5.1-Danishbits",
              "21160180253",
              "5045",
              "5045",
              "21160180253",
              "4470554624",
              "211",
              "114688",
              "0",
              "4194304",
              "",
              "1",
              "0",
              "1",
              "0",
              "0",
              "2",
              "1622459402",
              "0",
              "0",
              "5045",
              "/home/xxxxxxxx/files/Joshy.2016.NORDIC.1080p.BluRay.REMUX.AVC.DTS-HD.MA.5.1-Danishbits",
              "1622413504",
              "2",
              "1",
              "",
              "",
              "4436465131520",
              "1",
              "1"
            ],
            "671CA27A76DC35E8E9F46723F1F6596A8BC75DA0": [
              "1",
              "0",
              "1",
              "1",
              "Working.Girl.1988.1080p.Bluray.REMUX.AVC.DTS-HD.MA.5.1-4K4U",
              "29680778067",
              "14153",
              "14153",
              "29680778067",
              "12426936320",
              "418",
              "0",
              "0",
              "2097152",
              "",
              "1",
              "0",
              "1",
              "0",
              "0",
              "2",
              "1622459402",
              "0",
              "0",
              "14153",
              "/home/xxxxxxxx/files/Working.Girl.1988.1080p.Bluray.REMUX.AVC.DTS-HD.MA.5.1-4K4U",
              "1622440882",
              "2",
              "1",
              "",
              "",
              "4436465131520",
              "1",
              "1"
            ]
          },
          "cid": 1423760010
        },
        "output": [
          "FAC73275BC376C4C26DFDA41D991D021838DB778",
          "2C3D7D91DFD0A57CFCA8B7092347B311088D3B6E",
          "671CA27A76DC35E8E9F46723F1F6596A8BC75DA0"
        ]
      }
    ],
    "identifier": 67819584
  },
  {
    "context": [
      "I want to extract in plain text just the *value* for a given *geo_name*: \"Pen\u00ednsula\"",
      "Try this one:\n```\njq '.indicator.values[] | select(.geo_name==\"Pen\u00ednsula\") | .value' myfile.json\n```",
      "What worked for me is:\n\n    jq '.indicator.values[] | select(.geo_name==\"Pen\u00ednsula\") .value'"
    ],
    "utterance": "Extract all values where geo_name is \"Pen\u00ednsula\".",
    "expressions": [
      ".indicator.values[] | select(.geo_name==\"Pen\u00ednsula\") | .value",
      ".indicator.values[] | select(.geo_name==\"Pen\u00ednsula\") .value"
    ],
    "data": [
      {
        "input": {
          "indicator": {
            "name": "T\u00e9rmino de facturaci\u00f3n de energ\u00eda activa del PVPC 2.0TD",
            "short_name": "PVPC T. 2.0TD",
            "id": 1001,
            "composited": false,
            "step_type": "linear",
            "disaggregated": true,
            "magnitud": [
              {
                "name": "Precio",
                "id": 23
              }
            ],
            "tiempo": [
              {
                "name": "Hora",
                "id": 4
              }
            ],
            "geos": [
              {
                "geo_id": 8741,
                "geo_name": "Pen\u00ednsula"
              },
              {
                "geo_id": 8742,
                "geo_name": "Canarias"
              },
              {
                "geo_id": 8743,
                "geo_name": "Baleares"
              },
              {
                "geo_id": 8744,
                "geo_name": "Ceuta"
              },
              {
                "geo_id": 8745,
                "geo_name": "Melilla"
              }
            ],
            "values": [
              {
                "value": 116.2,
                "datetime": "2021-06-02T00:00:00.000+02:00",
                "datetime_utc": "2021-06-01T22:00:00Z",
                "tz_time": "2021-06-01T22:00:00.000Z",
                "geo_id": 8741,
                "geo_name": "Pen\u00ednsula"
              },
              {
                "value": 116.2,
                "datetime": "2021-06-02T00:00:00.000+02:00",
                "datetime_utc": "2021-06-01T22:00:00Z",
                "tz_time": "2021-06-01T22:00:00.000Z",
                "geo_id": 8742,
                "geo_name": "Canarias"
              },
              {
                "value": 116.2,
                "datetime": "2021-06-02T00:00:00.000+02:00",
                "datetime_utc": "2021-06-01T22:00:00Z",
                "tz_time": "2021-06-01T22:00:00.000Z",
                "geo_id": 8743,
                "geo_name": "Baleares"
              },
              {
                "value": 116.2,
                "datetime": "2021-06-02T00:00:00.000+02:00",
                "datetime_utc": "2021-06-01T22:00:00Z",
                "tz_time": "2021-06-01T22:00:00.000Z",
                "geo_id": 8744,
                "geo_name": "Ceuta"
              },
              {
                "value": 116.2,
                "datetime": "2021-06-02T00:00:00.000+02:00",
                "datetime_utc": "2021-06-01T22:00:00Z",
                "tz_time": "2021-06-01T22:00:00.000Z",
                "geo_id": 8745,
                "geo_name": "Melilla"
              },
              {
                "value": 114.37,
                "datetime": "2021-06-02T01:00:00.000+02:00",
                "datetime_utc": "2021-06-01T23:00:00Z",
                "tz_time": "2021-06-01T23:00:00.000Z",
                "geo_id": 8741,
                "geo_name": "Pen\u00ednsula"
              },
              {
                "value": 114.37,
                "datetime": "2021-06-02T01:00:00.000+02:00",
                "datetime_utc": "2021-06-01T23:00:00Z",
                "tz_time": "2021-06-01T23:00:00.000Z",
                "geo_id": 8742,
                "geo_name": "Canarias"
              },
              {
                "value": 114.37,
                "datetime": "2021-06-02T01:00:00.000+02:00",
                "datetime_utc": "2021-06-01T23:00:00Z",
                "tz_time": "2021-06-01T23:00:00.000Z",
                "geo_id": 8743,
                "geo_name": "Baleares"
              },
              {
                "value": 114.37,
                "datetime": "2021-06-02T01:00:00.000+02:00",
                "datetime_utc": "2021-06-01T23:00:00Z",
                "tz_time": "2021-06-01T23:00:00.000Z",
                "geo_id": 8744,
                "geo_name": "Ceuta"
              },
              {
                "value": 114.37,
                "datetime": "2021-06-02T01:00:00.000+02:00",
                "datetime_utc": "2021-06-01T23:00:00Z",
                "tz_time": "2021-06-01T23:00:00.000Z",
                "geo_id": 8745,
                "geo_name": "Melilla"
              }
            ],
            "values_updated_at": "2021-06-01T20:18:22.000+02:00"
          }
        },
        "output": [
          116.2,
          114.37
        ]
      }
    ],
    "identifier": 67802622
  },
  {
    "context": [
      "I am trying to change values from array in a JSON object with sed and jq.",
      "And I am trying to change value from field \"selectedroles\" to a script argument.",
      "Modify the array directly with `jq`:",
      "jq '.selectedroles=$ARGS.positional' \"$json_file\" --args \"$@\" >\"$tmp_json\"",
      "Content of JSON file after running Example Usage:",
      "\"selectedroles\": [\n    \"hello\",\n    \"world\"\n  ],"
    ],
    "utterance": "Replace the value of the selectedroles field with new values provided as script arguments.",
    "expressions": [
      ".selectedroles=$ARGS.positional"
    ],
    "data": [
      {
        "input": {
          "alertrulemethoddata": "",
          "alertruleimportance": 50,
          "alertruletype": "any",
          "alertrule_any": "filter:\n- query_string:\n       query: 'data.win.system.eventID:\\\"4624\\\"'",
          "alertrulemethodusers": [],
          "alertrulemethod": "none",
          "alertruleindexpattern": "windows",
          "alertruleplaybooks": [],
          "alertrulefilename": "windows_logon",
          "alertrulename": "windows-logon",
          "enable": "Y",
          "selectedroles": [
            "admin"
          ],
          "alertruleriskkeyaggregation": "MAX",
          "authenticator": "index",
          "alertruleriskkey": "",
          "changed": false
        },
        "output": {
          "alertrulemethoddata": "",
          "alertruleimportance": 50,
          "alertruletype": "any",
          "alertrule_any": "filter:\n- query_string:\n       query: 'data.win.system.eventID:\\\"4624\\\"'",
          "alertrulemethodusers": [],
          "alertrulemethod": "none",
          "alertruleindexpattern": "windows",
          "alertruleplaybooks": [],
          "alertrulefilename": "windows_logon",
          "alertrulename": "windows-logon",
          "enable": "Y",
          "selectedroles": [
            "hello",
            "world"
          ],
          "alertruleriskkeyaggregation": "MAX",
          "authenticator": "index",
          "alertruleriskkey": "",
          "changed": false
        }
      }
    ],
    "identifier": 67951336
  },
  {
    "context": [
      "how do I get InstanceId value?",
      "I tried\n```\njq '.Instances[] .InstanceId[]' ec2.json\n```\nbut I get\n```\nError - jq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end (Windows cmd shell quoting issues?) at <top-level>, line 1:\n'.Instances[]\njq: 1 compile error\n```\nThe data is given below:",
      "Try this:\n```\njq '.Instances[].InstanceId' ec2.json\n```"
    ],
    "utterance": "Extract the value of InstanceId from each object in the Instances array where the input is a structure containing an Instances list.",
    "expressions": [
      ".Instances[].InstanceId"
    ],
    "data": [
      {
        "input": {
          "Groups": [],
          "Instances": [
            {
              "AmiLaunchIndex": 0,
              "ImageId": "ami-0c1a7f89451184c8b",
              "InstanceId": "i-0144deb73abecac7c",
              "InstanceType": "t2.micro",
              "KeyName": "SaasPectKeyPair",
              "LaunchTime": "2021-06-08T14:22:47+00:00",
              "Monitoring": {
                "State": "disabled"
              },
              "Placement": {
                "AvailabilityZone": "ap-south-1b",
                "GroupName": "",
                "Tenancy": "default"
              },
              "PrivateDnsName": "ip-172-31-9-94.ap-south-1.compute.internal",
              "PrivateIpAddress": "172.31.9.94",
              "ProductCodes": [],
              "PublicDnsName": "",
              "State": {
                "Code": 0,
                "Name": "pending"
              },
              "StateTransitionReason": "",
              "SubnetId": "subnet-b3134aff",
              "VpcId": "vpc-210ccf4a",
              "Architecture": "x86_64",
              "BlockDeviceMappings": [],
              "ClientToken": "7b867508-3a09-4fb5-ab54-9ef763417995",
              "EbsOptimized": false,
              "EnaSupport": true,
              "Hypervisor": "xen",
              "NetworkInterfaces": [
                {
                  "Attachment": {
                    "AttachTime": "2021-06-08T14:22:47+00:00",
                    "AttachmentId": "eni-attach-01c465a1559542bf5",
                    "DeleteOnTermination": true,
                    "DeviceIndex": 0,
                    "Status": "attaching",
                    "NetworkCardIndex": 0
                  },
                  "Description": "",
                  "Groups": [
                    {
                      "GroupName": "default",
                      "GroupId": "sg-04472279"
                    }
                  ],
                  "Ipv6Addresses": [],
                  "MacAddress": "0a:d4:9d:f4:48:a2",
                  "NetworkInterfaceId": "eni-0d2272b6397ad6cf3",
                  "OwnerId": "891999723090",
                  "PrivateDnsName": "ip-172-31-9-94.ap-south-1.compute.internal",
                  "PrivateIpAddress": "172.31.9.94",
                  "PrivateIpAddresses": [
                    {
                      "Primary": true,
                      "PrivateDnsName": "ip-172-31-9-94.ap-south-1.compute.internal",
                      "PrivateIpAddress": "172.31.9.94"
                    }
                  ],
                  "SourceDestCheck": true,
                  "Status": "in-use",
                  "SubnetId": "subnet-b3134aff",
                  "VpcId": "vpc-210ccf4a",
                  "InterfaceType": "interface"
                }
              ],
              "RootDeviceName": "/dev/sda1",
              "RootDeviceType": "ebs",
              "SecurityGroups": [
                {
                  "GroupName": "default",
                  "GroupId": "sg-04472279"
                }
              ],
              "SourceDestCheck": true,
              "StateReason": {
                "Code": "pending",
                "Message": "pending"
              },
              "VirtualizationType": "hvm",
              "CpuOptions": {
                "CoreCount": 1,
                "ThreadsPerCore": 1
              },
              "CapacityReservationSpecification": {
                "CapacityReservationPreference": "open"
              },
              "MetadataOptions": {
                "State": "pending",
                "HttpTokens": "optional",
                "HttpPutResponseHopLimit": 1,
                "HttpEndpoint": "enabled"
              },
              "EnclaveOptions": {
                "Enabled": false
              }
            }
          ],
          "OwnerId": "891999723090",
          "ReservationId": "r-03c1c9762da6ec46b"
        },
        "output": "i-0144deb73abecac7c"
      }
    ],
    "identifier": 67889468
  }
]