[
  {
    "context": [
      "I am trying to format a json string using `jq` with expected output like this:\n[\n  {\n    \"command\": [\n      \"printf 'this is a text'\"\n    ]\n  }\n]\n",
      "jq -n $'[{\"command\": [\"printf \\'this is a text\\'\"]}]'",
      "jq --arg cmd \"printf 'this is a text'\" -n '[{command: [ $cmd ]}]'"
    ],
    "utterance": "Produce a structure with a key 'command' containing an array whose only element is the string printf 'this is a text'.",
    "expressions": [
      "-n $'[{\"command\": [\"printf \\'this is a text\\'\"]}]'",
      "--arg cmd \"printf 'this is a text'\" -n '[{command: [ $cmd ]}]'"
    ],
    "data": [
      {
        "input": null,
        "output": [
          {
            "command": [
              "printf 'this is a text'"
            ]
          }
        ]
      }
    ],
    "identifier": 64601031
  },
  {
    "context": [
      "I have a json with a reasons array in the format [] or [\"a\",\"b\",\"c\"]. Basically i want to replace ... drop_reasons=[\"a\",\"b\",\"c\"] in json to drop_reasons=\"a,b,c\" . I know we can use join(\",\") for this with jq .However , don't know how to modify it in the json .",
      "$ jq '.drop_reasons |= join(\",\")' test.json",
      "{ \"drop_reasons\": [\"a\",\"b\",\"c\"] }",
      "{ \"drop_reasons\": \"a,b,c\" }",
      "Your sample with an empty array would change to an empty string.",
      "`x |= y` is essentially shorthand for `x = (x | y)`. The parens are what you were missing in your attempt; they're needed because of `jq` precedence rules."
    ],
    "utterance": "Convert the 'drop_reasons' array value to a string of comma-separated values, leaving it empty if the array is empty.",
    "expressions": [
      ".drop_reasons |= join(\",\")"
    ],
    "data": [
      {
        "input": {
          "drop_reasons": [
            "a",
            "b",
            "c"
          ]
        },
        "output": {
          "drop_reasons": "a,b,c"
        }
      },
      {
        "input": {
          "drop_reasons": []
        },
        "output": {
          "drop_reasons": ""
        }
      }
    ],
    "identifier": 64596104
  },
  {
    "context": [
      "The IP address is different for each file, but I'd like to use a single jq command to get the data.",
      "On my input in _a_file_ of:\n\n```\n{\n    \"facts\": {\n       \"1.1.1.1\": {\n            \"stuff\":\"value\"\n        }\n    }\n}\n```",
      "So I got an error:\n\n```\njq: error (at <stdin>:9): Cannot index string with string \"stuff\"\n```",
      "This fixed it- the question mark after .stuff:\n```\n.facts | keys_unsorted[] as $k | .[$k].stuff?\n```",
      "You almost got it right, but need the object value iterator construct, `.[]` to get the value corresponding to the key\n\n    .facts | keys_unsorted[] as $k | .[$k].stuff"
    ],
    "utterance": "Extract the 'stuff' object or value from every key under 'facts', regardless of the key name",
    "expressions": [
      ".facts | keys_unsorted[] as $k | .[$k].stuff?",
      ".facts | keys_unsorted[] as $k | .[$k].stuff"
    ],
    "data": [
      {
        "input": {
          "facts": {
            "1.1.1.1": {
              "stuff": "value"
            }
          }
        },
        "output": "value"
      },
      {
        "input": {
          "facts": {
            "1.1.1.1": {
              "stuff": {
                "thing1": "value1"
              }
            },
            "outer_thing": "outer_value"
          }
        },
        "output": {
          "thing1": "value1"
        }
      }
    ],
    "identifier": 64614241
  },
  {
    "context": [
      "I'd like to avoid specifying every property. Is there an equivalent to the Object spread operator in JS, something like `jq '{...a, b}'`?",
      "You can add objects together to combine their contents. If a key exists in both the left and right objects the value from the right object will remain.",
      "Here is a solution that only examines the top-level values, without referring to any key by name:\n```\nwith_entries(if .value|type==\"object\" then .value|to_entries[] else . end)\n```"
    ],
    "utterance": "Combine the first-level object's properties into a single object so that the properties of a nested object and sibling properties are at the same level without specifying each property explicitly.",
    "expressions": [
      ".a + {b}",
      "with_entries(if .value|type==\"object\" then .value|to_entries[] else . end)"
    ],
    "data": [
      {
        "input": {
          "a": {
            "a1": 1,
            "a2": 2
          },
          "b": 3
        },
        "output": {
          "a1": 1,
          "a2": 2,
          "b": 3
        }
      }
    ],
    "identifier": 64605920
  },
  {
    "context": [
      "I need to take the value `.Principal.AWS` and save that in a variable `$orig` or something, and then readd that variable as an element in an array that will become the new document.",
      ".Statement[0] |= ( .Principal.AWS as $orig | .Principal.AWS = [$orig] + [\"foo\", \"bar\"] )",
      ".Statement[].Principal.AWS |= [(arrays // [.][], \"foo\", \"bar\"]"
    ],
    "utterance": "Update each Statement's Principal.AWS so its value becomes an array containing the original value, followed by \"foo\" and \"bar\".",
    "expressions": [
      ".Statement[0] |= ( .Principal.AWS as $orig | .Principal.AWS = [$orig] + [\"foo\", \"bar\"] )",
      ".Statement[].Principal.AWS |= [(arrays // [.])[], \"foo\", \"bar\"]"
    ],
    "data": [
      {
        "input": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Effect": "Allow",
              "Principal": {
                "AWS": "arn:aws:iam::111122223333:root"
              },
              "Action": "sts:AssumeRole"
            }
          ]
        },
        "output": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn:aws:iam::111122223333:root",
                  "foo",
                  "bar"
                ]
              },
              "Action": "sts:AssumeRole"
            }
          ]
        }
      }
    ],
    "identifier": 64633716
  },
  {
    "context": [
      "Let\u2019s start with the lines of text in the problem description:\n```\n192.168.1.2\n192.168.1.3\n192.168.1.5\n192.168.1.6\n192.168.1.7\n```",
      "if you pipe these lines into this variant of your jq program:\n\n    jq -nR --arg stat fails --arg count $count  '[{$stat,$count},\n     {liststat: \"topips\",\n      items: [inputs]}]'",
      "you would get the output shown below.  You should be able to modify this example in accordance with your requirements.",
      "## Output\n```\n[\n  {\n    \"stat\": \"fails\",\n    \"count\": \"0\"\n  },\n  {\n    \"liststat\": \"topips\",\n    \"items\": [\n      \"192.168.1.2\",\n      \"192.168.1.3\",\n      \"192.168.1.5\",\n      \"192.168.1.6\",\n      \"192.168.1.7\"\n    ]\n  }\n]\n```"
    ],
    "utterance": "Return an object with stat and count fields and another field liststat with items as an array of given IP strings from input lines.",
    "expressions": [
      "jq -nR --arg stat fails --arg count \"$count\" '[{$stat,$count},{liststat: \"topips\", items: [inputs]}]'"
    ],
    "data": [
      {
        "input": "192.168.1.2\n192.168.1.3\n192.168.1.5\n192.168.1.6\n192.168.1.7\n",
        "output": [
          {
            "stat": "fails",
            "count": "0"
          },
          {
            "liststat": "topips",
            "items": [
              "192.168.1.2",
              "192.168.1.3",
              "192.168.1.5",
              "192.168.1.6",
              "192.168.1.7"
            ]
          }
        ]
      }
    ],
    "identifier": 64601197
  },
  {
    "context": [
      "I have been experimenting with jq but cannot parse out the iso_code value in the output from the Maxmind beta application [mmdbinspect][1] which is JSON output.",
      "Once you\u2019ve sorted out the encoding issues, you might want to consider:\r\n\r\n    .. | .iso_code? // empty",
      "or if you just want the distinct answers:\r\n\r\n    [.. | .iso_code? // empty] | unique[]"
    ],
    "utterance": "Extract all iso_code values, including handling missing values, from nested data structures such as the Maxmind mmdbinspect output.",
    "expressions": [
      ".. | .iso_code? // empty",
      "[.. | .iso_code? // empty] | unique[]"
    ],
    "data": [
      {
        "input": {
          "Database": "/usr/local/var/GeoIP/GeoLite2-City.mmdb",
          "Records": [
            {
              "Network": "8.8.8.8/17",
              "Record": {
                "continent": {
                  "code": "NA",
                  "geoname_id": 6255149,
                  "names": {
                    "de": "Nordamerika",
                    "en": "North America",
                    "es": "Norteam\u00e9rica",
                    "fr": "Am\u00e9rique du Nord",
                    "ja": "\u5317\u30a2\u30e1\u30ea\u30ab",
                    "pt-BR": "Am\u00e9rica do Norte",
                    "ru": "\u0421\u0435\u0432\u0435\u0440\u043d\u0430\u044f \u0410\u043c\u0435\u0440\u0438\u043a\u0430",
                    "zh-CN": "\u5317\u7f8e\u6d32"
                  }
                },
                "country": {
                  "geoname_id": 6252001,
                  "iso_code": "US",
                  "names": {
                    "de": "USA",
                    "en": "United States",
                    "es": "Estados Unidos",
                    "fr": "\u00c9tats-Unis",
                    "ja": "\u30a2\u30e1\u30ea\u30ab\u5408\u8846\u56fd",
                    "pt-BR": "Estados Unidos",
                    "ru": "\u0421\u0428\u0410",
                    "zh-CN": "\u7f8e\u56fd"
                  }
                },
                "location": {
                  "accuracy_radius": 1000,
                  "latitude": 37.751,
                  "longitude": -97.822,
                  "time_zone": "America/Chicago"
                },
                "registered_country": {
                  "geoname_id": 6252001,
                  "iso_code": "US",
                  "names": {
                    "de": "USA",
                    "en": "United States",
                    "es": "Estados Unidos",
                    "fr": "\u00c9tats-Unis",
                    "ja": "\u30a2\u30e1\u30ea\u30ab\u5408\u8846\u56fd",
                    "pt-BR": "Estados Unidos",
                    "ru": "\u0421\u0428\u0410",
                    "zh-CN": "\u7f8e\u56fd"
                  }
                }
              }
            }
          ],
          "Lookup": "8.8.8.8"
        },
        "output": [
          "US",
          "US"
        ]
      }
    ],
    "identifier": 64618513
  },
  {
    "context": [
      "I just want to extract any IPv4 or IPv6 address that is inside the expression field, so in this case, `192.168.1.1 192.168.1.2`",
      "jq -r '.result.filter.expression\n      | capture(\"{(?<ips>[^}]*)}\").ips' example.json"
    ],
    "utterance": "Extract the space-separated list of IP addresses found inside the curly braces in the result.filter.expression field.",
    "expressions": [
      ".result.filter.expression | capture(\"{(?<ips>[^}]*)}\").ips"
    ],
    "data": [
      {
        "input": {
          "result": {
            "id": "78839c481cd8424fa8f0f06abd33b55f",
            "paused": false,
            "description": "Test",
            "action": "block",
            "priority": 1,
            "filter": {
              "id": "68f2efc4fa6e43f584dd4b60aca09901",
              "expression": "(ip.src in {192.168.1.1 192.168.1.2 2408:14c:dc83:9119:f9f6:c105:923:a5e3})",
              "paused": false
            },
            "created_on": "2020-11-02T13:48:31Z",
            "modified_on": "2020-11-02T13:49:02Z"
          },
          "success": true,
          "errors": [],
          "messages": []
        },
        "output": "192.168.1.1 192.168.1.2 2408:14c:dc83:9119:f9f6:c105:923:a5e3"
      }
    ],
    "identifier": 64647762
  },
  {
    "context": [
      "How do I get `\"b\"` using the `jq` command?",
      "But the result isn't a json dictionary. It's a string that needs to be escaped and parsed into json.",
      "`jq .x.a` throws an error: `jq: error (at <stdin>:1): Cannot index string with string \"a\"`",
      "The following does the trick:",
      "echo '{\"x\": \"{\\\"a\\\": \\\"b\\\"}\"}' | jq -r .x | jq .a",
      "EDIT: Calling `jq` twice is not ideal (thanks @peak), the previous command can be combined in this oneliner",
      "| jq -r '.x|fromjson.a'"
    ],
    "utterance": "Extract the value of key 'a' from an object that is stored as an escaped string in key 'x' of the outer object.",
    "expressions": [
      ".x | fromjson | .a",
      ".x|fromjson.a",
      ".x | fromjson.a"
    ],
    "data": [
      {
        "input": {
          "x": "{\"a\": \"b\"}"
        },
        "output": "b"
      }
    ],
    "identifier": 64654911
  },
  {
    "context": [
      "I want to extract the name of the field name: when i know the value: ami-asd637ccb094d. I`m trying to do it with jq . The expected result is 2020-11-02-160548. Any help?",
      ".[] | select(.value==\"ami-asd637ccb094d\") | .name"
    ],
    "utterance": "Extract the name field when the value field matches ami-asd637ccb094d.",
    "expressions": [
      ".[] | select(.value==\"ami-asd637ccb094d\") | .name"
    ],
    "data": [
      {
        "input": [
          {
            "name": "2020-11-02-160548",
            "value": "ami-asd637ccb094d"
          }
        ],
        "output": "2020-11-02-160548"
      }
    ],
    "identifier": 64660269
  },
  {
    "context": [
      "I want the output in the below format like in a single row. Can some one help me to get the output.",
      "Required output:",
      "i-004f8269b087ec123 instance-event-0ad7ad7a2011a4123 instance-stop The instance is running on degraded hardware 2020-11-16T10:00:00.000Z",
      "jq -r '\n    .InstanceStatuses[] | \n    .InstanceId as $id |\n    .Events[] | \n    [$id, .InstanceEventId, .Code, .Description, .NotBefore] |\n    @tsv\n' file.json"
    ],
    "utterance": "Extract each instance's InstanceId along with each of its event's InstanceEventId, Code, Description, and NotBefore fields, all in a single row per event, separated by tabs.",
    "expressions": [
      ".InstanceStatuses[] | .InstanceId as $id | .Events[] | [$id, .InstanceEventId, .Code, .Description, .NotBefore] | @tsv"
    ],
    "data": [
      {
        "input": {
          "InstanceStatuses": [
            {
              "AvailabilityZone": "us-east-1b",
              "Events": [
                {
                  "InstanceEventId": "instance-event-0ad7ad7a2011a4123",
                  "Code": "instance-stop",
                  "Description": "The instance is running on degraded hardware",
                  "NotBefore": "2020-11-16T10:00:00.000Z"
                }
              ],
              "InstanceId": "i-004f8269b087ec123",
              "InstanceState": {
                "Code": 16,
                "Name": "running"
              },
              "InstanceStatus": {
                "Details": [
                  {
                    "ImpairedSince": "2020-11-01T23:36:00.000Z",
                    "Name": "reachability",
                    "Status": "failed"
                  }
                ],
                "Status": "impaired"
              },
              "SystemStatus": {
                "Details": [
                  {
                    "ImpairedSince": "2020-11-01T23:36:00.000Z",
                    "Name": "reachability",
                    "Status": "failed"
                  }
                ],
                "Status": "impaired"
              }
            }
          ]
        },
        "output": "i-004f8269b087ec123\tinstance-event-0ad7ad7a2011a4123\tinstance-stop\tThe instance is running on degraded hardware\t2020-11-16T10:00:00.000Z"
      }
    ],
    "identifier": 64647262
  },
  {
    "context": [
      "curl --silent -X GET https://url.com/api/servers -H \"Authorization: Token $token\" -H \"Content-Type: text/json\"  -H \"Accept:application/json\" | jq -r '.Result.servers[] | select(.ansible_local.local.local_facts.instance_type | tostring | contains(\"t2.micro\")) | (.ansible_fqdn+\"\\\": null,\")' | sed 's/^/\"/g'",
      "I just need a list of servers based on a matching variable in the JSON output that ansible can use.",
      "select(.ansible_local.local.local_facts.instance_type | tostring | contains(\"t2.micro\"))"
    ],
    "utterance": "Return the ansible_fqdn values for servers whose instance_type contains 't2.micro'.",
    "expressions": [
      ".Result.servers[] | select(.ansible_local.local.local_facts.instance_type | tostring | contains(\"t2.micro\")) | .ansible_fqdn"
    ],
    "identifier": 64659785
  },
  {
    "context": [
      "I want to get an array with the values of all the fields named `comments` (which can be nested in any level). So, in this case I want to get:",
      "You can use the `getpath` function. Use `paths` to identify all the paths leading upto `.comments` and get the paths' value",
      "Or use a recursive descent to filter objects containing `.comments` and get its value",
      "jq '[ getpath ( paths | select( .[-1] == \"comments\" ) ) ]'",
      "jq '[ recurse | select(has(\"comments\")?).comments ]'"
    ],
    "utterance": "Extract an array containing the values of all keys named 'comments', regardless of nesting level, from the input.",
    "expressions": [
      "[ getpath ( paths | select( .[-1] == \"comments\" ) ) ]",
      "[ recurse | select(has(\"comments\")?).comments ]"
    ],
    "data": [
      {
        "input": {
          "a": 0,
          "b": "c",
          "d": {
            "e": {
              "f": "g",
              "comments": {
                "leading": "Lorem ipsum"
              },
              "h": {
                "i": {
                  "j": [
                    1,
                    2
                  ]
                },
                "comments": {
                  "trailing": "dolor sit"
                }
              }
            },
            "comments": {
              "leading": "amet."
            }
          }
        },
        "output": [
          {
            "leading": "Lorem ipsum"
          },
          {
            "trailing": "dolor sit"
          },
          {
            "leading": "amet."
          }
        ]
      }
    ],
    "identifier": 64663297
  },
  {
    "context": [
      "I have an input object with nested objects like this:",
      "\"I'd like to restrict the sub-objects by the same set of keys, say `foo` and `bar`:\"",
      "\"I can do this with `map_values`, but it's such a basic thing I want to do that I feel like I must be missing something:\"",
      "$ jq 'map_values({foo, bar})'",
      "\"Is this the simplest and most readable way of selecting a set of keys from all sub-objects?\""
    ],
    "utterance": "Keep only the keys foo and bar in all immediate subobjects of a top-level object.",
    "expressions": [
      "map_values({foo, bar})"
    ],
    "data": [
      {
        "input": {
          "qux": {
            "foo": 1,
            "bar": 2,
            "baz": 3
          },
          "zyx": {
            "foo": 4,
            "bar": 5,
            "baz": 6
          }
        },
        "output": {
          "qux": {
            "foo": 1,
            "bar": 2
          },
          "zyx": {
            "foo": 4,
            "bar": 5
          }
        }
      }
    ],
    "identifier": 64680963
  },
  {
    "context": [
      "At this moment I need to modify only the keys in the object `.anomalyDetection.outageHandling.localOutagePolicy`, however, in the future I might need to change other keys as well and need a solution which is scalable and maintainable.",
      "updated_JSON=$(jq --argjson update_affectedLocations \"${1:-1}\" --argjson update_consecutiveRuns \"${2:-2}\" \\\n       '.anomalyDetection.outageHandling.globalOutage|=true\n        | .anomalyDetection.outageHandling.localOutagePolicy.affectedLocations|=$update_affectedLocations\n        | .anomalyDetection.outageHandling.localOutagePolicy.consecutiveRuns|=$update_consecutiveRuns' \\\n        <<<\"$template\")",
      "template |\n    jq --argjson update_affectedLocations \"${1:-1}\" \\\n       --argjson update_consecutiveRuns \"${2:-2}\" '\n       .anomalyDetection.outageHandling.localOutagePolicy\n         |= (.affectedLocations |= $update_affectedLocations\n             | .consecutiveRuns |= $update_consecutiveRuns )\n    '"
    ],
    "utterance": "Update the values of affectedLocations and consecutiveRuns in outageHandling.localOutagePolicy to specific parameter values, defaulting to 1 and 2 if not provided.",
    "expressions": [
      ".anomalyDetection.outageHandling.localOutagePolicy.affectedLocations |= $update_affectedLocations | .anomalyDetection.outageHandling.localOutagePolicy.consecutiveRuns |= $update_consecutiveRuns",
      ".anomalyDetection.outageHandling.localOutagePolicy |= (.affectedLocations |= $update_affectedLocations | .consecutiveRuns |= $update_consecutiveRuns )"
    ],
    "data": [
      {
        "input": {
          "anomalyDetection": {
            "loadingTimeThresholds": {
              "enabled": false,
              "thresholds": []
            },
            "outageHandling": {
              "globalOutage": true,
              "localOutage": true,
              "localOutagePolicy": {
                "affectedLocations": 1,
                "consecutiveRuns": 2
              }
            }
          }
        },
        "output": {
          "anomalyDetection": {
            "loadingTimeThresholds": {
              "enabled": false,
              "thresholds": []
            },
            "outageHandling": {
              "globalOutage": true,
              "localOutage": true,
              "localOutagePolicy": {
                "affectedLocations": 42,
                "consecutiveRuns": 666
              }
            }
          }
        }
      }
    ],
    "identifier": 64646374
  },
  {
    "context": [
      "i want to build a new JSON using JQ, and add more items, let me explain, i want to get this:",
      "{\n  \"NEWKEY1\": \"NEWVALUE2\",\n  \"NEWKEY2\": [\n    {\n      \"NEWKEY3\": \"UPSNEWVALUE3\",\n      \"NEWKEY4\": {\n        \"key1\": \"value1\",\n        \"key2\": \"value2\",\n        \"key3\": \"value3\",\n        \"key4\": \"value4,\n        \"key5\": {\n          \"subkey1\": \"subvalue1\",\n          \"subkey2\": \"subvalue2\",\n          \"subkey3\": \"subvalue3\"\n        }\n      }\n    }\n  ]\n}",
      "jq --argfile in data.json '.NEWKEY2[0].NEWKEY4 = $in[0]' template.json"
    ],
    "utterance": "Construct an output object with a top-level NEWKEY1 and an array NEWKEY2 containing one object with NEWKEY3 and NEWKEY4, where NEWKEY4 holds the original data object.",
    "expressions": [
      ".NEWKEY2[0].NEWKEY4 = $in[0]"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3",
            "key4": "value4",
            "key5": {
              "subkey1": "subvalue1",
              "subkey2": "subvalue2",
              "subkey3": "subvalue3"
            }
          }
        ],
        "output": {
          "NEWKEY1": "NEWVALUE2",
          "NEWKEY2": [
            {
              "NEWKEY3": "UPSNEWVALUE3",
              "NEWKEY4": {
                "key1": "value1",
                "key2": "value2",
                "key3": "value3",
                "key4": "value4",
                "key5": {
                  "subkey1": "subvalue1",
                  "subkey2": "subvalue2",
                  "subkey3": "subvalue3"
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 64683785
  },
  {
    "context": [
      "The output from the tool I am using is creating an element in the json that is an object when there is only 1 item but an array when there is more than 1.",
      "How do I parse this with jq to return the full list of names only from within content?",
      "jq '.data[].content | if type == \"array\" then .[] else . end | .name?'",
      "More succinctly:\n\n    jq '.data[].content | .name? // .[].name?'"
    ],
    "utterance": "Extract all the name values from each content field, where content may be either an object or an array of objects.",
    "expressions": [
      ".data[].content | if type == \"array\" then .[] else . end | .name?",
      ".data[].content | .name? // .[].name?"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "name": "data block1",
              "content": {
                "name": "1 bit of data"
              }
            },
            {
              "name": "data block2",
              "content": [
                {
                  "name": "first bit"
                },
                {
                  "name": "another bit"
                },
                {
                  "name": "last bit"
                }
              ]
            }
          ]
        },
        "output": [
          "1 bit of data",
          "first bit",
          "another bit",
          "last bit"
        ]
      }
    ],
    "identifier": 64684980
  },
  {
    "context": [
      "I want to extract key values from the above `result` object and put in the same text file where keys should go under `KEYS` and values under `VALUES` in the table.",
      "Outcome I am expecting is:\r\n\r\n    KEYS      VALUES\r\n    key1      val1\r\n    key2      val2\r\n    key3      val3",
      "% jq -r '{\"KEYS\": \"VALUES\"} + .result | to_entries[] | \"\\(.key)\\t\\(.value)\"' tmp.json",
      "I added the header to the input before conversion to the key/value list."
    ],
    "utterance": "Output all properties and their values from the 'result' object as a table with headers 'KEYS' and 'VALUES', with each key and value on a new line.",
    "expressions": [
      "{\"KEYS\": \"VALUES\"} + .result | to_entries[] | \"\\(.key)\\t\\(.value)\""
    ],
    "data": [
      {
        "input": {
          "result": {
            "key1": "val1",
            "key2": "val2",
            "key3": "val3"
          }
        },
        "output": [
          "KEYS\tVALUES",
          "key1\tval1",
          "key2\tval2",
          "key3\tval3"
        ]
      }
    ],
    "identifier": 64686634
  },
  {
    "context": [
      "\"For a given name ,\\\"some-name\\\", I'd like to extract json: { url: \\\"https://some-url\\\", cert: \\\"some-cert\\\", username: \\\"some-user\\\", password: \\\"some-password\\\" }\"",
      "\"(.clusters[] | select(.name == $name).cluster | {url: .server, cert: .\\\"certificate-authority-data\\\"}) + (.users[] | select(.name == $name).user | {username, password})\"",
      "\"For the second part of your question, if it turns out the mapped user is missing key properties and you want to omit them, just add another `select` filter to the end to test for those properties and replace with an empty object if nothing is found: ... | select(has(\\\"username\\\") and has(\\\"password\\\")) // {}\""
    ],
    "utterance": "For a specific name, extract an object with server URL, certificate, username, and password, but return an empty object if username or password is missing.",
    "expressions": [
      "(.clusters[] | select(.name == $name).cluster | {url: .server, cert: .\"certificate-authority-data\"}) + (.users[] | select(.name == $name).user | {username, password}) | select(has(\"username\") and has(\"password\")) // {}"
    ],
    "data": [
      {
        "input": {
          "kind": "Config",
          "apiVersion": "v1",
          "preferences": {},
          "clusters": [
            {
              "name": "some-name",
              "cluster": {
                "server": "https://some-url",
                "certificate-authority-data": "some-cert"
              }
            },
            {
              "name": "another-name",
              "cluster": {
                "server": "https://another-url",
                "certificate-authority-data": "another-cert"
              }
            }
          ],
          "users": [
            {
              "name": "some-name",
              "user": {
                "username": "some-user",
                "password": "some-password"
              }
            },
            {
              "name": "another-name",
              "user": {
                "username": "another-user",
                "password": "another-password"
              }
            }
          ],
          "contexts": [],
          "current-context": "some-context"
        },
        "output": {
          "url": "https://some-url",
          "cert": "some-cert",
          "username": "some-user",
          "password": "some-password"
        }
      },
      {
        "input": {
          "kind": "Config",
          "apiVersion": "v1",
          "preferences": {},
          "clusters": [
            {
              "name": "some-name",
              "cluster": {
                "server": "https://some-url",
                "certificate-authority-data": "some-cert"
              }
            }
          ],
          "users": [
            {
              "name": "some-name",
              "user": {
                "exec": {}
              }
            }
          ],
          "contexts": [],
          "current-context": "some-context"
        },
        "output": {}
      }
    ],
    "identifier": 64635160
  },
  {
    "context": [
      "I have a json with records like this:\n\n[\n {\"number\":1},\n {\"number\":3}\n]\n\nand want to select (filter) a record with a max or min value of the field \"number\".",
      "([ .[].number ] | min) as $m| map(select(.number== $m))",
      "jq has the built-ins `max_by` and `min_by`, as documented at https://stedolan.github.io/jq/manual/#Builtinoperatorsandfunctions"
    ],
    "utterance": "Select records from an array where the value of the field 'number' is minimal.",
    "expressions": [
      "([.[].number] | min) as $m | map(select(.number == $m))",
      "min_by(.number)"
    ],
    "data": [
      {
        "input": [
          {
            "number": 1
          },
          {
            "number": 3
          }
        ],
        "output": [
          {
            "number": 1
          }
        ]
      }
    ],
    "identifier": 64698091
  },
  {
    "context": [
      "I tried `jq --argjson value &#39;{\"foo\": \"bar\", \"bar\": \"foo\"}' \".x = $value\" <<< \"$json\"`",
      "I expect:",
      "{",
      "   \"x\":{",
      "      \"foo\": \"bar\",",
      "      \"bar\": \"foo\"",
      "   },",
      "   \"y\":{",
      "      \"foo\": \"world\"",
      "   }",
      "}",
      "I suggest to wrap the jq command in single quotes:",
      "jq --argjson value '{\"foo\": \"bar\", \"bar\": \"foo\"}' '.x = $value' <<< \"$json\""
    ],
    "utterance": "Set the value of the key x to an object with foo: \"bar\" and bar: \"foo\".",
    "expressions": [
      ".x = $value"
    ],
    "data": [
      {
        "input": {
          "x": {
            "foo": "hello"
          },
          "y": {
            "foo": "world"
          }
        },
        "output": {
          "x": {
            "foo": "bar",
            "bar": "foo"
          },
          "y": {
            "foo": "world"
          }
        }
      }
    ],
    "identifier": 64688691
  },
  {
    "context": [
      "I currently have the following JSON output from `echo $items | jq`:\r\n\r\n    {\r\n      \"Family_Name\": \"Type 1\",\r\n      \"Quantity_On_Hand\": \"335\"\r\n    }\r\n    {\r\n      \"Family_Name\": \"Type 2\",\r\n      \"Quantity_On_Hand\": \"215\"\r\n    }\r\n    {\r\n      \"Family_Name\": \"Type 9\",\r\n      \"Quantity_On_Hand\": \"159\"\r\n    }\r\n    {\r\n      \"Family_Name\": \"Type 4\",\r\n      \"Quantity_On_Hand\": \"500\"\r\n    }\r\n\r\n\r\nI also have a bash array `colors` of the same size looking like \r\n\r\n    \"Blue\" \"Red\" \"Green\" \"Blue\"\r\n\r\nHow can I use `jq` so that I get something like\r\n\r\n \r\n\r\n    {\r\n      \"Family_Name\": \"Type 1\",\r\n      \"Quantity_On_Hand\": \"335\",\r\n      \"Colors\": \"Blue\"\r\n    }\r\n    {\r\n      \"Family_Name\": \"Type 2\",\r\n      \"Quantity_On_Hand\": \"215\",\r\n      \"Colors\": \"Red\"\r\n    }\r\n    {\r\n      \"Family_Name\": \"Type 9\",\r\n      \"Quantity_On_Hand\": \"159\",\r\n      \"Colors\": \"Green\"\r\n    }\r\n    {\r\n      \"Family_Name\": \"Type 4\",\r\n      \"Quantity_On_Hand\": \"500\",\r\n      \"Colors\": \"Blue\"\r\n    }\r\n",
      "jq -s '\r\n  ($ARGS.positional | map({Colors: .})) as $colors\r\n  | [., $colors] | transpose | map(add)\r\n' --args \"${colors[@]}\"",
      "If you want the result to be a stream of the JSON objects, you could tack on `[]` or\r\nchange `transpose | map(add)` to `transpose[] | add`",
      "jq -R -s --argfile json <(echo \"$items\") '\r\n  (split(\"\\n\") | map(select(length>0))) as $colors\r\n  | [ range(0; $colors|length) | $json[.] + {Colors: $colors[.]} ]\r\n' <( printf \"%s\\n\" \"${colors[@]}\" )"
    ],
    "utterance": "Add the corresponding color from a separate array as a new Colors field to each object, matching by their order in the list.",
    "expressions": [
      "jq -s '($ARGS.positional | map({Colors: .})) as $colors | [., $colors] | transpose | map(add)' --args \"${colors[@]}\"",
      "jq -R -s --argfile json <(echo \"$items\") '(split(\"\\n\") | map(select(length>0))) as $colors | [ range(0; $colors|length) | $json[.] + {Colors: $colors[.]} ]' <( printf \"%s\\n\" \"${colors[@]}\" )"
    ],
    "data": [
      {
        "input": [
          {
            "Family_Name": "Type 1",
            "Quantity_On_Hand": "335"
          },
          {
            "Family_Name": "Type 2",
            "Quantity_On_Hand": "215"
          },
          {
            "Family_Name": "Type 9",
            "Quantity_On_Hand": "159"
          },
          {
            "Family_Name": "Type 4",
            "Quantity_On_Hand": "500"
          }
        ],
        "output": [
          {
            "Family_Name": "Type 1",
            "Quantity_On_Hand": "335",
            "Colors": "Blue"
          },
          {
            "Family_Name": "Type 2",
            "Quantity_On_Hand": "215",
            "Colors": "Red"
          },
          {
            "Family_Name": "Type 9",
            "Quantity_On_Hand": "159",
            "Colors": "Green"
          },
          {
            "Family_Name": "Type 4",
            "Quantity_On_Hand": "500",
            "Colors": "Blue"
          }
        ]
      }
    ],
    "identifier": 64623254
  },
  {
    "context": [
      "I am trying to figure out how to place an elif statement to check if this class is present `.result.CVE_Items[].configurations.nodes[].children[]` and if it is present for it to query the data.",
      "I have tried has(\"children\") and has(\"children[]\") but nothing has worked and I really don\u2019t have a clue...",
      "if $node | (type == \"object\" and has(\"children\"))",
      "{CVE: $ID, Description: $value, \"CVSS V3 Score\": .cvssV3.baseSeverity, \"Attack Vector\": .cvssV3.attackVector, \"Privileges Required\": .cvssV3.privilegesRequired, \"User Interaction\": .cvssV3.userInteraction, \"Impact Score\": .impactScore, \"Products Affected\": [$node.children[].cpe_match[].cpe23Uri]}",
      "else {CVE: $ID, Description: $value, \"CVSS V3 Score\": .cvssV3.baseSeverity, \"Attack Vector\": .cvssV3.attackVector, \"Privileges Required\": .cvssV3.privilegesRequired, \"User Interaction\": .cvssV3.userInteraction, \"Impact Score\": .impactScore, \"Products Affected\": [$node.cpe_match[].cpe23Uri]}"
    ],
    "utterance": "Return relevant vulnerability details, listing affected product URIs from either children.cpe_match or cpe_match depending on presence of children property inside each node.",
    "expressions": [
      "if .totalResults == 1 then .result.CVE_Items[]\n| .cve.CVE_data_meta.ID as $ID\n| .cve.description.description_data[].value as $value\n| .configurations.nodes[] as $node\n| if $node | (type == \"object\" and has(\"children\"))\nthen .impact.baseMetricV3 |\n{CVE: $ID, Description: $value, \"CVSS V3 Score\": .cvssV3.baseSeverity, \"Attack Vector\": .cvssV3.attackVector, \"Privileges Required\": .cvssV3.privilegesRequired, \"User Interaction\": .cvssV3.userInteraction, \"Impact Score\": .impactScore, \"Products Affected\": [$node.children[].cpe_match[].cpe23Uri]}\nelse .impact.baseMetricV3 |\n{CVE: $ID, Description: $value, \"CVSS V3 Score\": .cvssV3.baseSeverity, \"Attack Vector\": .cvssV3.attackVector, \"Privileges Required\": .cvssV3.privilegesRequired, \"User Interaction\": .cvssV3.userInteraction, \"Impact Score\": .impactScore, \"Products Affected\": [$node.cpe_match[].cpe23Uri]}\nend else . | {Results: .message} end"
    ],
    "identifier": 64674729
  },
  {
    "context": [
      "The key point is sometimes `details` is an object and sometimes it's an array of objects, and to quote from the doc *\"We can use the destructuring alternative operator to handle this structural change simply\"*",
      ".data[] | \"\\(.fruit) - \\(.details[].colour)\"",
      ".data[] as {$fruit, details: {$colour}} ?// {$fruit, details: [{$colour}]} | \"\\($fruit) - \\($colour)\"",
      "One way to generate the output you expect is by using `? //` rather than `?//`:",
      ".data[] | (.details | (.colour? // (.[] | .colour))) as $colour | \"\\(.fruit) - \\($colour)\""
    ],
    "utterance": "Output lines of the form \"fruit - colour\" for each object, handling cases where \"details\" is a single object or an array of objects, such that all colours are listed.",
    "expressions": [
      ".data[] | (.details | (.colour? // (.[] | .colour))) as $colour | \"\\(.fruit) - \\($colour)\""
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "fruit": "orange",
              "details": {
                "colour": "orange"
              }
            },
            {
              "fruit": "apple",
              "details": [
                {
                  "colour": "red"
                },
                {
                  "colour": "green"
                }
              ]
            }
          ]
        },
        "output": [
          "orange - orange",
          "apple - red",
          "apple - green"
        ]
      }
    ],
    "identifier": 64700815
  },
  {
    "context": [
      "I am looking to grab the email address only from the records with the UserStatus = FORCE_CHANGE_PASSWORD.",
      "Since you indicate you only want the email address, you will probably want something closer to:",
      ".Users[]\n| select(.UserStatus | contains(\"FORCE_CHANGE_PASSWORD\"))\n| {UserStatus, email: (.Attributes | from_entries.email) }",
      "Or for just the value of .email:",
      ".Users[]\n| select(.UserStatus | contains(\"FORCE_CHANGE_PASSWORD\"))\n| .Attributes[]\n| select(.Name == \"email\").Value"
    ],
    "utterance": "Extract the email address from users whose UserStatus is FORCE_CHANGE_PASSWORD.",
    "expressions": [
      ".Users[] | select(.UserStatus == \"FORCE_CHANGE_PASSWORD\") | {UserStatus, email: (.Attributes | from_entries.email) }",
      ".Users[] | select(.UserStatus == \"FORCE_CHANGE_PASSWORD\") | .Attributes[] | select(.Name == \"email\").Value",
      ".Users[] | select(.UserStatus | contains(\"FORCE_CHANGE_PASSWORD\")) | {UserStatus, email: (.Attributes | from_entries.email) }",
      ".Users[] | select(.UserStatus | contains(\"FORCE_CHANGE_PASSWORD\")) | .Attributes[] | select(.Name == \"email\").Value"
    ],
    "data": [
      {
        "input": {
          "Users": [
            {
              "Username": "",
              "Attributes": [
                {
                  "Name": "sub",
                  "Value": ""
                },
                {
                  "Name": "email_verified",
                  "Value": "true"
                },
                {
                  "Name": "email",
                  "Value": "john@example.com"
                }
              ],
              "UserCreateDate": "",
              "UserLastModifiedDate": "",
              "Enabled": true,
              "UserStatus": "CONFIRMED"
            },
            {
              "Username": "",
              "Attributes": [
                {
                  "Name": "sub",
                  "Value": ""
                },
                {
                  "Name": "email_verified",
                  "Value": "true"
                },
                {
                  "Name": "email",
                  "Value": "jane@example.com"
                }
              ],
              "UserCreateDate": "",
              "UserLastModifiedDate": "",
              "Enabled": true,
              "UserStatus": "FORCE_CHANGE_PASSWORD"
            }
          ]
        },
        "output": {
          "UserStatus": "FORCE_CHANGE_PASSWORD",
          "email": "jane@example.com"
        }
      },
      {
        "input": {
          "Users": [
            {
              "Username": "",
              "Attributes": [
                {
                  "Name": "sub",
                  "Value": ""
                },
                {
                  "Name": "email_verified",
                  "Value": "true"
                },
                {
                  "Name": "email",
                  "Value": "john@example.com"
                }
              ],
              "UserCreateDate": "",
              "UserLastModifiedDate": "",
              "Enabled": true,
              "UserStatus": "CONFIRMED"
            },
            {
              "Username": "",
              "Attributes": [
                {
                  "Name": "sub",
                  "Value": ""
                },
                {
                  "Name": "email_verified",
                  "Value": "true"
                },
                {
                  "Name": "email",
                  "Value": "jane@example.com"
                }
              ],
              "UserCreateDate": "",
              "UserLastModifiedDate": "",
              "Enabled": true,
              "UserStatus": "FORCE_CHANGE_PASSWORD"
            }
          ]
        },
        "output": "jane@example.com"
      }
    ],
    "identifier": 64709503
  },
  {
    "context": [
      "How I can via jq merge same keys  values in the two file json and in addiction to the merge operation remove from file1 keys the values non present in file2 ?",
      "jq --slurpfile s 2.json '\n  .list_1 as $l1  |\n  .list_2 as $l2  |\n  ( ( $l1 - ( $l1 - $s[].list_1 ) ) +  $s[].list_1 | unique ) as $f1 |\n  ( ( $l2 - ( $l2 - $s[].list_2 ) ) +  $s[].list_2 | unique ) as $f2 |\n  .list_1 |= $f1 |\n  .list_2 |= $f2\n' 1.json"
    ],
    "utterance": "For fields with the same key in two objects, create the union of their array values, but remove any values from the first object that are not present in the second object, and include all unique values from the second object.",
    "expressions": [
      ".list_1 as $l1  |\n.list_2 as $l2  |\n( ( $l1 - ( $l1 - $s[].list_1 ) ) +  $s[].list_1 | unique ) as $f1 |\n( ( $l2 - ( $l2 - $s[].list_2 ) ) +  $s[].list_2 | unique ) as $f2 |\n.list_1 |= $f1 |\n.list_2 |= $f2"
    ],
    "data": [
      {
        "input": {
          "id": "001",
          "name": "my_policy",
          "list_1": [
            "111111111",
            "22222222",
            "33333333"
          ],
          "list_2": [
            "a",
            "b",
            "c"
          ]
        },
        "output": {
          "id": "001",
          "name": "my_policy",
          "list_1": [
            "111111111",
            "111111122",
            "33333333"
          ],
          "list_2": [
            "a",
            "b",
            "c",
            "d",
            "e"
          ]
        }
      }
    ],
    "identifier": 64719770
  },
  {
    "context": [
      "I want to use JQ or some other bash json processing tool that can merge these json files into one file with a grouped format like so:",
      "[{ \"host\" : \"127.0.0.1\", \"data\": {\"80\": {}, \"443\" : {}}},\n{ \"host\" : \"127.0.0.2\", \"data\": {\"502\": {}}}]",
      "$ jq '. ' file*.jsonl -s  | jq  'group_by(.host)[]|{ host:.[0].host, data:(map( { (.port): {} } ))|add }' | jq '. ' -s",
      "Finally, we can display the results in compact format (one object by line) with the parameter (-c):",
      "$ jq '. ' file*.jsonl -s  | jq  'group_by(.host)[]|{ host:.[0].host ,data:( map({(.port):{} })|add ) }' -c",
      "If you want the results in compact format all into an array, only add jq '. ' -s -c  to the pipe:",
      "$ jq '. ' file*.jsonl -s  | jq  'group_by(.host)[]|{ host:.[0].host ,data:( map({(.port):{} })|add ) }' -c | jq '. ' -s -c",
      "[{\"host\":\"127.0.0.1\",\"data\":{\"80\":{},\"443\":{}}},{\"host\":\"127.0.0.2\",\"data\":{\"502\":{}}}]"
    ],
    "utterance": "Group multiple files by host; for each host, create an object where 'data' is a map from port numbers to empty objects.",
    "expressions": [
      "jq '. ' file*.jsonl -s | jq 'group_by(.host)[] | { host: .[0].host , data: (map({(.port): {}}) | add) }' | jq '. ' -s",
      "jq '. ' file*.jsonl -s | jq 'group_by(.host)[] | { host: .[0].host , data: (map({(.port): {}}) | add) }' -c | jq '. ' -s -c"
    ],
    "data": [
      {
        "input": [
          {
            "host": "127.0.0.1",
            "port": "80",
            "data": {}
          },
          {
            "host": "127.0.0.2",
            "port": "502",
            "data": {}
          },
          {
            "host": "127.0.0.1",
            "port": "443",
            "data": {}
          }
        ],
        "output": [
          {
            "host": "127.0.0.1",
            "data": {
              "80": {},
              "443": {}
            }
          },
          {
            "host": "127.0.0.2",
            "data": {
              "502": {}
            }
          }
        ]
      }
    ],
    "identifier": 64677102
  },
  {
    "context": [
      "Ideal output would be filtered by two columns - **nameColumn**, **infoColumn** - with each row being a single line of the values.",
      "Output example - \n\n```\n{ \n  \"name\": \"name1\",\n  \"info\": \"info1\"\n}\n{\n  \"name\": \"name2\",\n  \"info\": \"info2\"\n}\n{ \n  \"name\": \"name3\",\n  \"info\": \"info3\"\n}\n```",
      "The final output would ideally be a csv for the selected columns values\n\n```\nname1,info1\nname2,info2\n```",
      "One way would be to use `@csv` with the -r command-line option, e.g. with:\n\n```.rows[].cells\n| map(select(.columnId==\"nameColumn\" or .columnId==\"infoColumn\")\n      | {(.columnId): .value} )\n| add\n| [.nameColumn, .infoColumn]\n| @csv\n```"
    ],
    "utterance": "For each row, extract the values from columns with columnId equal to nameColumn and infoColumn, and output each as a CSV line containing the two values.",
    "expressions": [
      ".rows[].cells | map(select(.columnId==\"nameColumn\" or .columnId==\"infoColumn\") | {(.columnId): .value}) | add | [.nameColumn, .infoColumn] | @csv"
    ],
    "data": [
      {
        "input": {
          "rows": [
            {
              "id": 409363222161284,
              "rowNumber": 1,
              "cells": [
                {
                  "columnId": "nameColumn",
                  "value": "name1"
                },
                {
                  "columnId": "infoColumn",
                  "value": "info1"
                },
                {
                  "columnId": "excessColumn",
                  "value": "excess1"
                }
              ]
            },
            {
              "id": 11312541213,
              "rowNumber": 2,
              "cells": [
                {
                  "columnId": "nameColumn",
                  "value": "name2"
                },
                {
                  "columnId": "infoColumn",
                  "value": "info2"
                },
                {
                  "columnId": "excessColumn",
                  "value": "excess2"
                }
              ]
            },
            {
              "id": 11312541213,
              "rowNumber": 3,
              "cells": [
                {
                  "columnId": "nameColumn",
                  "value": "name3"
                },
                {
                  "columnId": "infoColumn",
                  "value": "info3"
                },
                {
                  "columnId": "excessColumn",
                  "value": "excess3"
                }
              ]
            }
          ]
        },
        "output": [
          "name1,info1",
          "name2,info2",
          "name3,info3"
        ]
      }
    ],
    "identifier": 64711904
  },
  {
    "identifier": 64748758
  },
  {
    "context": [
      "I'm trying to convert a json object into csv via jq. The following is the sample structure:",
      "Tried with ```jq -r '. | @csv' output2.json > output.csv``` but it returns ```jq: error (at output2.json:9486): array ([\"269713188...) is not valid in a csv row```",
      "You need to use `flatten` to explode/flatten the arrays first, before you can store the data as CSV. This will create a record for each element of the array.",
      "jq -r 'flatten | @csv' output2.json"
    ],
    "utterance": "Convert an array of two-element arrays, where the second element may itself be an array, into CSV lines with one line per element, flattening inner arrays.",
    "expressions": [
      "flatten | @csv"
    ],
    "data": [
      {
        "input": [
          [
            "193.176.211.70",
            [
              "2697131889764497b2beef1bac8e742d"
            ]
          ],
          [
            "193.176.211.70",
            [
              "2697131889764497b2beef1bac8e742d"
            ]
          ],
          [
            "205.169.39.30",
            []
          ],
          [
            "65.155.30.101",
            []
          ],
          [
            "45.64.241.129",
            [
              "2697131889764497b2beef1bac8e742d"
            ]
          ],
          [
            "45.64.241.129",
            [
              "2697131889764497b2beef1bac8e742d"
            ]
          ]
        ],
        "output": [
          "\"193.176.211.70\",\"2697131889764497b2beef1bac8e742d\"",
          "\"193.176.211.70\",\"2697131889764497b2beef1bac8e742d\"",
          "\"205.169.39.30\"",
          "\"65.155.30.101\"",
          "\"45.64.241.129\",\"2697131889764497b2beef1bac8e742d\"",
          "\"45.64.241.129\",\"2697131889764497b2beef1bac8e742d\""
        ]
      }
    ],
    "identifier": 64727825
  },
  {
    "context": [
      ".data.viewer.zones[] | .httpRequests1mGroups[0].sum|with_entries(select(.key|endswith(\"Map\")|not))  + {\"zoneTag\": .zoneTag}",
      "and got this result:",
      "{\n  \"bytes\": 2875120330,\n  \"cachedBytes\": 1475518778,\n  \"zoneTag\": null\n}",
      ".data.viewer.zones[] |  {\"zoneTag\": .zoneTag} +   .httpRequests1mGroups[0].sum|with_entries(select(.key|endswith(\"Map\")|not))",
      "and get what I expected:",
      "{\n  \"zoneTag\": \"zone 1\",\n  \"bytes\": 2875120330,\n  \"cachedBytes\": 1475518778,\n}",
      "So maybe you're looking for an explanation in terms of operator precedence.",
      "in the first case, {zoneTag} gets its value from B but in the\nsecond case, it comes from A."
    ],
    "utterance": "For each element, produce an object that includes the zoneTag property from the outer object alongside selected properties from the httpRequests1mGroups[0].sum object, excluding any keys ending with 'Map'.",
    "expressions": [
      ".data.viewer.zones[] | {\"zoneTag\": .zoneTag} + (.httpRequests1mGroups[0].sum | with_entries(select(.key|endswith(\"Map\")|not)))"
    ],
    "identifier": 64733252
  },
  {
    "context": [
      "how do I select that it will run only over _id:1 / db_name: postgres?",
      "An efficient approach would be based on using `any`, e.g. along the lines of the following:",
      "jq --arg db $database --argjson Today $Today '\n    select(.db_name==$db and\n           any(.daily[], .monthly[], .yearly[]; . == $Today) ) \n' file.json"
    ],
    "utterance": "For a given database name, check if today's value exists in any of the daily, monthly, or yearly days_to_backup arrays for that database entry.",
    "expressions": [
      "jq --arg db \"$database\" --argjson Today \"$Today\" 'select(.db_name==$db and (any(.daily.days_to_backup[]; . == $Today) or any(.monthly.days_to_backup[]; . == $Today) or any(.yearly.days_to_backup[]; . == $Today)))' file.json"
    ],
    "data": [
      {
        "input": {
          "_id": 1,
          "db_name": "postgres",
          "username": "postgres_user",
          "password": "postgres_pass",
          "daily": {
            "days_to_backup": [
              1,
              2
            ],
            "delete_after": 14,
            "compressed": true,
            "path": "localhost"
          },
          "monthly": {
            "days_to_backup": [
              2,
              5,
              30
            ],
            "delete_after": 7,
            "compressed": false,
            "path": " localhost"
          },
          "yearly": {
            "days_to_backup": [
              100
            ],
            "delete_after": 14,
            "compressed": true,
            "path": "localhost"
          }
        },
        "output": "if $database == 'postgres' and $Today == 2, then the above object is returned"
      }
    ],
    "identifier": 64739344
  },
  {
    "context": [
      "And this array [\"Bo\", \"Al\"]",
      "How do I loop through the array to check the json file for those students only and output their {Name, Grade}?",
      "Note: Edited to ask how to do this for substrings, like \"Bo\" and \"Al\" for \"Bob\" and \"Alice\".",
      "Or alternatively use the any/2 function",
      "jq --argjson names '[\"Bob\", \"Alice\"]' '\n map(select( .Name as $a | any( $names[]; . == $a) ))' json"
    ],
    "utterance": "Find and output all objects whose Name field contains any of the substrings \"Bo\" or \"Al\".",
    "expressions": [
      "[\"Bo\", \"Al\"] as $subs | map(select(.Name | any($subs[]; contains(.))))"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "Bob",
            "Grade": "Pass"
          },
          {
            "Name": "Alice",
            "Grade": "Fail"
          },
          {
            "Name": "Mallory",
            "Grade": "Fail"
          }
        ],
        "output": [
          {
            "Name": "Bob",
            "Grade": "Pass"
          },
          {
            "Name": "Alice",
            "Grade": "Fail"
          }
        ]
      }
    ],
    "identifier": 64749621
  },
  {
    "context": [
      "paths=$(jq '.paths | to_entries | map(select(.value[].tags | index(\"Filter\"))) | from_entries' input.json)",
      "jq --argjson prefix \"$paths\" '.paths=$prefix' input.json > output.json",
      "But this ^ fails as $paths has a very high line count (order of 100,000).",
      "In general, assuming your jq allows it, you could use `\u2014argfile` or `\u2014slurpfile` but in your case you can simply avoid the issue by invoking jq just once instead of twice.",
      ".paths |= ( to_entries | map(select(.value[].tags | index(\"Filter\"))) | from_entries)",
      "or better yet, use `with_entries`."
    ],
    "utterance": "Replace the paths object with only those entries whose value's tags array contains \"Filter\".",
    "expressions": [
      ".paths |= ( to_entries | map(select(.value[].tags | index(\"Filter\"))) | from_entries )"
    ],
    "identifier": 64785337
  },
  {
    "context": [
      "I want the output to have a list of targets that share the same labels.",
      "group_by(.labels)\n| map( { labels: (.[0].labels),\n         targets: (map(.targets)|add)} )"
    ],
    "utterance": "Group the objects by 'labels' value and combine the 'targets' arrays for each group.",
    "expressions": [
      "group_by(.labels)\n| map( { labels: (.[0].labels), targets: (map(.targets)|add)} )"
    ],
    "data": [
      {
        "input": [
          {
            "targets": [
              "host1"
            ],
            "labels": {
              "platform": "VMware",
              "os": "Windows",
              "datacenter": "dc1",
              "environment": "Production"
            }
          },
          {
            "targets": [
              "host2"
            ],
            "labels": {
              "platform": "VMware",
              "os": "Windows",
              "datacenter": "dc1",
              "environment": "Production"
            }
          },
          {
            "targets": [
              "host3"
            ],
            "labels": {
              "platform": "VMware",
              "os": "Windows",
              "datacenter": "dc2",
              "environment": "Production"
            }
          }
        ],
        "output": [
          {
            "targets": [
              "host1",
              "host2"
            ],
            "labels": {
              "platform": "VMware",
              "os": "Windows",
              "datacenter": "dc1",
              "environment": "Production"
            }
          },
          {
            "targets": [
              "host3"
            ],
            "labels": {
              "platform": "VMware",
              "os": "Windows",
              "datacenter": "dc2",
              "environment": "Production"
            }
          }
        ]
      }
    ],
    "identifier": 64746372
  },
  {
    "context": [
      "Executing the following jq command works fine on Mac OS Catalina (jq version 1.6) :",
      "echo $(jq '.paths | to_entries | map(select(.value[].tags | index(\"Tag123\"))) | from_entries' custom.json)",
      "However executing it on CentOS (CentOS release 6.9 (Final)) (jq version 1.3) returns the following error :",
      "error: index is not defined",
      "If you are absolutely stuck with jq 1.3, you could use contains/1 if you don't need the integer index."
    ],
    "utterance": "Filter entries where any tag equals \"Tag123\" in each value's tag array under paths, even on jq 1.3 where index() is unavailable.",
    "expressions": [
      ".paths | to_entries | map(select(.value[].tags | index(\"Tag123\"))) | from_entries",
      ".paths | to_entries | map(select(.value[].tags | contains([\"Tag123\"]))) | from_entries"
    ],
    "identifier": 64764896
  },
  {
    "context": [
      "I would like to divide the `\"throughput (K tps)\"` field in each object by 1000 and return the array in the same format.",
      "Should edit each `throughput (K tps)` by dividing it by 1000.",
      "You can use the [Update-assignment][1] operator\n\n```jq\nmap(.\"throughput (K tps)\" |= . / 1000)\n```",
      "But `jq` gives you much more to do [Arithmetic update assignments][2] of form `+=`, `*=` and also `/=`, so that you can do\n\n```jq\nmap(.\"throughput (K tps)\" /= 1000)\n```"
    ],
    "utterance": "Divide the field \"throughput (K tps)\" in every object of the array by 1000 and return the modified array of objects.",
    "expressions": [
      ".[] | .\"throughput (K tps)\" |= . / 1000",
      ".[].\"throughput (K tps)\" |= . / 1000",
      "map(.\"throughput (K tps)\" |= . / 1000)",
      "map(.\"throughput (K tps)\" /= 1000)"
    ],
    "data": [
      {
        "input": [
          {
            "impl": "pmdk",
            "pc_writes": 50,
            "threads": 1,
            "throughput (K tps)": 703014,
            "med_latency (ns)": 1334,
            "99_latency (ns)": 2358,
            "exec_time (s)": 14224471006
          }
        ],
        "output": [
          {
            "impl": "pmdk",
            "pc_writes": 50,
            "threads": 1,
            "throughput (K tps)": 703.014,
            "med_latency (ns)": 1334,
            "99_latency (ns)": 2358,
            "exec_time (s)": 14224471006
          }
        ]
      }
    ],
    "identifier": 64755461
  },
  {
    "context": [
      "I just want to update the value of **firstName**.",
      "End result I want is",
      "{ \"content\": \"{\\\"accountNumber\\\":\\\"12345\\\",\\\"transactionId\\\":\\\"568\\\",\\\"socialSecurityNumber\\\":\\\"123456796\\\",\\\"identificationNumber\\\":1,\\\"securityCode\\\":\\\"1234\\\",\\\"dateOfBirth\\\":\\\"1000-01-01\\\",\\\"firstName\\\":\\\"abcdef\\\",\\\"lastName\\\":\\\"xyz\\\",\\\"balance\\\":123}\", \"contentType\": \"application/json\", \"createdAt\": \"2020-11-11T12:55:41.350+0000\", \"cryptoKeyId\": null }",
      "I tried this ( .content | fromjson.firstName = \"abcdef\" ) but no success.",
      "Since you want to update the value, you would use `|=`, and don\u2019t forget the call to `tojson`:",
      ".content |= (fromjson | (.firstName = \"abcdef\") | tojson)"
    ],
    "utterance": "Update the value of firstName to \"abcdef\" in the content field, where content is a stringified object inside the main object.",
    "expressions": [
      ".content |= (fromjson | (.firstName = \"abcdef\") | tojson)"
    ],
    "data": [
      {
        "input": {
          "content": "{\"accountNumber\":\"12345\",\"transactionId\":\"568\",\"socialSecurityNumber\":\"123456796\",\"identificationNumber\":1,\"securityCode\":\"1234\",\"dateOfBirth\":\"1000-01-01\",\"firstName\":\"qwerty\",\"lastName\":\"xyz\",\"balance\":123}",
          "contentType": "application/json",
          "createdAt": "2020-11-11T12:55:41.350+0000",
          "cryptoKeyId": null
        },
        "output": {
          "content": "{\"accountNumber\":\"12345\",\"transactionId\":\"568\",\"socialSecurityNumber\":\"123456796\",\"identificationNumber\":1,\"securityCode\":\"1234\",\"dateOfBirth\":\"1000-01-01\",\"firstName\":\"abcdef\",\"lastName\":\"xyz\",\"balance\":123}",
          "contentType": "application/json",
          "createdAt": "2020-11-11T12:55:41.350+0000",
          "cryptoKeyId": null
        }
      }
    ],
    "identifier": 64787692
  },
  {
    "context": [
      "I want to select on a number that is greater than or equal to 2 and for that selection I want to return the values of `id` and `number`.",
      "Now I would also like to return a higher level key for my selection, in my case I need to return `c`.",
      "Assuming you want the string `\"c\"` instead of `2` in the output, this will work:",
      "jq '.data[] | .id as $ID | .info | to_entries[] | select(.value.number >= 2) | [$ID, .key]' input.json"
    ],
    "utterance": "For each object where a number is greater than or equal to 2, return both the object's id and the key that contains the matching number.",
    "expressions": [
      ".data[] | .id as $ID | .info | to_entries[] | select(.value.number >= 2) | [$ID, .key]"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "1a2b3c",
              "info": {
                "a": {
                  "number": 0
                },
                "b": {
                  "number": 1
                },
                "c": {
                  "number": 2
                }
              }
            }
          ]
        },
        "output": [
          [
            "1a2b3c",
            "c"
          ]
        ]
      }
    ],
    "identifier": 64806010
  },
  {
    "context": [
      "I want to replace null values of a specific key value pair with the value of the 0th array index. In the example below I want for array elements 1 to contain \"website\" and \"email\" of the \"email\" and \"website\" of the 0th array element because they are both null. For element 2 I only expect the \"website\" to be set with the result of the 0th array element as only that is null.",
      "jq '. as $orig | .offices |= map(.website //= $orig.offices[0].website | .email //= $orig.offices[0].email)' input.json"
    ],
    "utterance": "Replace null values of website and email in array elements with the values from the first element in the array.",
    "expressions": [
      ". as $orig | .offices |= map(.website //= $orig.offices[0].website | .email //= $orig.offices[0].email)"
    ],
    "data": [
      {
        "input": {
          "id": 123,
          "offices": [
            {
              "officeId": 12345,
              "name": "Name LLP",
              "website": "www.example.com",
              "email": "website@example.com",
              "officeType": "HO"
            },
            {
              "officeId": 123456,
              "name": "Name",
              "website": null,
              "email": null,
              "officeType": "BRANCH"
            },
            {
              "officeId": 1234567,
              "name": "Name",
              "website": null,
              "email": "example@website.com",
              "officeType": "BRANCH"
            }
          ]
        },
        "output": {
          "id": 123,
          "offices": [
            {
              "officeId": 12345,
              "name": "Name LLP",
              "website": "www.example.com",
              "email": "website@example.com",
              "officeType": "HO"
            },
            {
              "officeId": 123456,
              "name": "Name",
              "website": "www.example.com",
              "email": "website@example.com",
              "officeType": "BRANCH"
            },
            {
              "officeId": 1234567,
              "name": "Name",
              "website": "www.example.com",
              "email": "example@website.com",
              "officeType": "BRANCH"
            }
          ]
        }
      }
    ],
    "identifier": 64803904
  },
  {
    "identifier": 64815926
  },
  {
    "context": [
      "I would like the following format.\n\n{\n    \"field1\" : [Mazda RX4 ,Mazda RX4 Wag,Datsun 710],    \n    \"mpg\" : [21,21,22.8],    \n    \"cyl\" : [6,6,6],        \n    \"disp\" : [160,160,108],    \n   ...\n}",
      "Here\u2019s a concise, efficient, and conceptually simple solution based on just `map` and `reduce`:\n```\n. as $in\n| reduce (.[0] | keys_unsorted[]) as $k ( {}; .[$k] = ($in|map(.[$k])))\n```\n\n## Converting all number-valued strings to numbers\n```\n. as $in\n| reduce (.[0] | keys_unsorted[]) as $k ( {}; \n    .[$k] = ($in|map(.[$k] | (tonumber? // .))))\n```"
    ],
    "utterance": "Transpose an array of objects so that each key maps to an array of its values, with numeric columns represented as numbers when possible.",
    "expressions": [
      ". as $in | reduce (.[0] | keys_unsorted[]) as $k ( {}; .[$k] = ($in|map(.[$k])))",
      ". as $in | reduce (.[0] | keys_unsorted[]) as $k ( {}; .[$k] = ($in|map(.[$k] | (tonumber? // .))))"
    ],
    "data": [
      {
        "input": [
          {
            "field1": "Mazda RX4",
            "mpg": "21",
            "cyl": "6",
            "disp": "160",
            "hp": "110",
            "drat": "3.9",
            "wt": "2.62",
            "qsec": "16.46",
            "vs": "0",
            "am": "1",
            "gear": "4",
            "carb": "4"
          },
          {
            "field1": "Mazda RX4 Wag",
            "mpg": "21",
            "cyl": "6",
            "disp": "160",
            "hp": "110",
            "drat": "3.9",
            "wt": "2.875",
            "qsec": "17.02",
            "vs": "0",
            "am": "1",
            "gear": "4",
            "carb": "4"
          },
          {
            "field1": "Datsun 710",
            "mpg": "22.8",
            "cyl": "4",
            "disp": "108",
            "hp": "93",
            "drat": "3.85",
            "wt": "2.32",
            "qsec": "18.61",
            "vs": "1",
            "am": "1",
            "gear": "4",
            "carb": "1"
          }
        ],
        "output": {
          "field1": [
            "Mazda RX4",
            "Mazda RX4 Wag",
            "Datsun 710"
          ],
          "mpg": [
            21,
            21,
            22.8
          ],
          "cyl": [
            6,
            6,
            4
          ],
          "disp": [
            160,
            160,
            108
          ],
          "hp": [
            110,
            110,
            93
          ],
          "drat": [
            3.9,
            3.9,
            3.85
          ],
          "wt": [
            2.62,
            2.875,
            2.32
          ],
          "qsec": [
            16.46,
            17.02,
            18.61
          ],
          "vs": [
            0,
            0,
            1
          ],
          "am": [
            1,
            1,
            1
          ],
          "gear": [
            4,
            4,
            4
          ],
          "carb": [
            4,
            4,
            1
          ]
        }
      }
    ],
    "identifier": 64778327
  },
  {
    "context": [
      "How would you calculate the median (P50) of an array using jq? The jq manual describes how to calculate the mean, but I'd like to get the median.",
      "Algorithm: Given a list of numbers, sort it. If there are an odd number of entries then pick the middle one. If there are an even number of entries then calculate the mean of the middle two.",
      "echo '[1,5,9,3]' | jq <ANSWER>  # should output 4, since it's the mean of 3 and 5",
      "echo '[1,9,2]' | jq <ANSWER>  # should output 2, since it's the middle element",
      "echo '[]' | jq <ANSWER>  # undefined",
      "sort |\n  if length == 0 then null\n  elif length % 2 == 0 then (.[length/2] + .[length/2-1])/2\n  else .[length/2|floor] end",
      "sort | [ .[length/2 | ceil | -.,.-1] /2? ] | add"
    ],
    "utterance": "Calculate the median value of an array: if even number of elements, return the mean of the two middle values; if odd, return the middle value; for empty array, return null.",
    "expressions": [
      "sort | if length == 0 then null elif length % 2 == 0 then (.[length/2] + .[length/2-1])/2 else .[length/2|floor] end",
      "sort | [ .[length/2 | ceil | -.,.-1] /2? ] | add"
    ],
    "data": [
      {
        "input": [
          1,
          5,
          9,
          3
        ],
        "output": 4
      },
      {
        "input": [
          1,
          9,
          2
        ],
        "output": 2
      },
      {
        "input": [],
        "output": null
      }
    ],
    "identifier": 64809334
  },
  {
    "context": [
      "So for example: \r\n\r\n    {\r\n      \"items\": [\r\n        { \"id\": 1, \"other\": \"abc\"},\r\n        { \"id\": 2, \"other\": \"def\"},\r\n        { \"id\": 3, \"other\": \"ghi\"}\r\n      ]\r\n    }\r\n\r\nand say, that i'd like to duplicate record having id == 2, and replace char `e` in `other` field with char `x` using regex.",
      "jq '.items |= . + [.[]|select (.id == 2) as $orig | .id=4 | .other=($orig.other | sub(\"e\";\"x\"))]' <sample.json",
      "But suppose, that there ins't just one `other` field. There are multitude of them, and over deep tree. ...maybe we can turn the whole JSON subtree to string (trivial, tostring method) and replace all occurences using singe sub call. But how to turn that substituted string back to \u2014 is it call object? \u2014 to be able to add it back to items array?",
      "Note in particular that there is no explicit reference to a field named \"other\", and that (thanks to `walk`) the update function is applied to all candidate JSON objects in the input.",
      "walk(if type == \"object\" and has(\"items\") then update(2) else . end)"
    ],
    "utterance": "Duplicate the object in all 'items' arrays where id == 2 and, for all non-id fields in the duplicate, replace occurrences of 'e' with 'x', applying this transformation to every relevant subtree in the object.",
    "expressions": [
      "def update($n):\n  if .items | length > 0\n  then ((.items[0]|keys_unsorted) - [\"id\"]) as $keys\n  | if ($keys | length) == 1 \n    then $keys[0] as $key\n    | (.items|map(.id) | max + 1) as $newid\n    | .items |= . + [.[] | select(.id == $n) as $orig | .id=$newid | .[$key]=($orig[$key] | sub(\"e\";\"x\"))]\n    else .\n    end\n  else .\n  end;\n\nwalk(if type == \"object\" and has(\"items\") then update(2) else . end)"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "id": 1,
              "other": "abc"
            },
            {
              "id": 2,
              "other": "def"
            },
            {
              "id": 3,
              "other": "ghi"
            }
          ]
        },
        "output": {
          "items": [
            {
              "id": 1,
              "other": "abc"
            },
            {
              "id": 2,
              "other": "def"
            },
            {
              "id": 3,
              "other": "ghi"
            },
            {
              "id": 4,
              "other": "dxf"
            }
          ]
        }
      }
    ],
    "identifier": 64804111
  },
  {
    "context": [
      "get all the policy names in account",
      "get the policy version for each of the above policies",
      "aws iam list-policies |\n  jq -r '.Policies[] | \"\\(.PolicyName) \\(.Arn) \\(.DefaultVersionId)\"' |",
      "The jq filter will print all name, arn, version of one policy per line"
    ],
    "utterance": "Extract the policy name, arn, and default version id for each policy in the account.",
    "expressions": [
      ".Policies[] | \"\u001b[.PolicyName] [\u001b[.Arn] [\u001b[.DefaultVersionId]\"",
      ".Policies[] | \"\\(.PolicyName) \\(.Arn) \\(.DefaultVersionId)\""
    ],
    "identifier": 64818664
  },
  {
    "context": [
      "I am trying to get .metadata.namespace using jq from the following json object",
      "if following condition is met:",
      ".spec.components[].type == \"jobmanager\" and .spec.components[].image != \"test.com/jobmanager:1.1.1\"",
      "you could use any, so that your query would look like this:",
      ".items[]\n| select( any(.spec.components[];\n              (.name? | contains(\"jobmanager01\")) and\n              .image != \"test.com/jobmanager:1.1.1\") )\n| .metadata.namespace",
      "If you want all the distinct .namespace values satisfying the condition, you could go with:",
      "[.items[]\n | .metadata.namespace as $it\n | .spec.components[]\n | select( (.name? | contains(\"jobmanager01\")) and\n          .image != \"test.com/jobmanager:1.1.1\" )\n | $it]\n| unique[]",
      "Efficient version of \"all-distinct\" solution",
      "reduce .items[] as $item ({};\n   $item.metadata.namespace as $it\n   | if .[$it] then .   # already seen\n     elif any( $item.spec.components[];\n               ((.name? | contains(\"jobmanager01\")) and\n               .image != \"test.com/jobmanager:1.1.1\") )\n     then .[$it] = true\n     else . end )\n| keys_unsorted[]"
    ],
    "utterance": "Return the namespace of any item where at least one component's name contains \"jobmanager01\" and its image is not \"test.com/jobmanager:1.1.1\".",
    "expressions": [
      ".items[] | select(any(.spec.components[]; (.name? | contains(\"jobmanager01\")) and .image != \"test.com/jobmanager:1.1.1\")) | .metadata.namespace",
      "[.items[] | .metadata.namespace as $it | .spec.components[] | select((.name? | contains(\"jobmanager01\")) and .image != \"test.com/jobmanager:1.1.1\") | $it] | unique[]",
      "reduce .items[] as $item ({};\n   $item.metadata.namespace as $it\n   | if .[$it] then .\n     elif any($item.spec.components[]; ((.name? | contains(\"jobmanager01\")) and .image != \"test.com/jobmanager:1.1.1\"))\n     then .[$it] = true\n     else . end )\n| keys_unsorted[]"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "app",
                "namespace": "test1"
              },
              "spec": {
                "components": [
                  {
                    "database": {
                      "from": "service",
                      "value": "redis"
                    },
                    "image": "test.com/lockmanager:1.1.1",
                    "name": "lockmanager01",
                    "replicas": 2,
                    "type": "lockmanager"
                  },
                  {
                    "database": {
                      "from": "service",
                      "value": "postgresql"
                    },
                    "image": "test.com/jobmanager:1.1.1",
                    "name": "jobmanager01",
                    "replicas": 2,
                    "type": "jobmanager"
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 64795033
  },
  {
    "context": [
      "`range(2;5)` producing: 2 3 4 ... However for imperative-style programmer is only matter of time, when he will mistakenly separate parameters by comma (actually I misread the manual, so this was my first attempt), and try template: range(2, 5) producing surprising: 0 1 0 1 2 3 4",
      "The \"comma\" operator (as in `2,5`) produces a stream. So `2,5` emits two integers, which is why `[2,5]` evaluates to an array of two integers.",
      "For the rare functions like `range` and `sub` that take more than one explicit argument, the semicolon is used as a separator, not the comma."
    ],
    "utterance": "Produce the numbers 2, 3, and 4 using a function that starts from 2 up to (but not including) 5.",
    "expressions": [
      "range(2;5)"
    ],
    "data": [
      {
        "input": null,
        "output": [
          2,
          3,
          4
        ]
      }
    ],
    "identifier": 64827742
  },
  {
    "context": [
      "I would like to use jq to take the value of \"capital\" from File 2 and merge it with File 1 for each element where the same \"name\"-value pair occurs. Otherwise, the element from File 2 should not occur in the output. If there is no \"name\"-value pair for an element in File 1, it should have empty text for \"capital.\"",
      "$ jq --slurpfile file2 file2.json '\n   { countries:\n      [ .countries[] |\n        . as $curr |\n        $curr + { capital: (($file2[0].countries[] | select(.name == $curr.name) | .capital) // \"\") }\n      ]\n    }' file1.json",
      "$ jq -n '{ countries: ([inputs] | map(.countries) | flatten | group_by(.name) |\n                        map(select(.[] | has(\"continent\")) | add | .capital //= \"\"))\n          }' file[12].json",
      "jq --argfile dict File2.json '\n  ($dict.countries | map( {(.name): .capital}) | add) as $capitals\n  | .countries |= map( .capital = ($capitals[.name] // \"\"))\n' File2.json "
    ],
    "utterance": "For each country in the first file, add the capital from the second file where the names match, or set capital to an empty string if there is no match.",
    "expressions": [
      "--slurpfile file2 file2.json '{ countries: [ .countries[] | . as $curr | $curr + { capital: (($file2[0].countries[] | select(.name == $curr.name) | .capital) // \"\") } ] }'",
      "-n '{ countries: ([inputs] | map(.countries) | flatten | group_by(.name) | map(select(.[] | has(\"continent\")) | add | .capital //= \"\")) }' file[12].json",
      "--argfile dict File2.json '($dict.countries | map( {(.name): .capital}) | add) as $capitals | .countries |= map( .capital = ($capitals[.name] // \"\")) '"
    ],
    "data": [
      {
        "input": {
          "countries": [
            {
              "name": "china",
              "continent": "asia"
            },
            {
              "name": "france",
              "continent": "europe"
            }
          ]
        }
      },
      {
        "input": {
          "countries": [
            {
              "name": "china",
              "capital": "beijing"
            },
            {
              "name": "argentina",
              "capital": "buenos aires"
            }
          ]
        }
      },
      {
        "output": {
          "countries": [
            {
              "name": "china",
              "continent": "asia",
              "capital": "beijing"
            },
            {
              "name": "france",
              "continent": "europe",
              "capital": ""
            }
          ]
        }
      }
    ],
    "identifier": 64809910
  },
  {
    "context": [
      "$ jq -r '.a' <<< '{\"a\": 1}'\n1",
      "$ jq -M -c '.' <<< '{\"a\": 1}'\n{\"a\":1}",
      "I'd like to print the above two results in TSV (<TAB> is a tab character). Is there a way to do so with `jq`?",
      "Just convert the input value to a JSON text.",
      "$ jq -r '[ .a, tojson ] | @tsv' <<< '{\"a\":1}'\n1\t{\"a\":1}"
    ],
    "utterance": "Output the value of field 'a' and the stringified object as tab-separated values in one line.",
    "expressions": [
      "[.a, tojson] | @tsv"
    ],
    "data": [
      {
        "input": {
          "a": 1
        },
        "output": "1\t{\"a\":1}"
      }
    ],
    "identifier": 64831224
  },
  {
    "context": [
      "I'm trying to get 2 json registers of a query in same line comma separated but allways duplicate me the output.",
      ".statuses[].name, .statuses[].jobId  // empty",
      "\"\\(.statuses[].name), \\(.statuses[].jobId)\"",
      "You should only enumerate once:",
      ".statuses[] | \"\\(.name), \\(.jobId)\""
    ],
    "utterance": "For each object in 'statuses', print the 'name' and 'jobId' on the same line, separated by a comma.",
    "expressions": [
      ".statuses[] | \"\\(.name), \\(.jobId)\""
    ],
    "identifier": 64857525
  },
  {
    "context": [
      "\"i would like to read \\\"service.istio.io/canonical-name\\\" this key. But getting the error of jq: error: canonical/0 is not defined at <top-level>, line 1:\"",
      "jq '.labels[\"service.istio.io/canonical-name\"]'"
    ],
    "utterance": "Get the value associated with the key 'service.istio.io/canonical-name' inside the object labeled 'labels'.",
    "expressions": [
      ".labels[\"service.istio.io/canonical-name\"]"
    ],
    "data": [
      {
        "input": {
          "labels": {
            "chart": "boss",
            "heritage": "back",
            "istio": "gw",
            "released": "istio",
            "service.istio.io/canonical-name": "istio"
          }
        },
        "output": "istio"
      }
    ],
    "identifier": 64854105
  },
  {
    "context": [
      "I would like to having every result in one array element",
      "it gives me all results in the first array element.",
      "try=$(tm run jobs:status::get -s \"tm=serverA&work=*&status=Failed\" | $PATH_API/jq -r '.statuses[].name // empty')",
      "echo \"${#try[@]}\"",
      "If the status names are sufficiently uncomplicated, you could add an extra pair of parentheses:",
      "try=($(tm run ....))",
      "Otherwise, you could consider using `readarray`, or other techniques for initializing bash arrays."
    ],
    "utterance": "Assign each status name result to a separate bash array element so that array indexing works as expected.",
    "expressions": [
      ".statuses[].name // empty"
    ],
    "identifier": 64858905
  },
  {
    "context": [
      "I want to display the values of the ``.Header.Tenant`` key. So the simple jq call does its job:",
      "$ jq '[.[].Header.Tenant]' test.json",
      "Now I want to assign that jq filter to a bash variable and use it with jq's ``--arg`` variable.",
      "$ a=\".[].Header.Tenant\"; jq --arg xx \"$a\" '[$xx]' test.json",
      "$ a=\".[].Header.Tenant\"; jq -f  <(echo \"[$a]\") test.json",
      "[$a]                            # with process substitution"
    ],
    "utterance": "Use a bash variable containing a query as a filter argument to display all values of the Header.Tenant key, allowing additional parameters to be appended if necessary.",
    "expressions": [
      "a=\".[].Header.Tenant\"; jq -f <(echo \"[$a]\") test.json",
      "a=\".[].Header.Tenant\"; jq -f <(echo \"[$a]|length\") test.json"
    ],
    "data": [
      {
        "input": [
          {
            "Header": {
              "Region": "US",
              "Tenant": "Tenant1",
              "Stage": "testing",
              "ProductType": "old"
            },
            "Body": []
          },
          {
            "Header": {
              "Region": "EU",
              "Tenant": "Tenant2",
              "Stage": "development",
              "ProductType": "new"
            },
            "Body": []
          }
        ],
        "output": [
          "Tenant1",
          "Tenant2"
        ]
      }
    ],
    "identifier": 64834378
  },
  {
    "context": [
      "I am trying to create a script that extracts a few key/value from all the blocks of an array and then run another shell script using that value to generate a new value and then append that new key/value in all the blocks respectively.",
      "cat serv.json | jq '.server_details['\"$ac\"'] += {\"hostname\": \"'$HO'\"}' | sponge serv.json"
    ],
    "utterance": "For each object in the array under 'server_details', add a new key 'hostname' whose value is dynamically generated using fields from the same object.",
    "expressions": [
      ".server_details |= map(. + {hostname: ( .site + .domain + (if .usagetype == \"Database Server\" then \"DS\" else (if .usagetype == \"Web Server\" then \"WS\" else .usagetype end) end ))})",
      ".server_details |= map(. + {hostname: (external_script(.site; .environment; .seqNo))})"
    ],
    "data": [
      {
        "input": {
          "server_details": [
            {
              "seqNo": "01",
              "storage": "IBM",
              "datastore": "IDS-NR02",
              "cpu": 4,
              "site": "SGDC",
              "servertype": "Virtual Machine",
              "location": "Serangoon",
              "operatingsystem": "Linux",
              "systemcode": "BOC",
              "ram": 64,
              "databasesoftware": "MSSQL 2016",
              "usagetype": "Database Server",
              "environment": "Production_WithCustData",
              "domain": "DAPAC",
              "IPAddress": "10.117.254.25",
              "DNS": "10.118.76.34",
              "Gateway": "10.118.76.1",
              "drives": [
                {
                  "C": "100"
                },
                {
                  "D": "50"
                }
              ]
            },
            {
              "seqNo": "02",
              "storage": "HITACHI",
              "datastore": "HDS-NR02",
              "cpu": 4,
              "site": "SGDR",
              "servertype": "Virtual Machine",
              "location": "DRC",
              "operatingsystem": "Windows",
              "systemcode": "WOC",
              "ram": 64,
              "databasesoftware": "NA",
              "usagetype": "Web Server",
              "environment": "Production_NonCustData",
              "domain": "EDAPAC",
              "IPAddress": "10.117.254.26",
              "DNS": "10.118.76.34",
              "Gateway": "10.118.76.1",
              "drives": [
                {
                  "C": "100"
                },
                {
                  "D": "50"
                }
              ]
            }
          ]
        },
        "output": {
          "server_details": [
            {
              "seqNo": "01",
              "storage": "IBM",
              "datastore": "IDS-NR02",
              "cpu": 4,
              "site": "SGDC",
              "servertype": "Virtual Machine",
              "location": "Serangoon",
              "operatingsystem": "Linux",
              "systemcode": "BOC",
              "ram": 64,
              "databasesoftware": "MSSQL 2016",
              "usagetype": "Database Server",
              "environment": "Production_WithCustData",
              "domain": "DAPAC",
              "IPAddress": "10.117.254.25",
              "DNS": "10.118.76.34",
              "Gateway": "10.118.76.1",
              "drives": [
                {
                  "C": "100"
                },
                {
                  "D": "50"
                }
              ],
              "hostname": "SGDDAPACDS"
            },
            {
              "seqNo": "02",
              "storage": "HITACHI",
              "datastore": "HDS-NR02",
              "cpu": 4,
              "site": "SGDR",
              "servertype": "Virtual Machine",
              "location": "DRC",
              "operatingsystem": "Windows",
              "systemcode": "WOC",
              "ram": 64,
              "databasesoftware": "NA",
              "usagetype": "Web Server",
              "environment": "Production_NonCustData",
              "domain": "EDAPAC",
              "IPAddress": "10.117.254.26",
              "DNS": "10.118.76.34",
              "Gateway": "10.118.76.1",
              "drives": [
                {
                  "C": "100"
                },
                {
                  "D": "50"
                }
              ],
              "hostname": "SGDEDAPACWS"
            }
          ]
        }
      }
    ],
    "identifier": 64731626
  },
  {
    "context": [
      "So delete all except `.services.*.version`. Help please, can't handle it with my knowledge of the JQ.",
      "{services}\n| .services |= map_values(select(has(\"version\")) | {version} )",
      "Translating your expression `.services.*.version` quite generically, you could use `tostream` as follows:\n```\nreduce (tostream\n        | select(length==2 and\n                 (.[0] | (.[0] == \"services\" and\n                          .[-1] == \"version\")))) as $pv (null;\n    setpath($pv[0]; $pv[1]) )\n```"
    ],
    "utterance": "Remove all data except the version property of each service under services.",
    "expressions": [
      "{services} | .services |= map_values(select(has(\"version\")) | {version})",
      "reduce (tostream | select(length==2 and (.[0] | (.[0] == \"services\" and .[-1] == \"version\")))) as $pv (null; setpath($pv[0]; $pv[1]))"
    ],
    "data": [
      {
        "input": {
          "jobs": [
            {},
            {}
          ],
          "services": {
            "service-1": {
              "version": "master"
            },
            "service-2": {
              "foo": true,
              "version": "master"
            },
            "service-3": {
              "bar": "baz"
            }
          }
        },
        "output": {
          "services": {
            "service-1": {
              "version": "master"
            },
            "service-2": {
              "version": "master"
            }
          }
        }
      }
    ],
    "identifier": 64851773
  },
  {
    "context": [
      "However, there is one instance within the environment that I do not want to include in this list, so I have tried to include another filter within the original jq.",
      "Neither of these successfully filter out the Instance in question. What am I missing here?",
      "One way to reformulate your query would be to use `any/2` and/or `all/2` as appropriate.",
      "the criterion you want based on .Value would be (equivalent to):\n\n    all(.Instances[0].Tags[].Value; \n        contains(\"NFTPerformanceTest\")|not)",
      ".Reservations\n| map(select(.Instances[0]\n             | ( .State.Name==\"running\" and\n\t             any(.Tags[]; .Value==$env) and\n                 all(.Instances[0].Tags[].Value;\n                     contains(\"NFTPerformanceTest\")|not) )))"
    ],
    "utterance": "Select all running instances where at least one tag value matches the environment variable and no tag value contains 'NFTPerformanceTest'.",
    "expressions": [
      ".Reservations | map(select(.Instances[0] | (.State.Name==\"running\" and any(.Tags[]; .Value==$env) and all(.Tags[].Value; contains(\"NFTPerformanceTest\")|not))))"
    ],
    "identifier": 64876606
  },
  {
    "context": [
      "I would like to get both at once, ie: (does not work, expected output)\n[\n  2,\n  4\n]",
      "Pipe each separate dimension into `length`:",
      "$ echo '{\n  \"data\": [\n    [1,2,3,4],\n    [5,6,7,8]\n  ]\n}' | jq '.data | [length, (.[0] | length)]'\n[\n  2,\n  4\n]",
      "The filter could also be written as\n.data | [., .[0]] | map(length)"
    ],
    "utterance": "Retrieve both the number of rows and columns from a 2-dimensional array under the key 'data', returning them as an array of two numbers.",
    "expressions": [
      ".data | [length, (.[0] | length)]",
      ".data | [., .[0]] | map(length)"
    ],
    "data": [
      {
        "input": {
          "data": [
            [
              1,
              2,
              3,
              4
            ],
            [
              5,
              6,
              7,
              8
            ]
          ]
        },
        "output": [
          2,
          4
        ]
      }
    ],
    "identifier": 64904537
  },
  {
    "context": [
      "I am able to replace ms-madison with mr-harmison with an ugly solution .containers[0].args[8] |= \"mr-harmison\"",
      "ms-madison can come at any position. Can you suggest to me a better way to deal with this?",
      "here's a solution which is completely agnostic about where \"ms-madison\" appears but which will change every occurrence of the target string:\n\nwalk(if . == \"ms-madison\" then \"mr-harmison\" else . end)",
      "Here's an illustration of how to \"walk\" .containers to change all occurrences of the target string that occur as top-level elements of every array-valued \"args\" keys:\n.containers |= walk( if type==\"object\"\n                        and (.args|type)==\"array\"\n                     then .args\n                        |= map_values(\n                             if . == \"ms-madison\" \n                             then \"mr-harmison\"\n                             else . end)\n                     else . end)"
    ],
    "utterance": "Replace all occurrences of the string ms-madison with mr-harmison wherever it appears inside any args array under containers.",
    "expressions": [
      ".containers |= walk( if type==\"object\" and (.args|type)==\"array\" then .args |= map_values( if . == \"ms-madison\" then \"mr-harmison\" else . end) else . end)",
      "walk(if . == \"ms-madison\" then \"mr-harmison\" else . end)"
    ],
    "data": [
      {
        "input": {
          "containers": [
            {
              "args": [
                "water",
                "fight",
                "--homein",
                "$(POD_NAMESPACE).svc.cluster.local",
                "--proxyLogLevel=warning",
                "--proxyComponentLogLevel=misc:error",
                "--log_output_level=default:info",
                "ms-madison",
                "--trust-domain=cluster.local"
              ]
            }
          ]
        },
        "output": {
          "containers": [
            {
              "args": [
                "water",
                "fight",
                "--homein",
                "$(POD_NAMESPACE).svc.cluster.local",
                "--proxyLogLevel=warning",
                "--proxyComponentLogLevel=misc:error",
                "--log_output_level=default:info",
                "mr-harmison",
                "--trust-domain=cluster.local"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 64886393
  },
  {
    "context": [
      "my command is `jq -r '[.e[], .t[], .n, .linkedin, .a] | @tsv'`",
      "So i got an output like this\n\ndemo@example.com        demo1@example.com       demo2@example.com       demo3@example.com       007-414-7001   1-007-414-7002  0074147003      1-007-414-7005  phil demo       empty   orlando, florida, united states\n*As you can see for \"e\" field its just one column but in csv or tsv result give multiple columns not just one.*",
      "My question now how i can get between data in both fields of \"e\" and \"t\" separated by commas?",
      "I need to get a result like this:\n\ndemo@example.com,demo1@example.com,demo2@example.com,demo3@example.com       007-414-7001,1-007-414-7002,0074147003,1-007-414-7005  phil demo       empty   orlando, florida, united states\n",
      "You can use the [Update-assignment operator](https://stedolan.github.io/jq/manual/v1.6/#Assignment) `|=` to modify the values of \"e\" and \"t\".",
      "jq -r '.e |= join(\",\")\n         | .t |= join(\",\")\n         | [.e, .t, .n, .linkedin, .a]\n         | @tsv'"
    ],
    "utterance": "Combine the values in the 'e' and 't' fields into comma-separated strings and output them along with 'n', 'linkedin', and 'a' fields, as tab-separated values.",
    "expressions": [
      ".e |= join(\",\") | .t |= join(\",\") | [.e, .t, .n, .linkedin, .a] | @tsv"
    ],
    "data": [
      {
        "input": {
          "a": "orlando, florida, united states",
          "t": [
            "007-414-7001",
            "1-007-414-7002",
            "0074147003",
            "1-007-414-7005"
          ],
          "e": [
            "demo@example.com",
            "demo1@example.com",
            "demo2@example.com",
            "demo3@example.com"
          ],
          "liid": "empty",
          "linkedin": "empty",
          "n": "phil demo"
        },
        "output": "demo@example.com,demo1@example.com,demo2@example.com,demo3@example.com\t007-414-7001,1-007-414-7002,0074147003,1-007-414-7005\tphil demo\tempty\torlando, florida, united states"
      }
    ],
    "identifier": 64901377
  },
  {
    "context": [
      "how can I integrate the following json file\n\n    [source.json]\n    {\n      \"test\": \"value\", \n      \"test1\": \"value2\"\n    }\n\ninto this json file using jq?\n\n    [target.json] \n    {\n      \"header\": \"stuff\"\n      \"values\" : \n      {\n        \"test\": \"value\",   //from source.json\n        \"test1\": \"value2\"   //from source.json\n      }\n    }",
      "It is possible that the \"values\" key in the target json file does not yet exist or that it already contains values. In both cases, the target.json file shown here should be created.",
      "$ jq --slurpfile source source.json '.values = $source[0]' target.json"
    ],
    "utterance": "Replace or create the \"values\" field in an object with the contents of another file.",
    "expressions": [
      ".values = $source[0]"
    ],
    "data": [
      {
        "input": {
          "header": "stuff"
        },
        "output": {
          "header": "stuff",
          "values": {
            "test": "value",
            "test1": "value2"
          }
        }
      },
      {
        "input": {
          "header": "stuff",
          "values": {
            "old": "data"
          }
        },
        "output": {
          "header": "stuff",
          "values": {
            "test": "value",
            "test1": "value2"
          }
        }
      }
    ],
    "identifier": 64911926
  },
  {
    "context": [
      "echo -e \"1\\n2\\n\\n\\n3\\n4\\n5\" | jq --raw-input '. | select (. != \"\") | {(.):123} | reduce . as $i ({}; . + $i)'",
      "the reduction does nothing. Why? How to correct the reduction to produce single object having keys 1,2,3,4,5?",
      "echo -e \"1\\n2\\n\\n\\n3\\n4\\n5\" \\\n| jq --raw-input 'select (. != \"\") | {(.):123}' \\\n| jq --slurp 'reduce .[] as $o ({}; . + $o)'",
      "you will either need to use the -s option, or better, use the -n option with `inputs`.",
      "echo -e \"1\\n2\\n\\n\\n3\\n4\\n5\" | \n  jq -nR 'reduce (inputs|select(. != \"\")) as $i ({}; . + {($i): 123})'"
    ],
    "utterance": "Combine multiple lines of input, each representing a key, into a single object with those keys and the value 123, ignoring any empty lines.",
    "expressions": [
      "jq --raw-input 'select (. != \"\") | {(.):123}' | jq --slurp 'reduce .[] as $o ({}; . + $o)'",
      "jq -nR 'reduce (inputs|select(. != \"\")) as $i ({}; . + {($i): 123})'"
    ],
    "data": [
      {
        "input": "1\n2\n\n\n3\n4\n5",
        "output": {
          "1": 123,
          "2": 123,
          "3": 123,
          "4": 123,
          "5": 123
        }
      }
    ],
    "identifier": 64902535
  },
  {
    "context": [
      "I want to have the opportunity to \"force\" the `BestRegion` so I created the `else cycle`. Here I've the problem!",
      "echo $all_region_data | jq --arg REGION_ID \"$BestRegion\" --arg JQ_FILTER \"$jq_filter\" -r '$JQ_FILTER | select(.id==$REGION_ID)'",
      "You want to pass the former in as part of a larger JQ filter while passing the latter in as a JQ variable.",
      "Try:",
      "jq --arg REGION_ID \"$BestRegion\" \"$jq_filter\"'| select(.id==$REGION_ID)'"
    ],
    "utterance": "Filter regions using a composed filter string from a variable, and further select entries where the .id field matches a specified region name held in another variable.",
    "expressions": [
      "jq --arg REGION_ID \"$BestRegion\" \"$jq_filter\"'| select(.id==$REGION_ID)'"
    ],
    "identifier": 64937500
  },
  {
    "context": [
      "false and true values are replaced with some other values for the fields \"is_started\" and \"is_cancelled\", on all records of .result.",
      "Is it possible to do the same change with calling jq only once ?",
      ".result |= \n   map(if .is_cancelled == true then (.is_cancelled=$cancel) \n       elif .is_cancelled == false then (.is_cancelled=$replace) \n       else . \n       end\n       | if .is_started == true then (.is_started=$start) \n         elif .is_started == false then (.is_started=$stop) \n         else .\n         end )",
      "map(.is_cancelled |= if . then $cancel else $replace end\n     | .is_started |= if . then $start else $stop end)",
      "jq -r --argjson v '{\"cancel\": \"Cancelled\", \"start\": \"Started\", \"stop\": \"Stopped\",  \"replace\": \"Active\"}' '.result |= map(.is_cancelled |= if . then $v.cancel else $v.replace end | .is_started |= if . then $v.start else $v.stop end)'"
    ],
    "utterance": "Replace true and false values in the is_cancelled and is_started fields of all objects in the result array with the strings 'Cancelled', 'Active', 'Started', and 'Stopped' in a single call.",
    "expressions": [
      ".result |= map(if .is_cancelled == true then (.is_cancelled=$cancel) elif .is_cancelled == false then (.is_cancelled=$replace) else . end | if .is_started == true then (.is_started=$start) elif .is_started == false then (.is_started=$stop) else . end )",
      ".result |= map(.is_cancelled |= if . then $cancel else $replace end | .is_started |= if . then $start else $stop end)",
      ".result |= map(.is_cancelled |= if . then $v.cancel else $v.replace end | .is_started |= if . then $v.start else $v.stop end)"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "id": 8893,
              "entry_time": "2020-11-04T16:02:43+01:00",
              "author_id": 24,
              "author_name": "joe",
              "host_id": 2115,
              "service_id": 0,
              "is_cancelled": false,
              "comment": "Test 5236",
              "deletion_time": null,
              "duration": 4302000,
              "end_time": "2020-12-24T13:48:22+01:00",
              "internal_id": 513,
              "is_fixed": true,
              "poller_id": 2,
              "start_time": "2020-11-04T18:48:22+01:00",
              "actual_start_time": "2020-11-18T12:08:16+01:00",
              "actual_end_time": null,
              "is_started": true
            }
          ],
          "meta": {
            "pagination": {
              "page": 1,
              "limit": 999999999,
              "search": {},
              "sort_by": {
                "host.name": "DESC"
              },
              "total": 118
            }
          }
        },
        "output": {
          "result": [
            {
              "id": 8893,
              "entry_time": "2020-11-04T16:02:43+01:00",
              "author_id": 24,
              "author_name": "joe",
              "host_id": 2115,
              "service_id": 0,
              "is_cancelled": "Active",
              "comment": "Test 5236",
              "deletion_time": null,
              "duration": 4302000,
              "end_time": "2020-12-24T13:48:22+01:00",
              "internal_id": 513,
              "is_fixed": true,
              "poller_id": 2,
              "start_time": "2020-11-04T18:48:22+01:00",
              "actual_start_time": "2020-11-18T12:08:16+01:00",
              "actual_end_time": null,
              "is_started": "Started"
            }
          ],
          "meta": {
            "pagination": {
              "page": 1,
              "limit": 999999999,
              "search": {},
              "sort_by": {
                "host.name": "DESC"
              },
              "total": 118
            }
          }
        }
      }
    ],
    "identifier": 64895007
  },
  {
    "context": [
      "What I want to achieve is to parse the values to output the following\n\nhttps://test.com/gg?msg=gg\nhttps://test.com/gg?popup=gg\nhttps://test.com/gg?url=gg",
      "jq --raw-output 'to_entries[0] | .key as $url | .value[] | \"\\($url)?\\(.)=gg\"' <your json file here>"
    ],
    "utterance": "For each property in the object, output lines formatted as '<key>?<value>=gg' for every item in the array at that key.",
    "expressions": [
      "to_entries[0] | .key as $url | .value[] | \"\\($url)?\\(.)=gg\""
    ],
    "data": [
      {
        "input": {
          "https://test.com/gg": [
            "msg",
            "popup",
            "url"
          ]
        },
        "output": [
          "https://test.com/gg?msg=gg",
          "https://test.com/gg?popup=gg",
          "https://test.com/gg?url=gg"
        ]
      }
    ],
    "identifier": 64945822
  },
  {
    "context": [
      "How can I flatten this json array and write out to a csv file using jq so that each row contains all the fields i.e.",
      "To a csv as follows:\n\n```\n\"name\", \"unit\", \"timestamp\", \"value\"\n\"PM2.5\", \"ug/m3\", \"2020-11-16T13:10:21.135Z\", 3.696\n\"PM2.5\", \"ug/m3\", \"2020-11-16T13:10:31.649Z\", 3.696\n\"PM2.5\", \"ug/m3\", \"2020-11-16T13:10:42.35Z\", 3.696\n\"PM2.5\", \"ug/m3\", \"2020-11-16T13:10:52.953Z\", 3.696  \n\"PM10\", \"ug/m3\", \"2020-11-16T13:10:21.135Z\", 7.596\n\"PM10\", \"ug/m3\", \"2020-11-16T13:10:31.649Z\", 7.596\n\"PM10\", \"ug/m3\", \"2020-11-16T13:10:42.35Z\", 7.596\n\"PM10\", \"ug/m3\", \"2020-11-16T13:10:52.953Z\", 7.596\n```",
      "$ jq -r '\n  [[\"name\",\"unit\",\"timestamp\",\"value\"]], \n   [ .[] \n     | [ .name, .unit ] + \n       (.values[] | [.timestamp,.value]) ] \n  | .[] \n  | @csv' input.json"
    ],
    "utterance": "Convert an array of objects each containing a name, unit, and a nested values array into rows with columns name, unit, timestamp, and value, with one row per value entry.",
    "expressions": [
      "[[\"name\",\"unit\",\"timestamp\",\"value\"], (.[] | .values[] | [ .name, .unit, .timestamp, .value ])] | .[] | @csv",
      "[[\"name\",\"unit\",\"timestamp\",\"value\"]], [ .[] | [ .name, .unit ] + (.values[] | [.timestamp,.value]) ] | .[] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "PM2.5",
            "unit": "ug/m3",
            "values": [
              {
                "timestamp": "2020-11-16T13:10:21.135Z",
                "value": 3.696
              },
              {
                "timestamp": "2020-11-16T13:10:31.649Z",
                "value": 3.696
              },
              {
                "timestamp": "2020-11-16T13:10:42.35Z",
                "value": 3.696
              },
              {
                "timestamp": "2020-11-16T13:10:52.953Z",
                "value": 3.696
              }
            ]
          },
          {
            "name": "PM10",
            "unit": "ug/m3",
            "values": [
              {
                "timestamp": "2020-11-16T13:10:21.135Z",
                "value": 7.596
              },
              {
                "timestamp": "2020-11-16T13:10:31.649Z",
                "value": 7.596
              },
              {
                "timestamp": "2020-11-16T13:10:42.35Z",
                "value": 7.596
              },
              {
                "timestamp": "2020-11-16T13:10:52.953Z",
                "value": 7.596
              }
            ]
          }
        ],
        "output": [
          "\"name\",\"unit\",\"timestamp\",\"value\"",
          "\"PM2.5\",\"ug/m3\",\"2020-11-16T13:10:21.135Z\",3.696",
          "\"PM2.5\",\"ug/m3\",\"2020-11-16T13:10:31.649Z\",3.696",
          "\"PM2.5\",\"ug/m3\",\"2020-11-16T13:10:42.35Z\",3.696",
          "\"PM2.5\",\"ug/m3\",\"2020-11-16T13:10:52.953Z\",3.696",
          "\"PM10\",\"ug/m3\",\"2020-11-16T13:10:21.135Z\",7.596",
          "\"PM10\",\"ug/m3\",\"2020-11-16T13:10:31.649Z\",7.596",
          "\"PM10\",\"ug/m3\",\"2020-11-16T13:10:42.35Z\",7.596",
          "\"PM10\",\"ug/m3\",\"2020-11-16T13:10:52.953Z\",7.596"
        ]
      }
    ],
    "identifier": 64859291
  },
  {
    "context": [
      "Is it possible to output inverted matches using the [jq command-line JSON processor][1]? The tool `grep` supports the option `-v, --invert-match: select non-matching lines` for this.",
      "As an example, I'm searching for a command such as the following. However, `without(...)` doesn't exist:",
      "echo '{\"a\": 0, \"b\": 1, \"c\": 2}' | jq '. | without(c)'",
      "While writing this question, I found the [builtin `del(path_expression)` function][1] which solves the issue:",
      "The builtin function del removes a key and its corresponding value from an object.",
      "echo '{\"a\": 0, \"b\": 1, \"c\": 2}' | jq 'del(.c)'",
      "jq is generally quite minimalist, so when in doubt while looking for the opposite of something, `not` is always available to come to the rescue, e.g.",
      "with_entries(select(.key == \"c\"|not))",
      "with_entries(select(.key != \"c\"))"
    ],
    "utterance": "Remove the key 'c' and its value from an object.",
    "expressions": [
      "del(.c)",
      "with_entries(select(.key != \"c\"))",
      "with_entries(select(.key == \"c\"|not))"
    ],
    "data": [
      {
        "input": {
          "a": 0,
          "b": 1,
          "c": 2
        },
        "output": {
          "a": 0,
          "b": 1
        }
      }
    ],
    "identifier": 64940610
  },
  {
    "context": [
      "I would like to order this json based on startTime, I want to return the list ordered by the latest date.",
      "I tried this query\n`jq -r '.items[].status | sort_by(.startTime)'`\n\nbut it gives the following error:\n` jq: error (at <stdin>:4399): Cannot index string with string \"startTime\"`",
      "```\n.items | sort_by(.status.startTime) | map(.status) | reverse\n```\n\nWhere:\n\n1. Take out `.items`\n2. Sort items on the `.status.startTime` (ascending order)\n3. Then for each item only keep status\n4. And finally reverse the list"
    ],
    "utterance": "Return the list of status objects ordered by startTime with the latest date first.",
    "expressions": [
      ".items | sort_by(.status.startTime) | map(.status) | reverse"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "status": {
                "phase": "Failed",
                "startTime": "2020-11-15T15:42:26Z"
              }
            },
            {
              "status": {
                "environments": [
                  {
                    "dev": "test"
                  }
                ],
                "phase": "Running",
                "startTime": "2020-11-17T15:42:26Z"
              }
            },
            {
              "status": {
                "environments": [
                  {
                    "dev": "test2"
                  }
                ],
                "phase": "Running",
                "startTime": "2020-11-10T15:42:26Z"
              }
            }
          ]
        },
        "output": [
          {
            "environments": [
              {
                "dev": "test"
              }
            ],
            "phase": "Running",
            "startTime": "2020-11-17T15:42:26Z"
          },
          {
            "phase": "Failed",
            "startTime": "2020-11-15T15:42:26Z"
          },
          {
            "environments": [
              {
                "dev": "test2"
              }
            ],
            "phase": "Running",
            "startTime": "2020-11-10T15:42:26Z"
          }
        ]
      }
    ],
    "identifier": 64946480
  },
  {
    "context": [
      "For every `DOI`, I need to obtain the values of `given` and `family` key in the same cell of the same row of that DOI in the CSV/TSV format.",
      "The expected output for the above json is (in CSV/TSV format):\r\n\r\n    |DOI| givenName|familyName|\r\n    |10.1021/ol047829t|Emmanuel; Fr&#233;d&#233;ric; Bertrand; Daniel;|Allard; Oswald; Donnio; Guillon|",
      "Join given and family names by semicolons separately, then pass resulting strings as fields to the TSV filter.",
      "[\"DOI\", \"givenName\", \"familyName\"],\n(inputs | [.DOI, (.author | map(.given), map(.family) | join(\"; \"))])\n| @tsv"
    ],
    "utterance": "Output rows where each contains the DOI and all author given and family names joined by semicolons in separate columns, formatted as TSV.",
    "expressions": [
      "[\"DOI\", \"givenName\", \"familyName\"],\n(inputs | [.DOI, (.author | map(.given) | join(\"; \"), map(.family) | join(\"; \"))])\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "indexed": {
            "date-parts": [
              [
                2020,
                8,
                13
              ]
            ],
            "date-time": "2020-08-13T06:27:26Z",
            "timestamp": 1597300046660
          },
          "reference-count": 42,
          "publisher": "American Chemical Society (ACS)",
          "issue": "3",
          "content-domain": {
            "domain": [],
            "crossmark-restriction": false
          },
          "short-container-title": [
            "Org. Lett."
          ],
          "published-print": {
            "date-parts": [
              [
                2005,
                2
              ]
            ]
          },
          "DOI": "10.1021/ol047829t",
          "type": "journal-article",
          "created": {
            "date-parts": [
              [
                2005,
                1,
                27
              ]
            ],
            "date-time": "2005-01-27T05:53:29Z",
            "timestamp": 1106805209000
          },
          "page": "383-386",
          "source": "Crossref",
          "is-referenced-by-count": 38,
          "title": [
            "Liquid-Crystalline [60]Fullerene-TTF Dyads"
          ],
          "prefix": "10.1021",
          "volume": "7",
          "author": [
            {
              "given": "Emmanuel",
              "family": "Allard",
              "affiliation": []
            },
            {
              "given": "Fr\u0000e9d\u0000e9ric",
              "family": "Oswald",
              "affiliation": []
            },
            {
              "given": "Bertrand",
              "family": "Donnio",
              "affiliation": []
            },
            {
              "given": "Daniel",
              "family": "Guillon",
              "affiliation": []
            }
          ],
          "member": "316",
          "container-title": [
            "Organic Letters"
          ],
          "original-title": [],
          "link": [
            {
              "URL": "https://pubs.acs.org/doi/pdf/10.1021/ol047829t",
              "content-type": "unspecified",
              "content-version": "vor",
              "intended-application": "similarity-checking"
            }
          ],
          "deposited": {
            "date-parts": [
              [
                2020,
                4,
                7
              ]
            ],
            "date-time": "2020-04-07T13:39:55Z",
            "timestamp": 1586266795000
          },
          "score": null,
          "subtitle": [],
          "short-title": [],
          "issued": {
            "date-parts": [
              [
                2005,
                2
              ]
            ]
          },
          "references-count": 42,
          "alternative-id": [
            "10.1021/ol047829t"
          ],
          "URL": "http://dx.doi.org/10.1021/ol047829t",
          "relation": {},
          "ISSN": [
            "1523-7060",
            "1523-7052"
          ],
          "issn-type": [
            {
              "value": "1523-7060",
              "type": "print"
            },
            {
              "value": "1523-7052",
              "type": "electronic"
            }
          ],
          "subject": [
            "Physical and Theoretical Chemistry",
            "Organic Chemistry",
            "Biochemistry"
          ]
        },
        "output": "DOI\tgivenName\tfamilyName\n10.1021/ol047829t\tEmmanuel; Fr\u00e9d\u00e9ric; Bertrand; Daniel\tAllard; Oswald; Donnio; Guillon"
      }
    ],
    "identifier": 64927543
  },
  {
    "context": [
      "And now the `jq/del` works as expected:",
      "$ jq 'del(.key3)' <<< \"${jsonStr}\"",
      "{",
      "  \"key1\": \"value1\",",
      "  \"key2\": \"value2\"",
      "}",
      "And then the `+` operation also works:",
      "$ STRING=\"hello\"",
      "$ jq 'del(.key3)' <<< \"${jsonStr}\"  | jq '. + {\"'$STRING'\": \"value4\"}'",
      "{",
      "  \"key1\": \"value1\",",
      "  \"key2\": \"value2\",",
      "  \"hello\": \"value4\"",
      "}"
    ],
    "utterance": "Remove the key \"key3\" from the data and add a new key with the name given by the variable STRING and value \"value4\".",
    "expressions": [
      "jq 'del(.key3)'",
      "jq '. + {\"'\"$STRING\"'\": \"value4\"}'"
    ],
    "data": [
      {
        "input": {
          "key1": "value1",
          "key2": "value2",
          "key3": "value3"
        },
        "output": {
          "key1": "value1",
          "key2": "value2",
          "hello": "value4"
        }
      }
    ],
    "identifier": 64960452
  },
  {
    "context": [
      "How do I copy this value over to the `GMNotes` property of the same object using JQ?",
      "how does one go from",
      "{ \"ObjectStates\": [ { \"Description\": \"\", \"GMNotes\": \"\" }, { \"Description\": \"foo\", \"GMNotes\": \"\" } ] }",
      "to",
      "{ \"ObjectStates\": [ { \"Description\": \"\", \"GMNotes\": \"\" }, { \"Description\": \"foo\", \"GMNotes\": \"foo\" } ] }",
      "You can use `map()` in combination with the _update assignment_ operator `|=`:\n\n    jq '(.ObjectStates)|=map(.GMNotes=.Description)' file.json",
      "instead of using `map` you could also just use the following command, the key is using `|=`.\n\n    jq '.ObjectStates[]|=(.GMNotes=.Description)' file.json"
    ],
    "utterance": "Set the GMNotes property of each object in ObjectStates to the value of its Description property.",
    "expressions": [
      "(.ObjectStates)|=map(.GMNotes=.Description)",
      ".ObjectStates[]|=(.GMNotes=.Description)"
    ],
    "data": [
      {
        "input": {
          "ObjectStates": [
            {
              "Description": "",
              "GMNotes": ""
            },
            {
              "Description": "foo",
              "GMNotes": ""
            }
          ]
        },
        "output": {
          "ObjectStates": [
            {
              "Description": "",
              "GMNotes": ""
            },
            {
              "Description": "foo",
              "GMNotes": "foo"
            }
          ]
        }
      }
    ],
    "identifier": 64976998
  },
  {
    "context": [
      "I want to insert new json objects in between json objects using bash generated uuid.",
      "target output json",
      "{ \"id\": \"7e3ca7b0-48f1-41fe-9a19-092a62cba0dc\" }",
      "{ \"name\":\"a\",\"type\":1 }",
      "{ \"id\": \"3f793fdd-ec3b-4306-8153-12f3f9faf2c1\" }",
      "{ \"name\":\"b\",\"type\":2 }",
      "{ \"id\": \"cbcd759a-37e7-4da7-b7fe-7572f474ec31\" }",
      "{ \"name\":\"c\",\"type\":3 }",
      "jq program to insert uuid generated from bash:",
      "jq -c '{\"id\" | input}, .' test.json < <(uuidgen)",
      "jq -n -c -R --slurpfile objects test.json '\n  $objects[] | {\"id\": input}, .\n' <(while true ; do uuidgen ; done)"
    ],
    "utterance": "Insert a new object with a UUID as the id before each object in the input, using uuids generated from bash.",
    "expressions": [
      "jq -n -c -R --slurpfile objects test.json '$objects[] | {\"id\": input}, .' <(while true ; do uuidgen ; done)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "a",
            "type": 1
          },
          {
            "name": "b",
            "type": 2
          },
          {
            "name": "c",
            "type": 3
          }
        ],
        "output": [
          {
            "id": "7e3ca7b0-48f1-41fe-9a19-092a62cba0dc"
          },
          {
            "name": "a",
            "type": 1
          },
          {
            "id": "3f793fdd-ec3b-4306-8153-12f3f9faf2c1"
          },
          {
            "name": "b",
            "type": 2
          },
          {
            "id": "cbcd759a-37e7-4da7-b7fe-7572f474ec31"
          },
          {
            "name": "c",
            "type": 3
          }
        ]
      }
    ],
    "identifier": 64948257
  },
  {
    "context": [
      "Input file.json:",
      "Desired output (i.e., replace all top-level values with empty strings, and replace leaf values with key 'value', see nested values in `environment_*`, with empty strings).",
      "I'm looking for a solution which covers an arbitrary number of `environment_*` (top-level keys beginning with `environment_` and not only a single one).",
      "You could start with this:",
      "walk(if type == \"object\"\n         then with_entries(\n           if .key != \"name\" and (.value|type)==\"string\"\n           then .value=\"\" else . end)\n         else . end)",
      "Update every string value with the empty string except those with the keyname **name**.",
      "reduce (paths(strings) | select(.[-1] != \"name\")) as $p (.; setpath($p; \"\"))"
    ],
    "utterance": "Create a template by keeping all keys and structure, but replace all string values with empty strings except those whose key is 'name'.",
    "expressions": [
      "walk(if type == \"object\" then with_entries(if .key != \"name\" and (.value|type)==\"string\" then .value=\"\" else . end) else . end)",
      "reduce (paths(strings) | select(.[-1] != \"name\")) as $p (.; setpath($p; \"\"))"
    ],
    "data": [
      {
        "input": {
          "global_foo": "987",
          "global_bar": "qwertz",
          "global_baz": "123",
          "environment_a": [
            {
              "name": "baz",
              "value": "456"
            }
          ],
          "environment_b": [
            {
              "name": "foo",
              "value": "123"
            },
            {
              "name": "bar",
              "value": "abc"
            }
          ],
          "environment_test": [
            {
              "name": "foo",
              "value": "123"
            }
          ]
        },
        "output": {
          "global_foo": "",
          "global_bar": "",
          "global_baz": "",
          "environment_a": [
            {
              "name": "baz",
              "value": ""
            }
          ],
          "environment_b": [
            {
              "name": "foo",
              "value": ""
            },
            {
              "name": "bar",
              "value": ""
            }
          ],
          "environment_test": [
            {
              "name": "foo",
              "value": ""
            }
          ]
        }
      }
    ],
    "identifier": 64955068
  },
  {
    "context": [
      "I\u2019d like to add leading/trailing zeros to strings from numbers \u2014 resultant string needs to contain \"01\" or \"001\" and not \"1\".",
      "the padding itself \u2014 how to do it without this extra library?",
      "You can achieve `\"007\"` with the following filter: (or `\"042\"` with `42`)",
      "tostring | (length | if . >= 3 then \"\" else \"0\" * (3 - .) end) as $padding | \"\\($padding)\\(.)\"",
      "You could define these functions at the start of your filter or adding it to your `~/.jq` file then use it to pad the numbers.",
      "def pad_left($len; $chr):\n    (tostring | length) as $l\n    | \"\\($chr * ([$len - $l, 0] | max) // \"\")\\(.)\"\n    ;",
      "pad_left(3; \"0\")",
      "def lpad(n):\n  tostring\n  | if (n > length) then ((n - length) * \"0\") + . else . end;",
      "If you are sure the number will not overflow the format digits, you can simulate a \"%03d\" with:\n\naNumber+1000|tostring[1:]",
      "Here is a solution that handles overflow as well. It can pad any number:",
      "$ jq '3 as $pad | (fmax(0;.aNumber)|tostring) as $N|($N|length) as $D|[range($pad) as $_|\"0\"]|join(\"\")[fmax($D; $D-$pad):]+$N' <<<'{\"aNumber\": 1}'",
      "\"001\"",
      "\"00\\(.)\"[-3:]"
    ],
    "utterance": "Create a string representation of a number with leading zeros so that the total length is at least three digits, producing outputs like \"001\" for 1, without using external libraries.",
    "expressions": [
      "tostring | (length | if . >= 3 then \"\" else \"0\" * (3 - .) end) as $padding | \"\\($padding)\\(.)\"",
      "def pad_left($len; $chr): (tostring | length) as $l | \"\\($chr * ([$len - $l, 0] | max) // \"\")\\(.)\"; pad_left(3; \"0\")",
      "def lpad(n): tostring | if (n > length) then ((n - length) * \"0\") + . else . end; lpad(3)",
      ".aNumber+1000|tostring[1:]",
      "3 as $pad | (fmax(0;.aNumber)|tostring) as $N|($N|length) as $D|[range($pad) as $_|\"0\"]|join(\"\")[fmax($D; $D-$pad):]+$N",
      "\"00\\(.)\"[-3:]"
    ],
    "data": [
      {
        "input": 7,
        "output": "007"
      },
      {
        "input": 42,
        "output": "042"
      },
      {
        "input": {
          "aNumber": 1
        },
        "output": "001"
      },
      {
        "input": {
          "aNumber": 1234
        },
        "output": "1234"
      }
    ],
    "identifier": 64957982
  },
  {
    "context": [
      "Now I want to select this object, if the array measurements has an object that has key_c==\"Value 3\", as long as it does not have any object that has key_c==\"Value 4\".",
      "I would suggest a filter like this one\n```\ndef condition1: any(.key_c == \"Value_3\");\ndef condition2: any(.key_c == \"Value_4\") | not;\nselect(.measurements|condition1 and condition2)\n```",
      "As a scrunched one-liner:\n```\nselect(.measurements|any(.key_c==\"Value_3\") and all(.key_c!=\"Value_4\"))\n```"
    ],
    "utterance": "Select an object if its measurements array contains an object where key_c is \"Value_3\" but no object where key_c is \"Value_4\".",
    "expressions": [
      "def condition1: any(.key_c == \"Value_3\");\ndef condition2: any(.key_c == \"Value_4\") | not;\nselect(.measurements|condition1 and condition2)",
      "select(.measurements|any(.key_c==\"Value_3\") and all(.key_c!=\"Value_4\"))"
    ],
    "data": [
      {
        "input": {
          "key_1": "uo2",
          "key_2": false,
          "measurements": [
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_P"
            },
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_3"
            },
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_001"
            }
          ],
          "key_3": "bwr",
          "key_4": null,
          "key_5": 31066.0
        },
        "output": {
          "key_1": "uo2",
          "key_2": false,
          "measurements": [
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_P"
            },
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_3"
            },
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_001"
            }
          ],
          "key_3": "bwr",
          "key_4": null,
          "key_5": 31066.0
        }
      },
      {
        "input": {
          "key_1": "uo2",
          "key_2": false,
          "measurements": [
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_4"
            },
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_P"
            },
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_3"
            },
            {
              "key_a": null,
              "key_b": 37.5,
              "key_c": "Value_001"
            }
          ],
          "key_3": "bwr",
          "key_4": null,
          "key_5": 31066.0
        },
        "output": null
      }
    ],
    "identifier": 64993513
  },
  {
    "context": [
      "What I want is to get all the top level objects for a certain `code.name`, let\u2019s say `foo`.",
      "The problem is that since there is two sub-objects with `foo` as name, the top level object is returned twice. I\u2019d like to have it only once, is that possible?",
      "You're looking for [`any/1`](https://stedolan.github.io/jq/manual/#any,any(condition),any(generator;condition)).",
      "```\n.[] | select(.code | any(.name == \"foo\"))\n```"
    ],
    "utterance": "Select all top-level objects where at least one 'code' entry has name equal to 'foo', ensuring each object appears only once.",
    "expressions": [
      ".[] | select(.code | any(.name == \"foo\"))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "model1",
            "reference": 0.1,
            "code": [
              {
                "name": "foo",
                "version": "a",
                "value": 0.2
              },
              {
                "name": "foo",
                "version": "b",
                "value": 0.2
              },
              {
                "name": "bar",
                "version": "a",
                "value": 0.15
              }
            ]
          },
          {
            "name": "model2",
            "reference": 0.12,
            "code": [
              {
                "name": "bar",
                "version": "a",
                "value": 0.09
              },
              {
                "name": "baz",
                "version": "a",
                "value": 0.15
              }
            ]
          }
        ],
        "output": [
          {
            "name": "model1",
            "reference": 0.1,
            "code": [
              {
                "name": "foo",
                "version": "a",
                "value": 0.2
              },
              {
                "name": "foo",
                "version": "b",
                "value": 0.2
              },
              {
                "name": "bar",
                "version": "a",
                "value": 0.15
              }
            ]
          }
        ]
      }
    ],
    "identifier": 65002113
  },
  {
    "context": [
      "Test1=\"*/15 * * * *\"",
      "json=$( jq -n --arg bob \"$Test1\" '{ Kate: $bob}' )",
      "I want the output to be \n\n```bash\n{ \"Kate\": \"*/15 * * * *\" }\n```",
      "The problem is not with your invocation of jq, but with the way you examined jq's output.",
      "$ jq -n --arg bob \"$Test1\" '{ Kate: $bob}'\n{\n  \"Kate\": \"*/15 * * * *\"\n}",
      "$ echo \"$json\"\n{\n  \"Kate\": \"*/15 * * * *\"\n}"
    ],
    "utterance": "Create an object with the key Kate set to the string '*/15 * * * *', ensuring that asterisks are preserved in the value.",
    "expressions": [
      "jq -n --arg bob \"$Test1\" '{ Kate: $bob }'"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "Kate": "*/15 * * * *"
        }
      }
    ],
    "identifier": 65020149
  },
  {
    "context": [
      "and I want this as the result:",
      "{\r\n  \"model\": \"model1\",\r\n  \"code\": \"foo\",\r\n  \"version\": \"a\"\r\n}",
      "So I wrote the following query.\r\n```\r\n.[] | { \"model\": .name, \"code\": .code[].name, \"version\": .code[].version }\r\n```\r\nThe problem is that for each use of `.code[]` in the output structure the results are multiplied, resulting in many duplicates. How can I avoid that, and get only the desired result?",
      "You need to avoid expanding the same array more than once as shown below to prevent a combinatorial explosion.",
      "```\r\n.[].models[] | {model: .name} + (.code[] | {name, version})\r\n```"
    ],
    "utterance": "Produce one object for each (model, code name, version) pair, including the model name and the nested code name and version, with no duplicate combinations.",
    "expressions": [
      ".[].models[] | {model: .name} + (.code[] | {name, version})"
    ],
    "data": [
      {
        "input": [
          {
            "experiment": "ex1",
            "models": [
              {
                "name": "model1",
                "reference": 0.1,
                "code": [
                  {
                    "name": "foo",
                    "version": "a",
                    "value": 0.2
                  },
                  {
                    "name": "foo",
                    "version": "b",
                    "value": 0.2
                  },
                  {
                    "name": "bar",
                    "version": "a",
                    "value": 0.15
                  }
                ]
              },
              {
                "name": "model2",
                "reference": 0.12,
                "code": [
                  {
                    "name": "foo",
                    "version": "a",
                    "value": 0.09
                  },
                  {
                    "name": "baz",
                    "version": "a",
                    "value": 0.15
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "model": "model1",
            "name": "foo",
            "version": "a"
          },
          {
            "model": "model1",
            "name": "foo",
            "version": "b"
          },
          {
            "model": "model1",
            "name": "bar",
            "version": "a"
          },
          {
            "model": "model2",
            "name": "foo",
            "version": "a"
          },
          {
            "model": "model2",
            "name": "baz",
            "version": "a"
          }
        ]
      }
    ],
    "identifier": 65003395
  },
  {
    "context": [
      "I want to parse the apps array and get each value inside that node.",
      "appls=$(jq -c '.apps[]?' \"${work_dir}/scripts/applications.json\")"
    ],
    "utterance": "Extract each element in the 'apps' array as a compact object.",
    "expressions": [
      ".apps[]?",
      "jq -c '.apps[]?'"
    ],
    "data": [
      {
        "input": {
          "apps": [
            {
              "name": "Root Certification Authority - G2",
              "expiryDate": "Monday, 09 October 2023 20:03:25",
              "impactStatement": "Apps using this root certificate will have an actual impact",
              "notifyBeforeInDays": 60
            },
            {
              "name": "Bamboo",
              "expiryDate": "Sunday, 20 November 2022 03:25:23",
              "impactStatement": "CI/CD wont be working",
              "sop": "https://somelink/Bamboo+SOPs",
              "notifyBeforeInDays": 30
            },
            {
              "name": "Vault - Client",
              "expiryDate": "Monday, 09 October 2023 20:03:25",
              "impactStatement": "All Mule applications for that particular environment will stop working",
              "notifyBeforeInDays": 60
            },
            {
              "name": "Consul",
              "expiryDate": "Monday, 21 August 2023 14:43:56",
              "impactStatement": "No Direct impact or never had any such scenario so far",
              "notifyBeforeInDays": 30
            },
            {
              "name": "bitbucket",
              "expiryDate": "08 September 2021 13:16:06",
              "impactStatement": "No Impact",
              "notifyBeforeInDays": 15
            }
          ]
        },
        "output": [
          {
            "name": "Root Certification Authority - G2",
            "expiryDate": "Monday, 09 October 2023 20:03:25",
            "impactStatement": "Apps using this root certificate will have an actual impact",
            "notifyBeforeInDays": 60
          },
          {
            "name": "Bamboo",
            "expiryDate": "Sunday, 20 November 2022 03:25:23",
            "impactStatement": "CI/CD wont be working",
            "sop": "https://somelink/Bamboo+SOPs",
            "notifyBeforeInDays": 30
          },
          {
            "name": "Vault - Client",
            "expiryDate": "Monday, 09 October 2023 20:03:25",
            "impactStatement": "All Mule applications for that particular environment will stop working",
            "notifyBeforeInDays": 60
          },
          {
            "name": "Consul",
            "expiryDate": "Monday, 21 August 2023 14:43:56",
            "impactStatement": "No Direct impact or never had any such scenario so far",
            "notifyBeforeInDays": 30
          },
          {
            "name": "bitbucket",
            "expiryDate": "08 September 2021 13:16:06",
            "impactStatement": "No Impact",
            "notifyBeforeInDays": 15
          }
        ]
      }
    ],
    "identifier": 65014334
  },
  {
    "context": [
      "can i assign to a variable and use back in my bash script?",
      "export test=\"jq '(.metadata.labels.istio, .spec.selector.istio)|=\\\"internal-ingressgateway\\\"'\"",
      "when i echoed, it is showing correctly and i am able to execute that query but when i try to run it in the script, it is not working.",
      "To make this work, you'll have to escape the inner double-quotation marks:",
      "export test=\"jq '(.metadata.labels.istio, .spec.selector.istio)|=\\\"internal-ingressgateway\\\"'\""
    ],
    "utterance": "Assign a jq filter that sets both .metadata.labels.istio and .spec.selector.istio to \"internal-ingressgateway\" to a bash variable for later use in a script.",
    "expressions": [
      "export test=\"jq '(.metadata.labels.istio, .spec.selector.istio)|=\\\"internal-ingressgateway\\\"'\""
    ],
    "identifier": 65046497
  },
  {
    "context": [
      "Figure out a `jq` query to return `\"3\"\"5\"\"2\"`.",
      "I tried `jq -n '[inputs] | unique[]'`, but this reorders results.",
      "Here is an extract, omitting two defs that are unnecessary for defining `uniques/1`:",
      "# Produce a stream of the distinct elements in the given stream\ndef uniques(stream):\n  bag(stream)\n  | to_entries[]\n  | .key as $type\n  | .value\n  | to_entries[]\n  | if $type == \"string\" then .key else .key|fromjson end ;"
    ],
    "utterance": "Remove duplicate elements from a stream while preserving the order of their first occurrence.",
    "expressions": [
      "def bag(stream): reduce stream as $x ({}; .[$x|type][$x|tostring] += 1 );\ndef uniques(stream): bag(stream) | to_entries[] | .key as $type | .value | to_entries[] | if $type == \"string\" then .key else .key|fromjson end ;\nuniques(inputs)"
    ],
    "data": [
      {
        "input": [
          "3",
          "5",
          "2",
          "2"
        ],
        "output": [
          "3",
          "5",
          "2"
        ]
      }
    ],
    "identifier": 65039429
  },
  {
    "context": [
      "My goal is to get this response into:",
      "{\n\t\"id\": 44,\n\t\"extra_domain_id\": 3,\n\t\"extra_domain_name\": \"person\",\n\t\"extra_entity_label\": \"Noon\",\n\t\"extra_entity_serial\": 8938493\n}, ...",
      "Notice how in the third item with `id` 46, `domain.name` is missing in the last two entries, 91 and 92 of the `extra` array, so they're replaced with null.",
      "This is what I tried\n\n    {\"id\": .id, \"extra_domain_id\": .extra[].domain.id, \"extra_domain_name\": .extra[].domain.name, \"extra_entity_label\": .extra[].entity.label, \"extra_entity_serial\": .extra[].entity.serial}\n\nbut it doesn't give me the desired output, it returns a cartesian product of all possible combinations in each item in the response!",
      "one possible solution would be to use an invocation such as:\n\n    jq -nf program.jq input.json\n\nwhere program.jq contains:\n```\n\n[inputs\n | {id} +\n   ((.extra[]? // {})\n    | {\"extra_domain_id\": .domain.id,\n       \"extra_domain_name\": .domain.name,\n       \"extra_entity_label\": .entity.label,\n       \"extra_entity_serial\": .entity.serial} ) ]\n```\nThis produces an array with the desired objects.",
      "If you wanted a stream of valid JSON objects as the output, you could simplify things a bit by dropping the `-n` option and the use of `inputs` to wrap everything into an array."
    ],
    "utterance": "For each item, flatten each element in the extra array into a new object containing id, extra_domain_id, extra_domain_name, extra_entity_label, and extra_entity_serial, filling missing fields with nulls; if extra is null, emit a single object with all extra fields null.",
    "expressions": [
      "[.[] | (.extra // [null])[] | {id, extra_domain_id: .domain?.id, extra_domain_name: .domain?.name, extra_entity_label: .entity?.label, extra_entity_serial: .entity?.serial}]"
    ],
    "data": [
      {
        "input": [
          {
            "id": 44,
            "extra": [
              {
                "domain": {
                  "id": 3,
                  "name": "person"
                },
                "entity": {
                  "label": "Noon",
                  "serial": 8938493
                }
              },
              {
                "domain": {
                  "id": 4,
                  "name": "place"
                },
                "entity": {
                  "label": "Rad",
                  "serial": 8932321
                }
              }
            ]
          },
          {
            "id": 45,
            "extra": null
          },
          {
            "id": 46,
            "extra": [
              {
                "domain": {
                  "id": 90,
                  "name": "animal"
                },
                "entity": {
                  "label": "Foo",
                  "serial": 892121
                }
              },
              {
                "domain": {
                  "id": 91
                },
                "entity": {
                  "label": "Ear",
                  "serial": 823414
                }
              },
              {
                "domain": {
                  "id": 92
                },
                "entity": {
                  "label": "Owl",
                  "serial": 889232
                }
              }
            ]
          }
        ],
        "output": [
          {
            "id": 44,
            "extra_domain_id": 3,
            "extra_domain_name": "person",
            "extra_entity_label": "Noon",
            "extra_entity_serial": 8938493
          },
          {
            "id": 44,
            "extra_domain_id": 4,
            "extra_domain_name": "place",
            "extra_entity_label": "Rad",
            "extra_entity_serial": 8932321
          },
          {
            "id": 45,
            "extra_domain_id": null,
            "extra_domain_name": null,
            "extra_entity_label": null,
            "extra_entity_serial": null
          },
          {
            "id": 46,
            "extra_domain_id": 90,
            "extra_domain_name": "animal",
            "extra_entity_label": "Foo",
            "extra_entity_serial": 892121
          },
          {
            "id": 46,
            "extra_domain_id": 91,
            "extra_domain_name": null,
            "extra_entity_label": "Ear",
            "extra_entity_serial": 823414
          },
          {
            "id": 46,
            "extra_domain_id": 92,
            "extra_domain_name": null,
            "extra_entity_label": "Owl",
            "extra_entity_serial": 889232
          }
        ]
      }
    ],
    "identifier": 65000653
  },
  {
    "context": [
      "I would like to convert JSON string into \"key=value\" format separated by commas.",
      "{ \"foo\": \"bar\", \"number\": 123 }",
      "Should be converted into",
      "foo=bar, number=123",
      "I'm having a hard time to achieve this dynamically, without knowing the names of the fields before hand.",
      "to_entries | map(join(\"=\")) | join(\", \")"
    ],
    "utterance": "Convert an object into a comma-separated string of key=value pairs, without knowing the keys in advance.",
    "expressions": [
      "to_entries | map(join(\"=\")) | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "number": 123
        },
        "output": "foo=bar, number=123"
      },
      {
        "input": {
          "time_utc": 1606488980,
          "Temperature": -0.3,
          "Humidity": 100,
          "min_temp": -1.4,
          "max_temp": -0.2,
          "date_max_temp": 1606476880,
          "date_min_temp": 1606428232,
          "temp_trend": "stable"
        },
        "output": "time_utc=1606488980, Temperature=-0.3, Humidity=100, min_temp=-1.4, max_temp=-0.2, date_max_temp=1606476880, date_min_temp=1606428232, temp_trend=stable"
      }
    ],
    "identifier": 65040990
  },
  {
    "context": [
      "I need to filter it by all such packages by lastModified  attribute with jq",
      "jq '.hits[] | select( .lastModified[:10] <= \"2020-06-25\") | .name'"
    ],
    "utterance": "List the names of all items where lastModified is on or before 2020-06-25.",
    "expressions": [
      ".hits[] | select(.lastModified[:10] <= \"2020-06-25\") | .name"
    ],
    "data": [
      {
        "input": {
          "success": true,
          "results": 6,
          "total": 6,
          "more": false,
          "offset": 0,
          "hits": [
            {
              "path": "/etc/packages/com.change.aem.platform/change-editor-user-accounts-1.3.0.zip",
              "excerpt": "/etc/packages/com.change.aem.platform/change-editor-user-accounts-1.3.0.zip",
              "name": "change-editor-user-accounts-1.3.0.zip",
              "title": "change-editor-user-accounts-1.3.0.zip",
              "lastModified": "2020-06-25 17:50:12",
              "created": "2020-06-25 17:50:12",
              "size": "36 KB",
              "mimeType": "application/zip"
            },
            {
              "path": "/etc/packages/com.change.aem.platform/change-editor-user-accounts-1.3.0.zip/jcr:content/vlt:definition/thumbnail.png",
              "excerpt": "/etc/packages/com.change.aem.platform/change-editor-user-accounts-1.3.0.zip/jcr:content/vlt:definition/thumbnail.png",
              "name": "thumbnail.png",
              "title": "thumbnail.png",
              "lastModified": "2020-06-25 17:50:13",
              "created": "2020-06-25 17:50:13",
              "size": "2 KB",
              "mimeType": "image/png"
            },
            {
              "path": "/etc/packages/com.change.aem.platform/.snapshot/change-editor-user-accounts-1.3.0.zip",
              "excerpt": "/etc/packages/com.change.aem.platform/.snapshot/change-editor-user-accounts-1.3.0.zip",
              "name": "change-editor-user-accounts-1.3.0.zip",
              "title": "change-editor-user-accounts-1.3.0.zip",
              "lastModified": "2020-06-25 17:50:13",
              "created": "2020-06-25 17:50:13",
              "size": "7 KB",
              "mimeType": "application/zip"
            },
            {
              "path": "/etc/packages/com.change.aem.platform/.snapshot/change-editor-user-groups-1.7.0.zip",
              "excerpt": "/etc/packages/com.change.aem.platform/.snapshot/change-editor-user-groups-1.7.0.zip",
              "name": "change-editor-user-groups-1.7.0.zip",
              "title": "change-editor-user-groups-1.7.0.zip",
              "lastModified": "2020-06-25 17:50:13",
              "created": "2020-06-25 17:50:13",
              "size": "12 KB",
              "mimeType": "application/zip"
            },
            {
              "path": "/etc/packages/com.change.aem.platform/change-editor-user-groups-1.7.0.zip",
              "excerpt": "/etc/packages/com.change.aem.platform/change-editor-user-groups-1.7.0.zip",
              "name": "change-editor-user-groups-1.7.0.zip",
              "title": "change-editor-user-groups-1.7.0.zip",
              "lastModified": "2020-06-25 17:50:13",
              "created": "2020-06-25 17:50:13",
              "size": "31 KB",
              "mimeType": "application/zip"
            },
            {
              "path": "/etc/packages/com.change.aem.platform/change-editor-user-groups-1.7.0.zip/jcr:content/vlt:definition/thumbnail.png",
              "excerpt": "/etc/packages/com.change.aem.platform/change-editor-user-groups-1.7.0.zip/jcr:content/vlt:definition/thumbnail.png",
              "name": "thumbnail.png",
              "title": "thumbnail.png",
              "lastModified": "2020-06-25 17:50:13",
              "created": "2020-06-25 17:50:13",
              "size": "2 KB",
              "mimeType": "image/png"
            }
          ]
        },
        "output": [
          "change-editor-user-accounts-1.3.0.zip",
          "thumbnail.png",
          "change-editor-user-accounts-1.3.0.zip",
          "change-editor-user-groups-1.7.0.zip",
          "change-editor-user-groups-1.7.0.zip",
          "thumbnail.png"
        ]
      }
    ],
    "identifier": 64915205
  },
  {
    "context": [
      "I am trying to write a script to parse over an api response using jq. I can get it to work using bash and the cli, but i want to script it in python so i can put a lot more logic into it.",
      "The problem i am having is that i can get the api response but when i try load it using the json.loads() or json.dump() i keep getting the following error:\r\n\r\n    TypeError: the JSON object must be str, bytes or bytearray, not APIResponse",
      "Your problem is that the API response is not JSON; it looks like a javascript call.\r\n\r\nPerhaps the API has a parameter which you can use to insist that the response be valid JSON.  Otherwise, you might find it easiest to strip off the leading `APIResponse(` and the trailing `)`..."
    ],
    "utterance": "Extract the embedded object from a text response wrapped as APIResponse(...) to enable further data processing.",
    "expressions": [
      "sub(\"^APIResponse\\\\((.*)\\\\)$\"; \"\\1\")"
    ],
    "data": [
      {
        "input": "APIResponse({\"data\": {\"color\": \"red\"}})",
        "output": "{\"data\": {\"color\": \"red\"}}"
      }
    ],
    "identifier": 65031256
  },
  {
    "context": [
      "My dedicated servers are generating 2 laptime arrays and I would like to use a script to merge them into a single, new json file, with duplicate \"steamids\" removed (and kept grouped together as they still are) and both arrays under a single loggedTimes {} (so I can feed it to a html script that produces laptimes and a leaderboard). In other words, I want the structure to remain.",
      "jq -n '\n  input as $one\n  | input as $two\n  | ($one + $two)\n  | .loggedTimes.steamids = ($one.loggedTimes.steamids + $two.loggedTimes.steamids)\n'  1.json 2.json"
    ],
    "utterance": "Merge two files combining the 'loggedTimes' objects, ensuring steamids are deduplicated and the hierarchical structure is preserved.",
    "expressions": [
      "jq -n '\n  input as $one\n  | input as $two\n  | ($one + $two)\n  | .loggedTimes.steamids = ($one.loggedTimes.steamids + $two.loggedTimes.steamids)\n'  1.json 2.json"
    ],
    "identifier": 65055484
  },
  {
    "context": [
      "cat json.txt | jq '.members[] | [.name]",
      "print(pyjq.all( \".members[] | [.name]\", {\"members\": [ {\"name\": \"foo\"} ]} ))",
      "[['foo']]"
    ],
    "utterance": "Select all member names from the top-level 'members' array.",
    "expressions": [
      ".members[] | [.name]"
    ],
    "data": [
      {
        "input": {
          "members": [
            {
              "name": "foo"
            },
            {
              "name": "bar"
            }
          ]
        },
        "output": [
          [
            "foo"
          ],
          [
            "bar"
          ]
        ]
      }
    ],
    "identifier": 65074812
  },
  {
    "context": [
      "this outputs a pretty JSON object in Bash, but fails in Powershell:",
      "I am looking for a more nimble approach for prototyping JQ filters and integrating them in PowerShell scripts.",
      "Powershell might want you to escape the double-quotes inside the `&#39;..&#39;` expression. Try",
      "jq --null-input '{ \"key\": \\\"val\\\" }'",
      "or just below as the key names in `jq` don't need an explicit quote",
      "jq --null-input '{ key: \\\"val\\\" }'",
      "From the `jq` manual under - [Invoking jq][1]",
      "> When using the Windows command shell (`cmd.exe`) it's best to use double quotes around your jq program when given on the command-line (instead of the `-f program-file` option), but then double-quotes in the jq program need backslash escaping."
    ],
    "utterance": "Output an object with the key 'key' and the string value 'val' using a one-liner command in PowerShell.",
    "expressions": [
      "jq --null-input \"{ \\\"key\\\": \\\"val\\\" }\""
    ],
    "data": [
      {
        "input": null,
        "output": {
          "key": "val"
        }
      }
    ],
    "identifier": 65074916
  },
  {
    "context": [
      "I want to access six reference links from this list.",
      "jq -r .result.CVE_Items[].cve.references.reference_data[0:5].url result2.json",
      "`.reference_data[0:5]` produces a slice, i.e. an array, so in your query, you would need to itemize it, e.g. by appending []:",
      ".reference_data[0:5][]"
    ],
    "utterance": "Extract the first six reference link URLs from each item's reference_data list.",
    "expressions": [
      ".result.CVE_Items[].cve.references.reference_data[0:6][].url"
    ],
    "identifier": 65109169
  },
  {
    "context": [
      "How to get the value for the `\"bar\"` key?",
      "You can use `select(expr)` to find the object with a key-value `\"k\":\"bar\"` and then you can extract the value of the `\"v\"` key.",
      "$ jq -r '.[] | select(.k == \"bar\") | .v' test.json",
      "2"
    ],
    "utterance": "Select the value associated with key 'v' from the object where key 'k' equals 'bar'.",
    "expressions": [
      ".[] | select(.k == \"bar\") | .v"
    ],
    "data": [
      {
        "input": [
          {
            "k": "foo",
            "v": 1
          },
          {
            "k": "bar",
            "v": 2
          }
        ],
        "output": 2
      }
    ],
    "identifier": 65103269
  },
  {
    "context": [
      "I use [jq][1] to treat the export of my mongodb, but this one is acting strangely on strings values containing whitespaces.",
      "For example, I've got this exported document from a mongodb collection named users (using --jsonArray as mongoexport option), file named mycollectionexported.json:",
      "documents=$(jq -c \".[]\" ./mycollectionexported.json)",
      "When I try to store my newly exported collection into a classic variable using jq, and display it on the stdout, jq is acting quite strangely.",
      "Expected (no newlines):",
      "If the output from jq is a single line, why not just:",
      "echo \"$documents\"",
      "The idea here is that invoking jq with the -c option ensures that the only raw newlines that jq emits will be the ones demarking the items in the stream."
    ],
    "utterance": "Output each element of the JSON array as a single compact line without introducing newlines inside string values containing spaces.",
    "expressions": [
      ".[]",
      "-c .[]"
    ],
    "data": [
      {
        "input": [
          {
            "_id": {
              "$oid": "5fc253c493b9f7363c8d1011"
            },
            "emailVerified": true,
            "disabled": false,
            "isKickstarter": false,
            "isPremiun": false,
            "gender": "Male",
            "nationality": "None",
            "type": "admin",
            "optMarketing": false,
            "optNewsletter": false,
            "cguValidated": true,
            "providers": [],
            "email": "test@reflect.com",
            "displayName": "John Doe",
            "phoneNumber": "0644080050",
            "homeAddress": {
              "street": "rue Pasteur",
              "number": 24,
              "zipcode": 94270,
              "city": "Le Kremlin-Bic\u00eatre",
              "country": "France"
            },
            "familyId": {
              "$oid": "5fc253c493b9f7363c8d1010"
            },
            "createdAt": {
              "$date": "2020-11-28T13:42:28.51Z"
            },
            "updatedAt": {
              "$date": "2020-11-28T13:42:28.51Z"
            },
            "__v": 0
          }
        ],
        "output": "{\"_id\":{\"$oid\":\"5fc253c493b9f7363c8d1011\"},\"emailVerified\":true,\"disabled\":false,\"isKickstarter\":false,\"isPremiun\":false,\"gender\":\"Male\",\"nationality\":\"None\",\"type\":\"admin\",\"optMarketing\":false,\"optNewsletter\":false,\"cguValidated\":true,\"providers\":[],\"email\":\"test@reflect.com\",\"displayName\":\"John Doe\",\"phoneNumber\":\"0644080050\",\"homeAddress\":{\"street\":\"rue Pasteur\",\"number\":24,\"zipcode\":94270,\"city\":\"Le Kremlin-Bic\u00eatre\",\"country\":\"France\"},\"familyId\":{\"$oid\":\"5fc253c493b9f7363c8d1010\"},\"createdAt\":{\"$date\":\"2020-11-28T13:42:28.51Z\"},\"updatedAt\":{\"$date\":\"2020-11-28T13:42:28.51Z\"},\"__v\":0}"
      }
    ],
    "identifier": 65050988
  },
  {
    "context": [
      "To append the object, you can use the idiom:\r\n\r\n    .profiles += [...]\r\n\r\nBecause of the friendly way jq handles `null`, the above will also work initially.",
      "Then you can invoke jq uniformly (without the -n option), e.g.\r\n\r\n```\r\njq --arg name \"$name\" --arg car \"$car\" --arg colour \"$colour\" '\r\n  .profiles += [{ $name, $car, $colour}]\r\n' model.json | sponge model.json\r\n```"
    ],
    "utterance": "Append a new object with variables name, car, and colour to the profiles array in the file, without overwriting existing entries.",
    "expressions": [
      ".profiles += [{ $name, $car, $colour }]"
    ],
    "data": [
      {
        "input": {
          "profiles": [
            {
              "name": "Joe",
              "car": "BMW",
              "colour": "Red"
            }
          ]
        },
        "output": {
          "profiles": [
            {
              "name": "Joe",
              "car": "BMW",
              "colour": "Red"
            },
            {
              "name": "Peter",
              "car": "Nissan",
              "colour": "White"
            }
          ]
        }
      }
    ],
    "identifier": 65090702
  },
  {
    "context": [
      "My Input JSON:\n\n```\n{\n    \"PendingMaintenanceActions\": [\n        {\n            \"ResourceIdentifier\": \"arn:aws:rds:xxxxxx1230000345\",\n            \"PendingMaintenanceActionDetails\": [\n                {\n                    \"Action\": \"hardware-maintenance\",\n                    \"AutoAppliedAfterDate\": \"2020-12-17T08:00:00Z\",\n                    \"ForcedApplyDate\": \"2020-12-18T13:00:00Z\",\n                    \"CurrentApplyDate\": \"2020-12-17T08:00:00Z\",\n                    \"Description\": \"Maintenance on the underlying hardware\"\n                }\n            ]\n        }\n    ]\n}\n```",
      "Required output:\n```\narn:aws:rds:xxxxxx1230000345,hardware-maintenance,2020-12-17T08:00:00Z,Maintenance on the underlying hardware\n```",
      "aws rds ... | jq '.PendingMaintenanceActions[].ResourceIdentifier + \",\" + .PendingMaintenanceActions[].PendingMaintenanceActionDetails[].Action + \",\" + .PendingMaintenanceActions[].PendingMaintenanceActionDetails[].CurrentApplyDate + \",\" + .PendingMaintenanceActions[].PendingMaintenanceActionDetails[].Description'"
    ],
    "utterance": "Extract the resource identifier, action, current apply date, and description as a single comma-separated line.",
    "expressions": [
      ".PendingMaintenanceActions[] | .ResourceIdentifier + \",\" + (.PendingMaintenanceActionDetails[] | .Action + \",\" + .CurrentApplyDate + \",\" + .Description)"
    ],
    "data": [
      {
        "input": {
          "PendingMaintenanceActions": [
            {
              "ResourceIdentifier": "arn:aws:rds:xxxxxx1230000345",
              "PendingMaintenanceActionDetails": [
                {
                  "Action": "hardware-maintenance",
                  "AutoAppliedAfterDate": "2020-12-17T08:00:00Z",
                  "ForcedApplyDate": "2020-12-18T13:00:00Z",
                  "CurrentApplyDate": "2020-12-17T08:00:00Z",
                  "Description": "Maintenance on the underlying hardware"
                }
              ]
            }
          ]
        },
        "output": "arn:aws:rds:xxxxxx1230000345,hardware-maintenance,2020-12-17T08:00:00Z,Maintenance on the underlying hardware"
      }
    ],
    "identifier": 65073609
  },
  {
    "context": [
      "I am reformatting some JSON with JQ into a TSV file.  I am able to create a TSV with the values only, but I cannot figure out how to include a single row with the key values as column headers?",
      "Is there a way to print the keys on the first row only, and then print only the values on the remaining rows, using only JQ?",
      "One way to make such a flat object JSON to a TSV format, using the `@tsv` function would be to do",
      "jq -n '[\"location\", \"timestamp\", \"src_ip\", \"dest_ip\", \"dest_port\"] as $hdr | $hdr, ( inputs | [ .[ $hdr[] ] ] ) | @tsv'"
    ],
    "utterance": "Print a TSV file with specified columns as headers on the first row and only the corresponding values from each object on subsequent rows, with columns: location, timestamp, src_ip, dest_ip, dest_port.",
    "expressions": [
      "[\"location\", \"timestamp\", \"src_ip\", \"dest_ip\", \"dest_port\"] as $hdr | $hdr, ( inputs | [ .[ $hdr[] ] ] ) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1234",
            "host": "6789",
            "proto": "UDP",
            "location": "Boston",
            "timestamp": "2020-12-01T15:13:16.242Z",
            "src_ip": "10.8.25.63",
            "dest_ip": "10.8.1.3",
            "dest_port": 445,
            "message": "Some Information",
            "severity": 1,
            "details": "Some Details",
            "categories": [
              "a",
              "b",
              "c"
            ]
          },
          {
            "id": "5678",
            "host": "4321",
            "proto": "TCP",
            "location": "Atlanta",
            "timestamp": "2020-12-01T15:11:15.929Z",
            "src_ip": "10.8.25.63",
            "dest_ip": "10.80.1.3",
            "dest_port": 445,
            "message": "Other Information",
            "severity": 2,
            "details": "Different Details",
            "categories": [
              "d",
              "e"
            ]
          },
          {
            "id": "1111",
            "host": "2222",
            "proto": "UDP",
            "location": "Chicago",
            "timestamp": "2020-12-01T15:09:45.271Z",
            "src_ip": "10.34.196.12",
            "dest_ip": "10.8.1.3",
            "dest_port": 445,
            "message": "Yet Another",
            "severity": 3,
            "details": "Details Again",
            "categories": [
              "x"
            ]
          }
        ],
        "output": "location\ttimestamp\tsrc_ip\tdest_ip\tdest_port\nBoston\t2020-12-01T15:13:16.242Z\t10.8.25.63\t10.8.1.3\t445\nAtlanta\t2020-12-01T15:11:15.929Z\t10.8.25.63\t10.80.1.3\t445\nChicago\t2020-12-01T15:09:45.271Z\t10.34.196.12\t10.8.1.3\t445"
      }
    ],
    "identifier": 65095500
  },
  {
    "context": [
      "I have a json file which has looks like this:\n\n{\n  \"some_label\": {\n    \"message\": \"a string in English with a $VARIABLE$\",\n    \"description\": \"directions to translators\",\n    \"placeholders\": {\n      \"VARIABLE\": {\n        \"content\": \"{variable}\"\n      }\n    }\n  },\n  // more of the same...\n}\n\nAnd I need that to turn in to \"some-label\": \"a string in English with a {variable}\"",
      "Here is one way of achieving the desired result. It could be simplified further too. At the top level it removes the usage of `to_entries`/`from_entries` by enclosing the whole filter under `with_entries()` and modifying the `.value` field as required\n\n```jq\nwith_entries(\n  .key |= ( gsub(\"_\";\"-\") )  |\n  .value.placeholders as $p  |\n  .value.message as $m       |\n  ( $m | match(\".*\\\\$(.*)\\\\$\") | .captures[0].string ) as $c |\n  ( $p | .[$c].content ) as $v |\n  ( \"\\\\$\" + $c + \"\\\\$\" ) as $t     |\n  .value = ( $m | sub($t; $v) )\n)\n```",
      "output -\n\n{\n  \"some_label\": \"a string in English with a {variable}\"\n}"
    ],
    "utterance": "Replace underscores with dashes in the keys and substitute placeholders like $VARIABLE$ in the message field with the corresponding content from the placeholders object.",
    "expressions": [
      "with_entries(\n  .key |= ( gsub(\"_\";\"-\") )  |\n  .value.placeholders as $p  |\n  .value.message as $m       |\n  ( $m | match(\".*\\\\$(.*)\\\\$\") | .captures[0].string ) as $c |\n  ( $p | .[$c].content ) as $v |\n  ( \"\\\\$\" + $c + \"\\\\$\" ) as $t     |\n  .value = ( $m | sub($t; $v) )\n)"
    ],
    "data": [
      {
        "input": {
          "some_label": {
            "message": "a string in English with a $VARIABLE$",
            "description": "directions to translators",
            "placeholders": {
              "VARIABLE": {
                "content": "{variable}"
              }
            }
          }
        },
        "output": {
          "some-label": "a string in English with a {variable}"
        }
      }
    ],
    "identifier": 65111840
  },
  {
    "context": [
      "I would like to parse so only results with **key** *requirementSourceType* and **value** is only *ABC*. *DEF* should be filtered out.",
      "Expected CSV output:",
      "\"complianceId\",\"status\",\"title\"",
      "\"Report_ID1\",\"FULFILLED\",\"Title of Report ID1\"",
      "\"Report_ID2\",\"FULFILLED\",\"Title of Report ID2\"",
      "\"Report_ID3\",\"FULFILLED\",\"Title of Report ID3\"",
      "jq -r '[\n    .report.moduleReports.COMPLIANCE.items[]\n    | select(.requirementSourceType==\"CIS\")\n    | [.complianceId, .title, .status]\n] | unique | .[] | @csv' report.json"
    ],
    "utterance": "Get a CSV with complianceId, status, and title for all items where requirementSourceType is ABC, omitting those with DEF.",
    "expressions": [
      ".report.moduleReports.COMPLIANCE.items[] | select(.requirementSourceType==\"ABC\") | [.complianceId, .status, .title] | @csv",
      "[.report.moduleReports.COMPLIANCE.items[] | select(.requirementSourceType==\"ABC\") | [.complianceId, .status, .title]] | .[] | @csv"
    ],
    "data": [
      {
        "input": {
          "report": {
            "id": "xxx-xxxxx-xxxx",
            "machineId": "xxx-xxxxx-xxxx",
            "scanDate": "2020-12-03T09:11:28Z",
            "moduleReports": {
              "COMPLIANCE": {
                "complianceCheckVersion": "1.3.1",
                "items": [
                  {
                    "complianceId": "Report_ID1",
                    "title": "Title of Report ID1",
                    "status": "FULFILLED",
                    "requirementSourceType": "ABC"
                  },
                  {
                    "complianceId": "Report_ID2",
                    "title": "Title of Report ID2",
                    "status": "FULFILLED",
                    "requirementSourceType": "ABC"
                  },
                  {
                    "complianceId": "Report_ID3",
                    "title": "Title of Report ID3",
                    "status": "FULFILLED",
                    "requirementSourceType": "DEF"
                  }
                ]
              }
            }
          }
        },
        "output": [
          "\"Report_ID1\",\"FULFILLED\",\"Title of Report ID1\"",
          "\"Report_ID2\",\"FULFILLED\",\"Title of Report ID2\""
        ]
      }
    ],
    "identifier": 65127096
  },
  {
    "context": [
      "jq -r --arg key \"$key\"  '. | .\"Time Series (Daily)\" | .[$key] | .\"1. open\"' newdata.json",
      "Use `| .[$key] |` to get the key from your `$key` variable;",
      "I am using a for loop to iterate over all the keys of \"Time Series (Daily)\" and the keys are generated correctly. There is no issue with that. I then want to use the $key variable in each iteration to get the data I need.",
      "jq -r --arg key \"$key\"  '.\"Time Series (Daily)\" | .[$key] | .\"1. open\"' newdata.json",
      "Or, combined with the for() ... for key in \"${keys[@]}\"; do jq -r --arg key \"$key\"  '.\"Time Series (Daily)\" | .[$key] | .\"1. open\"' newdata.json; done"
    ],
    "utterance": "Extract the value of the '1. open' field for a given date key stored in a Bash variable within a for loop",
    "expressions": [
      ".\"Time Series (Daily)\" | .[$key] | .\"1. open\""
    ],
    "data": [
      {
        "input": {
          "Meta Data": {
            "1. Information": "Daily Prices (open, high, low, close) and Volumes",
            "2. Symbol": "AB",
            "3. Last Refreshed": "2020-12-02",
            "4. Output Size": "Compact",
            "5. Time Zone": "US/Eastern"
          },
          "Time Series (Daily)": {
            "2020-12-02": {
              "1. open": "32.6700",
              "2. high": "33.3300",
              "3. low": "32.5000",
              "4. close": "33.1200",
              "5. volume": "273799"
            },
            "2020-12-01": {
              "1. open": "32.1500",
              "2. high": "32.8000",
              "3. low": "32.0000",
              "4. close": "32.6000",
              "5. volume": "265086"
            },
            "2020-11-30": {
              "1. open": "32.3800",
              "2. high": "32.4900",
              "3. low": "31.7500",
              "4. close": "31.8700",
              "5. volume": "251970"
            }
          }
        },
        "output": "32.6700"
      }
    ],
    "identifier": 65128519
  },
  {
    "context": [
      "I am only interested in specific roles, say `role1`, `role3`, and `role4`. I want to produce a CSV formatted as:\r\n\r\n```\r\nusername,role1?,role3?,role4?\r\n```\r\n\r\ne.g.,\r\n\r\n```\r\njanedoe,true,false,true\r\n```",
      "The part I haven&#39;t figured out is how to output booleans or Y / N in response to the values in the list object. Is this something I can do in `jq` itself?",
      "jq -r --argjson whitelist '[\"role1\", \"role3\", \"role4\"]' '\r\n  ([\"username\"] + $whitelist),\r\n  [.username, ($whitelist[] as $w | .roles | index([$w]) != null)]\r\n  | @csv\r\n'",
      "([\"username\"] + $whitelist),\r\n  (.roles as $roles | [.username, ($whitelist[] | IN($roles[]) )])\r\n  | @csv",
      "(reduce .roles[] as $r ({}; .[$r]=true)) as $roles\r\n  | ([\"username\"] + $whitelist),\r\n    [.username, ($roles[$whitelist[]] != null)]\r\n  | @csv"
    ],
    "utterance": "Output a CSV where each row contains the username and, for each of role1, role3, and role4, a boolean indicating if the user has that role.",
    "expressions": [
      "jq -r --argjson whitelist '[\"role1\", \"role3\", \"role4\"]' '([\"username\"] + $whitelist), [.username, ($whitelist[] as $w | .roles | index([$w]) != null)] | @csv'",
      "([\"username\"] + $whitelist), (.roles as $roles | [.username, ($whitelist[] | IN($roles[]) )]) | @csv",
      "(reduce .roles[] as $r ({}; .[$r]=true)) as $roles | ([\"username\"] + $whitelist), [.username, ($roles[$whitelist[]] != null)] | @csv"
    ],
    "data": [
      {
        "input": {
          "username": "janedoe",
          "roles": [
            "role1",
            "role4",
            "role5"
          ]
        },
        "output": [
          "\"username\",\"role1\",\"role3\",\"role4\"",
          "\"janedoe\",true,false,true"
        ]
      }
    ],
    "identifier": 65131942
  },
  {
    "context": [
      "I want to modify the value of `DOMAIN_DISABLE` to true if `DOMAIN` equals `domain1.com`",
      "jq '.DATA |= map(\n        if .DOMAIN == \"domain1.com\"\n        then .DOMAIN_DISABLE = true\n        else .\n        end)' file.json",
      ".DATA |= map((.DOMAIN == \"domain1.com\") as $disable | .DOMAIN_DISABLE |= $disable)",
      "jq '(.DATA[] | select(.DOMAIN == \"domain1.com\")).DOMAIN_DISABLE = true'"
    ],
    "utterance": "Set DOMAIN_DISABLE to true for all elements in DATA where DOMAIN equals \"domain1.com\".",
    "expressions": [
      ".DATA |= map(if .DOMAIN == \"domain1.com\" then .DOMAIN_DISABLE = true else . end)",
      ".DATA |= map((.DOMAIN == \"domain1.com\") as $disable | .DOMAIN_DISABLE |= $disable)",
      "(.DATA[] | select(.DOMAIN == \"domain1.com\")).DOMAIN_DISABLE = true"
    ],
    "data": [
      {
        "input": {
          "ACTION": "domain.list",
          "DATA": [
            {
              "TYPE": "slave",
              "AXFR_IPS": "none",
              "DOMAIN": "domain1.com",
              "TTL_SEC": 0,
              "SOA_EMAIL": "",
              "DOMAINID": 11111,
              "DESCRIPTION": "",
              "EXPIRE_SEC": 0,
              "RETRY_SEC": 0,
              "STATUS": 1,
              "DOMAIN_DISABLE": false,
              "LPM_DISPLAYGROUP": "",
              "REFRESH_SEC": 0
            },
            {
              "TYPE": "slave",
              "AXFR_IPS": "none",
              "DOMAIN": "domain2.net",
              "TTL_SEC": 0,
              "SOA_EMAIL": "",
              "DOMAINID": 22222,
              "DESCRIPTION": "",
              "EXPIRE_SEC": 0,
              "RETRY_SEC": 0,
              "STATUS": 1,
              "DOMAIN_DISABLE": false,
              "LPM_DISPLAYGROUP": "",
              "REFRESH_SEC": 0
            },
            {
              "TYPE": "slave",
              "AXFR_IPS": "none",
              "DOMAIN": "domain3.edu",
              "TTL_SEC": 0,
              "SOA_EMAIL": "",
              "DOMAINID": 33333,
              "DESCRIPTION": "",
              "EXPIRE_SEC": 0,
              "RETRY_SEC": 0,
              "STATUS": 1,
              "DOMAIN_DISABLE": true,
              "LPM_DISPLAYGROUP": "",
              "REFRESH_SEC": 0
            }
          ],
          "ERRORARRAY": []
        },
        "output": {
          "ACTION": "domain.list",
          "DATA": [
            {
              "TYPE": "slave",
              "AXFR_IPS": "none",
              "DOMAIN": "domain1.com",
              "TTL_SEC": 0,
              "SOA_EMAIL": "",
              "DOMAINID": 11111,
              "DESCRIPTION": "",
              "EXPIRE_SEC": 0,
              "RETRY_SEC": 0,
              "STATUS": 1,
              "DOMAIN_DISABLE": true,
              "LPM_DISPLAYGROUP": "",
              "REFRESH_SEC": 0
            },
            {
              "TYPE": "slave",
              "AXFR_IPS": "none",
              "DOMAIN": "domain2.net",
              "TTL_SEC": 0,
              "SOA_EMAIL": "",
              "DOMAINID": 22222,
              "DESCRIPTION": "",
              "EXPIRE_SEC": 0,
              "RETRY_SEC": 0,
              "STATUS": 1,
              "DOMAIN_DISABLE": false,
              "LPM_DISPLAYGROUP": "",
              "REFRESH_SEC": 0
            },
            {
              "TYPE": "slave",
              "AXFR_IPS": "none",
              "DOMAIN": "domain3.edu",
              "TTL_SEC": 0,
              "SOA_EMAIL": "",
              "DOMAINID": 33333,
              "DESCRIPTION": "",
              "EXPIRE_SEC": 0,
              "RETRY_SEC": 0,
              "STATUS": 1,
              "DOMAIN_DISABLE": true,
              "LPM_DISPLAYGROUP": "",
              "REFRESH_SEC": 0
            }
          ],
          "ERRORARRAY": []
        }
      }
    ],
    "identifier": 65112659
  },
  {
    "context": [
      "What I need is to replace the value \r\n\r\n> (\"Value\": \"tpcohen45342@gmail.com\")\r\n\r\nof every email with a dummy email (let's say *\"yahoo@gmail.com\"*),",
      "So I will get a result of something looking like that:\r\n\r\n    [\r\n    \t\"Username\": \"user.rndmgt@restorem.com\",\r\n    \t\"Attributes\": [{\r\n    \t\t\"Name\": \"sub\",\r\n    \t\t\"Value\": \"d0b62a0d-2bc7-447a-af06-bebd68544307\"\r\n    \t}, {\r\n    \t\t\"Name\": \"email_verified\",\r\n    \t\t\"Value\": \"true\"\r\n    \t}, {\r\n    \t\t\"Name\": \"name\",\r\n    \t\t\"Value\": \"c 1\"\r\n    \t}, {\r\n    \t\t\"Name\": \"preferred_username\",\r\n    \t\t\"Value\": \"13109\"\r\n    \t}, {\r\n    \t\t\"Name\": \"email\",\r\n    \t\t\"Value\": \"yahoo@gmail.com\"\r\n    \t}],\r\n    \t\"UserCreateDate\": \"2020-06-22T15:59:50.944Z\",\r\n    \t\"UserLastModifiedDate\": \"2020-06-22T15:59:50.944Z\",\r\n    \t\"Enabled\": true,\r\n    \t\"UserStatus\": \"CONFIRMED\"\r\n    }]",
      "One way:\r\n\r\n```\r\njq 'map(.Attributes |= map(if .Name == \"email\" then \r\n                             .Value = \"yahoo@gmail.com\"\r\n                           else \r\n                              .\r\n                           end))' input.json\r\n```",
      "If the emphasis is on *recursively*, you might wish to consider using `walk`:\r\n\r\n    walk(if type == \"object\"\r\n         and .Name == \"Email\" \r\n         and .Value == \"tpcohen45342@gmail.com\"\r\n         then .Value = \"yahoo@gmail.com\" else . end)\r\n"
    ],
    "utterance": "Replace all values where Name is \"email\" with \"yahoo@gmail.com\" throughout the data.",
    "expressions": [
      "map(.Attributes |= map(if .Name == \"email\" then .Value = \"yahoo@gmail.com\" else . end))",
      "walk(if type == \"object\" and .Name == \"email\" then .Value = \"yahoo@gmail.com\" else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "Username": "user.rndmgt@restorem.com",
            "Attributes": [
              {
                "Name": "sub",
                "Value": "d0b62a0d-2bc7-447a-af06-bebd68544307"
              },
              {
                "Name": "email_verified",
                "Value": "true"
              },
              {
                "Name": "name",
                "Value": "c 1"
              },
              {
                "Name": "preferred_username",
                "Value": "13109"
              },
              {
                "Name": "email",
                "Value": "user.rndmgt@restorem.com"
              }
            ],
            "UserCreateDate": "2020-06-22T15:59:50.944Z",
            "UserLastModifiedDate": "2020-06-22T15:59:50.944Z",
            "Enabled": true,
            "UserStatus": "CONFIRMED"
          }
        ],
        "output": [
          {
            "Username": "user.rndmgt@restorem.com",
            "Attributes": [
              {
                "Name": "sub",
                "Value": "d0b62a0d-2bc7-447a-af06-bebd68544307"
              },
              {
                "Name": "email_verified",
                "Value": "true"
              },
              {
                "Name": "name",
                "Value": "c 1"
              },
              {
                "Name": "preferred_username",
                "Value": "13109"
              },
              {
                "Name": "email",
                "Value": "yahoo@gmail.com"
              }
            ],
            "UserCreateDate": "2020-06-22T15:59:50.944Z",
            "UserLastModifiedDate": "2020-06-22T15:59:50.944Z",
            "Enabled": true,
            "UserStatus": "CONFIRMED"
          }
        ]
      }
    ],
    "identifier": 65074442
  },
  {
    "context": [
      "I need a way to select the \"1. symbol\" attribute of all the records which have a \"matchScore\" greater than 0.5. This is a problematic thing for me to do since the matchScore contains a string, not a number.",
      "Convert the field value from integer to number with tonumber and so:",
      "jq -r '.bestMatches[] | select(.\"9. matchScore\" | tonumber > 0.5) | .\"1. symbol\"'"
    ],
    "utterance": "Select all records where the matchScore is greater than 0.5 and extract the value of the \"1. symbol\" attribute.",
    "expressions": [
      ".bestMatches[] | select(.\"9. matchScore\" | tonumber > 0.5) | .\"1. symbol\"",
      ".bestMatches | map(select(.\"9. matchScore\" | tonumber > 0.5) | .\"1. symbol\")"
    ],
    "data": [
      {
        "input": {
          "bestMatches": [
            {
              "1. symbol": "BA",
              "2. name": "The Boeing Company",
              "3. type": "Equity",
              "4. region": "United States",
              "5. marketOpen": "09:30",
              "6. marketClose": "16:00",
              "7. timezone": "UTC-05",
              "8. currency": "USD",
              "9. matchScore": "1.0000"
            },
            {
              "1. symbol": "BAC",
              "2. name": "Bank of America Corporation",
              "3. type": "Equity",
              "4. region": "United States",
              "5. marketOpen": "09:30",
              "6. marketClose": "16:00",
              "7. timezone": "UTC-05",
              "8. currency": "USD",
              "9. matchScore": "0.8000"
            },
            {
              "1. symbol": "BABA",
              "2. name": "Alibaba Group Holding Limited",
              "3. type": "Equity",
              "4. region": "United States",
              "5. marketOpen": "09:30",
              "6. marketClose": "16:00",
              "7. timezone": "UTC-05",
              "8. currency": "USD",
              "9. matchScore": "0.6667"
            },
            {
              "1. symbol": "GOLD",
              "2. name": "Barrick Gold Corporation",
              "3. type": "Equity",
              "4. region": "United States",
              "5. marketOpen": "09:30",
              "6. marketClose": "16:00",
              "7. timezone": "UTC-05",
              "8. currency": "USD",
              "9. matchScore": "0.5714"
            },
            {
              "1. symbol": "BIDU",
              "2. name": "Baidu Inc.",
              "3. type": "Equity",
              "4. region": "United States",
              "5. marketOpen": "09:30",
              "6. marketClose": "16:00",
              "7. timezone": "UTC-05",
              "8. currency": "USD",
              "9. matchScore": "0.5000"
            },
            {
              "1. symbol": "BAYRY",
              "2. name": "Bayer Aktiengesellschaft",
              "3. type": "Equity",
              "4. region": "United States",
              "5. marketOpen": "09:30",
              "6. marketClose": "16:00",
              "7. timezone": "UTC-05",
              "8. currency": "USD",
              "9. matchScore": "0.4000"
            },
            {
              "1. symbol": "BLDP",
              "2. name": "Ballard Power Systems Inc.",
              "3. type": "Equity",
              "4. region": "United States",
              "5. marketOpen": "09:30",
              "6. marketClose": "16:00",
              "7. timezone": "UTC-05",
              "8. currency": "USD",
              "9. matchScore": "0.3333"
            },
            {
              "1. symbol": "BHC",
              "2. name": "Bausch Health Companies Inc.",
              "3. type": "Equity",
              "4. region": "United States",
              "5. marketOpen": "09:30",
              "6. marketClose": "16:00",
              "7. timezone": "UTC-05",
              "8. currency": "USD",
              "9. matchScore": "0.3333"
            },
            {
              "1. symbol": "BK",
              "2. name": "The Bank of New York Mellon Corporation",
              "3. type": "Equity",
              "4. region": "United States",
              "5. marketOpen": "09:30",
              "6. marketClose": "16:00",
              "7. timezone": "UTC-05",
              "8. currency": "USD",
              "9. matchScore": "0.1538"
            }
          ]
        },
        "output": [
          "BA",
          "BAC",
          "BABA",
          "GOLD"
        ]
      }
    ],
    "identifier": 65121675
  }
]