[
  {
    "context": [
      "How can I run the jq command to replace the key `.x.y` to `[\"one\", \"two\", \"three\"]`",
      "< payload.json.tpl jq --arg a \"${array[*]}\" '.x.y=($a|split(\" \"))'",
      "jq '.x.y = $ARGS.positional' payload.json.tpl --args \"${array[@]}\""
    ],
    "utterance": "Replace the property .x.y with the array [\"one\", \"two\", \"three\"] using a shell variable as the source.",
    "expressions": [
      ".x.y = ($a | split(\" \"))",
      ".x.y = $ARGS.positional"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "x": {
            "y": "${array}"
          }
        },
        "output": {
          "foo": "bar",
          "x": {
            "y": [
              "one",
              "two",
              "three"
            ]
          }
        }
      }
    ],
    "identifier": 59153051
  },
  {
    "context": [
      "jq --arg line \"$data\" -R -r '. as $line | try fromjson catch $line'",
      "jq: error: syntax error, unexpected '|'",
      "echo \"$data\" | jq -rR '. as $line | try fromjson catch $line'",
      "echo 'Hello World' | pparselogs",
      "Hello World",
      "echo '{\"id\":1, \"message\":\"Hello World\"}' | pparselogs",
      "{\n  \"id\": 1,\n  \"message\": \"Hello World\"\n}"
    ],
    "utterance": "For each input line, emit parsed content if the line is parseable; otherwise, print the line unchanged.",
    "expressions": [
      ". as $line | try fromjson catch $line"
    ],
    "data": [
      {
        "input": "Hello World",
        "output": "Hello World"
      },
      {
        "input": "{\"id\":1, \"message\":\"Hello World\"}",
        "output": {
          "id": 1,
          "message": "Hello World"
        }
      }
    ],
    "identifier": 59180063
  },
  {
    "context": [
      "In your specific case I think you have a small bash quoting error causing `${branch}` to be treated as a constant. I think you want to quote it like this:",
      "'.\"'      \"${branch}\"         '\" | .auth'",
      "cat input.json | jq --raw-output '.\"'\"${branch}\"'\" | .auth'",
      "The variable substitution section of the [Advanced Bash Scripting Guide](http://tldp.org/LDP/abs/html/varsubn.html) is your friend.",
      "Environment variables (as opposed to shell variables) can be dereferenced in jq programs using the `env` object. In your case, you'd write `env.branch`.",
      "If you wanted to make the value of a variable accessible as `$branch` in the shell, it is best to use the --arg command-line option, along the lines of:",
      "jq --arg branch \"$branch\"",
      "That way, you can reference the value as `$branch` in the jq program. In the specific case of the Q, you could (for example) write:",
      "jq -r '.[$branch].auth'"
    ],
    "utterance": "Select the value associated with the key held in the shell variable branch and retrieve its auth subfield.",
    "expressions": [
      "jq -r --arg branch \"$branch\" '.[$branch].auth'",
      "jq -r '.[env.branch].auth'"
    ],
    "data": [
      {
        "input": {
          "feature/EBS_DDS_SC-27428": {
            "auth": "http://ab123:8080/service.jsp",
            "publish": "http://ab234:8080/service.jsp",
            "general_name": "PG1"
          }
        },
        "output": "http://ab123:8080/service.jsp"
      }
    ],
    "identifier": 59162608
  },
  {
    "context": [
      "When I apply these commands I get unreliable results:\r\n\r\n.Statement[0].Resource | length   --&gt;  73 incorrect &lt;/br&gt;\r\n.Statement[1].Resource | length   --&gt;  3 correct &lt;/br&gt;\r\n\r\nThe first command produces the number equal to the number of characters in that string, which is not what I need.  How can I achieve the 1 and 3 in a more certain way?",
      "Assuming `Resource` can either be of type `string` or `array`\r\n```\r\n.Statement[].Resource | if type == \"array\" then length else 1 end\r\n```\r\nwill output\r\n```\r\n1\r\n3\r\n```",
      "You can convert the `Resource` section to an array, flatten() it, then pipe it out to length() to get the correct number of elements.\r\n\r\n```\r\n$ cat api_return.json | jq '[.Statement[0].Resource] | flatten | length'\r\n1\r\n```"
    ],
    "utterance": "Count the number of elements in each Resource field inside the Statement array, treating a string as one and an array by its length.",
    "expressions": [
      ".Statement[].Resource | if type == \"array\" then length else 1 end",
      "[.Statement[0].Resource] | flatten | length"
    ],
    "data": [
      {
        "input": {
          "Statement": [
            {
              "Sid": "Group1",
              "Resource": "arn:aws:ecs:*:777744445555:task-rendition/${aws:PrincipalTag/Service}-*:*",
              "Effect": "Allow"
            },
            {
              "Sid": "Group2",
              "Resource": [
                "arn:aws:ecs:*:777744445555:task-definition/${aws:PrincipalTag/Service}-*:*",
                "arn:aws:ecs:*:777744445555:task-petition/${aws:PrincipalTag/Service}-*:*",
                "arn:aws:ecs:*:777744445555:task-fruition/${aws:PrincipalTag/Service}-*:*"
              ],
              "Effect": "Allow"
            }
          ]
        },
        "output": [
          1,
          3
        ]
      }
    ],
    "identifier": 59128837
  },
  {
    "context": [
      "Trying to get the codename of a specific android device having its model and brand from https://github.com/jaredrummler/AndroidDeviceNames :",
      "$curl $codeNameJSONDataBaseURL/$brand.json | jq -r --arg model $model '.devices[] | select( .model | match($model;\"i\") ).codename'",
      "$ ... | jq --arg model \"$model\" '.devices[] | select(.model == $model).codename'"
    ],
    "utterance": "Find the codename of a device given its brand and model (e.g., model B3-A20B within brand ACER).",
    "expressions": [
      ".devices[] | select(.model == $model).codename",
      ".devices[] | select(.model | match($model;\"i\")).codename"
    ],
    "identifier": 59203157
  },
  {
    "context": [
      "I have a JSON string without the separator `,`. How do I parse it using `jq`?",
      "The above line gives me the below error:",
      "parse error: Expected separator between values at line 1",
      "Here are two just-jq solutions, each with its own degree of brittleness. The first one attempts to convert each entire input line into valid JSON:",
      "echo '{\"access_token\":\"XXXX\"\"expires_in\":300\"token_type\":\"Bearer\"}' |\njq -rR 'gsub(\"(?<k>\\\"[^\\\"]*\\\")\"; \",\" + .k )\n    | gsub(\"{,\\\"\";\"{\\\"\") | gsub(\":,\\\"\"; \":\\\"\") \n    | fromjson | .access_token'",
      "jq -rR 'sub(\".*\\\"access_token\\\" *: *\\\"(?<v>[^\\\"]*)\\\".*\"; .v )'"
    ],
    "utterance": "Extract the value of access_token from an object string missing commas between fields and with some quotes missing.",
    "expressions": [
      "jq -rR 'gsub(\"(?<k>\\\\\\\"[^\\\\\\\"]*\\\\\\\")\"; \",\" + .k ) | gsub(\"{,\\\\\\\"\";\"{\\\\\\\"\") | gsub(\":,\\\\\\\"\"; \":\\\\\\\"\") | fromjson | .access_token'",
      "jq -rR 'sub(\".*\\\\\\\"access_token\\\\\\\" *: *\\\\\\\"(?<v>[^\\\\\\\"]*)\\\\\\\".*\"; .v )'"
    ],
    "data": [
      {
        "input": "{\"access_token\":\"XXXX\"\"expires_in\":300\"token_type\":\"Bearer\"}",
        "output": "XXXX"
      }
    ],
    "identifier": 59153661
  },
  {
    "context": [
      "I would like to insert this piece of code from the devices_format.json file ... in the empty array of test_3.json",
      "The result should look like this ... (output JSON shows the structure with devices_format.json inserted as first element of devices array)",
      "jq --argfile insert devices_format.json '\n  .drivers.lorawan.interfaces[0].devices |= [$insert]\n  ' test_3.json",
      "jq -n 'input as $insert\n       | input \n       | .drivers.lorawan.interfaces[0].devices |= [$insert]\n  ' devices_format.json test_3.json",
      "If you want every .devices array that's empty to be replaced by the specified JSON, you could go with walk/1, e.g.:",
      "jq -n 'input as $insert\n       | input\n       | walk(if type==\"object\" and .devices == [] \n              then .devices = [$insert] \n              else . end)\n  ' devices_format.json test_3.json"
    ],
    "utterance": "Insert the contents of one file as the sole element of the empty devices array in another file, so that the result matches the demonstrated nested structure.",
    "expressions": [
      "jq --argfile insert devices_format.json '.drivers.lorawan.interfaces[0].devices |= [$insert]' test_3.json",
      "jq -n 'input as $insert | input | .drivers.lorawan.interfaces[0].devices |= [$insert]' devices_format.json test_3.json",
      "jq -n 'input as $insert | input | walk(if type==\"object\" and .devices == [] then .devices = [$insert] else . end)' devices_format.json test_3.json"
    ],
    "data": [
      {
        "input": {
          "devices": [
            {
              "name": "new_elsys",
              "objects": [
                {
                  "name": "ServerRoomTemp",
                  "datapoint_type": "measurement",
                  "coder_field": "temperature"
                }
              ]
            },
            {
              "name": "old_elsys",
              "objects": [
                {
                  "name": "ServerRoomTemp",
                  "datapoint_type": "measurement",
                  "coder_field": "temperature"
                }
              ]
            }
          ]
        }
      },
      {
        "input": {
          "drivers": {
            "lorawan": {
              "interfaces": [
                {
                  "devices": []
                }
              ]
            }
          }
        },
        "output": {
          "drivers": {
            "lorawan": {
              "interfaces": [
                {
                  "devices": [
                    {
                      "devices": [
                        {
                          "name": "new_elsys",
                          "objects": [
                            {
                              "name": "ServerRoomTemp",
                              "datapoint_type": "measurement",
                              "coder_field": "temperature"
                            }
                          ]
                        },
                        {
                          "name": "old_elsys",
                          "objects": [
                            {
                              "name": "ServerRoomTemp",
                              "datapoint_type": "measurement",
                              "coder_field": "temperature"
                            }
                          ]
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 59152473
  },
  {
    "context": [
      "oc new-app abc/openshift-mysql:22 --output=json --dry-run=true | \\ jq '.items[] | select(.kind == \"DeploymentConfig\") | .spec.template.spec.containers[0].env +=\n             [{\"name\":\"db_name\",\"valueFrom\":{\"secretKeyRef\":{\"key\":\"database-name\",\"name\":\"mysql\"}}},{\"name\":\"db_username\",\"valueFrom\":{\"secretKeyRef\":{\"key\":\"database-user\",\"name\":\"mysql\"}}},{\"name\":\"db_password\",\"valueFrom\":{\"secretKeyRef\":{\"key\":\"database-password\",\"name\":\"mysql\"}}}]'",
      "The `jq` command runs fine against the sample input - see [here][1] (if someone is trying it on their own, do not paste the single quotes `&#39;` in the Filter input line)."
    ],
    "utterance": "Add environment variables db_name, db_username, and db_password using secretKeyRef to the env list of the first container in items with kind equal to DeploymentConfig.",
    "expressions": [
      ".items[] | select(.kind == \"DeploymentConfig\") | .spec.template.spec.containers[0].env += [{\"name\":\"db_name\",\"valueFrom\":{\"secretKeyRef\":{\"key\":\"database-name\",\"name\":\"mysql\"}}},{\"name\":\"db_username\",\"valueFrom\":{\"secretKeyRef\":{\"key\":\"database-user\",\"name\":\"mysql\"}}},{\"name\":\"db_password\",\"valueFrom\":{\"secretKeyRef\":{\"key\":\"database-password\",\"name\":\"mysql\"}}}]"
    ],
    "data": [
      {
        "input": {
          "kind": "List",
          "apiVersion": "v1",
          "metadata": {},
          "items": [
            {
              "kind": "DeploymentConfig",
              "apiVersion": "v1",
              "metadata": {
                "name": "openshift-mysql",
                "creationTimestamp": null,
                "labels": {
                  "app": "openshift-mysql"
                },
                "annotations": {
                  "openshift.io/generated-by": "OpenShiftNewApp"
                }
              },
              "spec": {
                "strategy": {
                  "resources": {}
                },
                "triggers": [
                  {
                    "type": "ConfigChange"
                  },
                  {
                    "type": "ImageChange",
                    "imageChangeParams": {
                      "automatic": true,
                      "containerNames": [
                        "openshift-mysql"
                      ],
                      "from": {
                        "kind": "ImageStreamTag",
                        "namespace": "abc",
                        "name": "openshift-mysql:22"
                      }
                    }
                  }
                ],
                "replicas": 1,
                "test": false,
                "selector": {
                  "app": "openshift-mysql",
                  "deploymentconfig": "openshift-mysql"
                },
                "template": {
                  "metadata": {
                    "creationTimestamp": null,
                    "labels": {
                      "app": "openshift-mysql",
                      "deploymentconfig": "openshift-mysql"
                    },
                    "annotations": {
                      "openshift.io/generated-by": "OpenShiftNewApp"
                    }
                  },
                  "spec": {
                    "containers": [
                      {
                        "name": "openshift-mysql",
                        "image": "172.30.1.1:5000/abc/openshift-mysql:22",
                        "ports": [
                          {
                            "containerPort": 8080,
                            "protocol": "TCP"
                          }
                        ],
                        "resources": {}
                      }
                    ]
                  }
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 59164392
  },
  {
    "context": [
      "I am trying to export json as a variable:",
      "$ export VARIABLE='[{\"id\": 2, \"name\": \"job\", \"description\": \"job\", \"token\": \"toknetokentokentoken/token=\"}]'",
      "and then I am trying to get the value from token:",
      "TOKEN=$(echo \"$VARIABLE\" | jq -r '.[] | select (.name == \"job\").token')",
      "but it returns nothing.",
      "try\n\n    VARIABLE='[{\"id\": 2, \"name\": \"job\", \"description\": \"job\", \"token\": \"toknetokentokentoken/token=\"}]'\n    TOKEN=$(echo \"$VARIABLE\"|jq '.[] | select(.name == \"job\").token')\n    echo \"$TOKEN\""
    ],
    "utterance": "Extract the token field from the array element where name equals job.",
    "expressions": [
      ".[] | select(.name == \"job\").token"
    ],
    "data": [
      {
        "input": [
          {
            "id": 2,
            "name": "job",
            "description": "job",
            "token": "toknetokentokentoken/token="
          }
        ],
        "output": "toknetokentokentoken/token="
      }
    ],
    "identifier": 59212769
  },
  {
    "context": [
      "How can I use jq to combine the two files above, into a single array, by merging each object?",
      "Desired output:\n[\n  {\n    \"command\": \"cat test.txt\",\n    \"datetime\": \"2019-12-08 11:34\"\n  },\n  {\n    \"command\": \"cat test2.txt\",\n    \"datetime\": \"2019-12-08 11:35\"\n  },\n  {\n    \"command\": \"cat test3.txt\",\n    \"datetime\": \"2019-12-08 12:03\"\n  }\n]",
      "Just slurp them. `-n` is for null input, and is overkill for this trivial task.",
      "jq -s 'transpose | map(add)' a.json b.json"
    ],
    "utterance": "Combine two arrays from separate files by merging objects at the same position into single objects containing all fields.",
    "expressions": [
      "jq -s 'transpose | map(add)' a.json b.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "datetime": "2019-12-08 11:34"
            },
            {
              "datetime": "2019-12-08 11:35"
            },
            {
              "datetime": "2019-12-08 12:03"
            }
          ],
          [
            {
              "command": "cat test.txt"
            },
            {
              "command": "cat test2.txt"
            },
            {
              "command": "cat test3.txt"
            }
          ]
        ],
        "output": [
          {
            "command": "cat test.txt",
            "datetime": "2019-12-08 11:34"
          },
          {
            "command": "cat test2.txt",
            "datetime": "2019-12-08 11:35"
          },
          {
            "command": "cat test3.txt",
            "datetime": "2019-12-08 12:03"
          }
        ]
      }
    ],
    "identifier": 59235418
  },
  {
    "context": [
      "i have a json file with user access data similar to this. I am trying to filter out user (name and accessDate fields) who has not accessed system for last 30 days. Does anyone know if this can be done using jq operation?",
      "Assuming the input is valid JSON, with \"items\" as the top-level key, then the value of \"items\" can be updated relative to `now` as follows:",
      "(now - 30*24*60*60 | strflocaltime(\"%Y-%m-%dT%H:%M:%S\")) as $recent",
      "| .items |= map( select((.accessDate",
      "| sub(\"-(?<d>[0-9]-)\";\"-0\\(.d)\")) >= $recent) )"
    ],
    "utterance": "Filter the list to include only users whose accessDate is within the last 30 days.",
    "expressions": [
      "(now - 30*24*60*60 | strflocaltime(\"%Y-%m-%dT%H:%M:%S\")) as $recent | .items |= map(select((.accessDate | sub(\"-(?<d>[0-9]-)\";\"-0\\(.d)\")) >= $recent))"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "id": "1",
              "accessDate": "2019-11-13T11:35:39.1097956",
              "user": {
                "name": "john doe"
              }
            },
            {
              "id": "2",
              "accessDate": "2019-10-13T11:35:39.1097956",
              "user": {
                "name": "scott doe"
              }
            },
            {
              "id": "3",
              "accessDate": "2019-9-13T11:35:39.1097956",
              "user": {
                "name": "matt doe"
              }
            }
          ]
        }
      }
    ],
    "identifier": 59241552
  },
  {
    "context": [
      "I need to extract `0.3889104875437488` and `0.2267407994117705`",
      "I have to add this : \"AUB\" for row 1 and \"VDR\" for row 2 before each line. Like :",
      "AUB : 0.3889104875437488 seconds",
      "VDR : 0.2267407994117705 seconds",
      "Use [tag:jq] for parsing JSON, for example:",
      "$ jq -r '.data.result[] | \"\\(.metric.project_site) : \\(.value[1]) seconds\"' file",
      "AUB : 0.3889104875437488 seconds",
      "VDR : 0.2267407994117705 seconds"
    ],
    "utterance": "Extract the second number from each result and print it with the corresponding project_site name and 'seconds' as a label.",
    "expressions": [
      ".data.result[] | \"\u001b[.metric.project_site] : \u001b[.value[1]] seconds\"",
      ".data.result[] | \"\\(.metric.project_site) : \\(.value[1]) seconds\""
    ],
    "data": [
      {
        "input": {
          "status": "success",
          "data": {
            "resultType": "vector",
            "result": [
              {
                "metric": {
                  "project_site": "AUB"
                },
                "value": [
                  1575277537.052,
                  "0.3889104875437488"
                ]
              },
              {
                "metric": {
                  "project_site": "VDR"
                },
                "value": [
                  1575277537.052,
                  "0.2267407994117705"
                ]
              }
            ]
          }
        },
        "output": [
          "AUB : 0.3889104875437488 seconds",
          "VDR : 0.2267407994117705 seconds"
        ]
      }
    ],
    "identifier": 59264302
  },
  {
    "context": [
      "I have two json files: 1.json and 2.json below.  Files both contain Statement[] array of objects that I want to combine into one file (result.json).",
      "For this specific case, you can simply add `Statement` fields of two objects like this:",
      "jq '.Statement += input.Statement' file1 file2"
    ],
    "utterance": "Combine the Statement arrays from two objects so that the result contains all Statement elements from both files in a single array.",
    "expressions": [
      ".Statement += input.Statement"
    ],
    "data": [
      {
        "input": [
          {
            "Statement": [
              {
                "Resource": [
                  "arn:aws:autoscaling:*:55555555:autoScalingGroup:*:autoScalingGroupName/${aws:PrincipalTag/Service}-*"
                ],
                "Effect": "Allow",
                "Action": [
                  "autoscaling:ExitStandby",
                  "autoscaling:RecordLifecycleActionHeartbeat"
                ],
                "Sid": "ascIBP0"
              }
            ],
            "Version": "2012-10-17"
          },
          {
            "Version": "2012-10-17",
            "Statement": [
              {
                "Action": [
                  "lambda:UpdateEventSourceMapping",
                  "lambda:CreateEventSourceMapping",
                  "lambda:DeleteEventSourceMapping"
                ],
                "Effect": "Allow",
                "Condition": {
                  "ArnLike": {
                    "lambda:FunctionArn": "arn:aws:lambda:*:*:function:${aws:PrincipalTag/Service}-*"
                  }
                },
                "Resource": "*",
                "Sid": "lmbIBP0"
              }
            ]
          }
        ],
        "output": {
          "Statement": [
            {
              "Resource": [
                "arn:aws:autoscaling:*:55555555:autoScalingGroup:*:autoScalingGroupName/${aws:PrincipalTag/Service}-*"
              ],
              "Effect": "Allow",
              "Action": [
                "autoscaling:ExitStandby",
                "autoscaling:RecordLifecycleActionHeartbeat"
              ],
              "Sid": "ascIBP0"
            },
            {
              "Action": [
                "lambda:UpdateEventSourceMapping",
                "lambda:CreateEventSourceMapping",
                "lambda:DeleteEventSourceMapping"
              ],
              "Effect": "Allow",
              "Condition": {
                "ArnLike": {
                  "lambda:FunctionArn": "arn:aws:lambda:*:*:function:${aws:PrincipalTag/Service}-*"
                }
              },
              "Resource": "*",
              "Sid": "lmbIBP0"
            }
          ],
          "Version": "2012-10-17"
        }
      }
    ],
    "identifier": 59274735
  },
  {
    "context": [
      "using jq for json replace",
      "jq --arg httpsas \"$newtoken\" '.OutboxAccessTicket.HttpSas=$httpsas' registrationticket.json_old > registrationticket.json",
      "So if we can look over the Comnmand arguments section, we notice that AZ CLI is losing the jq variable:",
      "jq --arg httpsas 'ASDASD ASD ASD ASD ASD' '.OutboxAccessTicket.HttpSas='"
    ],
    "utterance": "Set the value of OutboxAccessTicket.HttpSas to a given token in the file registrationticket.json_old and write the result to registrationticket.json.",
    "expressions": [
      "jq --arg httpsas \"$newtoken\" '.OutboxAccessTicket.HttpSas=$httpsas' registrationticket.json_old > registrationticket.json"
    ],
    "data": [
      {
        "input": {
          "OutboxAccessTicket": {
            "HttpSas": "OLDTOKEN",
            "OtherField": 123
          }
        },
        "output": {
          "OutboxAccessTicket": {
            "HttpSas": "ASDASD ASD ASD ASD ASD",
            "OtherField": 123
          }
        }
      }
    ],
    "identifier": 59281120
  },
  {
    "context": [
      "I need to filter some JSON such that only objects with a `www` key that is NOT in the `keysstoremove` array are kept in the final output.",
      "keysstoremove = [\"KLLIE2D\", \"FLLIE2D\", \"SLLIE2D\", \"ELLIE2D\"]",
      ".configurations[] | {www, en_key} | select(.en_key != null)",
      "Expected output:\n\n    [{\n        \"www\": \"BLLIE2D\",\n        \"en_key\": \"hashAAAAB3NzaC1y\"\n    },\n    {\n        \"www\": \"JLLIE2D\",\n        \"en_key\": \"hashnAAAt8zlnwg1Pj\"\n    }]",
      "def keysstoremove:\n  [\"KLLIE2D\", \"FLLIE2D\", \"SLLIE2D\", \"ELLIE2D\"];\n\n.configurations[]\n| .en_key as $k\n| select( keysstoremove | index($k) | not)\n| {www, en_key}"
    ],
    "utterance": "Filter to keep only objects where en_key is not in [\"KLLIE2D\", \"FLLIE2D\", \"SLLIE2D\", \"ELLIE2D\"] and return their www and en_key fields.",
    "expressions": [
      "def keysstoremove: [\"KLLIE2D\", \"FLLIE2D\", \"SLLIE2D\", \"ELLIE2D\"]; .configurations[] | select((.en_key as $k | keysstoremove | index($k) | not)) | {www, en_key}",
      "def keysstoremove: [\"KLLIE2D\", \"FLLIE2D\", \"SLLIE2D\", \"ELLIE2D\"]; .configurations[] | select((.en_key | keysstoremove | index(.) | not)) | {www, en_key}"
    ],
    "data": [
      {
        "input": {
          "configurations": [
            {
              "www": "BLLIE2D",
              "en_key": "hashAAAAB3NzaC1y"
            },
            {
              "www": "KLLIE2D",
              "en_key": "hashAAAAB3NwCXr57"
            },
            {
              "www": "JLLIE2D",
              "en_key": "hashnAAAt8zlnwg1Pj"
            },
            {
              "www": "FLLIE2D",
              "en_key": "hashAAAAB3NzaC1ycA"
            },
            {
              "www": "ELLIE2D",
              "en_key": "hashAAAAB3Nz0Md9sdvs"
            },
            {
              "www": "SLLIE2D",
              "en_key": "hashAAAAB3NzaC1yc2EAJ"
            }
          ]
        },
        "output": [
          {
            "www": "BLLIE2D",
            "en_key": "hashAAAAB3NzaC1y"
          },
          {
            "www": "JLLIE2D",
            "en_key": "hashnAAAt8zlnwg1Pj"
          }
        ]
      }
    ],
    "identifier": 59264692
  },
  {
    "identifier": 59299383
  },
  {
    "context": [
      "what I want to know is if there is a simple way to combine these so they can effectively be passed to jq (or maybe jq can just do this) such that I get:\r\n\r\n\r\n    [{\r\n       \"thing\": 1,\r\n       \"other\": \"foo\"\r\n    },\r\n    {\r\n       \"thing\": 2,\r\n       \"other\": \"baz\"\r\n    }]",
      "Use `-s` if you want JQ to *slurp* the input into one big array.",
      "```\r\n$ jq -s '. ' test.json\r\n[\r\n  {\r\n    \"thing\": 1,\r\n    \"other\": \"foo\"\r\n  },\r\n  {\r\n    \"thing\": 2,\r\n    \"other\": \"baz\"\r\n  }\r\n]\r\n```"
    ],
    "utterance": "Combine a stream of objects from multiple sources into a single array.",
    "expressions": [
      "jq -s '.'"
    ],
    "data": [
      {
        "input": [
          {
            "thing": 1,
            "other": "foo"
          },
          {
            "thing": 2,
            "other": "baz"
          }
        ],
        "output": [
          {
            "thing": 1,
            "other": "foo"
          },
          {
            "thing": 2,
            "other": "baz"
          }
        ]
      }
    ],
    "identifier": 59287280
  },
  {
    "context": [
      "With the command above if `${city}` argument I passed is `empty` or `null` then I want to remove the filter with **city** and just filter with **name**",
      "So you could achieve what you want by using this jq program:\n\ndef agrees(value): \n  value == null or value == \"\" or . == value;\n\nselect( (.city | agrees($city)) and\n        (.person.name | agrees($name)) )"
    ],
    "utterance": "Select entries where city matches a given argument unless the argument is empty or null, in which case ignore the city filter, and also filter by person.name in the same way.",
    "expressions": [
      "def agrees(value): value == null or value == \"\" or . == value;\nselect((.city | agrees($city)) and (.person.name | agrees($name)))"
    ],
    "identifier": 59297265
  },
  {
    "context": [
      "Is there any way to create nested json in bash.",
      "var1=\"aa bb cc dd\" -- which gives t1,t2 etc in the sample json",
      "var2=\"ee ff gg hh\" -- which gives k1,k2 etc in the sample json",
      "Upon iterating the variables i should derive the values of t's, k's and v's in the json.",
      "Here's an only-jq solution.  Notice that all the iteration can be done within the jq program itself:",
      "jq -n --arg var1 \"$var1\" --arg var2 \"$var2\" '\n  [$var2|splits(\"  *\")] as $v2\n  | (reduce range(0; $v2|length) as $i ({};\n       . + { ($v2[$i]): \"v\\($i + 1)\" })) as $o\n  | reduce ($var1|splits(\"  *\")) as $v1 ({};\n      setpath([$v1]; $o) )\n'",
      "var1=\"t1 t2\"",
      "var2=\"k1 k2\"",
      "{\n  \"t1\": {\n    \"k1\": \"v1\",\n    \"k2\": \"v2\"\n  },\n  \"t2\": {\n    \"k1\": \"v1\",\n    \"k2\": \"v2\"\n  }\n}"
    ],
    "utterance": "Construct a nested data structure where each element from the first variable is a key containing an object with keys from the second variable, each mapped to a value in the format 'v1', 'v2', etc.",
    "expressions": [
      "jq -n --arg var1 \"$var1\" --arg var2 \"$var2\" '\n  [$var2|splits(\"  *\")] as $v2\n  | (reduce range(0; $v2|length) as $i ({};\n       . + { ($v2[$i]): \"v\\($i + 1)\" })) as $o\n  | reduce ($var1|splits(\"  *\")) as $v1 ({};\n      setpath([$v1]; $o) )\n'"
    ],
    "data": [
      {
        "input": {
          "var1": "t1 t2",
          "var2": "k1 k2"
        },
        "output": {
          "t1": {
            "k1": "v1",
            "k2": "v2"
          },
          "t2": {
            "k1": "v1",
            "k2": "v2"
          }
        }
      }
    ],
    "identifier": 59285870
  },
  {
    "context": [
      "I am trying to get both jsonObjects, so that I can do something with them for my problem statement.",
      "$inputJson = '[{\"name\":\"JSON\", \"good\":true}, {\"name\":\"XML\", \"good\":false}]'",
      "$items = $inputJson | \tjq '.[]'",
      "The only way I see it doing what you want, is with jq's `--compact-output` option, which outputs one object (to jq) per line.",
      "$items = $inputJson | jq '.[]' --compact-output",
      "{ \"name\":\"JSON\", \"good\":true }",
      "{ \"name\":\"XML\", \"good\":false }"
    ],
    "utterance": "Output each object from an array as a separate compact string for further processing in PowerShell.",
    "expressions": [
      ".[]",
      ".[] | @json"
    ],
    "data": [
      {
        "input": [
          {
            "name": "JSON",
            "good": true
          },
          {
            "name": "XML",
            "good": false
          }
        ],
        "output": [
          {
            "name": "JSON",
            "good": true
          },
          {
            "name": "XML",
            "good": false
          }
        ]
      }
    ],
    "identifier": 59302509
  },
  {
    "context": [
      "I am trying to get values from a json file from a url using curl and then printing specific keys with jq command (e.g. company). Unfortunately when I use:\n```jq '.[] | .company' JB.json```\nI get the error: \n```parse error: Invalid numeric literal at line 1, column 9```.",
      "So presumably your JB.json contains the \"//\"-style comments.  The simplest workaround would probably be to filter out those first two lines (e.g. using `sed` (or jq!)) first.",
      "Here's a jq-only solution:\n```\n< JB.json jq -Rr 'select( test(\"^//\")|not)' |\n   jq '.[] | .company'\n```"
    ],
    "utterance": "Print the value of the 'company' key for each object in a file that may contain lines starting with '//' that should be ignored.",
    "expressions": [
      "< JB.json jq -Rr 'select( test(\"^//\")|not)' | jq '.[] | .company'"
    ],
    "identifier": 59337414
  },
  {
    "context": [
      "But this doesn't work:",
      "split(\",\") | map(tonumber) as $list | $list[0] = 30",
      "Invalid path expression near attempt to access element 0 of [1,0]",
      "From the [Assignment section of the jq manual](https://stedolan.github.io/jq/manual/#Assignment).",
      "use `$var | .foo = 1` instead.",
      "split(\",\") | map(tonumber) as $list | $list | .[0] = 30",
      "split(\",\") | map(tonumber) | .[0]=30"
    ],
    "utterance": "Set the first element of a comma-separated list of numbers to 30 after converting them to numbers.",
    "expressions": [
      "split(\",\") | map(tonumber) | .[0]=30",
      "split(\",\") | map(tonumber) as $list | $list | .[0]=30"
    ],
    "data": [
      {
        "input": "1,0",
        "output": [
          30,
          0
        ]
      }
    ],
    "identifier": 59324676
  },
  {
    "context": [
      "An example of the output JSON I\u2019m fetching:\n\n    {\n        \"plugins\": [\n            {\n                \"shortName\": \"foo\",\n                \"version\": \"6.9\",\n                \"dependencies\": [\n                    {\n                        \"shortName\": \"bar\",\n                        \"version\": \"4.2.0\"\n                    },\n                    {\n                        \"shortName\": \"baz\",\n                        \"version\": \"6.6.6\"\n                    }\n                ]\n            },\n            {\n                \"shortName\": \"fah\",\n                \"version\": \"4.2\",\n                \"dependencies\": [\n                    {\n                        \"shortName\": \"bah\",\n                        \"version\": \"1.3\"\n                    },\n                    {\n                        \"shortName\": \"bar\",\n                        \"version\": \"2.1.0\"\n                    },\n                    {\n                        \"shortName\": \"baz\",\n                        \"version\": \"6.6.6\"\n                ]\n            }\n        ]\n    }",
      "And here's the result that I\u2019d like to get:\n\n    [\n        {\n            \"shortName\": \"bah\",\n            \"version\": \"1.3\"\n        },\n        {\n            \"shortName\": \"bar\",\n            \"version\": \"2.1.0\"\n        },\n        {\n            \"shortName\": \"bar\",\n            \"version\": \"4.2.0\"\n        },\n        {\n            \"shortName\": \"baz\",\n            \"version\": \"6.6.6\"\n        },\n        {\n            \"shortName\": \"fah\",\n            \"version\": \"4.2\"\n        },\n        {\n            \"shortName\": \"foo\",\n            \"version\": \"6.9\"\n        },\n    ]",
      "I've made various attempts at using map and flatten but can\u2019t seem to preserve the parent\u2019s keys, let alone getting a comprehensive array of each plugin and its version."
    ],
    "utterance": "Extract all plugins and all their dependencies as a flat array of shortName and version pairs.",
    "expressions": [
      "[.plugins[] | {shortName, version}] + [.plugins[].dependencies[]? | {shortName, version}] | sort_by(.shortName, .version)"
    ],
    "data": [
      {
        "input": {
          "plugins": [
            {
              "shortName": "foo",
              "version": "6.9",
              "dependencies": [
                {
                  "shortName": "bar",
                  "version": "4.2.0"
                },
                {
                  "shortName": "baz",
                  "version": "6.6.6"
                }
              ]
            },
            {
              "shortName": "fah",
              "version": "4.2",
              "dependencies": [
                {
                  "shortName": "bah",
                  "version": "1.3"
                },
                {
                  "shortName": "bar",
                  "version": "2.1.0"
                },
                {
                  "shortName": "baz",
                  "version": "6.6.6"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "shortName": "bah",
            "version": "1.3"
          },
          {
            "shortName": "bar",
            "version": "2.1.0"
          },
          {
            "shortName": "bar",
            "version": "4.2.0"
          },
          {
            "shortName": "baz",
            "version": "6.6.6"
          },
          {
            "shortName": "fah",
            "version": "4.2"
          },
          {
            "shortName": "foo",
            "version": "6.9"
          }
        ]
      }
    ],
    "identifier": 59295890
  },
  {
    "context": [
      "What I need to accomplish is to \"merge\" each `id`-sharing pair into one object.",
      "I&#39;ve gotten these objects to appear next to each other via the `group_by(.id)` command, but I&#39;m at a loss as to how I should actually combine them.",
      "The merging you want can be achieved by object addition (`x + y`).",
      "group_by(.id) | map(add)"
    ],
    "utterance": "Combine all objects in the array with the same id into a single object merging their properties.",
    "expressions": [
      "group_by(.id) | map(add)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "names": [
              {
                "name": "Bulbasaur",
                "language": {
                  "name": "en",
                  "url": "http://myserver.com:8000/api/v2/language/9/"
                }
              }
            ]
          },
          {
            "id": 1,
            "types": [
              {
                "slot": 1,
                "type": {
                  "name": "grass",
                  "url": "http://myserver.com:8000/api/v2/type/12/"
                }
              },
              {
                "slot": 2,
                "type": {
                  "name": "poison",
                  "url": "http://myserver.com:8000/api/v2/type/4/"
                }
              }
            ]
          },
          {
            "id": 2,
            "names": [
              {
                "name": "Ivysaur",
                "language": {
                  "name": "en",
                  "url": "http://myserver.com:8000/api/v2/language/9/"
                }
              }
            ]
          },
          {
            "id": 2,
            "types": [
              {
                "slot": 1,
                "type": {
                  "name": "ice",
                  "url": "http://myserver.com:8000/api/v2/type/10/"
                }
              },
              {
                "slot": 2,
                "type": {
                  "name": "electric",
                  "url": "http://myserver.com:8000/api/v2/type/8/"
                }
              }
            ]
          }
        ],
        "output": [
          {
            "id": 1,
            "names": [
              {
                "name": "Bulbasaur",
                "language": {
                  "name": "en",
                  "url": "http://myserver.com:8000/api/v2/language/9/"
                }
              }
            ],
            "types": [
              {
                "slot": 1,
                "type": {
                  "name": "grass",
                  "url": "http://myserver.com:8000/api/v2/type/12/"
                }
              },
              {
                "slot": 2,
                "type": {
                  "name": "poison",
                  "url": "http://myserver.com:8000/api/v2/type/4/"
                }
              }
            ]
          },
          {
            "id": 2,
            "names": [
              {
                "name": "Ivysaur",
                "language": {
                  "name": "en",
                  "url": "http://myserver.com:8000/api/v2/language/9/"
                }
              }
            ],
            "types": [
              {
                "slot": 1,
                "type": {
                  "name": "ice",
                  "url": "http://myserver.com:8000/api/v2/type/10/"
                }
              },
              {
                "slot": 2,
                "type": {
                  "name": "electric",
                  "url": "http://myserver.com:8000/api/v2/type/8/"
                }
              }
            ]
          }
        ]
      }
    ],
    "identifier": 59150845
  },
  {
    "context": [
      "I am looking for JQ in bash to retrieve sGName, where \"attributeName\"=\"serverName\", and  \"value\"=\"Sever101\"",
      "I might have multiple \"sGName\"",
      "jq --raw-output 'map( select(.filters | any(.attributeName == \"serverName\" and .value == \"Sever101\")) |.sGName) | join(\"\\n\")'",
      "jq --raw-output --arg serverName \"Sever101\" 'map( select(.filters | any(.attributeName == \"serverName\" and .value == $serverName)) |.sGName) | join(\"\\n\")'",
      "jq --raw-output --arg serverName \"Sever101\" '.[] | select(any(.filters[]; .attributeName==\"serverName\" and .value==$serverName)).sGName'"
    ],
    "utterance": "Return all sGName properties from objects where one of the filters has attributeName equal to serverName and value equal to Sever101.",
    "expressions": [
      "map( select(.filters | any(.attributeName == \"serverName\" and .value == \"Sever101\")) | .sGName ) | join(\"\\n\")",
      "map( select(.filters | any(.attributeName == \"serverName\" and .value == $serverName)) | .sGName ) | join(\"\\n\")",
      ".[] | select(any(.filters[]; .attributeName==\"serverName\" and .value==$serverName)).sGName"
    ],
    "data": [
      {
        "input": [
          {
            "id": 0,
            "sGName": "SG1",
            "customProperties": [
              {
                "id": 100000,
                "name": "clustersIP",
                "value": "ABC"
              }
            ],
            "filters": [
              {
                "id": 74616,
                "attributeName": "serverName",
                "value": "Sever101"
              },
              {
                "id": 74617,
                "attributeName": "bigIPPool",
                "value": "server101v1"
              }
            ]
          },
          {
            "id": 1,
            "sGName": "SG2",
            "customProperties": [
              {
                "id": 100001,
                "name": "clustersIP",
                "value": "XYZ"
              }
            ],
            "filters": [
              {
                "id": 74618,
                "attributeName": "serverName",
                "value": "OtherServer"
              }
            ]
          }
        ],
        "output": [
          "SG1"
        ]
      }
    ],
    "identifier": 59309499
  },
  {
    "context": [
      "It needs to download entire resultset and then parse using tools like `jq` to extract row per line.",
      "If you have enough RAM, the simplest would be to use:\r\n\r\n    jq -sc '.[]'",
      "If you don't have enough RAM, then use:\r\n\r\n    jq -cn --stream 'fromstream(1|truncate_stream(inputs))'"
    ],
    "utterance": "Output each object in the root array as a separate line, for streaming large result sets.",
    "expressions": [
      ".[]",
      "-sc '.[]'",
      "-cn --stream 'fromstream(1|truncate_stream(inputs))'"
    ],
    "identifier": 59379953
  },
  {
    "context": [
      "What I am actually looking for is the record where the GUID is the largest in the dataset.",
      "To extract the object with the largest GUID ... jq has `max_by`, e.g:",
      "jq -s 'max_by(.guid)' conn.json",
      "and `reduce`, which is a more convenient construct for large inputs and eliminates the need for slurping.",
      "jq 'reduce inputs as $in (input; if $in.guid > .guid then $in else . end)' conn.json"
    ],
    "utterance": "Find the object with the largest value of guid.",
    "expressions": [
      "jq -s 'max_by(.guid)' conn.json",
      "jq 'reduce inputs as $in (input; if $in.guid > .guid then $in else . end)' conn.json"
    ],
    "data": [
      {
        "input": [
          {
            "ID": "XX",
            "guid": 1
          },
          {
            "ID": "YY",
            "guid": 2
          },
          {
            "ID": "ZZ",
            "guid": 5
          },
          {
            "ID": "WW",
            "guid": 3
          }
        ],
        "output": {
          "ID": "ZZ",
          "guid": 5
        }
      }
    ],
    "identifier": 59354507
  },
  {
    "context": [
      "Input:",
      "{ \"results\": { \"2019-11-27 00:00:00\": [ { \"e\": \"10814\", \"s\": \"153330\", \"t\": \"164144\" } ], \"2019-11-27 00:15:00\": [ { \"e\": \"11052\", \"s\": \"148692\", \"t\": \"159744\" } ], \"2019-11-27 00:30:00\": [ { \"e\": \"11550\", \"s\": \"152379\", \"t\": \"163929\" } ], \"2019-11-27 00:45:00\": [ { \"e\": \"12640\", \"s\": \"154984\", \"t\": \"167624\" } ] } }",
      "This is the output I&#39;m trying to reach:",
      "{\"timestamp\":\"2019-11-27 00:00:00\",\"e\":\"10814\",\"s\":\"153330\",\"t\":\"164144\"}",
      "{\"timestamp\":\"2019-11-27 00:15:00\",\"e\":\"11052\",\"s\":\"148692\",\"t\":\"159744\"}",
      "{\"timestamp\":\"2019-11-27 00:30:00\",\"e\":\"11550\",\"s\":\"152379\",\"t\":\"163929\"}",
      "{\"timestamp\":\"2019-11-27 00:45:00\",\"e\":\"12640\",\"s\":\"154984\",\"t\":\"167624\"}",
      "You were almost there. Just add the objects in those arrays to objects you created out of keys.",
      "```\n.results | keys_unsorted[] as $k | { timestamp: $k } + .[$k][]\n```",
      "Or using `to_entries`:\n```\n.results\n| to_entries[]\n| { timestamp: .key } + .value[]\n```"
    ],
    "utterance": "For each timestamp in results, produce an object with a timestamp property and the properties e, s, t from the corresponding entry.",
    "expressions": [
      ".results | keys_unsorted[] as $k | { timestamp: $k } + .[$k][]",
      ".results | to_entries[] | { timestamp: .key } + .value[]"
    ],
    "data": [
      {
        "input": {
          "results": {
            "2019-11-27 00:00:00": [
              {
                "e": "10814",
                "s": "153330",
                "t": "164144"
              }
            ],
            "2019-11-27 00:15:00": [
              {
                "e": "11052",
                "s": "148692",
                "t": "159744"
              }
            ],
            "2019-11-27 00:30:00": [
              {
                "e": "11550",
                "s": "152379",
                "t": "163929"
              }
            ],
            "2019-11-27 00:45:00": [
              {
                "e": "12640",
                "s": "154984",
                "t": "167624"
              }
            ]
          }
        },
        "output": [
          {
            "timestamp": "2019-11-27 00:00:00",
            "e": "10814",
            "s": "153330",
            "t": "164144"
          },
          {
            "timestamp": "2019-11-27 00:15:00",
            "e": "11052",
            "s": "148692",
            "t": "159744"
          },
          {
            "timestamp": "2019-11-27 00:30:00",
            "e": "11550",
            "s": "152379",
            "t": "163929"
          },
          {
            "timestamp": "2019-11-27 00:45:00",
            "e": "12640",
            "s": "154984",
            "t": "167624"
          }
        ]
      }
    ],
    "identifier": 59323232
  },
  {
    "context": [
      "My JSON looks like this.",
      "Expected Output:",
      "{      id: null,      date: \"2016-11-13T14:34:27.353Z\",      type: \"submission\",      user: abcd,      _processDate: todaysDate    }",
      "There could 'rejections' in the json and the output should display the rejections .",
      "I\u2019d take a completely different approach and do this instead.",
      "(now | todate) as $_processDate | [\n    .[].changes[]\n    | (.change\n        | scan(\"\\b(submitted|rejected)=true\\b\")[]\n        | {submitted:\"submission\",rejected:\"rejection\"}[.]) as $type\n    | {id, date, $type, user, $_processDate}\n]",
      "Then determine what type of change it is. Assuming that \"submitted\" and \"rejected\" (or other \"types\") are mutually exclusive, easier to match on the key name. Then build up the result."
    ],
    "utterance": "Extract each change with its date, user, and type as 'submission' or 'rejection' based on whether 'submitted=true' or 'rejected=true' appear in the change string, and include process date as the current date.",
    "expressions": [
      "(now | todate) as $_processDate | [\n    .[].changes[]\n    | (.change\n        | scan(\"\\b(submitted|rejected)=true\\b\")[]\n        | {submitted:\"submission\",rejected:\"rejection\"}[.]) as $type\n    | {id, date, $type, user, $_processDate}\n]"
    ],
    "data": [
      {
        "input": [
          {
            "changes": [
              {
                "change": "{users=[7], submitted=true}",
                "date": "2016-11-13T14:34:27.353Z",
                "user": "abcd"
              }
            ]
          }
        ],
        "output": [
          {
            "id": null,
            "date": "2016-11-13T14:34:27.353Z",
            "type": "submission",
            "user": "abcd",
            "_processDate": "todaysDate"
          }
        ]
      }
    ],
    "identifier": 59340401
  },
  {
    "context": [
      "This is the json file",
      "{ \"remote\":  [ {\"name\": \"cast-1\", \"id\": 1212 }, {\"name\": \"cast-1\", \"id\": 1214 }, {\"name\": \"home-11\", \"id\": 3212 }, {\"name\": \"cast-3\", \"id\": 3212 }, {\"name\": \"cast-3\", \"id\": 3213 }, {\"name\": \"cast-4\", \"id\": 4211 } ] }",
      "my desired output is",
      "\"cast-1\": 1212 , 1214,\n\"cast-3\": 3212 , 3213,\n\"cast-4\": 4211,",
      "with my attempt, i only am able to output this",
      "\"cast-1\": 1214,\n\"cast-3\": 3213, \n\"cast-4\": 4211,",
      "my code so far",
      "curl ... | jq  'reduce .remote[] as $v ({}; . + {\"\\($v.name)\":$v.id})'",
      "Cant figure out to add the second id from cast-1 and cast-3.",
      "You don't need reduce here, `group_by` should suffice. E.g:",
      ".remote | group_by(.name) | map({(.[0].name): map(.id)}) | add"
    ],
    "utterance": "For each unique name, list all associated ids as an array, grouped by that name.",
    "expressions": [
      ".remote | group_by(.name) | map({(.[0].name): map(.id)}) | add"
    ],
    "data": [
      {
        "input": {
          "remote": [
            {
              "name": "cast-1",
              "id": 1212
            },
            {
              "name": "cast-1",
              "id": 1214
            },
            {
              "name": "home-11",
              "id": 3212
            },
            {
              "name": "cast-3",
              "id": 3212
            },
            {
              "name": "cast-3",
              "id": 3213
            },
            {
              "name": "cast-4",
              "id": 4211
            }
          ]
        },
        "output": {
          "cast-1": [
            1212,
            1214
          ],
          "cast-3": [
            3212,
            3213
          ],
          "cast-4": [
            4211
          ],
          "home-11": [
            3212
          ]
        }
      }
    ],
    "identifier": 59342412
  },
  {
    "context": [
      "I want to replace the \"Items\": in the org json",
      "jq --arg originResponse ZZZ --arg viewerRequest YYY --arg originRequest XXX '\n.DistributionConfig.DefaultCacheBehavior.LambdaFunctionAssociations.Items |= map(\n  .EventType as $t | .LambdaFunctionARN =\n    if $t == \"origin-response\" then $originResponse\n    elif $t == \"viewer-request\" then $viewerRequest\n    elif $t == \"origin-request\" then $originRequest\n    else . end\n)' file"
    ],
    "utterance": "Replace all LambdaFunctionARN values in Items with specified variables based on their EventType within DistributionConfig.DefaultCacheBehavior.LambdaFunctionAssociations.",
    "expressions": [
      ".DistributionConfig.DefaultCacheBehavior.LambdaFunctionAssociations.Items |= map(.EventType as $t | .LambdaFunctionARN = if $t == \"origin-response\" then $originResponse elif $t == \"viewer-request\" then $viewerRequest elif $t == \"origin-request\" then $originRequest else . end)"
    ],
    "data": [
      {
        "input": {
          "DistributionConfig": {
            "DefaultCacheBehavior": {
              "LambdaFunctionAssociations": {
                "Quantity": 3,
                "Items": [
                  {
                    "LambdaFunctionARN": "3",
                    "EventType": "origin-response",
                    "IncludeBody": false
                  },
                  {
                    "LambdaFunctionARN": "2",
                    "EventType": "viewer-request",
                    "IncludeBody": false
                  },
                  {
                    "LambdaFunctionARN": "1",
                    "EventType": "origin-request",
                    "IncludeBody": false
                  }
                ]
              }
            }
          }
        },
        "output": {
          "DistributionConfig": {
            "DefaultCacheBehavior": {
              "LambdaFunctionAssociations": {
                "Quantity": 3,
                "Items": [
                  {
                    "LambdaFunctionARN": "ZZZ",
                    "EventType": "origin-response",
                    "IncludeBody": false
                  },
                  {
                    "LambdaFunctionARN": "YYY",
                    "EventType": "viewer-request",
                    "IncludeBody": false
                  },
                  {
                    "LambdaFunctionARN": "XXX",
                    "EventType": "origin-request",
                    "IncludeBody": false
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 59358553
  },
  {
    "context": [
      "Given JSON like:\n```\n{\"thing\": [\"hello\", \"bye\"], \"other\": {\"hello\": \"myval\"}}\n```\nI want a jq expression which takes the first element of the array under \"thing\" and looks it up in \"other\".",
      ".thing[0] as $tofind | .other[$tofind]",
      "You could simply write:\n\n    jq '.other[.thing[0]]'\n\n"
    ],
    "utterance": "Get the value from the object at the key given by the first element in the array under 'thing', using the value of that element as the object key in 'other'.",
    "expressions": [
      ".thing[0] as $tofind | .other[$tofind]",
      ".other[.thing[0]]"
    ],
    "data": [
      {
        "input": {
          "thing": [
            "hello",
            "bye"
          ],
          "other": {
            "hello": "myval"
          }
        },
        "output": "myval"
      }
    ],
    "identifier": 59380424
  },
  {
    "context": [
      "curl -s 'https://bch-chain.api.btc.com/v3/block/latest' | jq '.data.height'",
      "output",
      "613777"
    ],
    "utterance": "Extract the value of the height field inside the data object from the latest block response from the API at https://bch-chain.api.btc.com/v3/block/latest.",
    "expressions": [
      ".data.height"
    ],
    "data": [
      {
        "input": {
          "err_no": 0,
          "err_msg": "success",
          "data": {
            "height": 613777,
            "version": 536870912
          }
        },
        "output": 613777
      }
    ],
    "identifier": 59381644
  },
  {
    "context": [
      "For each top-level key, $host (e.g. kube-prod-worker-0), and for each key, $fs, at the next level (e.g. \"/var/lib/docker/aufs\"), compute the percentage available, $pc; if the percentage is less than 5% then output as CSV:",
      "jq 'keys[] as $host  \n  | .[]\n  | keys[] as $fs\n  | .[$fs][\"available\"] as $val \n  | .[$fs][\"total\"] as $tot\n  | {host:$host, fs: $fs, val: $val, tot: $tot }\n  | select(.tot>0)\n  | (($val/$tot)*100) as $perc\n  | select($perc<5) \n  | [$host,$fs,$perc]\n  | @csv\n'",
      "keys_unsorted[] as $host\n| .[$host]\n| keys_unsorted[] as $fs\n| .[$fs]\n| select(.total > 0)\n| ((.available/.total)*100) as $perc\n| select($perc < 5)\n| [$host, $fs, $perc]\n| @csv"
    ],
    "utterance": "For each host and filesystem, output host, filesystem, and percentage available as CSV if the available space is less than 5 percent of total.",
    "expressions": [
      "keys[] as $host  | .[] | keys[] as $fs | .[$fs][\"available\"] as $val | .[$fs][\"total\"] as $tot | {host:$host, fs: $fs, val: $val, tot: $tot } | select(.tot>0) | (($val/$tot)*100) as $perc | select($perc<5) | [$host,$fs,$perc] | @csv",
      "keys_unsorted[] as $host | .[$host] | keys_unsorted[] as $fs | .[$fs] | select(.total > 0) | ((.available/.total)*100) as $perc | select($perc < 5) | [$host, $fs, $perc] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "kube-prod-worker-0": {
              "/var/lib/docker/aufs": {
                "available": 222222733312,
                "total": 312202997760
              },
              "/var/lib/docker/aufs/mnt/0000000000000007ffb4e1xxxx5": {
                "available": 222222733399,
                "total": 1634054144
              }
            }
          },
          {
            "kube-prod-worker-7": {
              "/var/lib/docker/aufs": {
                "available": 253056245760,
                "total": 3122029977600
              },
              "/var/lib/docker/aufs/mnt/000000000dc1150f1xxxxdd3e4e4d3": {
                "available": 253056245760,
                "total": 3122029977605
              }
            }
          }
        ],
        "output": []
      }
    ],
    "identifier": 59358517
  },
  {
    "context": [
      "This code will turn a giant array into just the contents of the array, that can be output piece by piece.",
      "get-content file.json | \r\n  jq -cn --stream 'fromstream(1|truncate_stream(inputs))' | \r\n  % { $_ | convertfrom-json }",
      "'[{\"name\":\"joe\"},{\"name\":\"john\"}]' | jq -cn --stream 'fromstream(1|truncate_stream(inputs))'",
      "{\n  \"name\":\"joe\"\n}\n{\n  \"name\":\"john\"\n}\n"
    ],
    "utterance": "Output each top-level object from a large array in the file one at a time as individual objects.",
    "expressions": [
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs))'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "joe"
          },
          {
            "name": "john"
          }
        ],
        "output": [
          {
            "name": "joe"
          },
          {
            "name": "john"
          }
        ]
      }
    ],
    "identifier": 59403294
  },
  {
    "identifier": 59421549
  },
  {
    "context": [
      "I'm trying to extract values from JSON data using jq in shell once I get the value i would like to give column name to it.",
      "... | jq '[].name'",
      "output should be",
      "name",
      "\"tom\"",
      "\"harry\"",
      "Use the \",\" operator, e.g.:",
      "jq '\"name\", .[].name'",
      "If you really want `name` to be unquoted but the names to be quoted, then consider:",
      "jq -r '\"name\", (.[].name | \"\\\"\\(.)\\\"\")'"
    ],
    "utterance": "Output the list of names as a column under the header 'name', so that the first line is 'name' and each subsequent line is a quoted name value.",
    "expressions": [
      "jq '\"name\", .[].name'",
      "jq -r '\"name\", (.[].name | \"\\\"\\(.)\\\"\")'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "tom"
          },
          {
            "name": "harry"
          }
        ],
        "output": [
          "name",
          "\"tom\"",
          "\"harry\""
        ]
      }
    ],
    "identifier": 59415968
  },
  {
    "context": [
      "Input JSON example:\r\n```json\r\n[\r\n  {\"name\":\"\u0398\u03b5\u03bc\u03b9\u03c3\u03c4\u03bf\u03ba\u03bb\u03ae\u03c2\",\"surname\":\"\u03a0\u03b1\u03c0\u03b1\u03ca\u03c9\u03ac\u03bd\u03bd\u03bf\u03c5\",\"gender\":\"male\",\"region\":\"Greece\"}, \r\n  {\"name\":\"Casian\",\"surname\":\"Cusin\",\"gender\":\"male\",\"region\":\"Romania\"}\r\n]\r\n```",
      "Now with my code I have output as strings:\r\n```\r\n$ curl -s https://uinames.com/api/?amount=3 | jq '.[] | [.name, .surname] | @csv'\r\n\"\\\"Anamaria\\\"\",\\\"T\u0103ma\u0219\\\"\"\r\n\"\\\"Aurora\\\"\",\\\"Coronado\\\"\"\r\n\"\\\"\u0395\u03cd\u03b7\u03bd\u03bf\u03c2\\\"\",\\\"\u0395\u03bb\u03b5\u03c5\u03b8\u03b5\u03c1\u03cc\u03c0\u03bf\u03c5\u03bb\u03bf\u03c2\\\"\"\r\n```",
      "What I need:\r\n```\r\n\"Anamaria\",\"T\u0103ma\u0219\"\r\n\"Aurora\",\"Coronado\"\r\n\"\u0395\u03cd\u03b7\u03bd\u03bf\u03c2\",\"\u0395\u03bb\u03b5\u03c5\u03b8\u03b5\u03c1\u03cc\u03c0\u03bf\u03c5\u03bb\u03bf\u03c2\"\r\n```",
      "You should add the -r command-line option when invoking jq.",
      "Example:\r\n\r\n```\r\n$ curl -Ss 'https://uinames.com/api/?amount=3' |\r\n   jq -r '.[] | [.name, .surname] | @csv' \r\n\"\u0393\u03cc\u03c1\u03b3\u03b1\u03c3\u03bf\u03c2\",\"\u0398\u03b5\u03bf\u03b4\u03c9\u03c1\u03af\u03b4\u03b7\u03c2\"\r\n\"Marta\",\"Brediceanu\"\r\n\"Iulian\",\"B\u00e2rc\u0103\"\r\n```"
    ],
    "utterance": "Produce CSV lines containing the name and surname fields as raw, unescaped strings in each line.",
    "expressions": [
      ".[] | [.name, .surname] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "\u0398\u03b5\u03bc\u03b9\u03c3\u03c4\u03bf\u03ba\u03bb\u03ae\u03c2",
            "surname": "\u03a0\u03b1\u03c0\u03b1\u03ca\u03c9\u03ac\u03bd\u03bd\u03bf\u03c5",
            "gender": "male",
            "region": "Greece"
          },
          {
            "name": "Casian",
            "surname": "Cusin",
            "gender": "male",
            "region": "Romania"
          }
        ],
        "output": [
          "\"\u0398\u03b5\u03bc\u03b9\u03c3\u03c4\u03bf\u03ba\u03bb\u03ae\u03c2\",\"\u03a0\u03b1\u03c0\u03b1\u03ca\u03c9\u03ac\u03bd\u03bd\u03bf\u03c5\"",
          "\"Casian\",\"Cusin\""
        ]
      }
    ],
    "identifier": 59381620
  },
  {
    "context": [
      "How can I use `jq` to transform this:",
      "[{\"k\": \"a\", \"v\": 123}, {\"k\": \"b\", \"v\": 456}]",
      "into this:",
      "{\"a\": 123, \"b\": 456}",
      "map({(.k): .v}) | add",
      "reduce .[] as {$k,$v} ({}; . + {($k): $v})",
      "map({key: .k, value: .v}) | from_entries"
    ],
    "utterance": "Convert an array where each element has keys 'k' and 'v' into an object mapping each 'k' value to its corresponding 'v' value.",
    "expressions": [
      "map({(.k): .v}) | add",
      "reduce .[] as {$k,$v} ({}; . + {($k): $v})",
      "map({key: .k, value: .v}) | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "k": "a",
            "v": 123
          },
          {
            "k": "b",
            "v": 456
          }
        ],
        "output": {
          "a": 123,
          "b": 456
        }
      }
    ],
    "identifier": 59416540
  },
  {
    "context": [
      ".items[] | \"[\\\"\\(.node)\\\",\\\"\\(.result.stdout)\\\"]\"",
      ".items[]|[.node],[.result.stdout]|@csv"
    ],
    "utterance": "Produce output pairing each node with its stdout data in the format [\"nodename\":\"stdout data\"] for each item.",
    "expressions": [
      ".items[] | \"[\\\"\\(.node)\\\":\\\"\\(.result.stdout)\\\"]\""
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "node": "node-name",
              "result": {
                "stdout": "stdout data\n"
              }
            }
          ]
        },
        "output": [
          "[\"node-name\":\"stdout data\n\"]"
        ]
      }
    ],
    "identifier": 59416185
  },
  {
    "context": [
      "My object is to display a mapping of the identifier and values like : \r\n\r\n    apiproxy=IO\r\n    response_status_code=502\r\n    target_response_code=502 \r\n    target_ip=7.1.143.6",
      "I have been able to parse both names and values with \r\n\r\n`.[].stats.data[]  | (.identifier.names[])` and `.[].stats.data[]  | (.identifier.values[])`  \r\n\r\nbut I need help with the jq way to map the values.",
      "The whole thing can be done in jq using the -r command-line option:\r\n\r\n```\r\n.[].stats.data[]\r\n| [.identifier.names, .identifier.values]\r\n| transpose[]\r\n| &quot;\\(.[0])=\\(.[1])&quot;\r\n```"
    ],
    "utterance": "Map each value in the names array to the corresponding value in the values array, displaying each as key=value pairs.",
    "expressions": [
      ".[].stats.data[]|[.identifier.names, .identifier.values]|transpose[]|\"\\(.[0])=\\(.[1])\""
    ],
    "data": [
      {
        "input": {
          "Response": {
            "TimeUnit": [
              1576126800000
            ],
            "metaData": {
              "errors": [],
              "notices": [
                "query served by:1"
              ]
            },
            "stats": {
              "data": [
                {
                  "identifier": {
                    "names": [
                      "apiproxy",
                      "response_status_code",
                      "target_response_code",
                      "target_ip"
                    ],
                    "values": [
                      "IO",
                      "502",
                      "502",
                      "7.1.143.6"
                    ]
                  },
                  "metric": [
                    {
                      "env": "dev",
                      "name": "sum(message_count)",
                      "values": [
                        0.0
                      ]
                    }
                  ]
                }
              ]
            }
          }
        },
        "output": [
          "apiproxy=IO",
          "response_status_code=502",
          "target_response_code=502",
          "target_ip=7.1.143.6"
        ]
      }
    ],
    "identifier": 59418412
  },
  {
    "context": [
      "I\u2019m using `jq` to iterate through a JSON file and am having issues with occurrences of `\\u0022` within the json values.",
      "This works for all values except that `jq` decodes the values which causes an error when encountering `\\u0022` since it translates to a double quote.",
      "About your issue with parsing the `$node` Bash variable with `jq` when it contains double quotes `\"`; is because the `read` command needs a `-r` option or it will un-escape the double-quotes (remove the backslash `\\`) from the JSON string, turning it into an invalid JSON string.",
      "jq -r '.node[]|.description' file.json"
    ],
    "utterance": "Extract the description values from each object in the node array, including those containing encoded double quotes like \\u0022.",
    "expressions": [
      ".node[] | .description",
      ".node[] | .description // empty"
    ],
    "data": [
      {
        "input": {
          "node": [
            {
              "description": "This is my \\u0022real\\u0022 name"
            },
            {
              "description": "Another entry"
            }
          ]
        },
        "output": [
          "This is my \"real\" name",
          "Another entry"
        ]
      }
    ],
    "identifier": 59439487
  },
  {
    "context": [
      "How can I split it into multiple text files, where file names are taken from \"name\" and file content is taken from \"content\"? Other keys can be ignored. Currently toying with `jq` tool without luck.",
      "jq -c '.name, .content' input.json | \n  awk 'fn {print > fn; close(fn); fn=\"\"; next;}\n       {fn=$0; sub(/^\"/,\"\",fn); sub(/\"$/,\"\",fn);}'"
    ],
    "utterance": "Write each object's content field to a separate file named according to the name field, processing each line of newline-delimited data and ignoring other keys.",
    "expressions": [
      "jq -c '.name, .content' input.json | awk 'fn {print > fn; close(fn); fn=\"\"; next;} {fn=$0; sub(/^\"/,\"\",fn); sub(/\"$/,\"\",fn);}'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "a.txt",
            "content": "alpha",
            "other_keys": "..."
          },
          {
            "name": "b.txt",
            "content": "beta",
            "something_else": "..."
          },
          {
            "name": "c.txt",
            "content": "gamma",
            "etc": "..."
          }
        ],
        "output": [
          {
            "a.txt": "alpha",
            "b.txt": "beta",
            "c.txt": "gamma"
          }
        ]
      }
    ],
    "identifier": 59426914
  },
  {
    "context": [
      "I need help about how to convert long line of json file to readable file",
      "while we want the file as the following format",
      "You can pretty print a json string using Python 3 if you cant install jq for some reason :"
    ],
    "utterance": "Display structured output for a minified file with indentation and line breaks.",
    "expressions": [
      "."
    ],
    "identifier": 59458409
  },
  {
    "context": [
      "I have written a small Bash script to read a JSON file to CSV for import into MySQL.",
      "jq -r '.data | [.val1, .val2, .val3] | @csv' <$_source/raw/\"$_today\".json >raw/\"$_today\".csv",
      "With `jq`, I have tried the `-a` and the `-c` flag as well with no noticeable difference.",
      "The problem arises because of the way you're reading in the SQL commands.",
      "So if you're going to use the HEREDOC technique to specify the LINES TERMINATED BY value, you'll either need to write\n\n    LINES TERMINATED BY '\\\\\\n'\n\nor use the -r option of `read`.",
      "Since `\\n` is supposedly the default anyway (at least in MYSQL V8), you could try simply omitting the LINES TERMINATED BY specification."
    ],
    "utterance": "Select specific fields from an object array and output as CSV, using each field's value in the order: val1, val2, val3.",
    "expressions": [
      ".data | [.val1, .val2, .val3] | @csv"
    ],
    "identifier": 59447428
  },
  {
    "context": [
      "but I want the command to return like below, so that I get key type of nested json -",
      "[\"parmeter\".\"colA\",\"string\"]\n[\"parmeter\".\"colB\",\"string\"]\n[\"workRequired\",\"string\"]\n[\"work\",\"null\"]\n[\"updateType\",\"number\"]",
      "jq -c 'to_entries[] \n       | if .value|type == \"object\"\n         then .key as $k \n            | .value\n            | to_entries[]\n            | [\"\\($k).\\(.key)\", (.value|type)]\n         else [.key, (.value|type)]\n         end'"
    ],
    "utterance": "List each key at the top level and, for nested objects, append their keys separated by a dot, together with the type of each value.",
    "expressions": [
      "to_entries[] | if .value|type == \"object\" then .key as $k | .value | to_entries[] | [\"\\($k).\\(.key)\", (.value|type)] else [.key, (.value|type)] end"
    ],
    "data": [
      {
        "input": {
          "parameter": {
            "colA": "No",
            "COLB": "No"
          },
          "workRequired": 0,
          "work": 0,
          "updateType": "AUTO"
        },
        "output": [
          [
            "parameter.colA",
            "string"
          ],
          [
            "parameter.COLB",
            "string"
          ],
          [
            "workRequired",
            "number"
          ],
          [
            "work",
            "number"
          ],
          [
            "updateType",
            "string"
          ]
        ]
      }
    ],
    "identifier": 59440452
  },
  {
    "context": [
      "Given this input:\n\n```\n{\"id\":\"gid:\\/\\/shopify\\/Product\\/123456789\",\"title\":\"Gift Card\"}\n{\"originalSrc\":\"https:\\/\\/cdn.shopify.com\\/s\\/files\\/1\\/1111\\/2222\\/products\\/gift-card-01.jpg\",\"__parentId\":\"gid:\\/\\/shopify\\/Product\\/123456789\"}\n{\"originalSrc\":\"https:\\/\\/cdn.shopify.com\\/s\\/files\\/1\\/1111\\/2222\\/products\\/gift-card-02.jpg\",\"__parentId\":\"gid:\\/\\/shopify\\/Product\\/123456789\"}\n```",
      "I'd like to have the images, mapped to the correct product id using __parentId.",
      "```\n[\n  {\n    \"id\":\"gid:\\/\\/shopify\\/Product\\/123456789\",\n    \"title\":\"Gift Card\",\n    \"images: [\n      \"https:\\/\\/cdn.shopify.com\\/s\\/files\\/1\\/1111\\/2222\\/products\\/gift-card-01.jpg\",\n      \"https:\\/\\/cdn.shopify.com\\/s\\/files\\/1\\/1111\\/2222\\/products\\/gift-card-02.jpg\"\n    ]\n  },\n  ...\n]\n```",
      "The following solution first incrementally constructs both the dictionary and the array of objects with an id,\nand then produces the desired result using `map`:",
      "```\nreduce inputs as $x ({};\n  if $x|has(\"id\") then .objects += [$x]\n  elif $x|has(\"__parentId\") then .dict[$x.__parentId] += [$x.originalSrc]\n  else . # an error?\n  end)\n| .dict as $dict\n| .objects\n| map( . + {images: $dict[.id]})\n```"
    ],
    "utterance": "Produce an array where each product object with an id includes an images array containing originalSrc values from items linked via __parentId matching the product id.",
    "expressions": [
      "reduce inputs as $x ({};\n  if $x|has(\"id\") then .objects += [$x]\n  elif $x|has(\"__parentId\") then .dict[$x.__parentId] += [$x.originalSrc]\n  else .\n  end)\n| .dict as $dict\n| .objects\n| map( . + {images: $dict[.id]})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "gid://shopify/Product/123456789",
            "title": "Gift Card"
          },
          {
            "originalSrc": "https://cdn.shopify.com/s/files/1/1111/2222/products/gift-card-01.jpg",
            "__parentId": "gid://shopify/Product/123456789"
          },
          {
            "originalSrc": "https://cdn.shopify.com/s/files/1/1111/2222/products/gift-card-02.jpg",
            "__parentId": "gid://shopify/Product/123456789"
          }
        ],
        "output": [
          {
            "id": "gid://shopify/Product/123456789",
            "title": "Gift Card",
            "images": [
              "https://cdn.shopify.com/s/files/1/1111/2222/products/gift-card-01.jpg",
              "https://cdn.shopify.com/s/files/1/1111/2222/products/gift-card-02.jpg"
            ]
          }
        ]
      }
    ],
    "identifier": 59429051
  },
  {
    "context": [
      "Got `{\"a\": 1, \"b\": 2, \"c\": 3}`",
      "want it be `{\"a\": 1, \"b\": 6, \"c\": 3}`",
      "but if I `{\"a\": 1, \"b\": 2, \"c\": 3} * {\"b\": 3}` it ends up `{\"a\": 1, \"b\": 3, \"c\": 3}`.",
      "If you want to define a multiplication operation on JSON objects, consider:",
      "def multiply(o):\n  reduce (o|keys_unsorted[]) as $k (.; .[$k] *= o[$k]);",
      "{\"a\": 1, \"b\": 2, \"c\": 3} | multiply({\"b\":3})",
      "yields:\n{\n  \"a\": 1,\n  \"b\": 6,\n  \"c\": 3\n}"
    ],
    "utterance": "Multiply the value of key 'b' by 3 in the given object, leaving other keys unchanged.",
    "expressions": [
      ".b *= 3",
      "def multiply(o): reduce (o|keys_unsorted[]) as $k (.; .[$k] *= o[$k]); {\"a\": 1, \"b\": 2, \"c\": 3} | multiply({\"b\":3})"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2,
          "c": 3
        },
        "output": {
          "a": 1,
          "b": 6,
          "c": 3
        }
      }
    ],
    "identifier": 59487933
  },
  {
    "context": [
      "Using jq i want to insert one more string to this key/value pair `\"-Dhttps.protocols=TLSv1.2\"`",
      "jq '.JAVA_OPTS |= . + \" -Dhttps.protocols=TLSv1.2\"'"
    ],
    "utterance": "Append ' -Dhttps.protocols=TLSv1.2' to the value of the JAVA_OPTS key.",
    "expressions": [
      ".JAVA_OPTS |= . + \" -Dhttps.protocols=TLSv1.2\""
    ],
    "data": [
      {
        "input": {
          "JAVA_OPTS": "-Xms1g -Xmx2g -Dapi.version=v1 -Dspring.profiles.active=test -Dservice.name=xyz"
        },
        "output": {
          "JAVA_OPTS": "-Xms1g -Xmx2g -Dapi.version=v1 -Dspring.profiles.active=test -Dservice.name=xyz -Dhttps.protocols=TLSv1.2"
        }
      }
    ],
    "identifier": 59490059
  },
  {
    "context": [
      "Lets say we want to print the json part for partition id \u2013 4",
      "the best case is to print the following valid format ( if it possible )",
      "jq --arg part_id \"4\" '.partitions[] | select(.partition == ($part_id|tonumber))'",
      "jq --arg part_id \"4\" '.partitions |= map(select(.partition == ($part_id|tonumber)))'"
    ],
    "utterance": "Extract the object from the partitions list whose partition field equals 4, optionally returning the result as a top-level object with version and a single-item partitions array.",
    "expressions": [
      ".partitions[] | select(.partition == 4)",
      ".partitions[] | select(.partition == ($part_id|tonumber))",
      ".partitions |= map(select(.partition == 4))",
      ".partitions |= map(select(.partition == ($part_id|tonumber)))"
    ],
    "data": [
      {
        "input": {
          "version": 1,
          "partitions": [
            {
              "topic": "list_of_cars",
              "partition": 2,
              "replicas": [
                1003,
                1004,
                1005
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "topic": "list_of_cars",
              "partition": 4,
              "replicas": [
                1005,
                1006,
                1001
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "topic": "list_of_cars",
              "partition": 0,
              "replicas": [
                1001,
                1002,
                1003
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "topic": "list_of_cars",
              "partition": 1,
              "replicas": [
                1002,
                1003,
                1004
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "topic": "list_of_cars",
              "partition": 5,
              "replicas": [
                1006,
                1001,
                1002
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            },
            {
              "topic": "list_of_cars",
              "partition": 3,
              "replicas": [
                1004,
                1005,
                1006
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            }
          ]
        },
        "output": {
          "version": 1,
          "partitions": [
            {
              "topic": "list_of_cars",
              "partition": 4,
              "replicas": [
                1005,
                1006,
                1001
              ],
              "log_dirs": [
                "any",
                "any",
                "any"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 59469594
  },
  {
    "context": [
      "How to extract json's values as JSON array with `jq`?",
      "I would like to extract values as JSON array:",
      "`echo $json | jq keys` returns: ... [ \"a\", \"b\" ]",
      "One solution is to use `to_entries` then `map` to extract only the values:",
      "$ echo '{ \"a\" : 1, \"b\" : 2 }' | jq 'to_entries|map(.value)'",
      "Another solution, simpler and faster, is to use just `map(.)`:",
      "$ echo '{ \"a\" : 1, \"b\" : 2 }' | jq 'map(.)'",
      "echo $json | jq '[.[]]'",
      "output: [ 1, 2 ]"
    ],
    "utterance": "Extract all top-level values as an array in the order they appear in the object.",
    "expressions": [
      "[.[]]",
      "map(.)",
      "to_entries | map(.value)"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2
        },
        "output": [
          1,
          2
        ]
      }
    ],
    "identifier": 59491079
  },
  {
    "context": [
      "I want to get a value from a definition header into the output data in place of an index.",
      "I need to get \"Cats\" or \"Dogs\" into the result, heading towards an SQL insert.",
      "Or better yet:",
      "{\n  \"time\": \"2019-01-01T02:00:00Z\",\n  \"Cats\": {                    <- label set to \"Cats\" instead of \"data\"\n    \"value\": 90,\n    \"note\": \"start\"\n  }\n}",
      "Is there a way I can get - what I see as the array index \"0\" or \"3\" - to be added as \"Cats\" or \"Dogs\"?",
      ".header.type | INDEX(to_entries[]; .key) | map_values(.value.name)) as $dict | .data[] | (.reading | keys_unsorted[]) as $k | {time} + { ($dict[$k]) : .reading[$k] }"
    ],
    "utterance": "For each entry, output an object with the time and a key whose name is the type name (e.g., 'Cats' or 'Dogs'), with its value set to the corresponding reading object.",
    "expressions": [
      "(.header.type | INDEX(to_entries[]; .key) | map_values(.value.name)) as $dict | .data[] | (.reading | keys_unsorted[]) as $k | {time} + { ($dict[$k]) : .reading[$k] }"
    ],
    "data": [
      {
        "input": {
          "header": {
            "type": {
              "0": {
                "name": "Cats"
              },
              "3": {
                "name": "Dogs"
              }
            }
          },
          "data": [
            {
              "time": "2019-01-01T02:00:00Z",
              "reading": {
                "0": {
                  "value": 90,
                  "note": "start"
                },
                "3": {
                  "value": 100
                }
              }
            }
          ]
        },
        "output": [
          {
            "time": "2019-01-01T02:00:00Z",
            "Cats": {
              "value": 90,
              "note": "start"
            }
          },
          {
            "time": "2019-01-01T02:00:00Z",
            "Dogs": {
              "value": 100
            }
          }
        ]
      }
    ],
    "identifier": 59475031
  },
  {
    "context": [
      "How can I convert this\n\n    http://www.google.co.uk\n    http://www.reddit.com\n    http://www.ebay.com\n\nto this using `jq` if possible:\n\n    { \"listing\": \"http://www.google.co.uk\" }\n    { \"listing\": \"http://www.reddit.com\" }\n    { \"listing\": \"http://www.ebay.com\" }\n\nBraces and stuff cannot be in a line of its own, because I'm doing \"line oriented processing\" where each line represents a \"row\" of data.",
      "Create objects for each input line:\n\n    echo -e \"l1\\nl2\\nl3\" | jq -c -R '{\"listing\": .}'\n",
      "This should do it:\n\n    jq -cR '{listing: .}'\n"
    ],
    "utterance": "Wrap each input line as an object with a 'listing' key, outputting one object per line.",
    "expressions": [
      "jq -cR '{listing: .}'",
      "jq -c -R '{\"listing\": .}'"
    ],
    "data": [
      {
        "input": "http://www.google.co.uk\nhttp://www.reddit.com\nhttp://www.ebay.com",
        "output": [
          "{\"listing\":\"http://www.google.co.uk\"}",
          "{\"listing\":\"http://www.reddit.com\"}",
          "{\"listing\":\"http://www.ebay.com\"}"
        ]
      }
    ],
    "identifier": 59492888
  },
  {
    "context": [
      "I am trying to take a complex JSON file of 20,000+ lines and extract a specific key while retaining the surrounding metadata which adds necessary human-understandable context.",
      "**Option 1 output desired, same JSON structure with removing all other objects which does not match select filter \"ALL\" string criteria**",
      "The following filter produces the \"Option 2\" output:",
      "  | .Level2Contents[]?\n  | select(.Level3Name == \"ALL\")",
      "What you could do is search for the paths of all values you wish to keep (has the value you're searching for), then remove all other objects that are not on the paths of any of the paths to keep.",
      "[paths(strings == \"ALL\")[:-1]] as $keepers\n| delpaths([paths(objects) | select(is_subpath($keepers) | not)])"
    ],
    "utterance": "Filter the data to only include objects where Level3Name equals \"ALL\", while retaining the full nested structure above each match.",
    "expressions": [
      "[paths(strings == \"ALL\")[:-1]] as $keepers | delpaths([paths(objects) | select(is_subpath($keepers) | not)])"
    ],
    "data": [
      {
        "input": {
          "Marketplace": [
            {
              "Level1Name": "Company A Products",
              "Level1Array": [
                {
                  "Level2Name": "USA Products List",
                  "Level2Contents": [
                    {
                      "Level3Name": "ALL",
                      "Level3URL": "https://a.com/products"
                    },
                    {
                      "Level3Name": "Subset1001",
                      "Level3URL": "https://a.com/products/subset1001"
                    }
                  ]
                }
              ]
            },
            {
              "Level1Name": "Company B Products",
              "Level1Array": [
                {
                  "Level2Name": "USA Products List",
                  "Level2Contents": [
                    {
                      "Level3Name": "ALL",
                      "Level3URL": "https://b.com/products"
                    },
                    {
                      "Level3Name": "Subset500",
                      "Level3URL": "https://b.com/products/subset500"
                    }
                  ]
                },
                {
                  "Level2Name": "EU Products List",
                  "Level2Contents": [
                    {
                      "Level3Name": "ALL",
                      "Level3URL": "https://b.eu/products"
                    },
                    {
                      "Level3Name": "Subset200",
                      "Level3URL": "https://b.eu/products/subset200"
                    }
                  ]
                }
              ]
            },
            {
              "Level1Name": "Company X Products",
              "Level1Array": [
                {
                  "Level2Name": "Deleted Products",
                  "Level2URL": "https://internal.x.com/products"
                }
              ]
            }
          ]
        },
        "output": {
          "Marketplace": [
            {
              "Level1Name": "Company A Products",
              "Level1Array": [
                {
                  "Level2Name": "USA Products List",
                  "Level2Contents": [
                    {
                      "Level3Name": "ALL",
                      "Level3URL": "https://a.com/products"
                    }
                  ]
                }
              ]
            },
            {
              "Level1Name": "Company B Products",
              "Level1Array": [
                {
                  "Level2Name": "USA Products List",
                  "Level2Contents": [
                    {
                      "Level3Name": "ALL",
                      "Level3URL": "https://b.com/products"
                    }
                  ]
                },
                {
                  "Level2Name": "EU Products List",
                  "Level2Contents": [
                    {
                      "Level3Name": "ALL",
                      "Level3URL": "https://b.eu/products"
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 59383329
  },
  {
    "context": [
      "Would like to get:\r\n```\r\n1;0\r\n```",
      "jq -r \"[.foo2, .foo] | join(\\\";\\\")\""
    ],
    "utterance": "Return the values of foo2 and foo, separated by a semicolon, on the same line in the order foo2;foo.",
    "expressions": [
      "[.foo2, .foo] | join(\";\")"
    ],
    "data": [
      {
        "input": {
          "foo": 0,
          "foo2": 1
        },
        "output": "1;0"
      }
    ],
    "identifier": 59549459
  },
  {
    "context": [
      "json_val='{\"code\":\"lyz1To6ZTWClDHSiaeXyxg\",\"redirect_to\":\"http://example.com/client-redirect-uri?code=lyz1To6ZTWClDHSiaeXyxg\"}'",
      "code_val=$(jq -r '.code' <<< \"$json_val\")",
      "echo \"$code_val\"",
      "$ echo '{\"code\":\"lyz1To6ZTWClDHSiaeXyxg\",\"redirect_to\":\"http://example.com/client-redirect-uri?code=lyz1To6ZTWClDHSiaeXyxg\"}' | jq '.code'",
      "\"lyz1To6ZTWClDHSiaeXyxg\""
    ],
    "utterance": "Extract the value of the key 'code' from an object where 'code' has the value 'lyz1To6ZTWClDHSiaeXyxg' and assign it to a shell variable.",
    "expressions": [
      "jq -r '.code' <<< \"$json_val\"",
      "jq '.code'"
    ],
    "data": [
      {
        "input": {
          "code": "lyz1To6ZTWClDHSiaeXyxg",
          "redirect_to": "http://example.com/client-redirect-uri?code=lyz1To6ZTWClDHSiaeXyxg"
        },
        "output": "lyz1To6ZTWClDHSiaeXyxg"
      }
    ],
    "identifier": 59551619
  },
  {
    "context": [
      "jenkins@10.0.0.0:/tmp$ aws secretsmanager get-secret-value --secret-id Build-db --query SecretString --output text",
      "{\"username\":\"build_write\",\"password\":\"CHANGE_ME\"}",
      "jenkins@10.0.0.0:/tmp$ aws secretsmanager get-secret-value --secret-id Build-db --query SecretString --output text| jq -r '{\"password\"}'",
      "{\"password\": \"CHANGE_ME\"}",
      "But the expected result should be only the value: `{\"CHANGE_ME\"}`",
      "aws secretsmanager get-secret-value --secret-id Build-db --query SecretString --output text | jq -r '\"{ \\(.password) }\"'",
      "{ CHANGE_ME }"
    ],
    "utterance": "Extract only the password value in the format { CHANGE_ME } from command output where the input is an object with a password key.",
    "expressions": [
      "\"{ \\(.password) }\""
    ],
    "data": [
      {
        "input": {
          "username": "build_write",
          "password": "CHANGE_ME"
        },
        "output": "{ CHANGE_ME }"
      }
    ],
    "identifier": 59532410
  },
  {
    "context": [
      "How can I query for the \"Power\": 0 value only? I only need the \"0\".",
      "I tried with \r\n\r\n    jq -r '.Power'\r\nbut that only returns\r\n\r\n    null",
      "One way is to \u201cdrill down\u201d:\r\n\r\n    .Status.Power"
    ],
    "utterance": "Extract the number under the Power key nested within the Status object.",
    "expressions": [
      ".Status.Power"
    ],
    "data": [
      {
        "input": {
          "Status": {
            "Module": 52,
            "FriendlyName": [
              "stecker2"
            ],
            "Topic": "sensors",
            "ButtonTopic": "0",
            "Power": 0,
            "PowerOnState": 3,
            "LedState": 1,
            "SaveData": 1,
            "SaveState": 1,
            "SwitchTopic": "0",
            "SwitchMode": [
              0,
              0,
              0,
              0,
              0,
              0,
              0,
              0
            ],
            "ButtonRetain": 0,
            "SwitchRetain": 0,
            "SensorRetain": 0,
            "PowerRetain": 0
          }
        },
        "output": 0
      }
    ],
    "identifier": 59552469
  },
  {
    "context": [
      "Im extracting few fields from a list of jsons in a file using jq and one of the field contains a float value (eg.float 0.0000875) which when extracted through jq changed to '8.75e-05'. Is there a way we can extract these values without being converted to exponential form?",
      "The \"master\" version of jq now generally preserves the \"external\" number format, e.g.",
      "$ jq -n '0.0000875'\n0.0000875"
    ],
    "utterance": "Extract a float value such as 0.0000875 without converting it to exponential notation.",
    "expressions": [
      ".",
      "tostring"
    ],
    "data": [
      {
        "input": 8.75e-05,
        "output": "0.0000875"
      }
    ],
    "identifier": 59558912
  },
  {
    "context": [
      "For each object, I want to 1] check if \"test\" is a string and 2] if test is a string, parse it into an actual JSON array and then re-assign it.",
      "So the output would be:\n\n    [\n    {\n        \"test\": [\"example\"]\n    },\n    {\n        \"test\": [\"example2\"]\n    }\n    ]",
      "The solution turned out to be \n\n`map(if .test|type == \"string\" then .test=(.test|fromjson) else . end)`",
      "The jq filter can be simplified to:\n    map(if .test|type == \"string\" then .test |= fromjson else . end)",
      "or even:\n    map(.test |= if type == \"string\" then fromjson else . end)"
    ],
    "utterance": "For each object, if the value of the field \"test\" is a string, replace it with its parsed array, otherwise leave it unchanged.",
    "expressions": [
      "map(if .test|type == \"string\" then .test=(.test|fromjson) else . end)",
      "map(if .test|type == \"string\" then .test |= fromjson else . end)",
      "map(.test |= if type == \"string\" then fromjson else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "test": "[\"example\"]"
          },
          {
            "test": [
              "example2"
            ]
          }
        ],
        "output": [
          {
            "test": [
              "example"
            ]
          },
          {
            "test": [
              "example2"
            ]
          }
        ]
      }
    ],
    "identifier": 59556986
  },
  {
    "context": [
      "I would like to get the value of response > textAnnotations > description but i'm doing something wrong.",
      "Both responses and textAnnotations are arrays, so as far as i remember, you have to either loop through them, or access the first response element's first textAnnotation like so: responses[0].textAnnotations[0].description",
      "If you want all the descriptions under .responses[].textAnnotations you could write:",
      ".responses[].textAnnotations[].description",
      "which is short for:",
      ".responses[] | .textAnnotations[] |.description"
    ],
    "utterance": "Extract all values of description inside every textAnnotations element under all responses.",
    "expressions": [
      ".responses[].textAnnotations[].description",
      ".responses[] | .textAnnotations[] | .description"
    ],
    "data": [
      {
        "input": {
          "responses": [
            {
              "textAnnotations": [
                {
                  "locale": "und",
                  "description": "24\nmois\n12\nmois\n",
                  "boundingPoly": {
                    "vertices": [
                      {
                        "x": 12,
                        "y": 24
                      },
                      {
                        "x": 285,
                        "y": 24
                      },
                      {
                        "x": 285,
                        "y": 206
                      },
                      {
                        "x": 12,
                        "y": 206
                      }
                    ]
                  }
                },
                {
                  "description": "24",
                  "boundingPoly": {
                    "vertices": [
                      {
                        "x": 216,
                        "y": 24
                      },
                      {
                        "x": 285,
                        "y": 24
                      },
                      {
                        "x": 285,
                        "y": 83
                      },
                      {
                        "x": 216,
                        "y": 83
                      }
                    ]
                  }
                },
                {
                  "description": "mois",
                  "boundingPoly": {
                    "vertices": [
                      {
                        "x": 223,
                        "y": 83
                      },
                      {
                        "x": 280,
                        "y": 84
                      },
                      {
                        "x": 280,
                        "y": 110
                      },
                      {
                        "x": 223,
                        "y": 109
                      }
                    ]
                  }
                },
                {
                  "description": "12",
                  "boundingPoly": {
                    "vertices": [
                      {
                        "x": 12,
                        "y": 122
                      },
                      {
                        "x": 81,
                        "y": 122
                      },
                      {
                        "x": 81,
                        "y": 179
                      },
                      {
                        "x": 12,
                        "y": 179
                      }
                    ]
                  }
                },
                {
                  "description": "mois",
                  "boundingPoly": {
                    "vertices": [
                      {
                        "x": 19,
                        "y": 177
                      },
                      {
                        "x": 76,
                        "y": 176
                      },
                      {
                        "x": 76,
                        "y": 205
                      },
                      {
                        "x": 19,
                        "y": 206
                      }
                    ]
                  }
                }
              ],
              "fullTextAnnotation": {
                "pages": [],
                "text": "24\nmois\n12\nmois\n"
              }
            }
          ]
        },
        "output": [
          "24\nmois\n12\nmois\n",
          "24",
          "mois",
          "12",
          "mois"
        ]
      }
    ],
    "identifier": 59438639
  },
  {
    "context": [
      "But how do I convert it back to jpg format? This returns an error \"**base64: invalid input**\"",
      "jq -r '.instances[0].image.b64' input.json | base64 -d > output.jpg",
      "< input.json jq -r '.instances[0].image.b64' | base64 -d >output.jpg"
    ],
    "utterance": "Extract the value at .instances[0].image.b64 and decode it as base64 to restore the original image file.",
    "expressions": [
      "jq -r '.instances[0].image.b64' input.json | base64 -d > output.jpg",
      "< input.json jq -r '.instances[0].image.b64' | base64 -d >output.jpg"
    ],
    "data": [
      {
        "input": {
          "instances": [
            {
              "image": {
                "b64": "<base64-encoded-data>"
              }
            }
          ]
        }
      }
    ],
    "identifier": 59576828
  },
  {
    "context": [
      "Suppose I have a json document* as follow:\r\n\r\n```js\r\n[{\r\n  \"first_name\": \"Angela\",\r\n  \"last_name\": \"Sleney\",\r\n  \"email\": \"asleney0@nytimes.com\"\r\n}, {\r\n  \"first_name\": \"Clint\",\r\n  \"last_name\": \"Ducroe\",\r\n  \"email\": \"cducroe1@aboutads.info\"\r\n}, {\r\n  \"first_name\": \"Aurthur\",\r\n  \"last_name\": \"Tebb\",\r\n  \"email\": \"atebb2@fastcompany.com\"\r\n}]\r\n```",
      "I'd like to print with JQ 3 lines as follow:\r\n\r\n```lang-none\r\nEmail address for user Angela Sleney is \"asleney0@nytimes.com\"\r\nEmail address for user Clint Ducroe is \"cducroe1@aboutads.info\"\r\nEmail address for user Aurthur Tebb is \"atebb2@fastcompany.com\"\r\n```",
      "I got the desired result -\r\n\r\n    Email address for user Angela Sleney is \"asleney0@nytimes.com\"\r\n    Email address for user Clint Ducroe is \"cducroe1@aboutads.info\"\r\n    Email address for user Aurthur Tebb is \"atebb2@fastcompany.com\"\r\n\r\nwith this filter - \r\n\r\n    .[] | \"Email address for user \\(.first_name) \\(.last_name) is \\\"\\(.email)\\\"\""
    ],
    "utterance": "Print each user's first and last name along with their email address in the format: Email address for user <first_name> <last_name> is \"<email>\"",
    "expressions": [
      ".[] | \"Email address for user \\(.first_name) \\(.last_name) is \\\"\\(.email)\\\"\""
    ],
    "data": [
      {
        "input": [
          {
            "first_name": "Angela",
            "last_name": "Sleney",
            "email": "asleney0@nytimes.com"
          },
          {
            "first_name": "Clint",
            "last_name": "Ducroe",
            "email": "cducroe1@aboutads.info"
          },
          {
            "first_name": "Aurthur",
            "last_name": "Tebb",
            "email": "atebb2@fastcompany.com"
          }
        ],
        "output": [
          "Email address for user Angela Sleney is \"asleney0@nytimes.com\"",
          "Email address for user Clint Ducroe is \"cducroe1@aboutads.info\"",
          "Email address for user Aurthur Tebb is \"atebb2@fastcompany.com\""
        ]
      }
    ],
    "identifier": 59551206
  },
  {
    "context": [
      "I could, per example, write this command; \n\n> jq -s -c 'group_by(.type[0]) | .[]' pokemini.json",
      "I don\u2019t get why this does not work though; \n\n> jq -s '.[] | group_by(.type[0])' pokemini.json\njq: error (at pokemini.json:10): Cannot index string with string \"type\"",
      "`group_by/1` expects its input to be an array. By calling .[] first, you are effectively undoing the work of the -s option."
    ],
    "utterance": "Group all entries by the first element of their 'type' field and output each group as a separate array.",
    "expressions": [
      "group_by(.type[0]) | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Bulbasaur",
            "type": [
              "Grass",
              "Poison"
            ],
            "total": 318,
            "hp": 45,
            "attack": 49
          },
          {
            "name": "Ivysaur",
            "type": [
              "Grass",
              "Poison"
            ],
            "total": 405,
            "hp": 60,
            "attack": 62
          },
          {
            "name": "Venusaur",
            "type": [
              "Grass",
              "Poison"
            ],
            "total": 525,
            "hp": 80,
            "attack": 82
          },
          {
            "name": "VenusaurMega Venusaur",
            "type": [
              "Grass",
              "Poison"
            ],
            "total": 625,
            "hp": 80,
            "attack": 100
          },
          {
            "name": "Charmander",
            "type": [
              "Fire"
            ],
            "total": 309,
            "hp": 39,
            "attack": 52
          },
          {
            "name": "Charmeleon",
            "type": [
              "Fire"
            ],
            "total": 405,
            "hp": 58,
            "attack": 64
          },
          {
            "name": "Charizard",
            "type": [
              "Fire",
              "Flying"
            ],
            "total": 534,
            "hp": 78,
            "attack": 84
          },
          {
            "name": "CharizardMega Charizard X",
            "type": [
              "Fire",
              "Dragon"
            ],
            "total": 634,
            "hp": 78,
            "attack": 130
          },
          {
            "name": "CharizardMega Charizard Y",
            "type": [
              "Fire",
              "Flying"
            ],
            "total": 634,
            "hp": 78,
            "attack": 104
          },
          {
            "name": "Squirtle",
            "type": [
              "Water"
            ],
            "total": 314,
            "hp": 44,
            "attack": 48
          }
        ],
        "output": [
          [
            {
              "name": "Charmander",
              "type": [
                "Fire"
              ],
              "total": 309,
              "hp": 39,
              "attack": 52
            },
            {
              "name": "Charmeleon",
              "type": [
                "Fire"
              ],
              "total": 405,
              "hp": 58,
              "attack": 64
            },
            {
              "name": "Charizard",
              "type": [
                "Fire",
                "Flying"
              ],
              "total": 534,
              "hp": 78,
              "attack": 84
            },
            {
              "name": "CharizardMega Charizard X",
              "type": [
                "Fire",
                "Dragon"
              ],
              "total": 634,
              "hp": 78,
              "attack": 130
            },
            {
              "name": "CharizardMega Charizard Y",
              "type": [
                "Fire",
                "Flying"
              ],
              "total": 634,
              "hp": 78,
              "attack": 104
            }
          ],
          [
            {
              "name": "Bulbasaur",
              "type": [
                "Grass",
                "Poison"
              ],
              "total": 318,
              "hp": 45,
              "attack": 49
            },
            {
              "name": "Ivysaur",
              "type": [
                "Grass",
                "Poison"
              ],
              "total": 405,
              "hp": 60,
              "attack": 62
            },
            {
              "name": "Venusaur",
              "type": [
                "Grass",
                "Poison"
              ],
              "total": 525,
              "hp": 80,
              "attack": 82
            },
            {
              "name": "VenusaurMega Venusaur",
              "type": [
                "Grass",
                "Poison"
              ],
              "total": 625,
              "hp": 80,
              "attack": 100
            }
          ],
          [
            {
              "name": "Squirtle",
              "type": [
                "Water"
              ],
              "total": 314,
              "hp": 44,
              "attack": 48
            }
          ]
        ]
      }
    ],
    "identifier": 59553403
  },
  {
    "context": [
      "The output I'm trying to achieve is, extracting the name value of the type object and inserting it into an array.",
      "So the solution might look like so:\n\n     jq -r '.pokemon[]|{name:.name, id:.id, types:.types|map(.type.name)}' pokemon.json"
    ],
    "utterance": "For each Pok\u00e9mon, list its name and id, and replace its types field with an array of type names.",
    "expressions": [
      ".pokemon[] | {name: .name, id: .id, types: (.types | map(.type.name)) }"
    ],
    "data": [
      {
        "input": [
          {
            "name": "onix",
            "id": 95,
            "types": [
              {
                "slot": 2,
                "type": {
                  "name": "ground"
                }
              },
              {
                "slot": 1,
                "type": {
                  "name": "rock"
                }
              }
            ]
          },
          {
            "name": "drowzee",
            "id": 96,
            "types": [
              {
                "slot": 1,
                "type": {
                  "name": "psychic"
                }
              }
            ]
          }
        ],
        "output": [
          {
            "name": "onix",
            "id": 95,
            "types": [
              "ground",
              "rock"
            ]
          },
          {
            "name": "drowzee",
            "id": 96,
            "types": [
              "psychic"
            ]
          }
        ]
      }
    ],
    "identifier": 59564652
  },
  {
    "context": [
      "i want it to be like this\n\n    [\"10.0.0.1\", \"10.0.0.2\", \"10.0.0.3\"]",
      "$ jq -c '.nodes | to_entries | map(.value[\":ip\"])' input\n[\"10.0.0.1\",\"10.0.0.2\",\"10.0.0.3\"]"
    ],
    "utterance": "Extract the IP addresses from all nodes as an array, with each address as a separate quoted string.",
    "expressions": [
      ".nodes | to_entries | map(.value[\":ip\"])"
    ],
    "data": [
      {
        "input": {
          "nodes": {
            "node1.local": {
              ":ip": "10.0.0.1",
              "ports": [],
              ":memory": 1024,
              ":bootstrap": "bootstrap.sh"
            },
            "node2.local": {
              ":ip": "10.0.0.2",
              "ports": [],
              ":memory": 1024,
              ":bootstrap": "bootstrap.sh"
            },
            "node3.local": {
              ":ip": "10.0.0.3",
              "ports": [],
              ":memory": 1024,
              ":bootstrap": "bootstrap.sh"
            }
          }
        },
        "output": [
          "10.0.0.1",
          "10.0.0.2",
          "10.0.0.3"
        ]
      }
    ],
    "identifier": 59599459
  },
  {
    "context": [
      "I am trying to print the results in tabular format.",
      "The following filter, when used in conjunction with the -r command-line option, produces the output as shown:",
      "map({id, severity, name, files})\n| sort_by(.id)[]\n| [.severity, .name, .files[]]\n| @tsv",
      "With this def, we essentially just add `headers` to the previous jq program:\n\nheaders,\n(map({id, severity, name, files})\n | sort_by(.id)[]\n | [.severity, .name, .files[]])\n| @tsv",
      "Instead of the line:\n    [.severity, .name, .files[]]\n\nyou might wish to use a different \"join\" character for the files, e.g.\n\n    [.severity, .name, (.files|join(\";\"))]"
    ],
    "utterance": "Produce a tabular output listing severity, name, and all filenames for each item, with the files either expanded as separate columns or joined as a single string.",
    "expressions": [
      "map({id, severity, name, files}) | sort_by(.id)[] | [.severity, .name, .files[]] | @tsv",
      "def headers: [\"Severity\",\"Name\",\"Files\"], [\"--------\",\"----\",\"-----\"];\nheaders,\n(map({id, severity, name, files}) | sort_by(.id)[] | [.severity, .name, .files[]])\n| @tsv",
      "map({id, severity, name, files}) | sort_by(.id)[] | [.severity, .name, (.files | join(\";\"))] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "severity": "low",
            "name": "AWS IAM policy attached to users",
            "rule": "$.resource[*].aws_iam_policy_attachment[*].*[*].users exists and $.resource[*].aws_iam_policy_attachment[*].*[*].users[*] is not empty",
            "files": [
              "main.tf"
            ],
            "id": "1903f355-b68f-4d9c-84dd-c46abe4f8673"
          },
          {
            "severity": "medium",
            "name": "AWS VPC allows unauthorized peering",
            "rule": "$.resource[*].aws_vpc_peering_connection[*].*[*].peer_vpc_id does not equal $.resource[*].aws_vpc_peering_connection[*].*[*].vpc_id",
            "files": [
              "vpcpeering.tf",
              "main.tf"
            ],
            "id": "59356130-d856-470d-a08e-b2a0ba2a4ac7"
          }
        ],
        "output": "low\tAWS IAM policy attached to users\tmain.tf\nmedium\tAWS VPC allows unauthorized peering\tvpcpeering.tf\tmain.tf"
      }
    ],
    "identifier": 59571431
  },
  {
    "context": [
      "EXISTING_SECRET=`aws secretsmanager get-secret-value --secret-id $SECRET_ID | jq '.SecretString | fromjson'`",
      "NEW_SECRET=`echo $EXISTING_SECRET $SECRET_STRING | jq  -s 'add tostring'`",
      "NEW_SECRET=`echo \"$EXISTING_SECRET $SECRET_STRING\" | jq  -s add`"
    ],
    "utterance": "Merge two objects so that the result is not wrapped in quotes or stringified.",
    "expressions": [
      "jq -s add"
    ],
    "data": [
      {
        "input": [
          {
            "db_1_pwd": "secret"
          },
          {
            "db_2_pwd": "secreter"
          }
        ],
        "output": {
          "db_1_pwd": "secret",
          "db_2_pwd": "secreter"
        }
      }
    ],
    "identifier": 59615607
  },
  {
    "context": [
      "Is there a way - using preferably jq - to convert the HTML entities then in this example to convert `&rsquo;` in `\u2019`.",
      "I need to convert them programmatically. This JSON is only an example."
    ],
    "utterance": "Decode HTML entities such as &rsquo; into their actual Unicode characters (e.g., \u2019) in all string values.",
    "expressions": [],
    "data": [
      {
        "input": {
          "foo": "bar &rsquo; foo &rsquo;"
        },
        "output": {
          "foo": "bar \u2019 foo \u2019"
        }
      }
    ],
    "identifier": 59614943
  },
  {
    "context": [
      "and i want it to be like this\r\n\r\n    [\"10.0.0.1:4546\", \"10.0.0.2:4546\", \"10.0.0.3:4546\"]",
      "You can simply use + operator:\r\n```\r\njq '.nodes | to_entries | map(.value.\":ip\" + \":4546\")'\r\n```",
      "You could use `map_values` \r\n\r\n     jq -c '.nodes | to_entries | map(.value.\":ip\")| map_values(.+\":4546\")' nodes.jso",
      "Another try :\r\n\r\n```\r\njq '[.nodes[][\":ip\"]+\":4546\"]' nodes.json\r\n```"
    ],
    "utterance": "Produce an array of all IP addresses from the nodes, each appended with :4546.",
    "expressions": [
      ".nodes | to_entries | map(.value[\":ip\"] + \":4546\")",
      ".nodes | to_entries | map(.value[\":ip\"]) | map_values(. + \":4546\")",
      "[.nodes[][\":ip\"]+\":4546\"]"
    ],
    "data": [
      {
        "input": {
          "nodes": {
            "node1.local": {
              ":ip": "10.0.0.1",
              "ports": [],
              ":memory": 1024,
              ":bootstrap": "bootstrap.sh"
            },
            "node2.local": {
              ":ip": "10.0.0.2",
              "ports": [],
              ":memory": 1024,
              ":bootstrap": "bootstrap.sh"
            },
            "node3.local": {
              ":ip": "10.0.0.3",
              "ports": [],
              ":memory": 1024,
              ":bootstrap": "bootstrap.sh"
            }
          }
        },
        "output": [
          "10.0.0.1:4546",
          "10.0.0.2:4546",
          "10.0.0.3:4546"
        ]
      }
    ],
    "identifier": 59599778
  },
  {
    "context": [
      "I want to group based on the org or the parent id.",
      "## Expected JSON Output",
      "You need to do something like below. You need to `group_by()` and then later do the processing",
      "jq '.items | {org: group_by(.org) | map({id: .[0].org, orgProperties: [{properties: { methodId: map({id: .methodId}) }}]})} ' input.json"
    ],
    "utterance": "Group entries by org so that each has its id and orgProperties, with methodId values for each org collected under properties.methodId as a list of ids.",
    "expressions": [
      ".items | {org: group_by(.org) | map({id: .[0].org, orgProperties: [{properties: { methodId: map({id: .methodId}) }}]})}"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "org": "750141",
              "methodId": "1-10F7IAK7"
            },
            {
              "org": "750141",
              "methodId": "1-10TP18L0"
            },
            {
              "org": "750142",
              "methodId": "1-10TP18L1"
            }
          ]
        },
        "output": {
          "org": [
            {
              "id": "750141",
              "orgProperties": [
                {
                  "properties": {
                    "methodId": [
                      {
                        "id": "1-10F7IAK7"
                      },
                      {
                        "id": "1-10TP18L0"
                      }
                    ]
                  }
                }
              ]
            },
            {
              "id": "750142",
              "orgProperties": [
                {
                  "properties": {
                    "methodId": [
                      {
                        "id": "1-10TP18L1"
                      }
                    ]
                  }
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 59605183
  },
  {
    "context": [
      "I wanted to extract only `\"sessionId=lhadasdfsdffdhjseodfjdksfjlsdjflsdjfldfjlsdf\"`",
      "jq -r '.cookie' file.json",
      "Output:",
      "sessionId=lhadasdfsdffdhjseodfjdksfjlsdjflsdjfldfjlsdf"
    ],
    "utterance": "Extract the value of the 'cookie' field where it is 'sessionId=lhadasdfsdffdhjseodfjdksfjlsdjflsdjfldfjlsdf'.",
    "expressions": [
      ".cookie",
      ".cookie | @text"
    ],
    "data": [
      {
        "input": {
          "uri": "/login-sessions",
          "cookie": "sessionId=lhadasdfsdffdhjseodfjdksfjlsdjflsdjfldfjlsdf"
        },
        "output": "sessionId=lhadasdfsdffdhjseodfjdksfjlsdjflsdjfldfjlsdf"
      }
    ],
    "identifier": 59649802
  },
  {
    "context": [
      "How can I merge the output of these two filters together so that each input flags line gets mapped to a single JSON object with none / one / both of the optional fields?",
      "The final output I'm trying to get here is where the foo and bar fields sit together in the same object:\n\n{\n  \"foo\": 1\n}\n{\n  \"bar\": 2\n}\n{\n  \"foo\": 3,\n  \"bar\": 4\n}\n{\n  \"foo\": 5,\n  \"bar\": 6\n}\n",
      "jq '.flags[]\n| capture(\"(?<foo>^f\\d+$)\"),\n  capture(\"(?<bar>^b\\d+$)\"),\n  capture(\"(?<foo>f\\d+)(?<bar>b\\d+)\"),\n  capture(\"(?<bar>b\\d+)(?<foo>f\\d+)\")\n| .[] |= ( sub(\"\\D\"; \"\") | tonumber )'"
    ],
    "utterance": "Produce an object for each flag string, containing foo and/or bar fields with their respective numerical values if present.",
    "expressions": [
      ".flags[]\n| capture(\"(?<foo>^f\\d+$)\"),\n  capture(\"(?<bar>^b\\d+$)\"),\n  capture(\"(?<foo>f\\d+)(?<bar>b\\d+)\"),\n  capture(\"(?<bar>b\\d+)(?<foo>f\\d+)\")\n| .[] |= ( sub(\"\\D\"; \"\") | tonumber )"
    ],
    "data": [
      {
        "input": {
          "flags": [
            "f1",
            "b2",
            "f3b4",
            "b6f5"
          ]
        },
        "output": [
          {
            "foo": 1
          },
          {
            "bar": 2
          },
          {
            "foo": 3,
            "bar": 4
          },
          {
            "bar": 6,
            "foo": 5
          }
        ]
      }
    ],
    "identifier": 59613182
  },
  {
    "context": [
      "I have a large JSON file which is an array of many objects which I want to submit to an API that accepts bulk data uploads. ... I\u2019d like to batch this so I\u2019m making a request in batches for, say, 100 objects at a time.",
      "$ jq --stream -n --argjson skip 0 --argjson top 100 '[fromstream(1|truncate_stream( inputs | . as [[$index]] | select($index >= $skip and $index < $skip + $top) ))]' data.json | curl ..."
    ],
    "utterance": "Extract objects from a large array in groups of 100 based on their indices, skipping a specified number of items.",
    "expressions": [
      "--stream -n --argjson skip 0 --argjson top 100 '[fromstream(1|truncate_stream( inputs | . as [[$index]] | select($index >= $skip and $index < $skip + $top) ))]'"
    ],
    "identifier": 59655060
  },
  {
    "context": [
      "Using jq (if possible), how can I replace the old values with the new ones?",
      "while IFS=\",\" read -r name profile os; do\n    jq \".name = \\\"$name\\\" | .profile = \\\"$profile\\\" | .selector.os = \\\"$os\\\"\" < template.json\ndone < ii.json",
      "jq -R --argfile template template.json '\n  split(\",\") as [$name,$profile,$os],\n  | $template\n  | .name = $name \n  | .profile = $profile\n  | .selector.os = $os' ii.json"
    ],
    "utterance": "Replace the values of 'name', 'profile', and 'selector.os' in a template with corresponding values from each line of a comma-separated file, repeating for all lines.",
    "expressions": [
      "jq -R --argfile template template.json 'split(\",\") as [$name,$profile,$os] | $template | .name = $name | .profile = $profile | .selector.os = $os' ii.json",
      ".name = \"$name\" | .profile = \"$profile\" | .selector.os = \"$os\""
    ],
    "data": [
      {
        "input": {
          "template.json": {
            "name": "jeff",
            "profile": "worker-install",
            "selector": {
              "mac": "4c:pc:ef:4d:33:29",
              "os": "n/a"
            }
          },
          "ii.json": [
            "Mark,controller-install,installed",
            "Chris,controller-install,installed"
          ]
        },
        "output": [
          {
            "name": "Mark",
            "profile": "controller-install",
            "selector": {
              "mac": "4c:pc:ef:4d:33:29",
              "os": "installed"
            }
          },
          {
            "name": "Chris",
            "profile": "controller-install",
            "selector": {
              "mac": "4c:pc:ef:4d:33:29",
              "os": "installed"
            }
          }
        ]
      }
    ],
    "identifier": 59617956
  },
  {
    "context": [
      "Original data after group by and mapping:",
      "and I would like this output:\r\n\r\n    {\r\n      \"Count\": 7,\r\n      \"Agents\": {\r\n        \"a\": 1,\r\n        \"b\": 50,\r\n        \"c\": 25,\r\n        \"d\": 1,\r\n        \"e\": 4,\r\n        \"f\": 4,\r\n        \"g\": 4\r\n      }\r\n    }",
      "Use `map` to create an input for `from_entries`:\r\n\r\n    map({key: .Agents, value: .Count}) | {Count: length, Agents: from_entries}",
      "Another variant using `reduce` would be to do. The reduce expression takes the array as input and puts the key as the `Agents` and the value as its corresponding `Count` value.\r\n\r\n    jq '{ Count: length, Agents: (reduce .[] as $d ({}; .[$d.Agents] = $d.Count)) }'"
    ],
    "utterance": "Reshape an array of objects with Agent and Count fields into an object with a Count of total entries and an Agents object mapping each agent name to its count.",
    "expressions": [
      "map({key: .Agents, value: .Count}) | {Count: length, Agents: from_entries}",
      "{ Count: length, Agents: (reduce .[] as $d ({}; .[$d.Agents] = $d.Count)) }"
    ],
    "data": [
      {
        "input": [
          {
            "Agents": "a",
            "Count": 1
          },
          {
            "Agents": "b",
            "Count": 50
          },
          {
            "Agents": "c",
            "Count": 25
          },
          {
            "Agents": "d",
            "Count": 1
          },
          {
            "Agents": "e",
            "Count": 4
          },
          {
            "Agents": "f",
            "Count": 4
          },
          {
            "Agents": "g",
            "Count": 4
          }
        ],
        "output": {
          "Count": 7,
          "Agents": {
            "a": 1,
            "b": 50,
            "c": 25,
            "d": 1,
            "e": 4,
            "f": 4,
            "g": 4
          }
        }
      }
    ],
    "identifier": 59666195
  },
  {
    "context": [
      "I want to add the contents of file2.json to file1.json but after the json object : **TB1-OSC-B** i.e., second json entry. In this case the entry is present at second location but it may be present any where else aswell.",
      "# Find the desired index and store it as $n\n(.[0].nodes | map(.name == \"TB1-OSC-B\") | index(true)) as $n   |\n\n# Splice the object from the second file  into the first\n.[0].nodes =   .[0].nodes[0:($n|tonumber+1)]   +\n             [ .[1].nodes[0] ]                 +\n               .[0].nodes[($n|tonumber+1):(.[0].nodes|length)] |\n\n# Only output the now modified object from the first file \n.[0]",
      ".[1].nodes[0] as $file2\n| .[0]\n| .nodes |= insert_after(.name == \"TB1-OSC-B\"; $file2)"
    ],
    "utterance": "Insert the object from the second file into the 'nodes' array of the first file immediately after the entry where 'name' equals 'TB1-OSC-B'.",
    "expressions": [
      "(.[0].nodes | map(.name == \"TB1-OSC-B\") | index(true)) as $n |\n.[0].nodes = .[0].nodes[0:($n|tonumber+1)] + [ .[1].nodes[0] ] + .[0].nodes[($n|tonumber+1):(.[0].nodes|length)] |\n.[0]",
      ".[1].nodes[0] as $file2\n| .[0]\n| .nodes |= insert_after(.name == \"TB1-OSC-B\"; $file2)"
    ],
    "data": [
      {
        "input": [
          {
            "nodes": [
              {
                "pm_addr": "192.100.0.4",
                "name": "TB1-OSC-A"
              },
              {
                "pm_addr": "192.100.0.6",
                "name": "TB1-OSC-B"
              },
              {
                "pm_addr": "192.100.0.7",
                "name": "TB1-OSC-C"
              }
            ]
          },
          {
            "nodes": [
              {
                "pm_addr": "192.100.0.4",
                "name": "TB1-OSC-D"
              }
            ]
          }
        ],
        "output": {
          "nodes": [
            {
              "pm_addr": "192.100.0.4",
              "name": "TB1-OSC-A"
            },
            {
              "pm_addr": "192.100.0.6",
              "name": "TB1-OSC-B"
            },
            {
              "pm_addr": "192.100.0.4",
              "name": "TB1-OSC-D"
            },
            {
              "pm_addr": "192.100.0.7",
              "name": "TB1-OSC-C"
            }
          ]
        }
      }
    ],
    "identifier": 59629569
  },
  {
    "context": [
      "I have the following example json document (object of objects):",
      "{ \"key1\": { \"key1a\": [{\"key1aa\": \"value1aa\"}, {\"key1ab\": \"value1ab\"}],... }, \"key2\": { \"key2a\": [{\"key2aa\": \"value2aa\"}, {\"key2ab\": \"value2ab\"}],... }, ... }",
      "And I try to reshape it to an Array of that objects like",
      "[ { \"key1\": { \"key1a\": [{\"key1aa\": \"value1aa\"}, {\"key1ab\": \"value1ab\"}],... }}, { \"key2\": { \"key2a\": [{\"key2aa\": \"value2aa\"}, {\"key2ab\": \"value2ab\"}],... }}, ... ]",
      "You can use `jq`: <file jq 'to_entries|map({(.key):.value})'",
      "So, given this example:\ncat file\n{\n  \"key1\": { \"key1a\": [{\"key1aa\": \"value1aa\"}, {\"key1ab\": \"value1ab\"}] },\n  \"key2\": { \"key2a\": [{\"key2aa\": \"value2aa\"}, {\"key2ab\": \"value2ab\"}] }\n}\n\nYou can use `jq`:\n\n    <file jq 'to_entries|map({(.key):.value})'"
    ],
    "utterance": "Reshape an object whose keys are 'key1', 'key2', each mapping to sub-objects, into an array of objects where each item is {key: value} pairs from the original object, preserving all internal structure.",
    "expressions": [
      "to_entries|map({(.key): .value})"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "key1a": [
              {
                "key1aa": "value1aa"
              },
              {
                "key1ab": "value1ab"
              }
            ]
          },
          "key2": {
            "key2a": [
              {
                "key2aa": "value2aa"
              },
              {
                "key2ab": "value2ab"
              }
            ]
          }
        },
        "output": [
          {
            "key1": {
              "key1a": [
                {
                  "key1aa": "value1aa"
                },
                {
                  "key1ab": "value1ab"
                }
              ]
            }
          },
          {
            "key2": {
              "key2a": [
                {
                  "key2aa": "value2aa"
                },
                {
                  "key2ab": "value2ab"
                }
              ]
            }
          }
        ]
      }
    ],
    "identifier": 59590507
  },
  {
    "context": [
      "given the following JSON : \r\n\r\n```\r\n{\r\n  \"id\": \"4\",\r\n  \"j\": [\r\n    {\r\n      \"f\": 1,\r\n      \"d\": \"x1\"\r\n    },\r\n    {\r\n      \"f\": 2,\r\n      \"d\": \"x2\"\r\n    },\r\n    {\r\n      \"f\": 3,\r\n      \"d\": \"x3\"\r\n    }\r\n  ]\r\n}\r\n```",
      "the following query yields an empty result if  selector is changed to a non existent filter value",
      "the result I wanted should be something like:\r\n \r\n```\r\n{\r\n  \"k\": \"4\",\r\n  \"m\": null\r\n}\r\n\r\n```",
      "the most simple solution I have come up with is \r\n\r\n\r\n```\r\n{k:.id,m:[.j[] | select(.f==4)|.d][0]}\r\n```",
      "you can come around it by actually doing it right with the alternative operator ;) \r\n\r\n```\r\n{k:.id,m:([.j[] | select(.f==4)|.d][]//null)}\r\n```",
      "With your data, the following modification of your original query produces the result shown below:\r\n\r\n    {k:.id, m: ((.j[] | select(.f==4)|.d) // null)}"
    ],
    "utterance": "Return an object with the original id and the d value of the object in j with f equal to 4, or null if no such object exists.",
    "expressions": [
      "{k:.id, m: ((.j[] | select(.f==4)|.d) // null)}",
      "{k:.id, m:[.j[] | select(.f==4)|.d][0]}",
      "{k:.id,m:([.j[] | select(.f==4)|.d][]//null)}"
    ],
    "data": [
      {
        "input": {
          "id": "4",
          "j": [
            {
              "f": 1,
              "d": "x1"
            },
            {
              "f": 2,
              "d": "x2"
            },
            {
              "f": 3,
              "d": "x3"
            }
          ]
        },
        "output": {
          "k": "4",
          "m": null
        }
      }
    ],
    "identifier": 59677955
  },
  {
    "context": [
      "you have quoted `env.MSPID` thereby making it a literal string.  Since you want to invoke the `env` function, you should instead write:",
      "{ (env.MSPID):.[1]}",
      "when an expression must be evaluated to determine the string-value of a key, the expression must be parenthesized, e.g.",
      "{($MSP):.[1]}"
    ],
    "utterance": "Create an object where the key is read dynamically from a shell variable or environment variable and its value is an element from the input, ensuring the dynamic key is evaluated and not a literal string.",
    "expressions": [
      "{ (env.MSPID): .[1] }",
      "{ ($MSP): .[1] }"
    ],
    "identifier": 59686938
  },
  {
    "context": [
      "I need the similar CSV output for both single dict and list of dicts.",
      "I tried a lot of variants with `if/else`, `select()`, `path()`, `//`, etc.. Unfortunately, I can't create working expresion.",
      "`type` is your friend:",
      "    if type == \"array\" then .[] else . end\n    | [.name, .surname]\n    | @csv'"
    ],
    "utterance": "Produce CSV output of name and surname fields, supporting both input as a single object or as a list of objects.",
    "expressions": [
      "if type == \"array\" then .[] else . end | [.name, .surname] | @csv"
    ],
    "data": [
      {
        "input": {
          "name": "Daniel",
          "surname": "Gligor",
          "gender": "male",
          "region": "Romania"
        },
        "output": "\"Daniel\",\"Gligor\""
      },
      {
        "input": [
          {
            "name": "Summer",
            "surname": "Lee",
            "gender": "female",
            "region": "Canada"
          },
          {
            "name": "J\u00falius",
            "surname": "Dzurjanin",
            "gender": "male",
            "region": "Slovakia"
          }
        ],
        "output": [
          "\"Summer\",\"Lee\"",
          "\"J\u00falius\",\"Dzurjanin\""
        ]
      }
    ],
    "identifier": 59717547
  },
  {
    "context": [
      "I want to collapse this JSON so that just the NAME field and the values of DATACLASSES of each record are output to a CSV file.",
      "jq -r '.[] | [.Name, .DataClasses[]] | @csv'",
      "\"Evite\",\"Dates of birth\",\"Email addresses\",\"Genders\",\"Names\",\"Passwords\",\"Phone numbers\",\"Physical addresses\"",
      "\"VerificationsIO\",\"Dates of birth\",\"Email addresses\",\"Employers\",\"Genders\",\"Geographic locations\",\"IP addresses\",\"Job titles\",\"Names\",\"Phone numbers\",\"Physical addresses\""
    ],
    "utterance": "Output each record so that the name field is combined with all of its DataClasses values in a single CSV row.",
    "expressions": [
      ".[] | [.Name, .DataClasses[]] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "Evite",
            "Title": "Evite",
            "Domain": "evite.com",
            "BreachDate": "2013-08-11",
            "AddedDate": "2019-07-14T14:51:51Z",
            "ModifiedDate": "2019-07-14T14:51:51Z",
            "PwnCount": 100985047,
            "Description": "In April 2019, the social planning website for managing online invitations <a href=\\\"https://www.evite.com/security/update?usource=lc&lctid=1800182\\\" target=\\\"_blank\\\" rel=\\\"noopener\\\">Evite identified a data breach of their systems</a>. Upon investigation, they found unauthorised access to a database archive dating back to 2013. The exposed data included a total of 101 million unique email addresses, most belonging to recipients of invitations. Members of the service also had names, phone numbers, physical addresses, dates of birth, genders and passwords stored in plain text exposed. The data was provided to HIBP by a source who requested it be attributed to &quot;JimScott.Sec@protonmail.com&quot;.",
            "LogoPath": "https://haveibeenpwned.com/Content/Images/PwnedLogos/Evite.png",
            "DataClasses": [
              "Dates of birth",
              "Email addresses",
              "Genders",
              "Names",
              "Passwords",
              "Phone numbers",
              "Physical addresses"
            ],
            "IsVerified": true,
            "IsFabricated": false,
            "IsSensitive": false,
            "IsRetired": false,
            "IsSpamList": false
          },
          {
            "Name": "VerificationsIO",
            "Title": "Verifications.io",
            "Domain": "verifications.io",
            "BreachDate": "2019-02-25",
            "AddedDate": "2019-03-09T19:29:54Z",
            "ModifiedDate": "2019-03-09T20:49:51Z",
            "PwnCount": 763117241,
            "Description": "In February 2019, the email address validation service <a href=\\\"https://securitydiscovery.com/800-million-emails-leaked-online-by-email-verification-service\\\" target=\\\"_blank\\\" rel=\\\"noopener\\\">verifications.io suffered a data breach</a>. Discovered by <a href=\\\"https://twitter.com/mayhemdayone\\\" target=\\\"_blank\\\" rel=\\\"noopener\\\">Bob Diachenko</a> and <a href=\\\"https://twitter.com/vinnytroia\\\" target=\\\"_blank\\\" rel=\\\"noopener\\\">Vinny Troia</a>, the breach was due to the data being stored in a MongoDB instance left publicly facing without a password and resulted in 763 million unique email addresses being exposed. Many records within the data also included additional personal attributes such as names, phone numbers, IP addresses, dates of birth and genders. No passwords were included in the data. The Verifications.io website went offline during the disclosure process, although <a href=\\\"https://web.archive.org/web/20190227230352/https://verifications.io/\\\" target=\\\"_blank\\\" rel=\\\"noopener\\\">an archived copy remains viewable</a>.",
            "LogoPath": "https://haveibeenpwned.com/Content/Images/PwnedLogos/VerificationsIO.png",
            "DataClasses": [
              "Dates of birth",
              "Email addresses",
              "Employers",
              "Genders",
              "Geographic locations",
              "IP addresses",
              "Job titles",
              "Names",
              "Phone numbers",
              "Physical addresses"
            ],
            "IsVerified": true,
            "IsFabricated": false,
            "IsSensitive": false,
            "IsRetired": false,
            "IsSpamList": false
          }
        ],
        "output": [
          "\"Evite\",\"Dates of birth\",\"Email addresses\",\"Genders\",\"Names\",\"Passwords\",\"Phone numbers\",\"Physical addresses\"",
          "\"VerificationsIO\",\"Dates of birth\",\"Email addresses\",\"Employers\",\"Genders\",\"Geographic locations\",\"IP addresses\",\"Job titles\",\"Names\",\"Phone numbers\",\"Physical addresses\""
        ]
      }
    ],
    "identifier": 59656085
  },
  {
    "context": [
      "echo '{\n   \"app\": \"K8s\",\n   \"version\": \"1.8\",\n   \"date\": \"2018-10-10\"\n}' | jq --arg app 'K8s' -c 'select(.app == [$app]).version'",
      "The jq program should be:\n\n    select(.app == $app).version"
    ],
    "utterance": "Output the version value only when the app field equals the provided variable value 'K8s'.",
    "expressions": [
      "select(.app == $app).version"
    ],
    "data": [
      {
        "input": {
          "app": "K8s",
          "version": "1.8",
          "date": "2018-10-10"
        },
        "output": "1.8"
      }
    ],
    "identifier": 59720680
  },
  {
    "context": [
      "The requirement is to convert the file paths into json as given in the below example",
      "the input is a valid JSON array of \"/\"-style pathnames of files;",
      "pathnames are all absolute (i.e., begin with \"/\").",
      "reduce .[] as $entry ({};\n  ($entry | split(\"/\") ) as $names\n   | $names[1:-1] as $p\n   | setpath($p; getpath($p) + [$names[-1]]) )",
      "### Input\n[\n    \"/parent/child1/grandchild1\",\n    \"/parent/child1/grandchild2\",\n    \"/parent/child2/grandchild3\",\n    \"/parent/child2/grandchild4\",\n    \"/parent2/child2/grandchild5\"\n]",
      "### Output\n{\n  \"parent\": {\n    \"child1\": [\n      \"grandchild1\",\n      \"grandchild2\"\n    ],\n    \"child2\": [\n      \"grandchild3\",\n      \"grandchild4\"\n    ]\n  },\n  \"parent2\": {\n    \"child2\": [\n      \"grandchild5\"\n    ]\n  }\n}"
    ],
    "utterance": "Transform an array of absolute file paths into a nested object where each path segment is a key and files are collected as arrays under their deepest parent.",
    "expressions": [
      "reduce .[] as $entry ({};\n  ($entry | split(\"/\")) as $names\n  | $names[1:-1] as $p\n  | setpath($p; getpath($p) + [$names[-1]]) )"
    ],
    "data": [
      {
        "input": [
          "/parent/child1/grandchild1",
          "/parent/child1/grandchild2",
          "/parent/child2/grandchild3",
          "/parent/child2/grandchild4",
          "/parent2/child2/grandchild5"
        ],
        "output": {
          "parent": {
            "child1": [
              "grandchild1",
              "grandchild2"
            ],
            "child2": [
              "grandchild3",
              "grandchild4"
            ]
          },
          "parent2": {
            "child2": [
              "grandchild5"
            ]
          }
        }
      }
    ],
    "identifier": 59710786
  },
  {
    "context": [
      "I would like to print each path and value of a [tag:JSON] file with included key values line by line. I would like the output to be comma delimited or at least very easy to cut and sort using Linux command line tools.",
      "My wish would be something like:",
      "$ cat short.json | jq -doit '.':\nReservations,0,Instances,0,ImageId,ami-a\nReservations,0,Instances,0,InstanceId,i-a\nReservations,0,Instances,0,InstanceType,t2.micro\nReservations,0,Instances,0,KeyName,ubuntu",
      "paths(scalars) as $p\n| $p + [getpath($p)] \n| join(\",\")",
      "paths(scalars) as $p\n| $p + [getpath($p)]\n| @tsv",
      "Output with the -r option\nReservations,0,Instances,0,ImageId,ami-a\nReservations,0,Instances,0,InstanceId,i-a\nReservations,0,Instances,0,InstanceType,t2.micro\nReservations,0,Instances,0,KeyName,ubuntu"
    ],
    "utterance": "Produce a comma-delimited list of the full path to each scalar value, followed by the value, with each path/value pair on its own line.",
    "expressions": [
      "paths(scalars) as $p | $p + [getpath($p)] | join(\",\")",
      "paths(scalars) as $p | $p + [getpath($p)] | @tsv"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Groups": [],
              "Instances": [
                {
                  "ImageId": "ami-a",
                  "InstanceId": "i-a",
                  "InstanceType": "t2.micro",
                  "KeyName": "ubuntu"
                }
              ]
            }
          ]
        },
        "output": [
          "Reservations,0,Instances,0,ImageId,ami-a",
          "Reservations,0,Instances,0,InstanceId,i-a",
          "Reservations,0,Instances,0,InstanceType,t2.micro",
          "Reservations,0,Instances,0,KeyName,ubuntu"
        ]
      }
    ],
    "identifier": 59700329
  },
  {
    "context": [
      "INPUT ARGS: \"description\" \"assets.url\"  \n^^^ we can change this INPUT format to assets[].url if it makes easier to handle arrays ^^^",
      "Expected OUTPUT:\n\n1) a property file (key=value)\n\ndescription=TEST DESCRIPTION\nassets_0_url=https://www.fakesite.com/image.jpg\nassets_1_url=https://www.fakesite.com/image2.jpg",
      "2) a transformed JSON file\n\n     {\n            \"title\": \"TEST TITLE\",\n            \"description\": \"${description}\",\n            \"type\": \"Promo\",\n            \"assets\": [{\n               \"content_type\": \"image\",\n               \"url\": \"${assets_0_url}\"\n               }, {\n               \"content_type\": \"image\",\n               \"url\": \"${assets_1_url}\"\n            }]\n        }",
      "The OUTPUT keys (in this case: description, assets_0_url, assets_1_url) don't need to follow this format, but it needs to be numbered and unique in case of arrays.",
      "The only requirement is that the OUTPUT property file's keys matches with the replaced values in the OUTPUT JSON.",
      "Which gives me the following json.properties file:\n\ndescription=TEST DESCRIPTION\nassets_0_url=https://www.fakesite.com/image.jpg\nassets_1_url=https://www.fakesite.com/image2.jpg",
      "The following addresses the bulk of the requirements but leaves the parsing of the \"INPUT ARGS\" as an exercise.",
      "def propertyValue(property):\n  \"\\(property)=\\(.[property])\";",
      "def propertyValue(arrayvaluedproperty; property):\n  .[arrayvaluedproperty] as $a\n  | range(0; $a|length) as $i\n  | \"\\(arrayvaluedproperty)_\\($i)_\\(property)=\\($a[$i][property])\";",
      "propertyValue(\"description\"),\npropertyValue(\"assets\"; \"url\")",
      "def updateProperty(p):\n  .[p] = \"${\\(p)}\";",
      "def updateProperty(arrayvaluedproperty; p):\n  .[arrayvaluedproperty] as $a\n  | reduce range(0; $a|length) as $i (.;\n    .[arrayvaluedproperty][$i] = \"${\\(arrayvaluedproperty)_\\($i)_\\(p)}\");",
      "updateProperty(\"description\")\n| updateProperty(\"assets\"; \"url\")"
    ],
    "utterance": "Produce a property file mapping selected keys and array elements to unique property names with their values, and also replace those original values in the data with their corresponding property name references.",
    "expressions": [
      "def propertyValue(property):\n  \"\\(property)=\\(.[property])\";\n\ndef propertyValue(arrayvaluedproperty; property):\n  .[arrayvaluedproperty] as $a\n  | range(0; $a|length) as $i\n  | \"\\(arrayvaluedproperty)_\\($i)_\\(property)=\\($a[$i][property])\";\n\npropertyValue(\"description\"),\npropertyValue(\"assets\"; \"url\")",
      "def updateProperty(p):\n  .[p] = \"${\\(p)}\";\n\ndef updateProperty(arrayvaluedproperty; p):\n  .[arrayvaluedproperty] as $a\n  | reduce range(0; $a|length) as $i (.;\n    .[arrayvaluedproperty][$i] = \"${\\(arrayvaluedproperty)_\\($i)_\\(p)}\");\n\nupdateProperty(\"description\")\n| updateProperty(\"assets\"; \"url\")"
    ],
    "data": [
      {
        "input": {
          "title": "TEST TITLE",
          "description": "TEST DESCRIPTION",
          "type": "Promo",
          "assets": [
            {
              "content_type": "image",
              "url": "https://www.fakesite.com/image.jpg"
            },
            {
              "content_type": "image",
              "url": "https://www.fakesite.com/image2.jpg"
            }
          ]
        },
        "output": {
          "property_file": [
            "description=TEST DESCRIPTION",
            "assets_0_url=https://www.fakesite.com/image.jpg",
            "assets_1_url=https://www.fakesite.com/image2.jpg"
          ],
          "transformed_json": {
            "title": "TEST TITLE",
            "description": "${description}",
            "type": "Promo",
            "assets": [
              {
                "content_type": "image",
                "url": "${assets_0_url}"
              },
              {
                "content_type": "image",
                "url": "${assets_1_url}"
              }
            ]
          }
        }
      }
    ],
    "identifier": 59674319
  },
  {
    "context": [
      "From the output above, I would like to append that to the contents of the **RandomFile.json** which currently looks like this:",
      "to this:\r\n\r\n```\r\n{\r\n  &quot;docs&quot;: {\r\n    &quot;Doc&quot;: [&quot;doc1&quot;],\r\n    &quot;Readme&quot;: [&quot;Readme/Readme.md&quot;, &quot;Readme/Readyou.md&quot;]\r\n  }\r\n}\r\n```",
      "jq --arg wd \"$(basename \"$PWD\")\" '.docs+={($wd): $ARGS.positional | map(\"\\($wd)/\\(.)\")}' ../RandomFile.json --args *"
    ],
    "utterance": "Append a new key to the docs object with the current directory as the key and an array of filenames in the format directory/filename as the value.",
    "expressions": [
      ".docs+={($wd): $ARGS.positional | map(\"\u0000($wd)/\u0000(.)\")}"
    ],
    "data": [
      {
        "input": {
          "docs": {
            "Doc": [
              "doc1"
            ]
          }
        },
        "output": {
          "docs": {
            "Doc": [
              "doc1"
            ],
            "Readme": [
              "Readme/Readme.md",
              "Readme/Readyou.md"
            ]
          }
        }
      }
    ],
    "identifier": 59717714
  },
  {
    "context": [
      "The following does what I intend, which is to determine if the array contains the empty string as an element.",
      "$ echo '[\"a\",\"b\"]' | jq 'any(.==\"\")'",
      "false"
    ],
    "utterance": "Check if an array contains the empty string as an element.",
    "expressions": [
      "any(.==\"\")"
    ],
    "data": [
      {
        "input": [
          "a",
          "",
          "b"
        ],
        "output": true
      },
      {
        "input": [
          "a",
          "b"
        ],
        "output": false
      }
    ],
    "identifier": 59742685
  },
  {
    "context": [
      "Goal is, given a full MAC (in upper or lower case), to retrieve the companyName field or \"Unknown\" (or \"\") if not found.",
      "For example: 14:18:77:34:23:12 MAC would match the 14:18:77 record (DeLL)",
      "And 00:50:C2:73:E3:27 MAC would match 00:50:C2:73:E record and not 00:50:C2:73:F record.",
      "def bestMatch($s):\n  $s[0:1] as $first\n  | [inputs | select(.oui | startswith($first))]\n  | (select(length>0) | winnow($s; 2)) // \"Unknown\"\n  | if type == \"array\" and length == 1 then .[0] else . end\n  ;",
      "bestMatch(\"14:18:77:34:23:12\")\nyields the JSON object with .oui == \"14:18:77\";",
      "bestMatch(\"00:50:C2:73:E3:27\") \nyields the JSON object with .oui == \"00:50:C2:73:E\""
    ],
    "utterance": "Given a complete MAC address, return the companyName field of the record with the longest matching oui prefix, or \"Unknown\" if no match is found.",
    "expressions": [
      "def winnow($s; $i):\n  if ($s|length) < $i then .\n  else $s[0:$i] as $ss\n  | map(select(.oui | startswith($ss))) as $result\n  | if ($result|length) == 0 then .\n    elif ($result|length) == 1 then $result\n    else $result | winnow($s; $i+1)\n    end\n  end;\ndef bestMatch($s):\n  $s[0:1] as $first\n  | [inputs | select(.oui | startswith($first))]\n  | (select(length>0) | winnow($s; 2)) // \"Unknown\"\n  | if type == \"array\" and length == 1 then .[0] else . end;\nbestMatch(\"14:18:77:34:23:12\") | .companyName // \"Unknown\""
    ],
    "data": [
      {
        "input": [
          {
            "oui": "14:18:77",
            "isPrivate": false,
            "companyName": "Dell Inc",
            "companyAddress": "One Dell way Round Rock 78682 US",
            "countryCode": "US",
            "assignmentBlockSize": "MA-L",
            "dateCreated": "2015-06-13",
            "dateUpdated": "2019-07-01"
          },
          {
            "oui": "00:50:C2:73:E",
            "isPrivate": false,
            "companyName": "Quantec Networks GmbH",
            "companyAddress": "Rieselwiese 1 Vienenburg Niedersachsen 38690 DE",
            "countryCode": "DE",
            "assignmentBlockSize": "IAB",
            "dateCreated": "2007-05-14",
            "dateUpdated": "2015-08-29"
          }
        ],
        "output": "Dell Inc"
      },
      {
        "input": [
          {
            "oui": "00:50:C2:73:E",
            "isPrivate": false,
            "companyName": "Quantec Networks GmbH",
            "companyAddress": "Rieselwiese 1 Vienenburg Niedersachsen 38690 DE",
            "countryCode": "DE",
            "assignmentBlockSize": "IAB",
            "dateCreated": "2007-05-14",
            "dateUpdated": "2015-08-29"
          }
        ],
        "output": "Quantec Networks GmbH"
      }
    ],
    "identifier": 59685626
  },
  {
    "context": [
      "if .foo == \"bar\" and [.bazes[] | .bat==\"blah\"] | any then \n   .add = \"added\"\nelse . end",
      "Adding parentheses to make your intentions clear is usually not a bad idea anyway:\nif .foo == \"bar\" \n   and ([.bazes[] | .bat==\"blah\"] | any)\nthen .add = \"added\"\nelse . end",
      "You could circumvent the issue, achieve a more efficient solution, and conform more closely to English usage by using `any/2`:\nif .foo == \"bar\" \n   and any(.bazes[]; .bat==\"blah\")\nthen .add = \"added\"\nelse . end"
    ],
    "utterance": "Set the field 'add' to 'added' if 'foo' equals 'bar' and any item in 'bazes' has 'bat' equal to 'blah'; otherwise, return the unchanged object.",
    "expressions": [
      "if .foo == \"bar\" and ([.bazes[] | .bat==\"blah\"] | any) then .add = \"added\" else . end",
      "if .foo == \"bar\" and any(.bazes[]; .bat==\"blah\") then .add = \"added\" else . end"
    ],
    "identifier": 59742405
  },
  {
    "context": [
      "With jq, I&#39;m trying to use entries in one array to index into a separate array.",
      "jq&#39;s nifty &#39;as&#39; operator is then able to bring the myArray array into scope and the indexing works fine:",
      ".myArray as $Array | .myFlags | .[] | $Array[.]   ====> yields \"EE\",\"DD\",\"CC\",\"BB\",\"AA\"",
      "However, if I try and move the $Array array access down into a function, the as-variable scope disappears:",
      "def myFun: $Array[.]; .myArray as $Array | .myFlags | .[] | myFun",
      "jq: error: $Array is not defined at <top-level>, line 1:",
      "You can simplify your original query to:",
      ".myArray[.myFlags[]]",
      "You can write jq functions with one or more arguments. This is the appropriate way to parameterize filters.",
      "def myFun(array; $ix): array | .[$ix];",
      "myFun(.myArray; .myFlags[])",
      "Here&#39;s an example showing how an &#39;as&#39; variable can be made visible inside a function:",
      "[1,2] as $array | def myFun: $array[1]; myFun"
    ],
    "utterance": "Retrieve elements from one array using each index in a separate array, demonstrating proper variable scope within a function.",
    "expressions": [
      ".myArray[.myFlags[]]",
      "def myFun(array; $ix): array | .[$ix]; myFun(.myArray; .myFlags[])"
    ],
    "data": [
      {
        "input": {
          "myArray": [
            "AA",
            "BB",
            "CC",
            "DD",
            "EE"
          ],
          "myFlags": [
            4,
            3,
            2,
            1,
            0
          ]
        },
        "output": [
          "EE",
          "DD",
          "CC",
          "BB",
          "AA"
        ]
      }
    ],
    "identifier": 59738722
  },
  {
    "context": [
      "which I'd like to transform into,\r\n\r\n    {\r\n        \"transactions\": [\r\n            {\r\n                \"version\": \"v1\",\r\n                \"transactionId\": \"4234234.2216238756\",\r\n                \"accountId\": \"345345345.10921962\",\r\n                \"rawData\": {\r\n                    \"id\": \"1234567\",\r\n                    \"account_id\": \"456451962\"\r\n                }\r\n            }\r\n        ]\r\n    }",
      "I'm not entirely sure how to create the `rawData` nested object from `.rawtransactiondata`",
      "One of many possibilities:\r\n```\r\n.[]\r\n| {transactions: \r\n    [(.transactiondatajson|fromjson)\r\n     + {rawData: (.rawtransactiondata|fromjson)} ] }\r\n```"
    ],
    "utterance": "Transform an array of objects so that each item becomes a single object in a 'transactions' array, extracting 'version', 'transactionId', and 'accountId' from a stringified object field, and parsing another string field as 'rawData'.",
    "expressions": [
      ".[] | {transactions: [(.transactiondatajson|fromjson) + {rawData: (.rawtransactiondata|fromjson)} ] }"
    ],
    "data": [
      {
        "input": [
          {
            "userid": "fe2e48b7-858b-4a0d-964a-efb8483a00c4",
            "lastupdateddate": "84798000-13cd-11ea-8080-808080808080",
            "transactionid": "10383117.2216238756",
            "accountid": "10383117.10921962",
            "misctransactiondata": null,
            "rawtransactiondata": "{\"id\":\"1234567\",\"account_id\":\"456451962\"}",
            "source": "gateway",
            "transactiondatajson": "{\"version\":\"v1\",\"transactionId\":\"4234234.2216238756\",\"accountId\":\"345345345.10921962\"}",
            "version": "v1"
          }
        ],
        "output": {
          "transactions": [
            {
              "version": "v1",
              "transactionId": "4234234.2216238756",
              "accountId": "345345345.10921962",
              "rawData": {
                "id": "1234567",
                "account_id": "456451962"
              }
            }
          ]
        }
      }
    ],
    "identifier": 59725789
  },
  {
    "context": [
      "I want to perform a Regex on Function each time it contains the `robot-support-dev` to `robot-support-prod-...`",
      "jq is an excellent match for this type of problem. In particular, a trivial solution can be obtained using the filter `sub` of arity 2 or 3, i.e. `sub/3`: sub(\"FROM\"; \"TO\"; \"g\").",
      "You might also wish to use `walk` so that you don't have to be concerned about where exactly the \"Function\" keys occur, e.g.",
      "walk( if type == \"object\" and (.Function|type) == \"string\"\n      then .Function |= sub( \"robot-support-(?<a>([^-]+-)?)dev-\"; \"robot-support-\\(.a)prod-\"; \"g\")\n\t  else . end)"
    ],
    "utterance": "Replace all occurrences of 'robot-support-dev-' with 'robot-support-prod-' in every Function property string, wherever it appears in the data structure.",
    "expressions": [
      "walk(if type == \"object\" and (.Function|type) == \"string\" then .Function |= sub(\"robot-support-(?<a>([^-]+-)?)dev-\"; \"robot-support-\\(.a)prod-\"; \"g\") else . end)"
    ],
    "identifier": 59752862
  },
  {
    "context": [
      "If you want a wild guess, replace `.path + [.value[]]` by",
      ".path + [.value[]|tostring]"
    ],
    "utterance": "Convert all values in the output rows to strings to prevent errors when converting nested objects to CSV, even if some values are not strings or numbers.",
    "expressions": [
      ".path + [.value[]|tostring] | @csv"
    ],
    "identifier": 59778708
  },
  {
    "context": [
      "What I want to do is use this file to generate a JSON string containing the names and current values of the named variables using jq like this:",
      "jq -n --arg arg1 \"$ENV_VAR_A\" --arg arg2 \"$ENV_VAR_B\" '{ENV_VAR_A:$arg1,ENV_VAR_B:$arg2}'",
      "`jq` can look up the values from the environment itself.",
      "$ jq -Rn '[inputs] | map({key: ., value: $ENV[.]}) | from_entries' tmp.txt",
      "Short and sweet (if you have jq 1.5 or higher): jq -Rn '[inputs | {(.): env[.]}] | add' tmp.txt"
    ],
    "utterance": "Produce an object mapping each variable name listed in an input file to the value of that shell variable in the current environment.",
    "expressions": [
      "[inputs] | map({key: ., value: $ENV[.]}) | from_entries",
      "[inputs | {(.): env[.]}] | add"
    ],
    "data": [
      {
        "input": "A\nB",
        "output": {
          "A": "1",
          "B": "2"
        }
      }
    ],
    "identifier": 59778578
  },
  {
    "context": [
      "How do you merge multiple JSON files using jq. Each of the merged objects must have their own key name in the final merged file.",
      "file1.json :\n    {\n      \"shoe\": 0,\n      \"temp\": \"10\"\n    }\n\nfile2.json:\n    {\n      \"num\": {\n        \"sock\": 0,\n        \"ratio\": {\n          \"cat\": 100,\n          \"dog\": 0\n        }\n      },\n      \"hair\": \"blue\"\n    }",
      "Desired merged output:\n    {\n      \"file1\": {\n        \"shoe\": 0,\n        \"temp\": \"10\"\n      },\n      \"file2\": {\n        \"num\": {\n          \"sock\": 0,\n          \"ratio\": {\n            \"cat\": 100,\n            \"dog\": 0\n          }\n        },\n        \"hair\": \"blue\"\n      }\n    }",
      "jq --slurp 'add' file1.json file2.json",
      "jq -n 'reduce inputs as $s (.; .[input_filename] += $s)'  file1.json file2.json",
      "You can go one level further and want to optionally remove the extension part of the JSON `.json`, use the trimming functions available. The below code assumes the input file is ending with `.json` and won\u2019t work with any other extensions",
      "jq -n 'reduce inputs as $s (.; (.[input_filename|rtrimstr(\".json\")]) += $s)'"
    ],
    "utterance": "Combine two files so that each file's contents become a value under a key named after the filename, optionally without the .json extension.",
    "expressions": [
      "jq -n 'reduce inputs as $s (.; .[input_filename] += $s)' file1.json file2.json",
      "jq -n 'reduce inputs as $s (.; (.[input_filename|rtrimstr(\".json\")]) += $s)' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          {
            "file": "file1.json",
            "contents": {
              "shoe": 0,
              "temp": "10"
            }
          },
          {
            "file": "file2.json",
            "contents": {
              "num": {
                "sock": 0,
                "ratio": {
                  "cat": 100,
                  "dog": 0
                }
              },
              "hair": "blue"
            }
          }
        ],
        "output": {
          "file1": {
            "shoe": 0,
            "temp": "10"
          },
          "file2": {
            "num": {
              "sock": 0,
              "ratio": {
                "cat": 100,
                "dog": 0
              }
            },
            "hair": "blue"
          }
        }
      }
    ],
    "identifier": 59768530
  },
  {
    "context": [
      "I need to updated two values (ver & date) in each array element. I have hardcoded the ver & date to simplify the script.",
      "input.json",
      "[\n  {\n    \"svcname\": \"svc1\",\n    \"repo\": \"https://repo.mycom.org/repocontext/svc1-list\",\n    \"ver\": \"0.1\",\n    \"date\": \"2019-11-05\"\n  },\n  {\n    \"svcname\": \"svc1\",\n    \"repo\": \"https://repo.mycom.org/repocontext/svc1-list\",\n    \"ver\": \"0.1\",\n    \"date\": \"2019-12-21\"\n  }\n]",
      "jq 'reduce range(0, length) as $d (.; (.[$d].ver = ($d+1|tostring)) | (.[$d].date = \"2020-01-\\($d+1)\") ) '"
    ],
    "utterance": "Update all elements in an array so their ver fields are set to their 1-based index as a string and their date fields are set to '2020-01-N' where N is their 1-based index.",
    "expressions": [
      "reduce range(0, length) as $d (.; (.[$d].ver = ($d+1|tostring)) | (.[$d].date = \"2020-01-\\($d+1)\") )"
    ],
    "data": [
      {
        "input": [
          {
            "svcname": "svc1",
            "repo": "https://repo.mycom.org/repocontext/svc1-list",
            "ver": "0.1",
            "date": "2019-11-05"
          },
          {
            "svcname": "svc1",
            "repo": "https://repo.mycom.org/repocontext/svc1-list",
            "ver": "0.1",
            "date": "2019-12-21"
          }
        ],
        "output": [
          {
            "svcname": "svc1",
            "repo": "https://repo.mycom.org/repocontext/svc1-list",
            "ver": "1",
            "date": "2020-01-1"
          },
          {
            "svcname": "svc1",
            "repo": "https://repo.mycom.org/repocontext/svc1-list",
            "ver": "2",
            "date": "2020-01-2"
          }
        ]
      }
    ],
    "identifier": 59772878
  },
  {
    "context": [
      "I want to extract info for each of the paths, the methods supported and the content-types expected in each case",
      "I would like to produce:",
      "{\n  \"path\": \"/1.0/kb/paymentGateways/hosted/form/{accountId}\",\n  \"method\": \"post\",\n  \"produces\": \"application/json\",\n  \"consumes\": \"application/json\"\n}",
      "jq 'def nvl(n): (n//[null])[];\\ .paths | keys[] as $path | .[$path] | keys[] as $method | .[$method] | { $path, $method, produces: nvl(.produces), consumes: nvl(.consumes)}' swagger.json",
      "Apart from the formatting, you might consider defining `nvl` as a 0-arity filter (which is more idiomatic and more efficient) or avoiding it altogether.",
      "jq 'def nvl: (.//[null])[]; .paths | keys_unsorted[] as $path | .[$path] | keys_unsorted[] as $method | .[$method] | { $path, $method, produces: .produces | nvl, consumes: .consumes | nvl }' swagger.json"
    ],
    "utterance": "List all paths with their methods, produces, and consumes fields, showing each produces or consumes value as a separate object with the path and method.",
    "expressions": [
      "def nvl(n): (n//[null])[]; .paths | keys[] as $path | .[$path] | keys[] as $method | .[$method] | { $path, $method, produces: nvl(.produces), consumes: nvl(.consumes)}",
      "def nvl: (.//[null])[]; .paths | keys_unsorted[] as $path | .[$path] | keys_unsorted[] as $method | .[$method] | { $path, $method, produces: .produces | nvl, consumes: .consumes | nvl }"
    ],
    "data": [
      {
        "input": {
          "paths": {
            "/1.0/kb/paymentGateways/hosted/form/{accountId}": {
              "post": {
                "produces": [
                  "application/json"
                ],
                "consumes": [
                  "application/json"
                ]
              }
            }
          }
        },
        "output": {
          "path": "/1.0/kb/paymentGateways/hosted/form/{accountId}",
          "method": "post",
          "produces": "application/json",
          "consumes": "application/json"
        }
      }
    ],
    "identifier": 59774043
  },
  {
    "context": [
      "And I need to return this data as a table, each value is a column.",
      "namespace,        timestamp,              request.storage",
      "Ignoring the header line, it looks like the jq query you want is more like this:",
      ".items[]\n| [.metadata.namespace,\n   .metadata.creationTimestamp,\n   .spec.hard[\"requests.storage\"],\n   .status.used[\"requests.storage\"],\n   .spec.hard[\"limits.cpu\"],\n   .spec.hard[\"limits.memory\"],\n   .status.used[\"limits.cpu\"],\n   .status.used[\"limits.memory\"]]\n| @tsv",
      "For CSV, use `@csv` instead of `@tsv`. In either case, you will probably want to invoke jq with the -r option."
    ],
    "utterance": "Output each resource quota as a table with columns for namespace, creationTimestamp, requests.storage (spec.hard), requests.storage (status.used), limits.cpu (spec.hard), limits.memory (spec.hard), limits.cpu (status.used), limits.memory (status.used).",
    "expressions": [
      ".items[] | [ .metadata.namespace, .metadata.creationTimestamp, .spec.hard[\"requests.storage\"], .status.used[\"requests.storage\"], .spec.hard[\"limits.cpu\"], .spec.hard[\"limits.memory\"], .status.used[\"limits.cpu\"], .status.used[\"limits.memory\"] ] | @tsv",
      ".items[] | [ .metadata.namespace, .metadata.creationTimestamp, .spec.hard[\"requests.storage\"], .status.used[\"requests.storage\"], .spec.hard[\"limits.cpu\"], .spec.hard[\"limits.memory\"], .status.used[\"limits.cpu\"], .status.used[\"limits.memory\"] ] | @csv"
    ],
    "identifier": 59775283
  },
  {
    "context": [
      "I need every column regardless of the value, and the values as-is.",
      "the keys with \"$\" in their names cannot be specified using the abbreviated `.foo` syntax; you could use `.[\"$foo\"]` instead.",
      "`@csv` expects an array of atomic values. Thus the keys with JSON objects as values must be handled specially.",
      "With your sample JSON, the following will work:",
      "([\"user_id\",\"server_received_time\",\"app\",\"device_carrier\",\"$schema\",\"city\",\"uuid\",\"event_time\",\"platform\",\"os_version\",\"amplitude_id\",\"processed_time\",\"user_creation_time\",\"version_name\",\"ip_address\",\"paying\",\"dma\",\"group_properties\",\"user_properties\",\"client_upload_time\",\"$insert_id\",\"event_type\",\"library\",\"amplitude_attribution_ids\",\"device_type\",\"device_manufacturer\",\"start_version\",\"location_lng\",\"server_upload_time\",\"event_id\",\"location_lat\",\"os_name\",\"amplitude_event_type\",\"device_brand\",\"groups\",\"event_properties\",\"data\",\"device_id\",\"language\",\"device_model\",\"country\",\"region\",\"is_attribution_event\",\"adid\",\"session_id\",\"device_family\",\"sample_rate\",\"idfa\",\"client_event_time\"]),",
      "([.user_id,.server_received_time,.app,.device_carrier,.[\"$schema\"],.city,.uuid,.event_time,.platform,.os_version,.amplitude_id,.processed_time,.user_creation_time,.version_name,.ip_address,.paying,.dma,.group_properties,.user_properties,.client_upload_time,.[\"$insert_id\"],.event_type,.library,.amplitude_attribution_ids,.device_type,.device_manufacturer,.start_version,.location_lng,.server_upload_time,.event_id,.location_lat,.os_name,.amplitude_event_type,.device_brand,.groups,.event_properties,.data,.device_id,.language,.device_model,.country,.region,.is_attribution_event,.adid,.session_id,.device_family,.sample_rate,.idfa,.client_event_time]\n | map(if type==\"object\"\n       then to_entries\n       | map( \"\\(.key):\\(.value)\" )\n       | join(\";\")\n\t   else . end))\n| @csv",
      "Specifying the long list of keys twice makes the above solution error-prone.  It would be better to specify the keys just once, and then programatically generate the rows.",
      "def toa($headers):\n  . as $in | $headers | map($in[.]);",
      "def toa($headers):\n  def flat: \n     if type == \"object\" or type == \"array\"\n     then to_entries | map( \"\\(.key):\\(.value)\" ) | join(\";\" ) \n     else .\n     end;\n  . as $in | $headers | map($in[.] | flat);"
    ],
    "utterance": "Output all specified fields from each object as a CSV row, flattening any object or array values, treating keys with '$' using bracket notation, and preserving all fields regardless of value.",
    "expressions": [
      "([\"user_id\",\"server_received_time\",\"app\",\"device_carrier\",\"$schema\",\"city\",\"uuid\",\"event_time\",\"platform\",\"os_version\",\"amplitude_id\",\"processed_time\",\"user_creation_time\",\"version_name\",\"ip_address\",\"paying\",\"dma\",\"group_properties\",\"user_properties\",\"client_upload_time\",\"$insert_id\",\"event_type\",\"library\",\"amplitude_attribution_ids\",\"device_type\",\"device_manufacturer\",\"start_version\",\"location_lng\",\"server_upload_time\",\"event_id\",\"location_lat\",\"os_name\",\"amplitude_event_type\",\"device_brand\",\"groups\",\"event_properties\",\"data\",\"device_id\",\"language\",\"device_model\",\"country\",\"region\",\"is_attribution_event\",\"adid\",\"session_id\",\"device_family\",\"sample_rate\",\"idfa\",\"client_event_time\"]),\n([.user_id,.server_received_time,.app,.device_carrier,.[\"$schema\"],.city,.uuid,.event_time,.platform,.os_version,.amplitude_id,.processed_time,.user_creation_time,.version_name,.ip_address,.paying,.dma,.group_properties,.user_properties,.client_upload_time,.[\"$insert_id\"],.event_type,.library,.amplitude_attribution_ids,.device_type,.device_manufacturer,.start_version,.location_lng,.server_upload_time,.event_id,.location_lat,.os_name,.amplitude_event_type,.device_brand,.groups,.event_properties,.data,.device_id,.language,.device_model,.country,.region,.is_attribution_event,.adid,.session_id,.device_family,.sample_rate,.idfa,.client_event_time]\n | map(if type==\"object\"\n       then to_entries\n       | map( \"\\(.key):\\(.value)\" )\n       | join(\";\")\n       else . end))\n| @csv",
      "def toa($headers):\n  def flat: \n     if type == \"object\" or type == \"array\"\n     then to_entries | map( \"\\(.key):\\(.value)\" ) | join(\";\") \n     else .\n     end;\n  . as $in | $headers | map($in[.] | flat);"
    ],
    "data": [
      {
        "input": [
          {
            "groups": {},
            "country": "United States",
            "device_id": "7f2d-8ac-45-86-edeR",
            "is_attribution_event": false,
            "server_received_time": "2019-12-17 17:29:11.113000",
            "language": "English",
            "event_time": "2019-12-17 17:27:44.775000",
            "user_creation_time": "2019-11-08 13:15:32.919000",
            "city": "Sure",
            "uuid": "someID",
            "device_model": "Windows",
            "amplitude_event_type": null,
            "client_upload_time": "2019-12-17 17:29:21.958000",
            "data": {},
            "library": "amplitude-js/5.2.2",
            "device_manufacturer": null,
            "dma": "Washington, DC (Townville, USA)",
            "version_name": null,
            "region": "Virginia",
            "group_properties": {},
            "location_lng": null,
            "device_family": "Windows",
            "paying": null,
            "client_event_time": "2019-12-17 17:27:55.620000",
            "$schema": 12,
            "device_brand": null,
            "user_id": "email@gmail.com",
            "event_properties": {
              "title": "Name",
              "id": "1-253251",
              "applicationName": "SomeName"
            },
            "os_version": "18",
            "device_carrier": null,
            "server_upload_time": "2019-12-17 17:29:11.135000",
            "session_id": 1576603675620,
            "app": 231165,
            "amplitude_attribution_ids": null,
            "event_type": "CHANGE_PERSPECTIVE",
            "user_properties": {},
            "adid": null,
            "device_type": "Windows",
            "$insert_id": "126ba765-147f-403b-92c9-3537",
            "event_id": 23,
            "amplitude_id": 13414,
            "processed_time": "2019-12-17 17:29:12.760365",
            "platform": "Web",
            "idfa": null,
            "os_name": "Edge",
            "location_lat": null,
            "ip_address": "123.456.78.90",
            "sample_rate": null,
            "start_version": null
          },
          {
            "groups": {},
            "country": "United States",
            "device_id": "3d-88c-45-b6-ed81277eR",
            "is_attribution_event": false,
            "server_received_time": "2019-12-17 17:29:11.113000",
            "language": "English",
            "event_time": "2019-12-17 17:27:49.047000",
            "user_creation_time": "2019-11-08 13:15:32.919000",
            "city": "Sure",
            "uuid": "someID",
            "device_model": "Windows",
            "amplitude_event_type": null,
            "client_upload_time": "2019-12-17 17:29:21.958000",
            "data": {},
            "library": "amplitude-js/5.2.2",
            "device_manufacturer": null,
            "dma": "Washington, DC (Townville, USA)",
            "version_name": null,
            "region": "Virginia",
            "group_properties": {},
            "location_lng": null,
            "device_family": "Windows",
            "paying": null,
            "client_event_time": "2019-12-17 17:27:59.892000",
            "$schema": 12,
            "device_brand": null,
            "user_id": "email@gmail.com",
            "event_properties": {
              "title": "Name",
              "id": "1-253251",
              "applicationName": "SomeName"
            },
            "os_version": "18",
            "device_carrier": null,
            "server_upload_time": "2019-12-17 17:29:11.135000",
            "session_id": 1576603675620,
            "app": 231165,
            "amplitude_attribution_ids": null,
            "event_type": "CHANGE_PERSPECTIVE",
            "user_properties": {},
            "adid": null,
            "device_type": "Windows",
            "$insert_id": "e308c923-d8eb-48c6-8ea5-600",
            "event_id": 24,
            "amplitude_id": 515,
            "processed_time": "2019-12-17 17:29:12.760372",
            "platform": "Web",
            "idfa": null,
            "os_name": "Edge",
            "location_lat": null,
            "ip_address": "123.456.78.90",
            "sample_rate": null,
            "start_version": null
          }
        ]
      }
    ],
    "identifier": 59742247
  }
]