[
  {
    "context": [
      "Take a look at `jq` it might already do what you are looking for.",
      "jq .messages[0]",
      "jq .node.message.ip"
    ],
    "utterance": "Extract the value of a specific field given a dot-delimited path, such as the first element of 'messages' or the 'ip' field nested in 'result.node'.",
    "expressions": [
      ".messages[0]",
      ".result.node.ip"
    ],
    "data": [
      {
        "input": {
          "status": "fail",
          "messages": [
            "Out of capacity"
          ]
        },
        "output": "Out of capacity"
      },
      {
        "input": {
          "status": "success",
          "messages": [],
          "result": {
            "node": {
              "ip": "1.2.3.4",
              "description": "",
              "id": 974,
              "name": "VM#3"
            }
          }
        },
        "output": "1.2.3.4"
      }
    ],
    "identifier": 14146297
  },
  {
    "context": [
      "I want to get the value foo without typing `.a.b.c.foo`",
      "is there a recursive wild in jq? like **?",
      "In jq 1.4 you could do this:\n\n    $ jq '..|.foo?' file.json",
      "If you're stuck with 1.3 you could use\n\n    $ jq 'recurse(if type == \"array\" or type == \"object\" then .[] else empty end) | if type == \"object\" then . else empty end | .foo' file.json"
    ],
    "utterance": "Retrieve the value associated with the key 'foo' at any depth in the input object without specifying the full path.",
    "expressions": [
      "..|.foo?",
      "recurse(if type == \"array\" or type == \"object\" then .[] else empty end) | if type == \"object\" then . else empty end | .foo"
    ],
    "data": [
      {
        "input": {
          "d": {
            "e": {
              "bar": 2
            }
          },
          "a": {
            "b": {
              "c": {
                "foo": 1
              }
            }
          }
        },
        "output": 1
      }
    ],
    "identifier": 19441454
  },
  {
    "context": [
      "How can I use [`jq`][1] to transform this array of arrays:\r\n\r\n    [\r\n      [\r\n        \"sequence\",\r\n        \"int\"\r\n      ],\r\n      [\r\n        \"time\",\r\n        \"string\"\r\n      ],\r\n      ...\r\n    ]\r\n\r\nInto an array that contains the first (0) element from every subarray? Meaning to produce output like this:\r\n\r\n    [\r\n        \"sequence\",\r\n        \"time\",\r\n        ...\r\n    ]",
      "You can use `map` filter this way:\r\n\r\n    jq 'map(.[0])'",
      "Another option would be `jq '[.[][0]]'` \r\n\r\nthis gives the same result as using `map(.[0])`",
      "Here is a solution using **reduce**\r\n\r\n    reduce .[] as $k ( null; . + [$k[0]] )"
    ],
    "utterance": "Extract the first element from every subarray and collect them into a new array.",
    "expressions": [
      "map(.[0])",
      "[.[][0]]",
      "reduce .[] as $k (null; . + [$k[0]])"
    ],
    "data": [
      {
        "input": [
          [
            "sequence",
            "int"
          ],
          [
            "time",
            "string"
          ]
        ],
        "output": [
          "sequence",
          "time"
        ]
      }
    ],
    "identifier": 18837939
  },
  {
    "context": [
      "I have the following json file:\r\n\r\n    {\r\n        \"FOO\": {\r\n            \"name\": \"Donald\",\r\n            \"location\": \"Stockholm\"\r\n        },\r\n        \"BAR\": {\r\n            \"name\": \"Walt\",\r\n            \"location\": \"Stockholm\"\r\n        },\r\n        \"BAZ\": {\r\n            \"name\": \"Jack\",\r\n            \"location\": \"Whereever\"\r\n        }\r\n    }",
      "I am using jq and want to get the \"name\" elements of the objects where 'location' is 'Stockholm'.",
      "To obtain a stream of just the names:\r\n\r\n    $ jq '.[] | select(.location==\"Stockholm\") | .name' json\r\n\r\nproduces:\r\n\r\n    \"Donald\"\r\n    \"Walt\""
    ],
    "utterance": "Get the name fields of all objects where location is 'Stockholm'.",
    "expressions": [
      ".[] | select(.location==\"Stockholm\") | .name"
    ],
    "data": [
      {
        "input": {
          "FOO": {
            "name": "Donald",
            "location": "Stockholm"
          },
          "BAR": {
            "name": "Walt",
            "location": "Stockholm"
          },
          "BAZ": {
            "name": "Jack",
            "location": "Whereever"
          }
        },
        "output": [
          "Donald",
          "Walt"
        ]
      }
    ],
    "identifier": 18592173
  },
  {
    "context": [
      "I want to just select if it contains a value for \"us-east-1b\", regardless of the other values.",
      "aws elb describe-load-balancers --region us-east-1 | jq '.LoadBalancerDescriptions[] | select((.AvailabilityZones[] | select(. == \"us-east-1b\")) == \"us-east-1b\") | .CanonicalHostedZoneName, .AvailabilityZones'"
    ],
    "utterance": "Return the name and availability zones of each load balancer where the availability zones include \"us-east-1b\".",
    "expressions": [
      ".LoadBalancerDescriptions[] | select((.AvailabilityZones[] | select(. == \"us-east-1b\")) == \"us-east-1b\") | .CanonicalHostedZoneName, .AvailabilityZones"
    ],
    "data": [
      {
        "input": {
          "LoadBalancerDescriptions": [
            {
              "CanonicalHostedZoneName": "example1.us-east-1.elb.amazonaws.com",
              "AvailabilityZones": [
                "us-east-1b",
                "us-east-1c",
                "us-east-1d"
              ]
            },
            {
              "CanonicalHostedZoneName": "example2.us-east-1.elb.amazonaws.com",
              "AvailabilityZones": [
                "us-east-1b",
                "us-east-1c"
              ]
            },
            {
              "CanonicalHostedZoneName": "example3.us-east-1.elb.amazonaws.com",
              "AvailabilityZones": [
                "us-east-1d"
              ]
            }
          ]
        },
        "output": [
          "example1.us-east-1.elb.amazonaws.com",
          [
            "us-east-1b",
            "us-east-1c",
            "us-east-1d"
          ],
          "example2.us-east-1.elb.amazonaws.com",
          [
            "us-east-1b",
            "us-east-1c"
          ]
        ]
      }
    ],
    "identifier": 18796515
  },
  {
    "context": [
      "How can I print out that entry only without printing everything else?",
      "You can use the [select][1] function to get only required entries:",
      "jq 'select(.geo != null)' all.json"
    ],
    "utterance": "Show only entries where the geo field is not null.",
    "expressions": [
      "select(.geo != null)"
    ],
    "identifier": 19573517
  },
  {
    "context": [
      "I would like to get a list of keys, up to a certain depth, for the JSON object.",
      "For example, given an input object like this ... I would like an output like such.\n\n    {\n        \"acquisition_parameters\": [\n            \"laser\",\n            \"date\",\n            \"camera\"\n        ],\n        \"software\": [\n            \"repo\",\n            \"commit\",\n            \"branch\"\n        ]\n    }",
      "The following should do exactly what you want\n\n    jq '[ (keys - [\"data\"])[] as $key | { ($key): .[$key] | keys } ] | add'",
      "Here is another variation uing **reduce** and **setpath** which assumes you have a specific set of top-level keys you want to examine:\n\n  . as $v\n| reduce (\"acquisition_parameters\", \"software\") as $k (\n     {}; setpath([$k]; $v[$k] | keys)\n  )"
    ],
    "utterance": "List the immediate keys of the 'acquisition_parameters' and 'software' top-level objects, omitting the 'data' key.",
    "expressions": [
      "[ (keys - [\"data\"])[] as $key | { ($key): .[$key] | keys } ] | add",
      ". as $v | reduce (\"acquisition_parameters\", \"software\") as $k ({}; setpath([$k]; $v[$k] | keys))"
    ],
    "data": [
      {
        "input": {
          "acquisition_parameters": {
            "laser": {
              "wavelength": {
                "value": 632,
                "units": "nm"
              }
            },
            "date": "02/03/2525",
            "camera": {}
          },
          "software": {
            "repo": "github.com/username/repo",
            "commit": "a7642f",
            "branch": "develop"
          },
          "data": [
            {},
            {},
            {}
          ]
        },
        "output": {
          "acquisition_parameters": [
            "laser",
            "date",
            "camera"
          ],
          "software": [
            "repo",
            "commit",
            "branch"
          ]
        }
      }
    ],
    "identifier": 18972180
  },
  {
    "context": [
      "I am trying to get the difficulty value out of a JSON structure using jq on the linux command line:",
      "./jq '.result.difficulty' status.txt",
      "It yields:",
      "28.20775972"
    ],
    "utterance": "Retrieve the difficulty value located inside the result object where the top-level object contains a result key.",
    "expressions": [
      ".result.difficulty"
    ],
    "data": [
      {
        "input": {
          "result": {
            "version": 1030000,
            "protocolversion": 60001,
            "walletversion": 60000,
            "balance": 2600.0002,
            "blocks": 16042,
            "connections": 6,
            "proxy": "",
            "difficulty": 28.20775972,
            "testnet": false,
            "keypoololdest": 1382340615,
            "keypoolsize": 94,
            "paytxfee": 0.0,
            "mininput": 0.0001,
            "unlocked_until": 0,
            "errors": ""
          },
          "error": null,
          "id": "curltest"
        },
        "output": 28.20775972
      }
    ],
    "identifier": 19703940
  },
  {
    "context": [
      "cast the result from jq into an array",
      "things=($(jq tostring myfile.json) )",
      "OIFS=$IFS",
      "IFS= things=($(jq -r 'tojson|tostring' myfile.json) )",
      "for x in \"${things[@]}\"; do",
      "echo \"-metadata\" \"$x\""
    ],
    "utterance": "Produce output that can be assigned to a bash array, where each element corresponds to an iterated value from the parsed data.",
    "expressions": [
      "jq -r 'tojson|tostring' myfile.json",
      "jq tostring myfile.json"
    ],
    "identifier": 20243696
  },
  {
    "context": [
      "There are a number of tools specifically designed for the purpose of manipulating JSON from the command line, and will be a lot easier and more reliable than doing it with Awk, such as [`jq`][1]:",
      "curl -s 'https://api.github.com/users/lambda' | jq -r '.name'",
      "The first answer for the original question would be:",
      "curl 'http://twitter.com/users/username.json' | jq -r '.text'",
      "You could just [download `jq` binary for your platform](http://stedolan.github.io/jq/download/) and run (`chmod +x jq`):",
      "$ curl 'https://twitter.com/users/username.json' | ./jq -r '.name'",
      "[`jq` homepage](http://stedolan.github.io/jq/) says it is like `sed` for JSON data."
    ],
    "utterance": "Extract the value associated with the key 'text' from the top level of the data returned by the Twitter users API endpoint.",
    "expressions": [
      ".text",
      "jq -r '.text'"
    ],
    "data": [
      {
        "input": {
          "geo_enabled": false,
          "friends_count": 245,
          "profile_text_color": "000000",
          "status": {
            "in_reply_to_screen_name": null,
            "source": "web",
            "truncated": false,
            "text": "My status",
            "favorited": false
          },
          "text": "My status"
        },
        "output": "My status"
      }
    ],
    "identifier": 1955505
  },
  {
    "context": [
      "I now need to convert these strings into one string formatted like\n\n    \"some value; another value; something else;\"",
      "Assuming `.after[]` returns the list of strings you describe, you can do this entirely with jq using **join** to format them as follows:\n\n    [ .after[] ] | join(\"; \") + \";\""
    ],
    "utterance": "Combine all values from the 'after' array into a single string with each value separated by '; ' and ending in a semicolon.",
    "expressions": [
      "[ .after[] ] | join(\"; \") + \";\"",
      ".after | join(\"; \") + \";\""
    ],
    "data": [
      {
        "input": {
          "after": [
            "some value",
            "another value",
            "something else"
          ]
        },
        "output": "\"some value; another value; something else;\""
      }
    ],
    "identifier": 20276744
  },
  {
    "context": [
      "Very good tool for this job is *jq* (https://stedolan.github.io/jq/) where you can do:",
      "jq -S . fileA.json > fileA_fmt.json",
      "jq -S . fileB.json > fileB_fmt.json",
      "Just to update on the answer from bartolomeon_n, you can actually do this all on one line.",
      "diff <(jq -S . fileA.json) <(jq -S . fileB.json)"
    ],
    "utterance": "Sort keys in both files so their structures are normalized for accurate comparison.",
    "expressions": [
      "jq -S . fileA.json",
      "jq -S . fileB.json"
    ],
    "data": [
      {
        "input": [
          {
            "type": 1,
            "children": {
              "nsubj": {
                "role": "topic",
                "POS": [
                  "noun"
                ]
              }
            },
            "role": "vehicle",
            "POS": [
              "noun"
            ]
          }
        ]
      }
    ],
    "identifier": 20850289
  },
  {
    "context": [
      "I managed to get the keys with `jq '. | keys' test.json` but couldn't figure out what to do next.",
      "The problem is you can't convert a k:v object like this straight into csv with `@csv`. It needs to be an array so we need to convert to an array first.",
      "Try this filter:\n\n    to_entries[] | [.key, .value]",
      "Then you can use the `@csv` filter to convert the rows to CSV rows.\n\n    $ echo '{\"123\":\"abc\",\"231\":\"dbh\",\"452\":\"xyz\"}' | jq -r 'to_entries[] | [.key, .value] | @csv'\n    \"123\",\"abc\"\n    \"231\",\"dbh\"\n    \"452\",\"xyz\"",
      "cat input.json | jq 'to_entries | map([.key, .value]|join(\",\"))'",
      "cat input.json | jq 'to_entries | map([.key, .value]|join(\",\"))|join(\"\\n\")'",
      "echo '{\"123\":\"abc\",\"231\":\"dbh\",\"452\":\"xyz\"}' | jq -r 'to_entries | .[] | \"\\\"\" + .key + \"\\\" , \\\"\" + (.value | tostring)+ \"\\\"\"'"
    ],
    "utterance": "Convert an object with dynamic keys and values to a list of CSV rows where each row contains a key and its corresponding value.",
    "expressions": [
      "to_entries[] | [.key, .value] | @csv",
      "to_entries | map([.key, .value] | join(\",\")) | join(\"\\n\")",
      "to_entries | .[] | \"\\\"\" + .key + \"\\\" ,\\\"\" + (.value | tostring) + \"\\\"\""
    ],
    "data": [
      {
        "input": {
          "123": "abc",
          "231": "dbh",
          "452": "xyz"
        },
        "output": [
          "\"123\",\"abc\"",
          "\"231\",\"dbh\"",
          "\"452\",\"xyz\""
        ]
      }
    ],
    "identifier": 20181467
  },
  {
    "context": [
      "I want to use `jq` for processing my `json` file in terminal. I am trying this command:\r\n\r\n    cat json.txt | jq &#39;name&#39;\r\nit&#39;s showing me\r\n\r\n    -bash: /usr/bin/jq: cannot execute binary file\r\n\r\nExpected result:\r\n\r\n    Google",
      "the filter you want to use is:\r\n\r\n    .name\r\n\r\nNote the `.`.  You want to get the value of the `name` property."
    ],
    "utterance": "Extract the value of the top-level property 'name' which should yield 'Google'.",
    "expressions": [
      ".name"
    ],
    "data": [
      {
        "input": {
          "name": "Google",
          "location": {
            "street": "1600 Amphitheatre Parkway",
            "city": "Mountain View",
            "state": "California",
            "country": "US"
          },
          "employees": [
            {
              "name": "Michael",
              "division": "Engineering"
            },
            {
              "name": "Laura",
              "division": "HR"
            },
            {
              "name": "Elise",
              "division": "Marketing"
            }
          ]
        },
        "output": "Google"
      }
    ],
    "identifier": 21902275
  },
  {
    "context": [
      "value=($(jq -r '.key1' jsonFile))",
      "After I run ./mycode.sh the result is aaaa",
      "but if I just run jq -r '.key1' jsonFile the result is aaaa bbbbb"
    ],
    "utterance": "Extract the value of key1 containing spaces and assign it to a Bash variable so that the full value is preserved.",
    "expressions": [
      "value=$(jq -r '.key1' jsonFile)"
    ],
    "data": [
      {
        "input": {
          "key1": "aaaa bbbbb",
          "key2": "cccc ddddd"
        },
        "output": "aaaa bbbbb"
      }
    ],
    "identifier": 22528142
  },
  {
    "context": [
      "How can I count the number of items in the array (here `2`), using `Bash` or a command line (e.g. `underscore`) ?",
      "Try [`jq`][1], a lightweight and flexible command-line JSON processor:\r\n\r\n    jq length /tmp/test.json\r\n\r\nPrints the length of the array of objects.",
      "The shortest expression is \r\n\r\n    curl &#39;http://\u2026&#39; | jq length",
      "If the `JSON` is being read from a file, try this -\r\n\r\n```\r\nnumber_of_objects=`jq &#39;. | length&#39; json_file_name.json`\r\necho $number_of_objects\r\n```"
    ],
    "utterance": "Count the number of top-level items in an array.",
    "expressions": [
      "jq length",
      "jq '. | length'"
    ],
    "data": [
      {
        "input": [
          {
            "cid": 49,
            "pyn": "yi4",
            "hans": "\u4ebf",
            "hant": "\u5104",
            "tid": 68,
            "l10n": "cent million",
            "pid": 1,
            "pos": "num",
            "pos_txt": ""
          },
          {
            "cid": 50,
            "pyn": "yi4",
            "hans": "\u4ebf",
            "hant": "\u5104",
            "tid": 69,
            "l10n": "100 millions",
            "pid": 1,
            "pos": "num",
            "pos_txt": ""
          }
        ],
        "output": 2
      }
    ],
    "identifier": 21334348
  },
  {
    "context": [
      "I need to extract something like this out of it :\r\n\r\n    Classes : 32.56351\r\n    Conditionals : 9.505888\r\n\r\nand so on for all the other values and store it in some array or varaible.",
      "With it, you can try with string interpolation, like:\r\n\r\n    jq -r '\"\\(.name): \\(.ratio)\"' infile\r\n\r\nThat yields:\r\n\r\n    Classes: 32.56351\r\n    Conditionals: 9.505888\r\n    File: 36.30363\r\n    Lines: 13.349417\r\n    Methods: 19.908062\r\n    Packages: 43.75"
    ],
    "utterance": "Extract pairs of name and ratio from each object and output them as lines in the format 'name: ratio' for all entries.",
    "expressions": [
      "\"\\(.name): \\(.ratio)\""
    ],
    "data": [
      {
        "input": [
          {
            "ratio": 32.56351,
            "name": "Classes"
          },
          {
            "ratio": 9.505888,
            "name": "Conditionals"
          },
          {
            "ratio": 36.30363,
            "name": "File"
          },
          {
            "ratio": 13.349417,
            "name": "Lines"
          },
          {
            "ratio": 19.908062,
            "name": "Methods"
          },
          {
            "ratio": 43.75,
            "name": "Packages"
          }
        ],
        "output": [
          "Classes: 32.56351",
          "Conditionals: 9.505888",
          "File: 36.30363",
          "Lines: 13.349417",
          "Methods: 19.908062",
          "Packages: 43.75"
        ]
      }
    ],
    "identifier": 22392819
  },
  {
    "context": [
      "I have a JSON array of Objects:\r\n\r\n    [{key1: value},{key2:value}, ...]\r\n\r\nI would like to reduce these into the following structure:\r\n\r\n    {key1: value, key2: value, ...}",
      "cat myjson.json | jq '.[] | {(.key): value}'\r\n\r\nThis doesn\u2019t quite work as it iterates over each datum rather than reducing it to one Object.",
      "cat myjson.json | jq 'reduce .[] as $item ({}; . + $item)'",
      "Note that jq has a builtin function called 'add' ... you ought to be able to write:\r\n\r\n    jq add myjson.json",
      "reduce .[] as $item ({}; . + $item)",
      "jq add myjson.json"
    ],
    "utterance": "Combine an array of single-key objects into a single object containing all key-value pairs.",
    "expressions": [
      "reduce .[] as $item ({}; . + $item)",
      "add"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value1"
          },
          {
            "key2": "value2"
          },
          {
            "key3": "value3"
          }
        ],
        "output": {
          "key1": "value1",
          "key2": "value2",
          "key3": "value3"
        }
      }
    ],
    "identifier": 22841472
  },
  {
    "context": [
      "I need to select all objects that contain a key named `updateDate`. How do I do that with jq?",
      "The accepted answer also produces `null` for every object that **doesn't** have the key.",
      "What worked for me was:",
      "jq '..|objects|.updateDate//empty'",
      "In that case, use this:",
      "jq '..|objects|select(has(\"updateDate\"))|.updateDate'"
    ],
    "utterance": "Find all values for the key updateDate anywhere in a nested structure, including only objects that actually have that key.",
    "expressions": [
      "..|objects|.updateDate//empty",
      "..|objects|select(has(\"updateDate\"))|.updateDate"
    ],
    "identifier": 23268506
  },
  {
    "context": [
      "But can't make arrays yet. I have\n\n    $ echo $ARR\n    one\n    two\n    three\n\nand want to get something like\n\n    {\n      \"arr\": [\"one\", \"two\", \"three\"]\n    }",
      "Once you have your variable loaded, you should use the [`split`](http://stedolan.github.io/jq/manual/#split) filter to split that string into an array.\n\n    $ jq -n --arg inarr \"${ARR}\" '{ arr: $inarr | split(\"\\n\") }'",
      "The original posting in this thread mentions VAR=\"one two three\".  For such a variable, a very simple solution in jq 1.4 is as follows:\n\n    $ jq -n -c -M --arg s \"$VAR\" '{var: ($s|split(\" \"))}'\n    {\"var\":[\"one\",\"two\",\"three\"]}",
      "If the separator character is a newline, then consider this typescript:\n\n    $ s=$(printf \"a\\nb\\nc\\n\")\n    $ jq -n -c -M --arg var \"$s\" '{\"var\": ($var|split(\"\\n\"))}'\n    {\"var\":[\"a\",\"b\",\"c\"]}"
    ],
    "utterance": "Produce an object with a property whose value is an array of strings, splitting a shell variable by spaces or newlines to form the array.",
    "expressions": [
      "jq -n --arg inarr \"${ARR}\" '{ arr: $inarr | split(\"\\n\") }'",
      "jq -n -c -M --arg s \"$VAR\" '{var: ($s|split(\" \"))}'",
      "jq -n -c -M --arg var \"$s\" '{\"var\": ($var|split(\"\\n\"))}'"
    ],
    "data": [
      {
        "input": {
          "ARR": "one\ntwo\nthree"
        },
        "output": {
          "arr": [
            "one",
            "two",
            "three"
          ]
        }
      },
      {
        "input": {
          "VAR": "one two three"
        },
        "output": {
          "var": [
            "one",
            "two",
            "three"
          ]
        }
      },
      {
        "input": {
          "s": "a\nb\nc\n"
        },
        "output": {
          "var": [
            "a",
            "b",
            "c"
          ]
        }
      }
    ],
    "identifier": 22434290
  },
  {
    "context": [
      "The above command outputs only the values as below:",
      "How can I get the key names instead like the below:",
      "You need to use `jq 'keys[]'`. For example:",
      "`echo '{\"ab\": 1, \"cd\": 2}' | jq -r 'keys[]'` prints all keys one key per line without quotes.",
      "Oddly enough, the accepted answer doesn\u2019t actually answer the Q exactly, so for reference, here is a solution that does:\n\n    $ jq -r 'keys_unsorted[]' file.json",
      "To get the keys on a deeper node in a JSON:\n\necho '{\"data\": \"1\", \"user\": { \"name\": 2, \"phone\": 3 } }' | jq '.user | keys[]'\n\"name\"\n\"phone\""
    ],
    "utterance": "Print all object key names, one per line, without quotes.",
    "expressions": [
      "jq -r 'keys[]'",
      "jq -r 'keys_unsorted[]'"
    ],
    "data": [
      {
        "input": {
          "email": "madireddy@test.com",
          "versionID": "2323",
          "context": "test",
          "date": "02-03-2014-13:41",
          "versionName": "application"
        },
        "output": [
          "email",
          "versionID",
          "context",
          "date",
          "versionName"
        ]
      }
    ],
    "identifier": 23118341
  },
  {
    "context": [
      "current_file_snapshots=$(cat $current_file | jq '.snapshots | length')",
      "jq: command not found",
      "Explicitly spelling out where JQ lives seemed to work:",
      "JQ=/usr/local/bin/jq",
      "and replaced all instances of 'jq' with: $JQ"
    ],
    "utterance": "Count the number of elements under the 'snapshots' key in each file.",
    "expressions": [
      ".snapshots | length"
    ],
    "identifier": 23598328
  },
  {
    "context": [
      "I have `input_file`:\r\n\r\n    {\"hi\":48.0, \"yep\":48.123}\r\n\r\nI run this\r\n\r\n    jq . < input_file > output_file\r\n    cat output_file\r\n\r\nMy output:\r\n\r\n    {\r\n      \"yep\": 48.123,\r\n      \"hi\": 48\r\n    }\r\n\r\nI would like the output to be \r\n\r\n    {\r\n      \"yep\": 48.123,\r\n      \"hi\": 48.0\r\n    }\r\n\r\nHow do I prevent jq from automatically converting my double values to an int?",
      "jq parses numbers into C doubles.  It then formats them back as numbers.  This conversion is lossy in two ways: a) there are many ways to represent the same number, but jq uses only one and has no options to do otherwise, b) C doubles have finite precision."
    ],
    "utterance": "Preserve trailing .0 for floating-point numbers when formatting numeric values such as 48.0.",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": {
          "hi": 48.0,
          "yep": 48.123
        },
        "output": {
          "yep": 48.123,
          "hi": 48
        }
      }
    ],
    "identifier": 23575963
  },
  {
    "context": [
      "I would like to use jq (http://stedolan.github.io/jq/) to parse the json output from aws ec2 describe-instances and return the Instance ID  and Tags only where Tags contains Name. owner, costcentre.",
      "Try this:",
      "$ aws ec2 describe-instances --output json | jq '.Reservations[].Instances[] | (.Tags | from_entries) as $tags | select($tags.Owner != null) | {InstanceID: .InstanceId, Name: $tags.Name, Owner: $tags.Owner, CostCenter: $tags.\"cost.center\"}'",
      "... which returns:",
      "{\n  \"InstanceID\": \"i-734cbc51\",\n  \"Name\": \"someserver001\",\n  \"Owner\": \"john.smith@null\",\n  \"CostCenter\": \"ABC001\"\n}"
    ],
    "utterance": "Return InstanceId, Name, Owner, and CostCenter for each instance where tags include Name, Owner, and cost.center.",
    "expressions": [
      ".Reservations[].Instances[] | (.Tags | from_entries) as $tags | select($tags.Owner != null and $tags.Name != null and $tags.\"cost.center\" != null) | {InstanceID: .InstanceId, Name: $tags.Name, Owner: $tags.Owner, CostCenter: $tags.\"cost.center\"}"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "InstanceId": "i-734cbc51",
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "someserver001"
                    },
                    {
                      "Key": "Owner",
                      "Value": "john.smith@null"
                    },
                    {
                      "Key": "cost.center",
                      "Value": "ABC001"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "InstanceID": "i-734cbc51",
          "Name": "someserver001",
          "Owner": "john.smith@null",
          "CostCenter": "ABC001"
        }
      }
    ],
    "identifier": 22704831
  },
  {
    "context": [
      "I want it to only return the first 10 characters `4ffceab674`.",
      "I\u2019ve tried to test this out with a simple example in the unix terminal:",
      "echo '\"abcdefghi\"' | jq '.[2:4]'",
      "this doesn\u2019t work => jq: error: Cannot index string with object",
      "So, it turns out most of these filters are not yet in the released version.",
      "After that, if indexing still doesn't work for strings, you should, at least, be able to do explode, index, implode combination, which seems to have been your plan."
    ],
    "utterance": "Return the first 10 characters of a string value.",
    "expressions": [
      ".[:10]"
    ],
    "data": [
      {
        "input": "4ffceab674ea8bb5ec421c612536696839bbaccecf64e851dfc270d795ee55d1",
        "output": "4ffceab674"
      },
      {
        "input": "abcdefghi",
        "output": "abcdefghi"
      }
    ],
    "identifier": 23773463
  },
  {
    "context": [
      "I want to use jq map my input\r\n\r\n    [\"a\", \"b\"]\r\n\r\nto output\r\n\r\n    [{name: \"a\", index: 0}, {name: \"b\", index: 1}]",
      "to_entries | map({name:.value, index:.key})",
      "[range(length) as $i | .[$i] | {name: ., index: $i}]",
      "[\"a\", \"b\"] | . as $in | reduce range(0;length) as $i ([]; . + [{\"name\": $in[$i], \"index\": $i}])",
      "keys[] as $k | {name:.[$k], index:$k}",
      "[keys, .] | transpose[] | {name:.[1], index:.[0]}"
    ],
    "utterance": "Transform an array of strings into an array of objects, each containing the string as 'name' and its position as 'index'.",
    "expressions": [
      "to_entries | map({name:.value, index:.key})",
      "[range(length) as $i | .[$i] | {name: ., index: $i}]",
      ". as $in | reduce range(0;length) as $i ([]; . + [{\"name\": $in[$i], \"index\": $i}])",
      "keys[] as $k | {name:.[$k], index:$k}",
      "[keys, .] | transpose[] | {name:.[1], index:.[0]}"
    ],
    "data": [
      {
        "input": [
          "a",
          "b"
        ],
        "output": [
          {
            "name": "a",
            "index": 0
          },
          {
            "name": "b",
            "index": 1
          }
        ]
      }
    ],
    "identifier": 24528256
  },
  {
    "context": [
      "I am trying to assign the KEYS and VALUES to separate arrays, so that I can iterate over them and display them in table format.",
      "these two commands are sorted in different way, I cannot assign the values and keys directly.",
      "Is there anyway to change the sorting of KEYS and VALUES so that both are same?",
      "keys enumerates the keys alphabetically *sorted*.",
      ".[] enumerates the values based on the keys' *input order*",
      "If you use keys to extract an object's *keys* in one pass, and then .[] to extract its *values* in another, the corresponding output elements might not match.",
      "jq v1.5 introduced the keys_unsorted/0 function, which enables a simple solution:",
      "Print ***keys* in input order**, using keys_unsorted/0:",
      "$ echo \"$json\" | jq -r 'keys_unsorted[]'",
      "Print ***values* in input order**, which [] invariably does:",
      "$ echo \"$json\" | jq -r '.[]'",
      "[v1.3+] to_entries/0, as used in [user2259432's helpful answer], also enumerates the properties **in input order**:",
      "# Extract keys\n$ echo \"$json\" | jq -r 'to_entries | map(.key)[]'",
      "# Extract values\n$ echo \"$json\" | jq -r 'to_entries | map(.value)[]'",
      "[v1.3+] If, by contrast, you want to **enumerate in *sorted-by-key* order**:",
      "# Print ***keys* in alphabetically sorted order**, using keys/0:\n$ echo \"$json\" | jq -r 'keys[]'",
      "# Print ***values* by alphabetically sorted keys**:\n$ echo \"$json\" | jq -r 'keys[] as $k | .[$k]'"
    ],
    "utterance": "Extract keys and values from an object in matching order so that each value corresponds to its key, either in input order or in sorted order.",
    "expressions": [
      "keys_unsorted[]",
      "// keys in input order (v1.5+)",
      ".[]",
      "// values in input order",
      "to_entries | map(.key)[]",
      "// keys in input order (v1.3+)",
      "to_entries | map(.value)[]",
      "// values in input order (v1.3+)",
      "keys[]",
      "// keys in sorted order",
      "keys[] as $k | .[$k]",
      "// values in sorted order"
    ],
    "data": [
      {
        "input": {
          "c": 3,
          "a": 1,
          "b": 2
        },
        "output": {
          "input_order_keys": [
            "c",
            "a",
            "b"
          ],
          "input_order_values": [
            3,
            1,
            2
          ],
          "sorted_keys": [
            "a",
            "b",
            "c"
          ],
          "sorted_values": [
            1,
            2,
            3
          ]
        }
      }
    ],
    "identifier": 23120359
  },
  {
    "context": [
      "I\u0019ve got 2 json files and **want to merge them into one unique file**",
      "**expected result**\r\n\r\n    {\r\n        \"value\": {\r\n            \"aaa\": {\r\n                \"value1\": \"v1\",\r\n                \"value2\": \"v2\",\r\n                \"value3\": \"v3\",\r\n                \"value4\": 4\r\n            },\r\n            \"bbb\": {\r\n                \"value1\": \"v1\",\r\n                \"value2\": \"v2\",\r\n                \"value3\": \"v3\"\r\n            },\r\n            \"ccc\": {\r\n                \"value1\": \"v1\",\r\n                \"value2\": \"v2\"\r\n            },\r\n            \"ddd\": {\r\n                \"value3\": \"v3\",\r\n                \"value4\": 4\r\n            }\r\n        }\r\n    }",
      "to recursively merge your two files, with both objects reduced to their `value` field, filter them first using `{value}`:\r\n~~~sh\r\njq '{value} * (input | {value})' file1.json file2.json\r\n~~~\r\n~~~json\r\n{\r\n  \"value\": {\r\n    \"aaa\": {\r\n      \"value1\": \"v1\",\r\n      \"value2\": \"v2\",\r\n      \"value3\": \"v3\",\r\n      \"value4\": 4\r\n    },\r\n    \"bbb\": {\r\n      \"value1\": \"v1\",\r\n      \"value2\": \"v2\",\r\n      \"value3\": \"v3\"\r\n    },\r\n    \"ccc\": {\r\n      \"value1\": \"v1\",\r\n      \"value2\": \"v2\"\r\n    },\r\n    \"ddd\": {\r\n      \"value3\": \"v3\",\r\n      \"value4\": 4\r\n    }\r\n  }\r\n}\r\n~~~",
      "If you also want to get rid of the other keys (like your expected result), one way to do it is this:\r\n\r\n    jq -s '.[0] * .[1] | {value: .value}' file1 file2\r\n\r\nOr the presumably somewhat more efficient (because it doesn't merge any other values):\r\n\r\n    jq -s '.[0].value * .[1].value | {value: .}' file1 file2",
      "the two objects in the two files can be combined in the specified way as follows:\r\n\r\n    $ jq -n --argfile o1 file1 --argfile o2 file2 '$o1 * $o2 | {value}'"
    ],
    "utterance": "Merge the \"value\" objects from two files so that keys and subkeys are combined recursively, producing a single object with only the merged \"value\" key.",
    "expressions": [
      "jq '{value} * (input | {value})' file1.json file2.json",
      "jq -s '.[0].value * .[1].value | {value: .}' file1 file2",
      "jq -s '.[0] * .[1] | {value: .value}' file1 file2",
      "jq -n --argfile o1 file1 --argfile o2 file2 '$o1 * $o2 | {value}'"
    ],
    "data": [
      {
        "input": {
          "file1": {
            "value1": 200,
            "timestamp": 1382461861,
            "value": {
              "aaa": {
                "value1": "v1",
                "value2": "v2"
              },
              "bbb": {
                "value1": "v1",
                "value2": "v2"
              },
              "ccc": {
                "value1": "v1",
                "value2": "v2"
              }
            }
          },
          "file2": {
            "status": 200,
            "timestamp": 1382461861,
            "value": {
              "aaa": {
                "value3": "v3",
                "value4": 4
              },
              "bbb": {
                "value3": "v3"
              },
              "ddd": {
                "value3": "v3",
                "value4": 4
              }
            }
          }
        },
        "output": {
          "value": {
            "aaa": {
              "value1": "v1",
              "value2": "v2",
              "value3": "v3",
              "value4": 4
            },
            "bbb": {
              "value1": "v1",
              "value2": "v2",
              "value3": "v3"
            },
            "ccc": {
              "value1": "v1",
              "value2": "v2"
            },
            "ddd": {
              "value3": "v3",
              "value4": 4
            }
          }
        }
      }
    ],
    "identifier": 19529688
  },
  {
    "context": [
      "I want to list the public IP addresses of my EC2 instances using Bash, separated by a delimiter (space or a new-line).",
      "I tried to pipe the output to [jq][1] with `aws ec2 describe-instances | jq`, but can&#39;t seem to isolate just the IP addresses.",
      "Can this be done by `aws` alone, specifying arguments to `jq`, or something else entirely?"
    ],
    "utterance": "Extract all public IP addresses from describe-instances output.",
    "expressions": [
      ".Reservations[].Instances[].PublicIpAddress"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "InstanceId": "i-0123456789abcdef0",
                  "PublicIpAddress": "203.0.113.42"
                },
                {
                  "InstanceId": "i-0123456789abcdeff",
                  "PublicIpAddress": "198.51.100.23"
                }
              ]
            },
            {
              "Instances": [
                {
                  "InstanceId": "i-0123456789abcdeff1",
                  "PublicIpAddress": "192.0.2.44"
                }
              ]
            }
          ]
        },
        "output": [
          "203.0.113.42",
          "198.51.100.23",
          "192.0.2.44"
        ]
      }
    ],
    "identifier": 24938971
  },
  {
    "context": [
      "I want to print the value of \"Value\" only when \"Key\" is \"Type\". So it should print out \"C\".",
      "Try this:\r\n\r\n    .Tags[] | select(.Key == \"Type\") | .Value"
    ],
    "utterance": "Print the value where the object's Key is equal to \"Type\".",
    "expressions": [
      ".Tags[] | select(.Key == \"Type\") | .Value"
    ],
    "data": [
      {
        "input": {
          "Tags": [
            {
              "Key": "Name",
              "Value": "foo"
            },
            {
              "Key": "Type",
              "Value": "C"
            }
          ]
        },
        "output": "C"
      }
    ],
    "identifier": 25001349
  },
  {
    "context": [
      "I would like to flatten it to get:\r\n\r\n    [\r\n      {\r\n        \"index\": \"index1\",\r\n        \"type\": \"type\",\r\n        \"id\": \"id1\",\r\n        \"deviceOs\": \"Android\",\r\n        \"deviceID\": \"deviceID1\",\r\n        \"country\": \"DE\"\r\n      },\r\n      {\r\n        \"index\": \"index2\",\r\n        \"type\": \"type\",\r\n        \"id\": \"id2\",\r\n        \"deviceOs\": \"Android\",\r\n        \"deviceID\": \"deviceID2\",\r\n        \"country\": \"US\"\r\n      }\r\n    ]",
      "map\n(\n    with_entries(select(.key != \"fields\"))\n    +\n    (.fields | with_entries(.value = .value[0]))\n)",
      "[.[] | {index: .index, type: .type, id: .id, deviceOs: .fields.deviceOs[],deviceID: .fields.deviceID[],country: .fields.country[]}]",
      ".[]\n| . + .fields\n| del(.fields)\n| with_entries( .value = if .value|type == \"array\" then .value[0] else .value end )",
      "jq 'map(. + (.fields | with_entries(.value |= .[])) | del(.fields))'"
    ],
    "utterance": "Flatten objects by moving the entries from 'fields' up one level, replacing array values in 'fields' with their first element, and removing the original 'fields' key.",
    "expressions": [
      "map(with_entries(select(.key != \"fields\")) + (.fields | with_entries(.value = .value[0])))",
      "[.[] | {index: .index, type: .type, id: .id, deviceOs: .fields.deviceOs[],deviceID: .fields.deviceID[],country: .fields.country[]}]",
      ".[] | . + .fields | del(.fields) | with_entries( .value = if .value|type == \"array\" then .value[0] else .value end )",
      "map(. + (.fields | with_entries(.value |= .[])) | del(.fields))"
    ],
    "data": [
      {
        "input": [
          {
            "index": "index1",
            "type": "type1",
            "id": "id1",
            "fields": {
              "deviceOs": [
                "Android"
              ],
              "deviceID": [
                "deviceID1"
              ],
              "type": [
                "type"
              ],
              "country": [
                "DE"
              ]
            }
          },
          {
            "index": "index2",
            "type": "type2",
            "id": "id2",
            "fields": {
              "deviceOs": [
                "Android"
              ],
              "deviceID": [
                "deviceID2"
              ],
              "type": [
                "type"
              ],
              "country": [
                "US"
              ]
            }
          }
        ],
        "output": [
          {
            "index": "index1",
            "type": "type",
            "id": "id1",
            "deviceOs": "Android",
            "deviceID": "deviceID1",
            "country": "DE"
          },
          {
            "index": "index2",
            "type": "type",
            "id": "id2",
            "deviceOs": "Android",
            "deviceID": "deviceID2",
            "country": "US"
          }
        ]
      }
    ],
    "identifier": 24698188
  },
  {
    "context": [
      "Given a JSON object containing a list of students, some personal info, and their grades, return a list of the name, ages, and cumulative gpa for each student that received an A in CSC101.",
      "I only want it to yield the semesters that have an entry for CSC101, but instead it returns all semesters for any student that took CSC101.",
      "Try this filter:",
      ".students | map(\n    {\n        name,\n        age,\n        gpa: .cum_gpa,\n        CSC101: .semesters | map(.grades) | add | .CSC101\n    }\n    |\n    select(.CSC101 == \"A\")\n)",
      "The idea is to merge all grades from all semesters for each student and grab the `CSC101` grade.  Then filter the students out that have an A grade.",
      "This results in:\n[\n  {\n    \"name\": \"John\",\n    \"age\": \"19\",\n    \"gpa\": \"3.83\",\n    \"CSC101\": \"A\"\n  },\n  {\n    \"name\": \"Mary\",\n    \"age\": \"20\",\n    \"gpa\": \"3.50\",\n    \"CSC101\": \"A\"\n  }\n]"
    ],
    "utterance": "Return the name, age, and cumulative gpa for each student who received an A in CSC101.",
    "expressions": [
      ".students | map({name, age, gpa: .cum_gpa, CSC101: .semesters | map(.grades) | add | .CSC101}) | map(select(.CSC101 == \"A\"))"
    ],
    "data": [
      {
        "input": {
          "students": [
            {
              "name": "John",
              "age": "19",
              "gender": "m",
              "from": "Tampa, FL",
              "cum_gpa": "3.83",
              "semesters": [
                {
                  "name": "201302",
                  "gpa": "3.67",
                  "grades": {
                    "CSC101": "A",
                    "MAT101": "A",
                    "PSY101": "B"
                  }
                },
                {
                  "name": "201401",
                  "gpa": "4.00",
                  "grades": {
                    "CSC201": "A",
                    "MAT201": "A",
                    "HIS101": "A"
                  }
                }
              ]
            },
            {
              "name": "Mary",
              "age": "20",
              "gender": "f",
              "from": "Chicago, IL",
              "cum_gpa": "3.50",
              "semesters": [
                {
                  "name": "201302",
                  "gpa": "4.00",
                  "grades": {
                    "CSC101": "A",
                    "MAT101": "A",
                    "ECO101": "A"
                  }
                },
                {
                  "name": "201401",
                  "gpa": "3.00",
                  "grades": {
                    "CSC201": "B",
                    "MAT201": "B",
                    "HUM101": "B"
                  }
                }
              ]
            },
            {
              "name": "Dan",
              "age": "20",
              "gender": "m",
              "from": "Seattle, WA",
              "cum_gpa": "3.33",
              "semesters": [
                {
                  "name": "201302",
                  "gpa": "3.33",
                  "grades": {
                    "CHE101": "B",
                    "MAT101": "A",
                    "PSY101": "B"
                  }
                },
                {
                  "name": "201401",
                  "gpa": "3.33",
                  "grades": {
                    "CHE201": "A",
                    "MAT201": "A",
                    "HUM101": "C"
                  }
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "John",
            "age": "19",
            "gpa": "3.83",
            "CSC101": "A"
          },
          {
            "name": "Mary",
            "age": "20",
            "gpa": "3.50",
            "CSC101": "A"
          }
        ]
      }
    ],
    "identifier": 24875419
  },
  {
    "context": [
      "I\u00019m trying to simplify the output, to show the 'name' field if present, and always show the id.",
      "If the goal is to produce:\r\n\r\n    {\"id\":\"id-1\",\"name\":\"name-1\"}\r\n    {\"id\":\"id-2\"}\r\n\r\nthen the following three expressions are essentially equivalent solutions:\r\n\r\n    .[] | if .tags.key == \"name\" then {id, name: .tags.value} else {id} end",
      "You could just add a conditional removal using [`if .. then .. else .. end`][1]:\r\n\r\n    | if .name == null then del(.name) else . end\r\n\r\nWith your test data, the following\r\n\r\n      .[]\r\n    | {id, name:.tags.value }\r\n    | if .name == null then del(.name) else . end\r\n\r\nproduces\r\n\r\n    {\r\n      \"id\": \"id-1\",\r\n      \"name\": \"name-1\"\r\n    }\r\n    {\r\n      \"id\": \"id-2\"\r\n    }",
      "Here are two additional possible solutions to the problem:\r\n\r\n* `.[] | { id, name: .tags | select(.key == \"name\").value } // { id }`\r\n* `.[] | { id } + ({ name: .tags | select(.key == \"name\").value } // {})`"
    ],
    "utterance": "Return a list of records each with id and, only if present, name where name comes from tags.value if tags.key equals \"name\".",
    "expressions": [
      ".[] | if .tags.key == \"name\" then {id, name: .tags.value} else {id} end",
      ".[] | {id} + (if .tags.key == \"name\" then {name: .tags.value} else {} end)",
      ".[] | (select(.tags.key  == \"name\") | {id, name: .tags.value}) // {id}",
      ".[] | { id, name: .tags | select(.key == \"name\").value } // { id }",
      ".[] | { id } + ({ name: .tags | select(.key == \"name\").value } // {})",
      ".[] | {id, name:.tags.value} | if .name == null then del(.name) else . end"
    ],
    "data": [
      {
        "input": [
          {
            "id": "id-1",
            "tags": {
              "key": "name",
              "value": "name-1"
            }
          },
          {
            "id": "id-2"
          }
        ],
        "output": [
          {
            "id": "id-1",
            "name": "name-1"
          },
          {
            "id": "id-2"
          }
        ]
      }
    ],
    "identifier": 24977872
  },
  {
    "context": [
      "Basically, I need to produce this output using jq, which is similar to the result of sql join:",
      "[{\"type\": \"item\", \"title\": \"item-1\", \"folder\": \"folder-1\"}, {\"type\": \"item\", \"title\": \"item-2\", \"folder\": \"folder-2\"}, {\"type\": \"item\", \"title\": \"item-3\"}]",
      "Here is another solution which works by separating the data into two objects `$folders` and `$items` and then constructing the desired result.",
      "if .folder == null then del(.folder) else .folder = $folders[.folder].title end"
    ],
    "utterance": "For all elements of type 'item', replace the 'folder' id with the corresponding folder's title, and omit the 'folder' field if it is missing.",
    "expressions": [
      "(\n  reduce map(select(.type == \"folder\"))[] as $f (\n    {} ; .[$f.id] = $f\n  )\n) as $folders\n| (\n    reduce map(select(.type == \"item\"))[] as $i (\n      {} ; .[$i.id] = $i\n    )\n  ) as $items\n| [\n      $items[]\n    | {type, title, folder}\n    | if .folder == null then del(.folder) else .folder = $folders[.folder].title end\n  ]",
      "INDEX(.[] | select(.type == \"folder\"); .id) as $folders\n| INDEX(.[] | select(.type == \"item\"); .id) as $items\n| [\n      $items[]\n    | {type, title, folder}\n    | if .folder == null then del(.folder) else .folder = $folders[.folder].title end\n  ]"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "type": "folder",
            "title": "folder-1"
          },
          {
            "id": "2",
            "type": "folder",
            "title": "folder-2"
          },
          {
            "id": "3",
            "type": "item",
            "title": "item-1",
            "folder": "1"
          },
          {
            "id": "4",
            "type": "item",
            "title": "item-2",
            "folder": "2"
          },
          {
            "id": "5",
            "type": "item",
            "title": "item-3"
          }
        ],
        "output": [
          {
            "type": "item",
            "title": "item-1",
            "folder": "folder-1"
          },
          {
            "type": "item",
            "title": "item-2",
            "folder": "folder-2"
          },
          {
            "type": "item",
            "title": "item-3"
          }
        ]
      }
    ],
    "identifier": 25131293
  },
  {
    "context": [
      "In jq, how can I convert a JSON to a string with `key=value`?",
      "From:\n\n    {\n        \"var\": 1,\n        \"foo\": \"bar\",\n        \"x\": \"test\"\n    }\n\nTo:\n\n    var=1\n    foo=bar\n    x=test",
      "You could try:\n\n    jq -r 'to_entries|map(\"\\(.key)=\\(.value|tostring)\")|.[]' test.json",
      "$ echo '{\"var\": 1, \"foo\": \"bar\", \"x\": \"test\"}' | \\\njq -r 'to_entries[]|join(\"=\")'\nvar=1\nfoo=bar\nx=test"
    ],
    "utterance": "Output each object's key and value as key=value pairs, one per line, for a flat object with string or numeric values.",
    "expressions": [
      "to_entries|map(\"\\(.key)=\\(.value|tostring)\")|.[]",
      "to_entries[]|join(\"=\")"
    ],
    "data": [
      {
        "input": {
          "var": 1,
          "foo": "bar",
          "x": "test"
        },
        "output": [
          "var=1",
          "foo=bar",
          "x=test"
        ]
      }
    ],
    "identifier": 25378013
  },
  {
    "context": [
      "What I want to end up with is a tab-delimited file with only the following information:\n\n>OL reference\ttitle\tname\tisbn_10\tisbn_13\tsubjects\tsubject_places\tsubject_people\n\nFor example:\n\n>/books/OL24712550M\tSaving graces\tElizabeth Edwards\t0786291672\t9780786291670\t\"Cancer\", \"Family\", \"Legislators' spouses\", \"Philosophy\", \"Patients\", \"Large type books\", \"Lawyers' spouses\", \"Biography\", \"Protected DAISY\"\t\"United States\", \"North Carolina\"\t\"Elizabeth Edwards (1949-)\", \"John Edwards (1953 June 10-)\"\n\n(In some cases of course some of these fields will be empty.)\n\nSo all of the information I want is in the editions dump except for the 'name' field which comes from the authors dump, looked up by the reference in the editions dump, eg /authors/OL6606949A.",
      "jq '.personal_name as $names | .authors as $authors| {title, name, author: $names[.key]}'"
    ],
    "utterance": "Produce a tab-delimited file for each book including OL reference, title, author name (looked up by author key), isbn_10, isbn_13, subjects, subject_places, and subject_people.",
    "expressions": [
      "jq -r --slurpfile authors authors.json '\n  . as $edition |\n  $edition.authors[0].key as $author_key |\n  $authors[0][] | select(.key == $author_key) | .name as $author_name |\n  \"\n    \"+($edition.key // \"\")+\t+\n    ($edition.title // \"\")+\t+\n    ($author_name // \"\")+\t+\n    ($edition.isbn_10 | join(\", \") // \"\")+\t+\n    ($edition.isbn_13 | join(\", \") // \"\")+\t+\n    ($edition.subjects | join(\", \") // \"\")+\t+\n    ($edition.subject_places | join(\", \") // \"\")+\t+\n    ($edition.subject_people | join(\", \") // \"\")\n  \"'\n"
    ],
    "data": [
      {
        "input": {
          "editions": [
            {
              "key": "/books/OL24712550M",
              "title": "Saving graces",
              "authors": [
                {
                  "key": "/authors/OL6606949A"
                }
              ],
              "isbn_10": [
                "0786291672"
              ],
              "isbn_13": [
                "9780786291670"
              ],
              "subjects": [
                "Cancer",
                "Family"
              ],
              "subject_places": [
                "United States",
                "North Carolina"
              ],
              "subject_people": [
                "Elizabeth Edwards (1949-)",
                "John Edwards (1953 June 10-)"
              ]
            }
          ],
          "authors": [
            {
              "key": "/authors/OL6606949A",
              "name": "Elizabeth Edwards"
            }
          ]
        },
        "output": "/books/OL24712550M\tSaving graces\tElizabeth Edwards\t0786291672\t9780786291670\tCancer, Family\tUnited States, North Carolina\tElizabeth Edwards (1949-), John Edwards (1953 June 10-)"
      }
    ],
    "identifier": 24067809
  },
  {
    "context": [
      "I want to generate a json in this format:\n\n    {\n      \"Project\": [\n        {\n          \"projectName\": {\n            \"branch\": [\n              {\n                \"branchName\": [\n                  \"path\"\n                ]\n              }\n            ],\n            \"tag\": [\n              {\n                \"tagName\": [\n                  \"path\"\n                ]\n              }\n            ]\n          }\n        }\n      ]\n    }",
      "when I want to create another entry in the same project and name, it creates a whole new entry ... But I would like to have\n\n    {\n      \"Project\": [\n        {\n          \"projectName\": {\n            \"branch\": [\n              {\n                \"branchName\": [\n                  \"path\",\n                  \"path2\"\n                ]\n              }\n            ],\n            \"tag\": [\n              {\n                \"tagName\": [\n                  \"path\",\n                  \"path2\"\n                ]\n              }\n            ]\n          }\n        }\n      ]\n    }",
      "cat test.json | jq '.Project[0].projectName.tag[0].tagName |= .+ [\"path2\"] | .Project[0].projectName.branch[0].branchName |= .+ [\"path2\"]'",
      "The `|= .+ [...]` essentially appends a new array item.",
      "jq \".Project.${Project}.tag.${Tag} |= .+ [\\\"${ProjectNumber}\\\"] | .Project.${Project}.branch.${Branch} |= .+ [\\\"${ProjectNumber}\\\"]\""
    ],
    "utterance": "Append the value \"path2\" to both the 'branchName' and 'tagName' arrays within the first project's branches and tags.",
    "expressions": [
      ".Project[0].projectName.tag[0].tagName |= .+ [\"path2\"] | .Project[0].projectName.branch[0].branchName |= .+ [\"path2\"]"
    ],
    "data": [
      {
        "input": {
          "Project": [
            {
              "projectName": {
                "branch": [
                  {
                    "branchName": [
                      "path"
                    ]
                  }
                ],
                "tag": [
                  {
                    "tagName": [
                      "path"
                    ]
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "Project": [
            {
              "projectName": {
                "branch": [
                  {
                    "branchName": [
                      "path",
                      "path2"
                    ]
                  }
                ],
                "tag": [
                  {
                    "tagName": [
                      "path",
                      "path2"
                    ]
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 25414854
  },
  {
    "context": [
      "How can I use [jq][1] to select and show only the JSON values that have \"blue\" in their \"items\" array?",
      "jq 'select(.items | index(\"blue\"))'",
      "select([.items[] == \"blue\"] | any)",
      "select( any( .items[]; . == \"blue\" ))",
      "select( .items as $items | \"blue\" | IN($items[]) )",
      "jq 'select(.items[]|test(\"bl.*\"))' yourfile.json"
    ],
    "utterance": "Select all objects where the 'items' array contains the value \"blue\".",
    "expressions": [
      "select(.items | index(\"blue\"))",
      "select([.items[] == \"blue\"] | any)",
      "select( any(.items[]; . == \"blue\"))",
      "select(.items as $items | \"blue\" | IN($items[]))",
      "select(.items[] | test(\"bl.*\"))"
    ],
    "data": [
      {
        "input": [
          {
            "items": [
              "blue",
              "green"
            ]
          },
          {
            "items": [
              "yellow",
              "green"
            ]
          },
          {
            "items": [
              "blue",
              "pink"
            ]
          }
        ],
        "output": [
          {
            "items": [
              "blue",
              "green"
            ]
          },
          {
            "items": [
              "blue",
              "pink"
            ]
          }
        ]
      }
    ],
    "identifier": 25649960
  },
  {
    "context": [
      "I have the following JSON data:\r\n \r\n    {\"id\":\"111\",\"case\":\"Y\",\"custom\":{\"speech invoked\":\"no\",\"input method\":\"hard\",\"session ID\":\"420\"}}\r\n\r\nHow can I convert it to CSV format using [jq](http://stedolan.github.io/jq/) so my result looks like this?\r\n\r\n    id,case,session Id,speech invoked,input method\r\n\r\n    111,Y,420,no,hard\r\n",
      "Using jq, you can use this filter:\r\n\r\n    with_entries(select(.key != \"custom\")) + .custom\r\n        | to_entries\r\n        | map(.key), map(.value)\r\n        | @csv\r\n\r\nJust note that written this way, the \"custom\" properties will always be written in the end, no matter what order the properties are in.",
      "Building upon Joe Harris' answer, you can use the @csv filter so that strings are properly quoted and escaped when necessary :\r\n\r\n    jq -r '[.case, .custom.\"speech invoked\", .custom.\"input method\"] | @csv'",
      "Here is another solution.  If `data.json` contains the sample data then\r\n\r\n    jq -M -s -r 'map(.+.custom|del(.custom)) | (.[0]|keys_unsorted), (.[]|[.[]]) | join(\",\")' data.json\r\n\r\nwill produce\r\n\r\n    id,case,speech invoked,input method,session ID\r\n    111,Y,no,hard,420\r\n"
    ],
    "utterance": "Produce a CSV file where the header is id,case,session Id,speech invoked,input method and the first data row is 111,Y,420,no,hard, taking values from the main object and the custom object fields.",
    "expressions": [
      "with_entries(select(.key != \"custom\")) + .custom | to_entries | map(.key), map(.value) | @csv",
      "[.id, .case, .custom.\"session ID\", .custom.\"speech invoked\", .custom.\"input method\"] | @csv",
      "map(.+.custom|del(.custom)) | (.[0]|keys_unsorted), (.[]|[.[]]) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "id": "111",
          "case": "Y",
          "custom": {
            "speech invoked": "no",
            "input method": "hard",
            "session ID": "420"
          }
        },
        "output": [
          "id,case,session Id,speech invoked,input method",
          "111,Y,420,no,hard"
        ]
      }
    ],
    "identifier": 25558456
  },
  {
    "context": [
      "You can try the great [jq][1] tool for parsing JSON in the shell. To de-pretty print with jq, you can use either method below:",
      "cat pretty-printed.json | jq -c .",
      "jq -c . pretty-printed.json",
      "the -c (or --compact-output) tells it to not pretty print (which is the default). The \".\" tells it to return the JSON content \"as is\" unmodified other than the reformatting. It gets dumped back to stdout, so you can redirect output or pipe it to something else."
    ],
    "utterance": "Convert a file containing pretty-printed data into a compact, single-line representation suitable for bulk ingestion, where all unnecessary whitespace is removed.",
    "expressions": [
      "jq -c . pretty-printed.json",
      "cat pretty-printed.json | jq -c ."
    ],
    "data": [
      {
        "input": {
          "version": "4.0",
          "success": true,
          "result": {
            "Focus": 0.000590008,
            "Arc": 12
          }
        },
        "output": "{\"version\":\"4.0\",\"success\":true,\"result\":{\"Focus\":0.000590008,\"Arc\":12}}"
      }
    ],
    "identifier": 25859100
  },
  {
    "context": [
      "Is it possible to use a relative path or name in JQ like the XPath // ?\r\n\r\nOr is it possible to use an wildcard in JQ like .level1.*.level3.element ?",
      "That&#39;s what the `..` filter was meant to represent.  The use would look like this:\r\n\r\n    .level1 | .. | .level3? .element\r\n\r\nNote: you must use the `?` otherwise you&#39;ll get errors as it recurses down objects that do not have the corresponding property.",
      "An alternative to using `?` is to use `objects`, e.g.\r\n\r\n    .level1 | .. | objects | .level3.element",
      "if one wants to retain nulls that do appear as values, then one possibility is to use `paths` as follows:\r\n\r\n    .level1\r\n    | (paths | select( .[-2:] == [\"level3\", \"element\"])) as $path\r\n    | getpath($path)\r\n\r\n(Since `paths` produces a stream of arrays of strings, the above expression produces a stream of the values corresponding to paths ending in .level3.element)\r\n\r\nEquivalently but as a one-liner:\r\n\r\n    .level1 | getpath(paths | select(.[-2:] == [\"level3\",\"element\"]))"
    ],
    "utterance": "Select all values corresponding to element fields located at any .level1.*.level3.element path, using a wildcard-like query.",
    "expressions": [
      ".level1 | .. | .level3? .element",
      ".level1 | .. | objects | .level3.element",
      ".level1 | (paths | select(.[-2:] == [\"level3\", \"element\"])) as $path | getpath($path)",
      ".level1 | getpath(paths | select(.[-2:] == [\"level3\",\"element\"]))"
    ],
    "identifier": 25780807
  },
  {
    "context": [
      "Essentially, I am trying to achieve this - if plants section is TUBERS, add tuber \"yam\" which is of type \"root\"",
      "cat veggies.json | jq '.plants.veggies[] | select(.section == \"TUBERS\") | .values |= . + [{ \"type\": \"root\", \"tuber\": \"yam\" }]'",
      "jq '(.plants.veggies[] | select(.section == \"TUBERS\") | .values) |= . + [{\"type\": \"root\", \"tuber\": \"yam\"}]' veggies.json",
      "This runs a sub-filter: selecting the elements of the veggies array, finding the element with a matching section and yielding the values varray.  Then it appends the object to the values array."
    ],
    "utterance": "Append an object with type \"root\" and tuber \"yam\" to the values array of the section where section equals TUBERS.",
    "expressions": [
      ".plants.veggies[] | select(.section == \"TUBERS\") | .values |= . + [{ \"type\": \"root\", \"tuber\": \"yam\" }]",
      "(.plants.veggies[] | select(.section == \"TUBERS\") | .values) |= . + [{\"type\": \"root\", \"tuber\": \"yam\"}]"
    ],
    "data": [
      {
        "input": {
          "plants": {
            "veggies": [
              {
                "section": "TUBERS",
                "values": [
                  {
                    "tuber": "potato",
                    "type": "stem"
                  }
                ]
              },
              {
                "section": "LEGUMES",
                "values": [
                  {
                    "legume": "beans"
                  },
                  {
                    "legume": "peanuts"
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "plants": {
            "veggies": [
              {
                "section": "TUBERS",
                "values": [
                  {
                    "tuber": "potato",
                    "type": "stem"
                  },
                  {
                    "type": "root",
                    "tuber": "yam"
                  }
                ]
              },
              {
                "section": "LEGUMES",
                "values": [
                  {
                    "legume": "beans"
                  },
                  {
                    "legume": "peanuts"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 25729683
  },
  {
    "context": [
      "Because some media packages fail on first processing, then gets \"picked up\" to be re-processed, they have more than one workflow object. This if-statement searches for the succeeded one between them, and extracts the data with the adjusted jq query",
      "state=$( jq -r '.workflows.workflow[] | select(.state == \"SUCCEEDED\" ) | .operations.operation[] | select(.description == \"Cleaning up\") | .state' < $LINE-curl-final.txt )",
      "if [ \"$state\" = \"SUCCEEDED\" ];then",
      "end_time=$( jq '.workflows.workflow[] | select(.state == \"SUCCEEDED\" ) | .operations.operation[] | select(.description == \"Cleaning up\") | .completed' < $LINE-curl-final.txt )",
      "Note the difference between",
      "jq '.workflows.workflow.operations.operation[] | select(.description == \"Cleaning up\") | .completed'",
      "and",
      "jq '.workflows.workflow[] | select(.state == \"SUCCEEDED\" ) | .operations.operation[] | select(.description == \"Cleaning up\") | .completed'"
    ],
    "utterance": "Extract the 'completed' value of the operation with description 'Cleaning up' within workflows whose state is 'SUCCEEDED'.",
    "expressions": [
      ".workflows.workflow[] | select(.state == \"SUCCEEDED\") | .operations.operation[] | select(.description == \"Cleaning up\") | .completed"
    ],
    "identifier": 25864097
  },
  {
    "context": [
      "I want to group everything with the same \"foo\" and collect the unique values of bar, and then collect the unique values inside of the \"baz\" arrays:",
      "[ {\"foo\":\"one\", \"bar\":[2, 3], \"baz\":[0,2,3,4]}, {\"foo\":\"two\", \"bar\":[3], \"baz\":[1]} ]",
      "jq -s 'group_by(.foo) | map({foo: .[0].foo, bar: map(.bar) | unique, baz: map(.baz) | add | unique})"
    ],
    "utterance": "Group objects by 'foo', collecting unique values of 'bar' and all unique values from all 'baz' arrays in each group.",
    "expressions": [
      "group_by(.foo) | map({foo: .[0].foo, bar: map(.bar) | unique, baz: map(.baz) | add | unique})"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "one",
            "bar": 2,
            "baz": [
              0
            ]
          },
          {
            "foo": "two",
            "bar": 3,
            "baz": [
              1
            ]
          },
          {
            "foo": "one",
            "bar": 3,
            "baz": [
              2,
              3
            ]
          },
          {
            "foo": "one",
            "bar": 2,
            "baz": [
              2,
              4
            ]
          }
        ],
        "output": [
          {
            "foo": "one",
            "bar": [
              2,
              3
            ],
            "baz": [
              0,
              2,
              3,
              4
            ]
          },
          {
            "foo": "two",
            "bar": [
              3
            ],
            "baz": [
              1
            ]
          }
        ]
      }
    ],
    "identifier": 26128753
  },
  {
    "context": [
      "Specifically, I want my resulting JSON data structure (that I'll then write some code to parse this JSON structure and create a Redis command file consisting of HSET, etc) to look more like\n\n    [{\n     \"000000\": { \"00000023\": \"INCD1234\",\n                 \"00000027\": \"INCF1423\",\n                  ....\n               },\n     ....\n     \"904293\": { \"90429300\": \"THXX0020\",\n                 \"90429302\": \"THXX0024\",\n                 \"90429305\": \"THXY0013\"}\n     }]\n",
      "The end result is \n\n    {\n       \"000001\": {\n         \"00000130\": \"CAXX3231\",\n         \"00000162\": \"CAXX4606\"\n       },\n       \"000002\": {\n         \"00000238\": \"CAXX1967\",\n         \"00000256\": \"CAXX0727\"\n       },\n       ...\n    }\n",
      "Try this filter instead:\n\n    .[0]\n        | to_entries\n        | group_by(.key[0:6])\n        | map({\n              key:   .[0].key[0:6],\n              value: map(.key=.key[6:8]) | from_entries\n          })\n        | from_entries\n\nGiven data that looks like this:\n\n    [{\n        \"91201544\":\"INXX0019\",\n        \"90429396\":\"THXX0020\",\n        \"20140367\":\"ITXX0043\",\n        \"00000023\":\"INCD1234\",\n        \"00000027\":\"INCF1423\",\n        \"90429300\":\"THXX0020\",\n        \"90429302\":\"THXX0024\",\n        \"90429305\":\"THXY0013\"\n    }]\n\nResults in this:\n\n    {\n      \"000000\": {\n        \"23\": \"INCD1234\",\n        \"27\": \"INCF1423\"\n      },\n      \"201403\": {\n        \"67\": \"ITXX0043\"\n      },\n      \"904293\": {\n        \"00\": \"THXX0020\",\n        \"02\": \"THXX0024\",\n        \"05\": \"THXY0013\",\n        \"96\": \"THXX0020\"\n      },\n      \"912015\": {\n        \"44\": \"INXX0019\"\n      }\n    }",
      "The following is about 40% faster even when the input array has just 100,000 items:\n\n    def compress:\n      . as $in\n      | reduce keys[] as $key ({};\n          $key[0:6] as $k6\n          | $key[6:] as $k2\n          | .[$k6] += {($k2): $in[$key]} );\n\n    .[0] | compress\n\nGiven Jeff's input, the output is identical."
    ],
    "utterance": "Group key-value pairs by the first six digits of each key, making these digits the top-level keys, with values being objects mapping the remaining digits to the original values.",
    "expressions": [
      ".[0]\n    | to_entries\n    | group_by(.key[0:6])\n    | map({\n          key:   .[0].key[0:6],\n          value: map(.key=.key[6:8]) | from_entries\n      })\n    | from_entries",
      "def compress:\n  . as $in\n  | reduce keys[] as $key ({};\n      $key[0:6] as $k6\n      | $key[6:] as $k2\n      | .[$k6] += {($k2): $in[$key]} );\n\n.[0] | compress"
    ],
    "data": [
      {
        "input": [
          {
            "91201544": "INXX0019",
            "90429396": "THXX0020",
            "20140367": "ITXX0043",
            "00000023": "INCD1234",
            "00000027": "INCF1423",
            "90429300": "THXX0020",
            "90429302": "THXX0024",
            "90429305": "THXY0013"
          }
        ],
        "output": {
          "000000": {
            "23": "INCD1234",
            "27": "INCF1423"
          },
          "201403": {
            "67": "ITXX0043"
          },
          "904293": {
            "00": "THXX0020",
            "02": "THXX0024",
            "05": "THXY0013",
            "96": "THXX0020"
          },
          "912015": {
            "44": "INXX0019"
          }
        }
      }
    ],
    "identifier": 24817244
  },
  {
    "context": [
      "I would like to convert a list into JSON array.  I&#39;m looking at `jq` for this but the examples are mostly about parsing JSON (not creating it).  It would be nice to know proper escaping will occur.  My list is single line elements so the new line will probably be the best delimiter.",
      "jq -R -s -c 'split(\"\\n\")' < just_lines.txt",
      "You can also use `jq -R .` to format each line as a JSON string and then `jq -s` (`--slurp`) to create an array for the input lines after parsing them as JSON:\n\n    $ printf %s\\\\n aa bb|jq -R .|jq -s .",
      "cat /etc/hosts  | jq  --raw-input .  | jq --slurp .",
      "jq -nR [inputs] /etc/hosts",
      "$ cat test_file.txt | jq -Rsc '. / \"\\n\" - [\"\"]'"
    ],
    "utterance": "Convert a list of lines in a file, each line being an element, into an array of strings ensuring proper escaping.",
    "expressions": [
      "jq -R -s -c 'split(\"\\n\")' < just_lines.txt",
      "jq -R . | jq -s .",
      "cat /etc/hosts | jq --raw-input . | jq --slurp .",
      "jq -nR [inputs] /etc/hosts",
      "jq -Rsc '. / \"\\n\" - [\"\"]'"
    ],
    "data": [
      {
        "input": "aa\nbb\n",
        "output": [
          "aa",
          "bb"
        ]
      }
    ],
    "identifier": 26287130
  },
  {
    "context": [
      "So, I am looking for \"response\":\"docs\" (which is an array) and then matching every item in that array with \"pub_type\" etc., renaming it, and so on. This works great, but it adds an empty array at the end:",
      "How do I get rid of the empty array?",
      "Use the `select` filter where length > 0.",
      "select(length > 0)"
    ],
    "utterance": "Return only the non-empty result arrays from mapping .response.docs[], dropping any empty array output.",
    "expressions": [
      "[.response.docs[] | {date: .pub_date, type: .document_type, title: .headline.main }] | select(length > 0)"
    ],
    "data": [
      {
        "input": {
          "response": {
            "docs": [
              {
                "pub_date": "2009-01-02T00:00:00Z",
                "document_type": "article",
                "headline": {
                  "main": "SPARE TIMES: AROUND TOWN"
                }
              },
              {
                "pub_date": "2009-01-02T00:00:00Z",
                "document_type": "article",
                "headline": {
                  "main": "Catskill Home Prices: How Low Will They Go?"
                }
              },
              {
                "pub_date": "2009-01-01T00:00:00Z",
                "document_type": "article",
                "headline": {
                  "main": "Ominous Cutbacks At Chanel"
                }
              }
            ]
          }
        },
        "output": [
          {
            "date": "2009-01-02T00:00:00Z",
            "type": "article",
            "title": "SPARE TIMES: AROUND TOWN"
          },
          {
            "date": "2009-01-02T00:00:00Z",
            "type": "article",
            "title": "Catskill Home Prices: How Low Will They Go?"
          },
          {
            "date": "2009-01-01T00:00:00Z",
            "type": "article",
            "title": "Ominous Cutbacks At Chanel"
          }
        ]
      }
    ],
    "identifier": 26195214
  },
  {
    "context": [
      "I want to add another tuber \"yam\", which can have cookstyle \"boil\" - this has to go under the section TUBERS, but uniquely. Meaning, I want to add this tuber only if it is not already there - if it already there, I just want to replace it with whatever \"cookstyle\" I am passing - it could be cookstyle:\"mashed\" as well.",
      "if [ -z ${IS_YAM_PRESENT} ]\nthen\n    jq '(.plants.veggies[] | select(.section == \"TUBERS\") | .values) |= . + [{ \"tuber\": \"yam\", \"cookstyle\": \"boiled\" }]' veggies.json\nelse\n    jq '(.plants.veggies[] | select(.section == \"TUBERS\") | .values[] | select(.tuber == \"yam\")) |= { \"tuber\": \"yam\", \"cookstyle\": \"boiled\" }' veggies.json\nfi",
      "(\n    .plants.veggies[]\n    | select(.section == \"TUBERS\")\n    | .values\n) |= (\n    . + [ {\"cookstyle\": \"boil\", \"tuber\": \"yam\"} ]\n    | unique\n)"
    ],
    "utterance": "Add an object with tuber equal to \"yam\" and cookstyle equal to \"boil\" under the section where section is \"TUBERS\", ensuring that if an entry with tuber \"yam\" already exists, it is replaced with the new cookstyle; otherwise, add it as new.",
    "expressions": [
      "(\n    .plants.veggies[]\n    | select(.section == \"TUBERS\")\n    | .values\n) |= (\n    map(select(.tuber != \"yam\")) + [{\"tuber\": \"yam\", \"cookstyle\": \"boil\"}]\n)"
    ],
    "data": [
      {
        "input": {
          "plants": {
            "veggies": [
              {
                "section": "TUBERS",
                "values": [
                  {
                    "tuber": "potato",
                    "cookstyle": "fry"
                  }
                ]
              },
              {
                "section": "LEGUMES",
                "values": [
                  {
                    "legume": "beans",
                    "cookstyle": "boil"
                  },
                  {
                    "legume": "peanuts",
                    "cookstyle": "salted"
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "plants": {
            "veggies": [
              {
                "section": "TUBERS",
                "values": [
                  {
                    "tuber": "potato",
                    "cookstyle": "fry"
                  },
                  {
                    "tuber": "yam",
                    "cookstyle": "boil"
                  }
                ]
              },
              {
                "section": "LEGUMES",
                "values": [
                  {
                    "legume": "beans",
                    "cookstyle": "boil"
                  },
                  {
                    "legume": "peanuts",
                    "cookstyle": "salted"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 25870599
  },
  {
    "context": [
      "Trying to get result in format",
      "[{name: \"plugin1name\", c_version: \"0.0.1\", n_version: \"0.0.5\"}, {name: \"plugin2name\", c_version: \"0.1.1\", n_version: \"0.1.5\"}]",
      "After fixing your json file, try this command:",
      "jq '\n  .dependencies |\n    to_entries |\n      map(.value |\n        {\n          name: .main.name,\n          c_version: .pkgMeta.version,\n          n_version: .update.latest\n        }\n      )' input.json"
    ],
    "utterance": "Extract a list containing each dependency's name, current version, and latest available version.",
    "expressions": [
      ".dependencies | to_entries | map(.value | {name: .main.name, c_version: .pkgMeta.version, n_version: .update.latest})"
    ],
    "data": [
      {
        "input": {
          "endpoint": {
            "name": "test-plugin",
            "version": "0.0.1"
          },
          "dependencies": {
            "plugin1": {
              "main": {
                "name": "plugin1name",
                "description": "Dummy text"
              },
              "pkgMeta": {
                "name": "plugin1name",
                "version": "0.0.1"
              },
              "dependencies": {},
              "versions": [
                "0.0.5",
                "0.0.4",
                "0.0.3",
                "0.0.2",
                "0.0.1"
              ],
              "update": {
                "latest": "0.0.5"
              }
            },
            "plugin2": {
              "main": {
                "name": "plugin2name",
                "description": "Dummy text"
              },
              "pkgMeta": {
                "name": "plugin2name",
                "version": "0.1.1"
              },
              "dependencies": {},
              "versions": [
                "0.1.5",
                "0.1.4",
                "0.1.3",
                "0.1.2",
                "0.1.1"
              ],
              "update": {
                "latest": "0.1.5"
              }
            }
          }
        },
        "output": [
          {
            "name": "plugin1name",
            "c_version": "0.0.1",
            "n_version": "0.0.5"
          },
          {
            "name": "plugin2name",
            "c_version": "0.1.1",
            "n_version": "0.1.5"
          }
        ]
      }
    ],
    "identifier": 26295285
  },
  {
    "context": [
      "I have the below json file:",
      "I would like to have a CSV file in this format:",
      "`First Name, Last Name, Position, Company Name, Country`",
      "`VALUE, VALUE, VALUE, VALUE, VALUE, VALUE`",
      "Is this possible by using only jq?",
      "Sure it is:",
      ".data | sort_by(.rank) | map(.displayName), map(.value) | @csv"
    ],
    "utterance": "Produce a CSV with each field's displayName as headers and value as the row, ordered by rank.",
    "expressions": [
      ".data | sort_by(.rank) | map(.displayName), map(.value) | @csv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "displayName": "First Name",
              "rank": 1,
              "value": "VALUE"
            },
            {
              "displayName": "Last Name",
              "rank": 2,
              "value": "VALUE"
            },
            {
              "displayName": "Position",
              "rank": 3,
              "value": "VALUE"
            },
            {
              "displayName": "Company Name",
              "rank": 4,
              "value": "VALUE"
            },
            {
              "displayName": "Country",
              "rank": 5,
              "value": "VALUE"
            }
          ]
        },
        "output": "\"First Name\",\"Last Name\",\"Position\",\"Company Name\",\"Country\"\n\"VALUE\",\"VALUE\",\"VALUE\",\"VALUE\",\"VALUE\""
      }
    ],
    "identifier": 26535102
  },
  {
    "context": [
      "I noticed that this works, but I'm skeptical about how it's interpolating ```$v``` within the single quotes. Is it possible to rewrite the expression ```'.[\"\\($v)\"]'``` within double quotes? What am I doing wrong?",
      "Trying the following doesn't work for whatever reason:",
      "recipe_url=$(cat ./*.json | jq -r --arg v \"$recipe_key\" \".[\\\"\\\\($v)\\\"]\")",
      "However, this does:",
      "recipe_key='Wilted Greens' # example key to interpolate",
      "recipe_url=$(cat ./*.json | jq -r --arg v \"$recipe_key\" '.[\"\\($v)\"]') # works!",
      "In my opinion, it is better in this situation to use use `--arg` with single quotes. `--arg` was implemented similar to awk `-v`, to fix exactly this type of situation with quoting headaches.",
      "Single quotes **don't** interpolate variables or evaluate anything else.",
      "The quoting/escaping problem you are having exists only because you are attempting to use double quotes instead of single quotes here."
    ],
    "utterance": "Extract the value of a key whose name is provided in a shell variable using --arg with a jq filter.",
    "expressions": [
      ".[\"\\($v)\"]"
    ],
    "identifier": 26642231
  },
  {
    "context": [
      "I want a list of the volume-ids for `/dev/sdb`, `/dev/sdc` and `/dev/sdd`, respectively.",
      "Also, it\u2019s possible that the `DeviceName` might not always come in the order that I can assume that the 2nd,3rd and 4th elements in the array are in the right order, so I\u2019d like to make sure that the desired output of volume-ids is always in the form: sdb, sdc, sdd if possible.",
      "The following works with jq-1.4,\n\n    ... | jq '.. | select(.DeviceName? as $dn | [\"b\",\"c\",\"d\"] | map($dn == \"/dev/sd\\(.)\") | any) | .Ebs.VolumeId'",
      "If you\u2019re using the latest version where the `test` filter is implemented, you could do this:",
      "    .. | select(.DeviceName? | test(\"/dev/sd[bcd]\")) | .Ebs.VolumeId",
      "Otherwise, you\u2019ll have to make some adjustments:",
      "    .. | select(.DeviceName? == (\"/dev/sdb\",\"/dev/sdc\",\"/dev/sdd\")) | .Ebs.VolumeId"
    ],
    "utterance": "Get the attached volume IDs whose DeviceName is /dev/sdb, /dev/sdc, or /dev/sdd, regardless of their order in the array.",
    "expressions": [
      ".. | select(.DeviceName? | test(\"/dev/sd[bcd]\")) | .Ebs.VolumeId",
      ".. | select(.DeviceName? == (\"/dev/sdb\",\"/dev/sdc\",\"/dev/sdd\")) | .Ebs.VolumeId",
      ".. | select(.DeviceName? as $dn | [\"/dev/sdb\",\"/dev/sdc\",\"/dev/sdd\"] | index($dn)) | .Ebs.VolumeId",
      ".. | select(.DeviceName? as $dn | [\"b\",\"c\",\"d\"] | map($dn == \"/dev/sd\\(.)\") | any) | .Ebs.VolumeId"
    ],
    "data": [
      {
        "input": [
          [
            [
              {
                "DeviceName": "/dev/xvda",
                "Ebs": {
                  "Status": "attached",
                  "DeleteOnTermination": true,
                  "VolumeId": "vol-xvda-xxx",
                  "AttachTime": "2014-10-13T14:40:13.000Z"
                }
              },
              {
                "DeviceName": "/dev/sdb",
                "Ebs": {
                  "Status": "attached",
                  "DeleteOnTermination": false,
                  "VolumeId": "vol-sdb-xxxx",
                  "AttachTime": "2014-10-13T14:40:13.000Z"
                }
              },
              {
                "DeviceName": "/dev/sdc",
                "Ebs": {
                  "Status": "attached",
                  "DeleteOnTermination": false,
                  "VolumeId": "vol-sdc-xxx",
                  "AttachTime": "2014-10-13T14:40:13.000Z"
                }
              },
              {
                "DeviceName": "/dev/sdd",
                "Ebs": {
                  "Status": "attached",
                  "DeleteOnTermination": false,
                  "VolumeId": "vol-sdd-xxx",
                  "AttachTime": "2014-10-13T14:40:13.000Z"
                }
              }
            ]
          ]
        ],
        "output": [
          "vol-sdb-xxxx",
          "vol-sdc-xxx",
          "vol-sdd-xxx"
        ]
      }
    ],
    "identifier": 26417153
  },
  {
    "context": [
      "but what I can't figure out is how to exclude windows servers (or, conversely, only include non-windows servers)",
      "I've also tried doing it on the jq side of the pipe, but my attempts were ridiculous and I will not publish them here.",
      "I think this filter should work.",
      ".Reservations[].Instances |",
      "    map(select(.Platform != \"Windows\") | .NetworkInterfaces[].PrivateIpAddress)"
    ],
    "utterance": "Extract the private IP addresses of all instances whose Platform is not \"Windows\".",
    "expressions": [
      ".Reservations[].Instances | map(select(.Platform != \"Windows\") | .NetworkInterfaces[].PrivateIpAddress)"
    ],
    "identifier": 26789915
  },
  {
    "context": [
      "From this Json input I need to filter apps that have names \"like\" Camfrog (It can be CAMFROG, camfrog .. etc, so the regex has to be case insensitive.along with this, I need to output a series of app_names like, say \"Camfrog\", \"Tubemate\", \"soundcloud\" etc.",
      "I think you&#39;re looking for a combination of `select` `ascii_downcase` and `test`, like so:",
      "$ echo '[{\"thing\": \"foo\"}, {\"thing\":\"Foo\"}, {\"thing\":\"fOo\"}, {\"thing\":\"Bar\"}]' \\\n    | jq '.[] | select(.thing | ascii_downcase | test(\"foo\"))'",
      "`select` takes a list and returns only certain elements from it",
      "`ascii_downcase` converts everything to lowercase",
      "`test` uses a regular expression to see if `select` should include the item or not"
    ],
    "utterance": "Filter objects where the app_name contains Camfrog, Tubemate, or soundcloud, case-insensitively, and return the complete objects.",
    "expressions": [
      ".[] | select(.app_name | ascii_downcase | test(\"camfrog|tubemate|soundcloud\"))"
    ],
    "data": [
      {
        "input": [
          {
            "appid": "537c6d4a9c4846b8bc44ebdf78ab8e2d",
            "app_name": "TubeMate\nYouTube Downloader",
            "publisher_id": "1690d6387fcc441091a2f2d73f89709d"
          },
          {
            "appid": "f8022204aaa7478a88fca1a417ddb125",
            "app_name": "Camfrog\nAndroid Smartphone",
            "publisher_id": "085d0268a9674ce885a2f185ec895246"
          },
          {
            "appid": "agltb3B1Yi1pbmNyDAsSA0FwcBih9tMUDA",
            "app_name": "TuneIn Radio\n- iPad",
            "publisher_id": "agltb3B1Yi1pbmNyEAsSB0FjY291bnQYsv-PFAw"
          },
          {
            "appid": "537c6d4a9c4846b8bc44ebdf78ab8e2d",
            "app_name": "TubeMate\nYouTube Downloader",
            "publisher_id": "1690d6387fcc441091a2f2d73f89709d"
          },
          {
            "appid": "f8022204aaa7478a88fca1a417ddb125",
            "app_name": "Camfrog\nAndroid Smartphone",
            "publisher_id": "085d0268a9674ce885a2f185ec895246"
          },
          {
            "appid": "92255b8b662148e59973b8eca128adde",
            "app_name": "SubwaySimulator3D",
            "publisher_id": "0d78f4d244ec4309b4aa06cdfb871341"
          },
          {
            "appid": "agltb3B1Yi1pbmNyDAsSA0FwcBjq_6EUDA",
            "app_name": "TuneIn\nRadio",
            "publisher_id": "agltb3B1Yi1pbmNyEAsSB0FjY291bnQYsv-PFAw"
          },
          {
            "appid": "f7cc119ca9e1426c8d162d2d37c8558f",
            "app_name": "Android Skout\nNew",
            "publisher_id": "agltb3B1Yi1pbmNyEAsSB0FjY291bnQY7cCnEgw"
          },
          {
            "appid": "agltb3B1Yi1pbmNyDAsSA0FwcBim6MAVDA",
            "app_name": "Draw\nSomething\nAndroid",
            "publisher_id": "agltb3B1Yi1pbmNyEAsSB0FjY291bnQYgYC-FQw"
          }
        ],
        "output": [
          {
            "appid": "537c6d4a9c4846b8bc44ebdf78ab8e2d",
            "app_name": "TubeMate\nYouTube Downloader",
            "publisher_id": "1690d6387fcc441091a2f2d73f89709d"
          },
          {
            "appid": "f8022204aaa7478a88fca1a417ddb125",
            "app_name": "Camfrog\nAndroid Smartphone",
            "publisher_id": "085d0268a9674ce885a2f185ec895246"
          },
          {
            "appid": "537c6d4a9c4846b8bc44ebdf78ab8e2d",
            "app_name": "TubeMate\nYouTube Downloader",
            "publisher_id": "1690d6387fcc441091a2f2d73f89709d"
          },
          {
            "appid": "f8022204aaa7478a88fca1a417ddb125",
            "app_name": "Camfrog\nAndroid Smartphone",
            "publisher_id": "085d0268a9674ce885a2f185ec895246"
          }
        ]
      }
    ],
    "identifier": 25463196
  },
  {
    "context": [
      "I\u2019d like to use [jq](https://stedolan.github.io/jq/) to filter through and select the `features` that possess the `MODE: D` property.",
      "`jq '.features[] | select(.properties.MODE == \"D\")'`",
      "'.features | map(select(.properties.MODE == \"D\"))'"
    ],
    "utterance": "Select all features where the MODE property is equal to \"D\".",
    "expressions": [
      ".features[] | select(.properties.MODE == \"D\")",
      ".features | map(select(.properties.MODE == \"D\"))"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "MODE": "A"
              },
              "geometry": {
                "type": "Point",
                "coordinates": [
                  -69.23583984375,
                  45.460130637921004
                ]
              }
            },
            {
              "type": "Feature",
              "properties": {
                "MODE": "D"
              },
              "geometry": {
                "type": "Point",
                "coordinates": [
                  -69.23651039600372,
                  45.46053888199693
                ]
              }
            }
          ]
        },
        "output": [
          {
            "type": "Feature",
            "properties": {
              "MODE": "D"
            },
            "geometry": {
              "type": "Point",
              "coordinates": [
                -69.23651039600372,
                45.46053888199693
              ]
            }
          }
        ]
      }
    ],
    "identifier": 26741075
  },
  {
    "context": [
      "I\u0019m trying to construct a filter with [jq](http://stedolan.github.io/jq/) that returns all objects with `Id`s that **do not** contain \"data\" in the inner `Names` array, with the output being newline-separated.  For the above data, the output I\u0019d like is:\r\n\r\n    cb94e7a42732b598ad18a8f27454a886c1aa8bbba6167646d8f064cd86191e2b\r\n    a4b7e6f5752d8dcb906a5901f7ab82e403b9dff4eaaeebea767a04bac4aada19",
      "Here is another solution which uses [any/2](https://stedolan.github.io/jq/manual/#any,any\\(condition\\),any\\(generator;condition\\))\r\n\r\n    map(select(any(.Names[]; contains(\"data\"))|not)|.Id)[]\r\n\r\nwith the sample data and the `-r` option it produces:\r\n\r\n    cb94e7a42732b598ad18a8f27454a886c1aa8bbba6167646d8f064cd86191e2b\r\n    a4b7e6f5752d8dcb906a5901f7ab82e403b9dff4eaaeebea767a04bac4aada19",
      "Very close! In your `select` expression, you have to use a pipe (`|`) before `contains`.\r\n\r\nThis filter produces the expected output.\r\n\r\n    . - map(select(.Names[] | contains (\"data\"))) | .[] .Id"
    ],
    "utterance": "List the Ids of all objects whose Names array does not contain any string including 'data'.",
    "expressions": [
      ". - map(select(.Names[] | contains (\"data\"))) | .[] .Id",
      "map(select(any(.Names[]; contains(\"data\"))|not)|.Id)[]"
    ],
    "data": [
      {
        "input": [
          {
            "Id": "cb94e7a42732b598ad18a8f27454a886c1aa8bbba6167646d8f064cd86191e2b",
            "Names": [
              "condescending_jones",
              "loving_hoover"
            ]
          },
          {
            "Id": "186db739b7509eb0114a09e14bcd16bf637019860d23c4fc20e98cbe068b55aa",
            "Names": [
              "foo_data"
            ]
          },
          {
            "Id": "a4b7e6f5752d8dcb906a5901f7ab82e403b9dff4eaaeebea767a04bac4aada19",
            "Names": [
              "jovial_wozniak"
            ]
          },
          {
            "Id": "76b71c496556912012c20dc3cbd37a54a1f05bffad3d5e92466900a003fbb623",
            "Names": [
              "bar_data"
            ]
          }
        ],
        "output": [
          "cb94e7a42732b598ad18a8f27454a886c1aa8bbba6167646d8f064cd86191e2b",
          "a4b7e6f5752d8dcb906a5901f7ab82e403b9dff4eaaeebea767a04bac4aada19"
        ]
      }
    ],
    "identifier": 26701538
  },
  {
    "context": [
      "How can I specify just bring the nodes where `&quot;types&quot; : [ &quot;country&quot;, &quot;political&quot; ]` ?",
      ".results[0].address_components[].short_name",
      "assuming you wanted to get a result object that had the types `&quot;country&quot;` and `&quot;political&quot;`, use the `contains()` filter.",
      ".results | map(\n    select(\n        .types | contains([\"country\",\"political\"])\n    )\n)"
    ],
    "utterance": "Select all elements where the types array contains both \"country\" and \"political\".",
    "expressions": [
      ".results | map(select(.types | contains([\"country\",\"political\"])))",
      ".results[].address_components[] | select(.types | contains([\"country\",\"political\"]))"
    ],
    "identifier": 27103393
  },
  {
    "context": [
      "I want this:\r\n\r\n    words[english][adjective][1]\r\n    >> good",
      "Using [tag:jq]\r\n\r\n    $ jq '.english.adjective[1]' file.js\r\n\r\nOutput:\r\n \r\n    good"
    ],
    "utterance": "Select the second adjective from the english section of the data structure.",
    "expressions": [
      ".english.adjective[1]"
    ],
    "data": [
      {
        "input": {
          "italian": {
            "name": [
              "gatto",
              "cane",
              "pasta",
              "telefono",
              "libro"
            ],
            "adjective": [
              "pesante",
              "sottile",
              "giallo",
              "stretto"
            ]
          },
          "english": {
            "name": [
              "fish",
              "book",
              "guitar",
              "piano"
            ],
            "adjective": [
              "dirty",
              "good",
              "ugly",
              "great"
            ]
          }
        },
        "output": "good"
      }
    ],
    "identifier": 27127091
  },
  {
    "context": [
      "Since jq 1.6 you can do this:",
      "jq --compact-output --null-input '$ARGS.positional' --args -- \"${X[@]}\"",
      "giving:",
      "[\"hello world\",\"goodnight moon\"]",
      "This has the benefit that no escaping is required at all. It handles strings containing newlines, tabs, double quotes, backslashes and other control characters."
    ],
    "utterance": "Convert a bash array with arbitrary strings, including spaces and special characters, to a properly escaped array using a single jq invocation without looping or manual escaping.",
    "expressions": [
      "jq --compact-output --null-input '$ARGS.positional' --args -- \"${X[@]}\""
    ],
    "data": [
      {
        "input": [
          "hello world",
          "goodnight moon"
        ],
        "output": [
          "hello world",
          "goodnight moon"
        ]
      }
    ],
    "identifier": 26808855
  },
  {
    "context": [
      "How can I prevent jq from truncating long decimal values?",
      "echo '18302628978110292481' | jq .",
      "result: 18302628978110292000",
      "To make it work, you'll need to treat them as strings:",
      "echo '\"18302628978110292481\"' | jq .",
      "# Prints \"18302628978110292481\""
    ],
    "utterance": "Display the full, exact value of 18302628978110292481 without truncation.",
    "expressions": [
      "echo '\"18302628978110292481\"' | jq ."
    ],
    "data": [
      {
        "input": "\"18302628978110292481\"",
        "output": "\"18302628978110292481\""
      }
    ],
    "identifier": 27211870
  },
  {
    "context": [
      "@curl.exe -H \"Content-Type: application/json\" -d '{\\\"cmd\\\":\\\"login\\\"}' http://localhost:80/json | jq -r .session > sess.txt",
      "no matter what I do, I cannot seem to suppress JQ's \"status\" output. In particular, it always outputs \"progress status,\" like:\n\n    % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current\n                                   Dload  Upload   Total   Spent    Left  Speed\n    100   116  100    99  100    17    908    155 --:--:-- --:--:-- --:--:--   908",
      "curl --silent",
      "In order to remove the progress bar on curl restful api response ,Use the `--silent` flag (in short `-s`) or use `--no-progress-meter`."
    ],
    "utterance": "Suppress the progress status output when piping curl data to extract the session using .session, so only the extracted session value is written to a file.",
    "expressions": [
      "curl -s -H \"Content-Type: application/json\" -d '{\"cmd\":\"login\"}' http://localhost:80/json | jq -r .session > sess.txt",
      "curl --no-progress-meter -H \"Content-Type: application/json\" -d '{\"cmd\":\"login\"}' http://localhost:80/json | jq -r .session > sess.txt"
    ],
    "identifier": 27261547
  },
  {
    "context": [
      "myJSONResponse=`curl -u username:password -X GET -H \"Content-Type: application/json\" \\\n--insecure --silent $fixVersionQuery |jq '.[] | {id,name} |  \\       \nselect(.name==\"Version-1.2.3\") | .[\"id\"]'`;",
      "However, I want to be querying a version whose name I'm passing to the function. So \"Version-1.2.3\" might be a variable such as \"${JIRA_FIXVERSION}\".",
      "The file takes the variable:\n\n`JIRA_FIXVERSION=$1`\n\n3. Wthin jq the quotes are escaped, and additional quotes and apostrophes are added. Note that the below line is also surrounded by single quotes and backticks. \n\n\n`.[] | {id,name} | select(.name=='\\\"\"${JIRA_FIXVERSION}\"\\\"') `"
    ],
    "utterance": "Select objects where the name field exactly matches the value stored in the shell variable JIRA_FIXVERSION.",
    "expressions": [
      ".[] | {id,name} | select(.name==\"${JIRA_FIXVERSION}\") | .[\"id\"]",
      ".[] | {id,name} | select(.name==\"\\\"${JIRA_FIXVERSION}\\\"\")"
    ],
    "identifier": 27444164
  },
  {
    "context": [
      "Next I want to produce one output object for each object in the performance list. These new objects should have attributes from the containing event object, such as date and venue.",
      "What is the correct way to do this in jq?",
      "This filter should work:",
      ".resultsPage.results.event | map(\n    {\n        venue_name: .venue.displayName,\n        start_date: .start.date\n    }\n    +\n    (.performance[].artist | {\n        artist_mbid: .identifier[].mbid,\n        artist_name: .displayName\n    })\n)\n",
      "You're trying to create an object for every corresponding `performance` so you'll have to flatten it down a bit before you start collecting results."
    ],
    "utterance": "Produce one object for each performance, combining venue display name, event start date, artist name, and artist mbid from nested fields.",
    "expressions": [
      ".resultsPage.results.event | map({venue_name: .venue.displayName, start_date: .start.date} + (.performance[].artist | {artist_mbid: .identifier[].mbid, artist_name: .displayName}))"
    ],
    "data": [
      {
        "input": {
          "resultsPage": {
            "results": {
              "event": [
                {
                  "start": {
                    "date": "2014-10-28"
                  },
                  "performance": [
                    {
                      "artist": {
                        "displayName": "James Keelaghan",
                        "identifier": [
                          {
                            "mbid": "08e5954e-efc0-4a95-95ac-d74cca5b79ff"
                          }
                        ]
                      }
                    }
                  ],
                  "venue": {
                    "displayName": "Live At The Star"
                  }
                },
                {
                  "start": {
                    "date": "2014-10-28"
                  },
                  "performance": [
                    {
                      "artist": {
                        "displayName": "Katy B",
                        "identifier": [
                          {
                            "mbid": "2df30b6c-997d-4c3f-abb5-5e0d6317ea57"
                          }
                        ]
                      }
                    },
                    {
                      "artist": {
                        "displayName": "Becky Hill",
                        "identifier": [
                          {
                            "mbid": "27bc6f5b-4585-49ab-8d7d-c62b59f5f010"
                          }
                        ]
                      }
                    }
                  ],
                  "venue": {
                    "displayName": "O2 ABC"
                  }
                }
              ]
            }
          }
        },
        "output": [
          {
            "venue_name": "Live At The Star",
            "start_date": "2014-10-28",
            "artist_mbid": "08e5954e-efc0-4a95-95ac-d74cca5b79ff",
            "artist_name": "James Keelaghan"
          },
          {
            "venue_name": "O2 ABC",
            "start_date": "2014-10-28",
            "artist_mbid": "2df30b6c-997d-4c3f-abb5-5e0d6317ea57",
            "artist_name": "Katy B"
          },
          {
            "venue_name": "O2 ABC",
            "start_date": "2014-10-28",
            "artist_mbid": "27bc6f5b-4585-49ab-8d7d-c62b59f5f010",
            "artist_name": "Becky Hill"
          }
        ]
      }
    ],
    "identifier": 26666120
  },
  {
    "context": [
      "If you want key and value, and based on [How do i convert a json object to key=value format in JQ](https://stackoverflow.com/a/25378171/1983854), you can do:\n\n    $ jq -r \"to_entries|map(\\\"\\(.key)=\\(.value|tostring)\\\")|.[]\" file\n    SALUTATION=Hello world\n    SOMETHING=bla bla bla Mr. Freeman",
      "# print associative array\n      local key value\n      for key in \"${!associativeArray[@]}\"; do\n        value=\"${associativeArray[\"$key\"]}\"\n        printf '%s = %s' \"$key\" \"$value\"\n      done",
      "To load JSON object into a bash associative array efficiently (without using loops in bash), one can use tool 'jq', as follows. \n\n    # first, load the json text into a variable:\n    json='{ \"SALUTATION\": \"Hello world\", \"SOMETHING\": \"bla bla bla Mr. Freeman\"}'\n\n    # then, prepare associative array, I use 'aa':\n\tunset aa\n\tdeclare -A aa\n\n\t# use jq to produce text defining name:value pairs in the bash format\n    # using @sh to properly escape the values\n\taacontent=$(jq -r '. | to_entries | .[] | \"[\\\"\" + .key + \"\\\"]=\\\" + (.value | @sh)' <<< \"$json\")\n\n\t# string containing whole definition of aa in bash\n\taadef=\"aa=($aacontent)\"\n\n\t# load the definition (because values may contain LF characters, aadef must be in double quotes)\n\teval \"$aadef\"\n\n    # now we can access the values like this: echo \"${aa[SOMETHING]}\"",
      "example () {\n      local json='{ \"key1\": \"val1\", \"key2\": \"val2\" }'\n      local -A associativeArray=\"($(jq -r '. | to_entries | .[] |\n        \"[\\\"\" + .key + \"\\\"]=\\\" + (.value | @sh)' <<< \"$json\"))\"\n\n      # print associative array\n    }"
    ],
    "utterance": "Convert an object with key-value pairs into a bash associative array so each key can be accessed as ${arr[KEY]}, using command-line tools.",
    "expressions": [
      "to_entries|map(\"\\(.key)=\\(.value|tostring)\")|.[]",
      ". | to_entries | .[] | \"[\\\"\" + .key + \"\\\"]=\\\" + (.value | @sh)",
      ". | to_entries | .[] | \"[\\\"\" + .key + \"\\\"]=\\\" + (.value | @sh)"
    ],
    "data": [
      {
        "input": {
          "SALUTATION": "Hello world",
          "SOMETHING": "bla bla bla Mr. Freeman"
        },
        "output": [
          "SALUTATION=Hello world",
          "SOMETHING=bla bla bla Mr. Freeman"
        ]
      }
    ],
    "identifier": 26717277
  },
  {
    "context": [
      "How would I get the total of the values returned? ie in this case 24.",
      "since the question has got a `jq` tag, here it goes...:\r\n\r\n    echo \"[[\\\"Graz\\\",5],[\\\"Rio de Janeiro\\\",3],[\\\"Br\u0000e4cke\\\",2],[\\\"Campinas\\\",2],[\\\"Colchester\\\",2],[\\\"Cunewalde\\\",2],[\\\"Lille\\\",2],[\\\"London\\\",2],[\\\"Charleroi\\\",1],[\\\"Caracas\\\",1],[\\\"Butte\\\",1],[\\\"Buenos Aires\\\",1]]\" | jq '[.[][1]] | add'"
    ],
    "utterance": "Get the sum of all second elements in each inner array where the data is a list of city names and numbers.",
    "expressions": [
      "[.[][1]] | add"
    ],
    "data": [
      {
        "input": [
          [
            "Graz",
            5.0
          ],
          [
            "Rio de Janeiro",
            3.0
          ],
          [
            "Br\u0000e4cke",
            2.0
          ],
          [
            "Campinas",
            2.0
          ],
          [
            "Colchester",
            2.0
          ],
          [
            "Cunewalde",
            2.0
          ],
          [
            "Lille",
            2.0
          ],
          [
            "London",
            2.0
          ],
          [
            "Charleroi",
            1.0
          ],
          [
            "Caracas",
            1.0
          ],
          [
            "Butte",
            1.0
          ],
          [
            "Buenos Aires",
            1.0
          ]
        ],
        "output": 24.0
      }
    ],
    "identifier": 27629419
  },
  {
    "context": [
      "What command do I need to add to JQ such that the objects passed to the bash variable are valid json?",
      "You can see that I'm doing two things with this one command:",
      "* Putting all the results into `jsonValues`.",
      "* Exporting to `FullClosedIssueList.json`.",
      "I find that the `jsonValues` objects are formatted missing `[`, `]` and `,`.",
      "Whereas the file output is valid json.",
      "you need the \"map\" command in that too, in which the select command should be enclosed:",
      "cat FullClosedIssueList.json | jq '.[] | map(select(.typeid==\"1\"))'"
    ],
    "utterance": "Store the output as a valid array containing all objects instead of separate objects without array brackets.",
    "expressions": [
      ".[\"issues\"] | map({key: .key, type: .fields.issuetype.name, typeid: .fields.issuetype.id, status: .fields.status.name, summary: .fields.summary})"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "key": "ON-12345",
              "fields": {
                "issuetype": {
                  "name": "Bug",
                  "id": "1"
                },
                "status": {
                  "name": "Closed"
                },
                "summary": "Some Bug Title"
              }
            },
            {
              "key": "ON-12346",
              "fields": {
                "issuetype": {
                  "name": "Bug",
                  "id": "1"
                },
                "status": {
                  "name": "Closed"
                },
                "summary": "Some Other Bug Title"
              }
            }
          ]
        },
        "output": [
          {
            "key": "ON-12345",
            "type": "Bug",
            "typeid": "1",
            "status": "Closed",
            "summary": "Some Bug Title"
          },
          {
            "key": "ON-12346",
            "type": "Bug",
            "typeid": "1",
            "status": "Closed",
            "summary": "Some Other Bug Title"
          }
        ]
      }
    ],
    "identifier": 27506416
  },
  {
    "context": [
      "But what would the query look like to extract `id` and `stuff.info-spec`?",
      "My desired output for this example, then, is\n\n    {\n      \"info-spec\": 12,\n      \"id\": 12345678\n    }\n    {\n      \"info-spec\": 23,\n      \"id\": 12345679\n    }",
      "I managed to figure it out.\n\n    $ jq '.[] | { id, \"info-spec\": .stuff[\"info-spec\"] }' xample.json\n    {\n      \"info-spec\": 12,\n      \"id\": 12345678\n    }\n    {\n      \"info-spec\": 23,\n      \"id\": 12345679\n    }\n\nThe key here seems to be to use the `newkey: .complex[\"key\"]` notation for lifting.",
      "jq '.[] | { id, \"info-spec\": .stuff.\"info-spec\" }' xample.json"
    ],
    "utterance": "Extract the top-level id and the value of info-spec from within the nested stuff object for each item.",
    "expressions": [
      ".[] | { id, \"info-spec\": .stuff[\"info-spec\"] }",
      ".[] | { id, \"info-spec\": .stuff.\"info-spec\" }"
    ],
    "data": [
      {
        "input": [
          {
            "id": 12345678,
            "stuff": {
              "book": "shelf",
              "hook": "line",
              "took": "off",
              "info-spec": 12
            },
            "votes": 23
          },
          {
            "id": 12345679,
            "stuff": {
              "book": "maker",
              "hook": "sinker",
              "took": "pisin",
              "info-spec": 23
            },
            "votes": 1
          }
        ],
        "output": [
          {
            "info-spec": 12,
            "id": 12345678
          },
          {
            "info-spec": 23,
            "id": 12345679
          }
        ]
      }
    ],
    "identifier": 27562424
  },
  {
    "context": [
      "id like to parse 2 (or more) security groups having one string formatted for every rule, both inbound and outbound",
      "The format that id like to have could be something as:\n\n    SecurityGroupId - GroupName - InBound/OutBound - IpProtocol - Port - SourceRanges/DestinationRanges",
      "Here is a jq solution",
      "def ports:\n   if .IpProtocol == \"-1\"\n   then {FromPort:\"ALLPORTS\", ToPort:\"ALLPORTS\", IpProtocol:\"ALLPROTO\"}\n   else {FromPort, ToPort, IpProtocol}\n   end\n;",
      "def tabella($g; $p; $dir; $ip):\n    [ $g.GroupId, $g.GroupName, $g.Description, $g.VpcId, $dir, $ip,\n      $p.FromPort, $p.ToPort, $p.IpProtocol ]\n;",
      "def creatab:\n      .SecurityGroups[]\n    | { GroupId, GroupName, Description, VpcId } as $g\n    | (\n          .IpPermissions[]\n        | ports as $p\n        | ( .IpRanges[]         | tabella($g; $p; \"INBOUND\"; .CidrIp) ),\n          ( .UserIdGroupPairs[] | tabella($g; $p; \"INBOUND\"; .GroupId) )\n      ),\n      (\n          .IpPermissionsEgress[]\n        | ports as $p\n        | ( .IpRanges[]         | tabella($g; $p; \"OUTBOUND\"; .CidrIp) ),\n          ( .UserIdGroupPairs[] | tabella($g; $p; \"OUTBOUND\"; .GroupId) )\n      )\n;",
      "creatab\n| map(tostring)\n| join(\"|\")",
      "when run as \n\n    jq -M -r -f filter.jq data.json\n    \nit will produce the same output as Marco's perl solution",
      "sg-000000001|server-db|server-db|vpc-0000001|INBOUND|10.12.0.0/16|3389|3389|tcp"
    ],
    "utterance": "List all rules for each security group as lines containing group ID, name, description, VPC ID, INBOUND/OUTBOUND, source or destination (CIDR or group ID), from port, to port, protocol, using fields separated by |",
    "expressions": [
      "def ports:\n   if .IpProtocol == \"-1\"\n   then {FromPort:\"ALLPORTS\", ToPort:\"ALLPORTS\", IpProtocol:\"ALLPROTO\"}\n   else {FromPort, ToPort, IpProtocol}\n   end\n;\ndef tabella($g; $p; $dir; $ip):\n    [ $g.GroupId, $g.GroupName, $g.Description, $g.VpcId, $dir, $ip,\n      $p.FromPort, $p.ToPort, $p.IpProtocol ]\n;\ndef creatab:\n      .SecurityGroups[]\n    | { GroupId, GroupName, Description, VpcId } as $g\n    | (\n          .IpPermissions[]\n        | ports as $p\n        | ( .IpRanges[]         | tabella($g; $p; \"INBOUND\"; .CidrIp) ),\n          ( .UserIdGroupPairs[] | tabella($g; $p; \"INBOUND\"; .GroupId) )\n      ),\n      (\n          .IpPermissionsEgress[]\n        | ports as $p\n        | ( .IpRanges[]         | tabella($g; $p; \"OUTBOUND\"; .CidrIp) ),\n          ( .UserIdGroupPairs[] | tabella($g; $p; \"OUTBOUND\"; .GroupId) )\n      )\n;\ncreatab\n| map(tostring)\n| join(\"|\")"
    ],
    "identifier": 26543318
  },
  {
    "context": [
      "I am receiving compilation error with content[$i] and cant get a workaround the same.",
      "id=\"$(cat red | jq '.content[$i].id')\"",
      "Ok I got the answer for this.",
      "We can use the below syntax to make is work in the for loop.",
      "id=$(cat red | jq '.content['${i}'].id')"
    ],
    "utterance": "For each element in the content array, extract the id field dynamically using a shell variable as the index.",
    "expressions": [
      ".content[${i}].id"
    ],
    "data": [
      {
        "input": {
          "content": [
            {
              "id": 951653,
              "version": 12,
              "score": 100,
              "entitySummary": {
                "source": "somewebsite",
                "summaryText": "someTEXT here",
                "domain": "www.domian.com",
                "sourceDate": "2014-12-19T17:00:00.000Z",
                "type": "WEB_PAGE"
              },
              "type": "SomeTYPE",
              "title": "some Title",
              "description": "some description ",
              "occurred": "2014-12-19T17:00:00.000Z",
              "verified": "2014-12-19T17:17:22.326Z",
              "tags": [
                {
                  "id": 424,
                  "name": "Data Breach or Compromise",
                  "type": "IMPACT_EFFECTS"
                },
                {
                  "id": 1064,
                  "name": "United States",
                  "type": "TARGET_GEOGRAPHY"
                }
              ],
              "severity": "MEDIUM",
              "clientId": "NET",
              "alerted": "2014-12-19T17:39:55.500Z",
              "mitigation": "MititgationINFO",
              "impactDescription": "IMpact description"
            },
            {
              "id": 951174,
              "version": 8,
              "score": 100,
              "entitySummary": {}
            }
          ]
        },
        "output": 951653
      }
    ],
    "identifier": 27800718
  },
  {
    "context": [
      "Using `jq` to convert a json array to csv results in this:",
      "$ echo '[\"a\",1,true,\"comment\"]' | jq '.|@csv'",
      "\"\\\"a\\\",1,true,\\\"comment\\\"\"",
      "What can I do to get",
      "\"a\",1,true,\"comment\"",
      "If you want the raw \"unstringified\" output, use the `-r` raw output option.",
      "$ echo '[\"a\",1,true,\"comment\"]' | jq -r '@csv'",
      "\"a\",1,true,\"comment\""
    ],
    "utterance": "Output a CSV-formatted string representing the elements of an array using raw output.",
    "expressions": [
      "@csv"
    ],
    "data": [
      {
        "input": [
          "a",
          1,
          true,
          "comment"
        ],
        "output": "\"a\",1,true,\"comment\""
      }
    ],
    "identifier": 27889137
  },
  {
    "context": [
      "How do I filter these objects to only include keys I want?",
      "I\u2019ve tried `jq '.[].name'` but that extracts the values, rather than preserving the objects.",
      "You can use the `map()` function to filter any key:",
      "jq 'map({name: .name})'",
      "The above filter can be abbreviated as follows:",
      "jq 'map({name})'",
      "Another solution without the `map` function:",
      "jq '[.[] | {name: .name}]'",
      "As of [`jq` version 1.7], [`pick`] can be used:",
      "jq 'pick(.[].name)'"
    ],
    "utterance": "Keep only the 'name' key in each object within an array, removing all other keys.",
    "expressions": [
      "map({name})",
      "map({name: .name})",
      "[.[] | {name: .name}]",
      "map(del(.group) | del(.created))",
      "map( to_entries | map(select(.key|test(\"^(name)$\"))) | from_entries )",
      "map(if has(\"name\") then {name} else {} end)",
      "pick(.[].name)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Alice",
            "group": "Admins",
            "created": "2014"
          },
          {
            "name": "Bob",
            "group": "Users",
            "created": "2014"
          }
        ],
        "output": [
          {
            "name": "Alice"
          },
          {
            "name": "Bob"
          }
        ]
      }
    ],
    "identifier": 27838154
  },
  {
    "context": [
      "I\u2019m trying to obtain just a single date value from across all of them. The desired output is:\n\n\"2014-12-16T08:59:08.000+0100\"",
      "Map each entry to the `closedDate` filtering out non-values, then get the minimum value.",
      "map(.closedDate | values) | min"
    ],
    "utterance": "Return the earliest closedDate from all objects, ignoring nulls.",
    "expressions": [
      "map(.closedDate | values) | min"
    ],
    "data": [
      {
        "input": [
          {
            "key": "AB-12345",
            "type": "Fault",
            "typeid": "19",
            "status": "Open",
            "summary": "I'm a big bad fault",
            "closedDate": null,
            "flag": null
          },
          {
            "key": "AB-12346",
            "type": "Bug",
            "typeid": "19",
            "status": "Open",
            "summary": "I'm a big bad bug",
            "closedDate": "2014-12-16T08:59:08.000+0100",
            "flag": null
          },
          {
            "key": "AB-12347",
            "type": "Feature",
            "typeid": "19",
            "status": "Open",
            "summary": "I'm a big bad feature",
            "closedDate": "2014-12-17T08:27:07.000+0100",
            "flag": null
          }
        ],
        "output": "2014-12-16T08:59:08.000+0100"
      }
    ],
    "identifier": 27848887
  },
  {
    "context": [
      "But adding that last line in order to get `value` as [suggested here](https://stackoverflow.com/questions/27562424/jq-nested-object-extract-top-level-id-and-lift-a-value-from-internal-object) results in the entire object being excluded from the output file.",
      "I wasn&#39;t treating the entry for `flag` as a separate array. So that single line should have been:",
      "`flag: .fields.customfield_10170[0].value`",
      "This takes the first element in the array, `[0]` and then requests the `value` field."
    ],
    "utterance": "Extract the first object's value property from customfield_10170 array and map it to flag, along with selected top-level and nested fields from each issue.",
    "expressions": [
      ".[\"issues\"] | map({key: .key, type: .fields.issuetype.name, typeid: .fields.issuetype.id, status: .fields.status.name, summary: .fields.summary, closedDate: .fields.resolutiondate, flag: .fields.customfield_10170[0].value})"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "key": "AB-12345",
              "fields": {
                "issuetype": {
                  "name": "Bug",
                  "id": "19"
                },
                "status": {
                  "name": "Backlog"
                },
                "summary": "I'm a big bad bug",
                "resolutiondate": null,
                "customfield_10170": [
                  {
                    "self": "http://address/1938",
                    "value": "Critical",
                    "id": "10404"
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "key": "AB-12345",
            "type": "Bug",
            "typeid": "19",
            "status": "Backlog",
            "summary": "I'm a big bad bug",
            "closedDate": null,
            "flag": "Critical"
          }
        ]
      }
    ],
    "identifier": 27841690
  },
  {
    "context": [
      "done <<<(jq -r '.data | .[].name' $2)",
      "done <<<(jq -r '.data | .[].name' \"$2\")",
      "done <<<(jq -r '.data | .[].name' \"$3\")",
      "done <<<(jq -r '.data | .[].name' $2);"
    ],
    "utterance": "Extract all name fields from every item inside the data array",
    "expressions": [
      ".data | .[].name",
      ".data[].name"
    ],
    "identifier": 28223432
  },
  {
    "context": [
      "and basically, I am trying to omit out the `map` section that it has, so that it will only display the `tags` section but the presence of commas and [] / {} are making it hard for me.",
      "Here is a solution that uses **del**. If `input.json` contains ... invoking jq as\n\n    jq -M -c 'del(.map, .unitmap)' input.json\n\nwill produce the output\n\n    {\"tags\":{}}\n    {\"tags\":{\"type\":[\"char\"],\"dynamic\":true}}\n"
    ],
    "utterance": "Remove the top-level keys 'map' and 'unitmap' from each object, leaving only the remaining keys such as 'tags'.",
    "expressions": [
      "del(.map, .unitmap)"
    ],
    "data": [
      {
        "input": {
          "tags": {},
          "map": {
            "KPA": {
              "State": true,
              "namespace": "KPA01"
            }
          }
        },
        "output": {
          "tags": {}
        }
      },
      {
        "input": {
          "tags": {
            "type": [
              "char"
            ],
            "dynamic": true
          },
          "unitmap": {
            "KPA01": {
              "State": true,
              "namespace": "KPA01"
            }
          }
        },
        "output": {
          "tags": {
            "type": [
              "char"
            ],
            "dynamic": true
          }
        }
      }
    ],
    "identifier": 28163355
  },
  {
    "context": [
      "v1=($(cat $INPUT | jq '.\"config\"[i].\"var1\"[]'))",
      "error: i is not defined",
      "v1=($(cat $INPUT | jq '.\"config\"[$i].\"var1\"[]'))",
      "Variables aren't interpolated inside single quotes. Use double quotes instead, and remove the existing quotes.",
      "v1=($(cat $INPUT | jq \".config[$i].var1[]\"))",
      "Or use the --arg option and then you can stick with single quotes.",
      "v1=($(cat $INPUT | jq --arg i \"$i\" '.config[$i].var1[]'))",
      "while IFS= read -r; do\n  echo \"read content from jq: $REPLY\"\ndone < <(jq -r --arg i \"$i\" '.config[$i | tonumber].var1[]' <\"$input\")",
      "jq -r '.\"config-vars\"[].\"var1\"' \"$INPUT\" | head -n \"${#nvars[@]}\""
    ],
    "utterance": "For a given index i, extract all elements of var1 from the i-th object in the config-vars array.",
    "expressions": [
      ".\"config-vars\"[$i].\"var1\"[]",
      ".config-vars[$i].var1[]",
      "jq -r --arg i \"$i\" '.\"config-vars\"[$i|tonumber].\"var1\"[]'",
      "jq -r '.\"config-vars\"[$i].\"var1\"[]'"
    ],
    "data": [
      {
        "input": {
          "config-vars": [
            {
              "var1": [
                "v1",
                "v2"
              ],
              "var2": ""
            },
            {
              "var1": [
                "v3",
                ""
              ],
              "var2": "v4"
            }
          ]
        },
        "output": [
          "v1",
          "v2"
        ]
      }
    ],
    "identifier": 27993448
  },
  {
    "context": [
      "If others are looking for how to avoid the `Cannot iterate over null` error in their own `jq` commands, add a question mark after `[]`. For example",
      "echo '{\n  \"AWSEBDockerrunVersion\": \"1\",\n  \"Image\": {\n    \"Name\": \"blah\",\n    \"Update\": \"false\"\n  },\n  \"Ports\": [\n    {\n      \"ContainerPort\": \"8080\"\n    }\n  ]\n}'|jq -c '.Volumes[]?|[.HostDirectory,.ContainerDirectory]'",
      "where `[]` was replaced with `[]?` does not display the error.",
      "From the manual:\n\n    .[]?\n        Like .[], but no errors will be output if . is not an array or object."
    ],
    "utterance": "Select HostDirectory and ContainerDirectory fields from each Volumes element, but avoid errors if Volumes is missing or null.",
    "expressions": [
      ".Volumes[]?|[.HostDirectory,.ContainerDirectory]"
    ],
    "data": [
      {
        "input": {
          "AWSEBDockerrunVersion": "1",
          "Image": {
            "Name": "blah",
            "Update": "false"
          },
          "Ports": [
            {
              "ContainerPort": "8080"
            }
          ]
        },
        "output": []
      }
    ],
    "identifier": 28213232
  },
  {
    "context": [
      "I have an array of keys and an array of values, how can I generate an object? Input:\r\n\r\n    [[\"key1\", \"key2\"], [\"val1\", \"val2\"]]\r\n\r\nOutput:\r\n\r\n    {\"key1\": \"val1\", \"key2\": \"val2\"}",
      "The current version of jq has a `transpose` filter that can be used to pair up the keys and values.  You could use it to build out the result object rather easily.\r\n\r\n    transpose | reduce .[] as $pair ({}; .[$pair[0]] = $pair[1])",
      ".[0] as $keys |\r\n.[1] as $values |\r\nreduce range(0; $keys|length) as $i  ( {}; . + { ($keys[$i]): $values[$i] })",
      "transpose | map( {(.[0]): .[1]} ) | add",
      "Input:\r\n\r\n    [[\"k1\",\"k2\",\"k3\"], [1,2,3] ]\r\n\r\nOutput:\r\n\r\n    {\r\n      \"k1\": 1,\r\n      \"k2\": 2,\r\n      \"k3\": 3\r\n    }"
    ],
    "utterance": "Generate an object mapping keys from the first array to corresponding values from the second array.",
    "expressions": [
      "transpose | reduce .[] as $pair ({}; .[$pair[0]] = $pair[1])",
      "transpose | map({(.[0]): .[1]}) | add",
      ".[0] as $keys | .[1] as $values | reduce range(0; $keys|length) as $i ( {}; . + { ($keys[$i]): $values[$i] })"
    ],
    "data": [
      {
        "input": [
          [
            "key1",
            "key2"
          ],
          [
            "val1",
            "val2"
          ]
        ],
        "output": {
          "key1": "val1",
          "key2": "val2"
        }
      },
      {
        "input": [
          [
            "k1",
            "k2",
            "k3"
          ],
          [
            1,
            2,
            3
          ]
        ],
        "output": {
          "k1": 1,
          "k2": 2,
          "k3": 3
        }
      }
    ],
    "identifier": 28103489
  },
  {
    "context": [
      "What I want to do is to count the number of records with a specific date and then doing the same looping through a starting date to an end date using [jq](http://stedolan.github.io/jq/)",
      "But, I can't figure out how to:\n\n1. Flatten the records so that they are one array not two\n2. Strip the `T09:01:23.000+0200` from the closedDate value\n3. Count the number of objects with a specific date value such as `2014-10-13`",
      "add | map(select(.closedDate[:10]==\"2014-10-13\")) | length"
    ],
    "utterance": "Count the number of records that have a closedDate of 2014-10-13, combining all arrays from separate inputs.",
    "expressions": [
      "add | map(select(.closedDate[:10]==\"2014-10-13\")) | length"
    ],
    "data": [
      {
        "input": [
          [
            {
              "key": "645",
              "type": "Bug",
              "typeid": "1",
              "status": "Closed",
              "summary": "Crash when saving document",
              "closedDate": "2014-10-03T09:01:23.000+0200",
              "flag": null,
              "fixVersionID": "123",
              "fixVersionName": "2.7"
            }
          ],
          [
            {
              "key": "552",
              "type": "Bug",
              "typeid": "1",
              "status": "Closed",
              "summary": "Graphical Issue",
              "closedDate": "2014-10-13T09:01:23.000+0200",
              "flag": null,
              "fixVersionID": "456",
              "fixVersionName": "2.8"
            }
          ]
        ],
        "output": 1
      }
    ],
    "identifier": 28472204
  },
  {
    "context": [
      "I would like to select everyone who is a Clown. My output should look like this:\r\n\r\n    {\r\n      \"Joe\" : {\"Job\" : \"Clown\", \"Age\" : 22},\r\n      \"Anne\" : {\"Job\" : \"Clown\", \"Age\" : 29}\r\n    }",
      "use `with_entries` to convert to/from an intermediate format that represents that data as an array of objects with `key` and `value` elements:\r\n\r\n    cat people.json | jq 'with_entries(select(.value.Job == \"Clown\"))'",
      "Here is a solution using **reduce** \r\n\r\n      . as $v\r\n    | reduce keys[] as $k (\r\n        {};\r\n        if $v[$k].Job == \"Clown\" then .[$k] = $v[$k] else . end\r\n      )"
    ],
    "utterance": "Select all entries where the person has the Job 'Clown', preserving the original key-value structure.",
    "expressions": [
      "with_entries(select(.value.Job == \"Clown\"))",
      ". as $v | reduce keys[] as $k ({}; if $v[$k].Job == \"Clown\" then .[$k] = $v[$k] else . end)"
    ],
    "data": [
      {
        "input": {
          "Joe": {
            "Job": "Clown",
            "Age": 22
          },
          "Sally": {
            "Job": "Programmer",
            "Age": 32
          },
          "Anne": {
            "Job": "Clown",
            "Age": 29
          }
        },
        "output": {
          "Joe": {
            "Job": "Clown",
            "Age": 22
          },
          "Anne": {
            "Job": "Clown",
            "Age": 29
          }
        }
      }
    ],
    "identifier": 28615174
  },
  {
    "context": [
      "Let&#39;s say, I would like to replace `MA` with `Massachussetts` in the location property. I know I could use `sed &#39;s/MA/Massachussetts&#39;` but this would also replace every `MA` in the `name` field.",
      "The [sub](http://stedolan.github.io/jq/manual/#subresubgsubresub) filter will alow you to do regex replacement on strings.  Then you could do something like this:\r\n\r\n    .location |= sub(\"MA$\"; \"Massachussetts\")",
      ".location = (\r\n   {\r\n     \"Boston, MA\":        \"Boston, Massachussettts\",\r\n     \"San Francisco, CA\": \"San Francisco, California\",\r\n     \"New York City, NY\": \"New York City, New York\"\r\n   }[.location] // .location\r\n)\r\n"
    ],
    "utterance": "Replace 'MA' at the end of the location field with 'Massachussetts', without affecting other fields or values.",
    "expressions": [
      ".location |= sub(\"MA$\"; \"Massachussetts\")"
    ],
    "data": [
      {
        "input": {
          "name": "Bob",
          "location": "Boston, MA"
        },
        "output": {
          "name": "Bob",
          "location": "Boston, Massachussetts"
        }
      },
      {
        "input": {
          "name": "Peter",
          "location": "San Francisco, CA"
        },
        "output": {
          "name": "Peter",
          "location": "San Francisco, CA"
        }
      }
    ],
    "identifier": 28603357
  },
  {
    "context": [
      "Given a JSON stream of the following form:\r\n\r\n    { \"a\": 10, \"b\": 11 } { \"a\": 20, \"b\": 21 } { \"a\": 30, \"b\": 31 }\r\n\r\nI would like to sum the values in each of the objects and output a single object, namely:\r\n\r\n    { \"a\": 60, \"b\": 63 }",
      "map(to_entries)\r\n    | add\r\n    | group_by(.key)\r\n    | map({\r\n          key: .[0].key,\r\n          value: map(.value) | add\r\n      })\r\n    | from_entries",
      "$ jq -n '\r\nreduce (inputs | to_entries[]) as {$key,$value} ({}; .[$key] += $value)\r\n' input.json",
      "def sumByKey:\r\n  . as $in\r\n  | reduce (.[0] | keys)[] as $key\r\n    ( {}; . + {($key): ($in | sum(.[$key]))})\r\n;",
      "{ \"a\": sum(.a), \"b\": sum(.b) }"
    ],
    "utterance": "Sum the values of each key across multiple objects and output a single object with the total for each key, such that {\"a\": 10, \"b\": 11} {\"a\": 20, \"b\": 21} {\"a\": 30, \"b\": 31} becomes {\"a\": 60, \"b\": 63}.",
    "expressions": [
      "map(to_entries) | add | group_by(.key) | map({key: .[0].key, value: map(.value) | add}) | from_entries",
      "reduce (inputs | to_entries[]) as {$key,$value} ({}; .[$key] += $value)",
      "{\"a\": sum(.a), \"b\": sum(.b)}",
      "def sumByKey: . as $in | reduce (.[0] | keys)[] as $key ( {}; . + {($key): ($in | sum(.[$key]))}); sumByKey"
    ],
    "data": [
      {
        "input": [
          {
            "a": 10,
            "b": 11
          },
          {
            "a": 20,
            "b": 21
          },
          {
            "a": 30,
            "b": 31
          }
        ],
        "output": {
          "a": 60,
          "b": 63
        }
      }
    ],
    "identifier": 28484534
  },
  {
    "context": [
      "I need to read it and write back an additional value (string) to the root of the object.",
      "The json written back should look like this:\r\n\r\n    {\r\n      \"Category\": \"Unknown\",\r\n      \"widget\": {...}\r\n    }",
      "Just set the new field directly using simple assignment.\r\n\r\n    .Category = \"Unknown\""
    ],
    "utterance": "Add a field named 'Category' with the value 'Unknown' to the root of the object.",
    "expressions": [
      ".Category = \"Unknown\""
    ],
    "data": [
      {
        "input": {
          "widget": {
            "debug": "on",
            "window": {
              "height": 500
            },
            "text": {
              "data": "Click Here",
              "size": 36,
              "style": "bold",
              "name": "text1",
              "hOffset": 250,
              "vOffset": 100,
              "alignment": "center",
              "onMouseUp": "sun1.opacity = (sun1.opacity / 100) * 90;"
            }
          }
        },
        "output": {
          "Category": "Unknown",
          "widget": {
            "debug": "on",
            "window": {
              "height": 500
            },
            "text": {
              "data": "Click Here",
              "size": 36,
              "style": "bold",
              "name": "text1",
              "hOffset": 250,
              "vOffset": 100,
              "alignment": "center",
              "onMouseUp": "sun1.opacity = (sun1.opacity / 100) * 90;"
            }
          }
        }
      }
    ],
    "identifier": 28727274
  },
  {
    "context": [
      "The problem is that the result is not an array of objects (frankly, I'm not sure what it is).  How can I start with an array of json objects, filter them and end up with a filtered list of objects?",
      "To ensure they are kept as an array, you can put the results back into an array by wrapping your filter with square brackets:",
      "[\n    .[] |\n    select(.Selected != null) |\n    {\n        \"Head Of House Name\",\n        \"Head Of House Phone\",\n        \"Head Of House Email\",\n        \"Family Phone\",\n        \"Family Email\"\n    }\n]",
      "Or keep it as an array by using the map() filter, you could then remove the .[] part:",
      "map(\n    select(.Selected != null) |\n    {\n        \"Head Of House Name\",\n        \"Head Of House Phone\",\n        \"Head Of House Email\",\n        \"Family Phone\",\n        \"Family Email\"\n    }\n)"
    ],
    "utterance": "Filter array objects where Selected is not null and return only Head Of House Name, Head Of House Phone, Head Of House Email, Family Phone, and Family Email fields, as an array.",
    "expressions": [
      "[.[] | select(.Selected != null) | {\"Head Of House Name\", \"Head Of House Phone\", \"Head Of House Email\", \"Family Phone\", \"Family Email\"}]",
      "map(select(.Selected != null) | {\"Head Of House Name\", \"Head Of House Phone\", \"Head Of House Email\", \"Family Phone\", \"Family Email\"})"
    ],
    "data": [
      {
        "input": [
          {
            "Selected": null,
            "Family Name": "Jones",
            "Couple Name": "Jones, Adam & Rachael Margaret",
            "Family Phone": "404-4477",
            "Family Email": "email@sbcglobal.net",
            "Family Address": "777 Aggies Court Kindly, California 95388 ",
            "Head Of House Name": "Jones, Adam",
            "Head Of House Phone": "(583) 404-2488",
            "Head Of House Email": "email@sbcglobal.net",
            "Spouse Name": "Jones, Rachael Margaret",
            "Spouse Phone": null,
            "Spouse Email": null,
            "Child Name": null,
            "Child Phone": null,
            "Child Email": null
          },
          {
            "Selected": "x",
            "Family Name": "Xiong",
            "Couple Name": "Xiong, Arlene Frances",
            "Family Phone": null,
            "Family Email": null,
            "Family Address": "888 Walnut Ave. Blatant, California 95388 ",
            "Head Of House Name": "Xiong, Arlene Frances",
            "Head Of House Phone": "583-500-7917",
            "Head Of House Email": "email@junk.net",
            "Spouse Name": null,
            "Spouse Phone": null,
            "Spouse Email": null,
            "Child Name": null,
            "Child Phone": null,
            "Child Email": null
          },
          {
            "Selected": "x",
            "Family Name": "Blair",
            "Couple Name": "Blair, Toby & Silvia",
            "Family Phone": "358-4645",
            "Family Email": null,
            "Family Address": "333 Cindy St. Stoic, California 95388 ",
            "Head Of House Name": "Blair, Toby",
            "Head Of House Phone": null,
            "Head Of House Email": "email@stuff.net",
            "Spouse Name": "Blair, Silvia",
            "Spouse Phone": null,
            "Spouse Email": null,
            "Child Name": null,
            "Child Phone": null,
            "Child Email": null
          }
        ],
        "output": [
          {
            "Head Of House Name": "Xiong, Arlene Frances",
            "Head Of House Phone": "583-500-7917",
            "Head Of House Email": "email@junk.net",
            "Family Phone": null,
            "Family Email": null
          },
          {
            "Head Of House Name": "Blair, Toby",
            "Head Of House Phone": null,
            "Head Of House Email": "email@stuff.net",
            "Family Phone": "358-4645",
            "Family Email": null
          }
        ]
      }
    ],
    "identifier": 28458046
  },
  {
    "context": [
      "Now I need to get the value of my_name for both other entries",
      "You need to use it in a context where it is unambiguously a key string.",
      "echo \"$temp\" | jq '.[\"1\"][\"my_name\"]'",
      "With a sufficiently new `jq` (I think >= 1.4) you can also say",
      "echo \"$temp\" | jq '.\"1\".my_name'",
      "For your other question on how to obtain the `my_name` values, you could do this:",
      "to_entries | map(.value.my_name)"
    ],
    "utterance": "Extract all my_name values from each entry where the keys are numerical strings.",
    "expressions": [
      "to_entries | map(.value.my_name)",
      ".[].my_name"
    ],
    "data": [
      {
        "input": {
          "1": {
            "my_name": "one"
          },
          "2": {
            "my_name": "two"
          }
        },
        "output": [
          "one",
          "two"
        ]
      }
    ],
    "identifier": 28844295
  },
  {
    "context": [
      "I have this Json\n\n    {\n        \"users\": [\n            {\n                \"first\": \"Stevie\",\n                \"last\": \"Wonder\"\n            },\n            {\n                \"first\": \"Michael\",\n                \"last\": \"Jackson\"\n            }\n        ]\n    }\n\nUsing jq I'd like to display first and last name serially. Like so - \n\n    Stevie Wonder\n    Michael Jackson\n\nThis is how far I have gotten - \n\n    jq '.users[].first, .users[].last'\n\nBut it displays\n\n    \"Stevie\"\n    \"Michael\"\n    \"Wonder\"\n    \"Jackson\"\n\nNotice the following:\n\n1. The double quotes that I do not want.\n2. The carriage return that I do not want.\n3. It's jumbled up. My query displays all the first names first, and then all the last names. However, I want first-last, first-last pair.",
      "I recommend using String Interpolation:\n\n    jq '.users[] | \"\\(.first) \\(.last)\"'\n",
      "You can use [addition][1] to concatenate strings.\n\n    jq '.users[] | .first + \" \" + .last'\n",
      "This will produce an array of names\n\n```\n> jq '[ .users[] | (.first + \" \" + .last) ]' ~/test.json\n\n[\n  \"Stevie Wonder\",\n  \"Michael Jackson\"\n]\n```",
      "In addition to what others have suggested, I think that two options are worth mentioning.\n\n### Print as CSV/TSV\n\n```bash\n$ cat file.json | jq -r '.users[] | [.first, .last] | @tsv'\nStevie  Wonder\nMichael Jackson\n```",
      "A little bit more steps but I noticed no one here mentions `join()`. `join()` only works for array so you need to construct one. To eliminate double quotes, use  `-r`:\n\n    echo $JSON | jq -r '.users[] | [.first,.last] | join(\" \")'\n"
    ],
    "utterance": "Display each user's first and last name together on one line in the format 'first last', without extra quotes or extra carriage returns.",
    "expressions": [
      ".users[] | \"\\(.first) \\(.last)\"",
      ".users[] | .first + \" \" + .last",
      ".users[] | [.first, .last] | join(\" \")",
      ".users[] | [.first, .last] | @tsv"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "first": "Stevie",
              "last": "Wonder"
            },
            {
              "first": "Michael",
              "last": "Jackson"
            }
          ]
        },
        "output": [
          "Stevie Wonder",
          "Michael Jackson"
        ]
      }
    ],
    "identifier": 28164849
  },
  {
    "context": [
      "I want to print each file on its own line, but including the id from the outer element.",
      "\"\\(.files[].name) \\(.id)\"",
      "If you wanted to pull more than just the name from each of the files, you would need to make adjustments to the filter.",
      "\"\\(.files[] | \\(.name) \\(.size)) \\(.id)\"",
      ".id as $id | .files[] | \"\\(.name) \\($id) \\(.size)\""
    ],
    "utterance": "For each file, print its name followed by the id from the outer object on the same line.",
    "expressions": [
      "\"\\(.files[].name) \\(.id)\"",
      ".id as $id | .files[] | \"\\(.name) \\($id)\""
    ],
    "data": [
      {
        "input": {
          "files": [
            {
              "size": 3227238,
              "name": "file1.mp3"
            },
            {
              "size": 3737995,
              "name": "file2.mp3"
            }
          ],
          "id": "music"
        },
        "output": [
          "file1.mp3 music",
          "file2.mp3 music"
        ]
      }
    ],
    "identifier": 29034529
  },
  {
    "context": [
      "Assume a Json array of numbers:\r\n\r\n    [ 1, 4, 6, 9, 8, 10, 5, 2]\r\n\r\nI want to compute a 3 day moving average.  The resulting array is computed by averaging the previous 3 entries.\r\n\r\nSo the first 3 entries don't care, the 4th is `(1+4+6)/3`, the 5th is `(4+6+9)/3` and so on.",
      "You can use a filter like this:\r\n\r\n    def rolling_average(size): . as $items |\r\n        [ range(0;length-size)\r\n        | $items[.:.+size]\r\n        | add/size\r\n        ]\r\n        ;\r\n    rolling_average(3)",
      "Here is a jq filter which uses a recursive function to compute the moving average of every n elements.\r\n\r\n    def avg(n):\r\n        if length < n then empty   # base case\r\n        else ( .[0:n] | add/n )    # average of first n elements\r\n           , ( .[1:]  | avg(n) )   # recursive call\r\n        end\r\n    ;\r\n\r\n    avg(3)"
    ],
    "utterance": "Produce the list of 3-entry moving averages for the array [1, 4, 6, 9, 8, 10, 5, 2]",
    "expressions": [
      ". as $val | to_entries | map((.value + $val[.key-1] + $val[.key-2])/3)  | .[2:]",
      "def rolling_average(size): . as $items | [ range(0;length-size+1) | $items[.:.+size] | add/size ]; rolling_average(3)",
      "def avg(n): if length < n then empty else ( .[0:n] | add/n ), ( .[1:] | avg(n) ) end; avg(3)"
    ],
    "data": [
      {
        "input": [
          1,
          4,
          6,
          9,
          8,
          10,
          5,
          2
        ],
        "output": [
          3.6666666666666665,
          6.333333333333333,
          7.666666666666667,
          9,
          7.666666666666667,
          5.666666666666667
        ]
      }
    ],
    "identifier": 28731718
  },
  {
    "identifier": 29112204
  },
  {
    "context": [
      "I have a large JSON file that is an object of objects, which I would like to split into separate files name after object keys. Is it possible to achieve this using jq or any other off-the-shelf tools?",
      "The original JSON is in the following format\n\n  `{ \"item1\": {...}, \"item2\": {...}, ...}`\n\nGiven this input I would like to produce files item1.json, item2.json etc.",
      "for f in `cat input.json | jq -r 'keys[]'` ; do\n  cat input.json | jq \".$f\" > $f.json\n done",
      "jq -cr 'keys[] as $k | \"\\($k)\\n\\(.[$k])\"' input.json |\n  while read -r key ; do\n\tread -r item\n\tprintf \"%s\\n\" \"$item\" > \"/tmp/$key.json\"\n  done",
      "jq -cr 'keys[] as $k | \"\\($k)\\t\\(.[$k])\"' input.json |\n  awk -F\\t '{ print $2 > \"/tmp/\" $1 \".json\" }'"
    ],
    "utterance": "Split a top-level object of objects into separate files named after each key, with each file containing its corresponding value.",
    "expressions": [
      "for f in $(jq -r 'keys[]' < input.json); do jq \".[\\\"$f\\\"]\" < input.json > \"$f.json\"; done",
      "jq -cr 'keys[] as $k | \"\\($k)\\n\\(.[$k])\"' input.json | while read -r key ; do read -r item; printf \"%s\\n\" \"$item\" > \"$key.json\"; done",
      "jq -cr 'keys[] as $k | \"\\($k)\\t\\(.[$k])\"' input.json | awk -F\\t '{ print $2 > \"./\" $1 \".json\" }'"
    ],
    "data": [
      {
        "input": {
          "item1": {
            "a": 1
          },
          "item2": {
            "b": 2
          },
          "item3": {
            "c": 3
          }
        },
        "output": [
          {
            "file": "item1.json",
            "content": {
              "a": 1
            }
          },
          {
            "file": "item2.json",
            "content": {
              "b": 2
            }
          },
          {
            "file": "item3.json",
            "content": {
              "c": 3
            }
          }
        ]
      }
    ],
    "identifier": 28744361
  },
  {
    "context": [
      "cat $file | jq '.Event'",
      "I get the list of \"Event\" values extracted from JSON file.I want to assign this value to a bash variable so that I can use it for comparision later. How do I do that?"
    ],
    "utterance": "Extract the value of the Event field from each file and assign it to a shell variable for later comparison.",
    "expressions": [
      "jq -r '.Event' \"$file\""
    ],
    "identifier": 29110979
  },
  {
    "context": [
      "And I need to flatten the file so it should read",
      "\"creator\": { \"name\": { \"$t\": \"Internet Explorer Network Inspector\" }, \"version\": { \"$t\": \"10.0.9200.17229\" } }",
      "this filter should be applied recursively to any element at any level.",
      "You can create a recursive filter by defining a new function:",
      "def untag: (objects | .\"$t\") // (objects | with_entries(.value |= untag)) // (arrays | map(untag)) // . ; untag",
      "If your jq has `walk`, you could use it as follows ... walk( if type==\"object\" and has(\"$t\") then .[\"$t\"] else . end )",
      "Put this in your `~/.jq` file: def untag: (objects | .\"$t\") // (objects | with_entries(.value |= untag)) // (arrays | map(untag)) // . ;"
    ],
    "utterance": "Replace every object of the form {\"$t\": value} with the contained value at any level in the structure.",
    "expressions": [
      "def untag: (objects | .\"$t\") // (objects | with_entries(.value |= untag)) // (arrays | map(untag)) // .; untag",
      "walk(if type==\"object\" and has(\"$t\") then .[\"$t\"] else . end)"
    ],
    "data": [
      {
        "input": {
          "log": {
            "version": {
              "$t": "1.1"
            },
            "creator": {
              "name": {
                "$t": "Internet Explorer Network Inspector"
              },
              "version": {
                "$t": "10.0.9200.17229"
              }
            }
          }
        },
        "output": {
          "log": {
            "version": "1.1",
            "creator": {
              "name": "Internet Explorer Network Inspector",
              "version": "10.0.9200.17229"
            }
          }
        }
      },
      {
        "input": {
          "some key": {
            "$t": "some string value"
          }
        },
        "output": {
          "some key": "some string value"
        }
      }
    ],
    "identifier": 28989994
  },
  {
    "context": [
      "cat data1.json | ./jq '[.[\"messages\"][] | {to: .to, from: .from, body: .body, direction: .direction, date_sent: .date_sent }]' > results1.json",
      "for file in *.json; do",
      "./jq '[.[\"messages\"][] | {to: .to, from: .from, body: .body, direction: .direction, date_sent: .date_sent }]' < \"$file\" > \"$file.scrubbed\"",
      "If your input files follow a consistent naming scheme like *data**n**.json* and you want the output files to be called e.g. *result**n**.json*, you could use > \"${file/data/result}\" instead"
    ],
    "utterance": "Iterate over all files in a directory, extract an array of messages mapping to, from, body, direction, and date_sent fields from each file, and save each result to a new output file.",
    "expressions": [
      "[.[\"messages\"][] | {to: .to, from: .from, body: .body, direction: .direction, date_sent: .date_sent }]"
    ],
    "identifier": 29106846
  },
  {
    "context": [
      "event=$(cat $file | jq '.Event')",
      "if [ \"$event\" = \"Time Exceeded\" ]  || [ \"$event\" = \"Load Time\" ]; then",
      "Check once if there are leading or trailing unwanted characters (whitespace, newline ...) in output of `cat $file | jq '.Event'`:",
      "cat $file | jq '.Event' | hexdump -C"
    ],
    "utterance": "Extract the value of the Event property from each file for use in a conditional in a shell script, such that the extracted value matches exactly, without quotes or trailing characters.",
    "expressions": [
      "jq -r '.Event' $file"
    ],
    "identifier": 29112449
  },
  {
    "context": [
      "I need to get a array (dimmer1, dimmer2)",
      "To retrieve the keys of the attributes of `devices` in an array:",
      "jq '.devices | keys' filename.json"
    ],
    "utterance": "Select all keys under 'devices' as an array.",
    "expressions": [
      ".devices | keys"
    ],
    "data": [
      {
        "input": {
          "devices": {
            "dimmer1": {
              "protocol": [
                "kaku_dimmer"
              ],
              "state": "off",
              "dimlevel": 1
            },
            "dimmer2": {
              "protocol": [
                "kaku_dimmer"
              ],
              "state": "off",
              "dimlevel": 1
            }
          }
        },
        "output": [
          "dimmer1",
          "dimmer2"
        ]
      }
    ],
    "identifier": 29389010
  },
  {
    "context": [
      "From the JSON file below I want to extract `X Time` and `Y Time`. What is the easiest way to do this?",
      "Here is a jq solution using **capture**:",
      ".Message\n| capture(\"X Time: (?<X Time>[^,]+), Y Time: (?<Y Time>[^)]+)\")",
      "will produce\n\n{\n  \"X Time\": \"306 ms\",\n  \"Y Time\": \"1923 ms\"\n}"
    ],
    "utterance": "Extract the values for X Time and Y Time from the Message field when both appear in the format 'X Time: <value>, Y Time: <value>'.",
    "expressions": [
      ".Message | capture(\"X Time: (?<X Time>[^,]+), Y Time: (?<Y Time>[^)]+)\")"
    ],
    "data": [
      {
        "input": {
          "Timestamp": "Mon Mar 16 21:37:22 EDT 2015",
          "Event": "Reporting  Time",
          "Message": "load for http://xxx.xx.xx.xx:1xxxx/operations&proxy=www.mywebsite.co.nz&send=https://xxx.xx.xx.xx:xxxx took (X Time: 306 ms, Y Time: 1923 ms)StatusCode: Unknown<br>Cookies: nzh_weatherlocation=12; dax_ppv=11|NZH:home|NZH:home|NZH:home|9|undefined; Safari/537.36<br>CPUs: 2<br>Language: en-GB"
        },
        "output": {
          "X Time": "306 ms",
          "Y Time": "1923 ms"
        }
      }
    ],
    "identifier": 29113687
  },
  {
    "context": [
      "I trying to select elements when VPCZoneIdentifier exists in my `$selected_subnets` (bash variable).",
      "$ echo $input | jq --arg subnets \"$selected_subnets\" '.elements | map(select(.VPCZoneIdentifier == ($subnets | split(\" \")[])))'",
      ".elements = [.elements[] | select(.VPCZoneIdentifier as $id | (\"$selected_subnets\" | split(\" \")) | reduce .[] as $v (false; . or $id == $v))]"
    ],
    "utterance": "Select all elements whose VPCZoneIdentifier property matches any value from a given string of space-separated values.",
    "expressions": [
      ".elements = [.elements[] | select(.VPCZoneIdentifier as $id | (\"$selected_subnets\" | split(\" \")) | reduce .[] as $v (false; . or $id == $v))]",
      ".elements | map(select(.VPCZoneIdentifier == ($subnets | split(\" \")[])))"
    ],
    "data": [
      {
        "input": {
          "elements": [
            {
              "name": "nameA",
              "VPCZoneIdentifier": "valueA"
            },
            {
              "name": "nameB",
              "VPCZoneIdentifier": "valueB"
            },
            {
              "name": "nameC",
              "VPCZoneIdentifier": "valueC"
            }
          ]
        },
        "output": [
          {
            "name": "nameA",
            "VPCZoneIdentifier": "valueA"
          },
          {
            "name": "nameB",
            "VPCZoneIdentifier": "valueB"
          }
        ]
      }
    ],
    "identifier": 29142185
  },
  {
    "context": [
      "I want to modify the file so as to add another key-value pair to it. The key should be `url` and the value should be `www.mywebsite.co.nz` extracted from the message given below.",
      "jq \".url = \\\"$(jq '.Message' input.json | sed 's/.*proxy=\\([^&]*\\).*/\\1/')\\\"\" input.json > output.json",
      "jq '.Message' input.json\n\nextracts the message part from the input JSON, \n\n    sed 's/.*proxy=\\([^&]*\\).*/\\1/'\n\nextracts the domain from the message, and\n\n    jq \".url = \\\"domainname\\\"\" input.json > output.json\n\nsets the `.url` attribute of the input json to the extracted domain name, writing the result to `output.json`."
    ],
    "utterance": "Add a url field with value www.mywebsite.co.nz extracted from the proxy parameter in the Message field",
    "expressions": [
      ".url = (.Message | capture(\"proxy=(?<url>[^&]+)\").url)"
    ],
    "data": [
      {
        "input": {
          "Timestamp": "Mon Mar 16 21:37:22 EDT 2015",
          "Event": "Reporting  Time",
          "Message": "load for http://xxx.xx.xx.xx:1xxxx/operations&proxy=www.mywebsite.co.nz&send=https://xxx.xx.xx.xx:xxxx/operations?event took 9426 ms (X Time: 306 ms, Y Time: 1923 ms)\r\n    StatusCode: Unknown<br>Cookies: nzh_weatherlocation=12; dax_ppv=11|NZH:home|NZH:home|NZH:home|9|undefined; _ga=GA1.4.1415798036.1426208630; _gat=1<br>Links: 225<br>Images: 24<br>Forms: 10<br>Browser: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Ubuntu Chromium/41.0.2272.76 Chrome/41.0.2272.76 Safari/537.36<br>CPUs: 2<br>Language: en-GB",
          "UserInfo": "Reporting Time"
        },
        "output": {
          "Timestamp": "Mon Mar 16 21:37:22 EDT 2015",
          "Event": "Reporting  Time",
          "Message": "load for http://xxx.xx.xx.xx:1xxxx/operations&proxy=www.mywebsite.co.nz&send=https://xxx.xx.xx.xx:xxxx/operations?event took 9426 ms (X Time: 306 ms, Y Time: 1923 ms)\r\n    StatusCode: Unknown<br>Cookies: nzh_weatherlocation=12; dax_ppv=11|NZH:home|NZH:home|NZH:home|9|undefined; _ga=GA1.4.1415798036.1426208630; _gat=1<br>Links: 225<br>Images: 24<br>Forms: 10<br>Browser: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Ubuntu Chromium/41.0.2272.76 Chrome/41.0.2272.76 Safari/537.36<br>CPUs: 2<br>Language: en-GB",
          "UserInfo": "Reporting Time",
          "url": "www.mywebsite.co.nz"
        }
      }
    ],
    "identifier": 29108688
  },
  {
    "context": [
      "I'd like to extract a subset of the key/values from the nested `properties`, whilst keeping other properties from the outer object intact, producing something like:",
      "i.e. remove all keys except `NAME` and `NAME_LONG`.",
      "You can use this filter:\r\n\r\n    map(\r\n        .properties |= with_entries(select(.key == (\"NAME\", \"NAME_LONG\")))\r\n    )",
      "`map(.properties |= {NAME, NAME_LONG})` is more straight-forward and understandable."
    ],
    "utterance": "Keep all outer object properties but only retain NAME and NAME_LONG within each object's properties field.",
    "expressions": [
      "map(.properties |= with_entries(select(.key == (\"NAME\", \"NAME_LONG\"))))",
      "map(.properties |= {NAME, NAME_LONG})"
    ],
    "data": [
      {
        "input": [
          {
            "geometry": {
              "type": "Polygon",
              "coordinates": [
                [
                  [
                    -69.9969376289999,
                    12.577582098000036
                  ]
                ]
              ]
            },
            "type": "Feature",
            "properties": {
              "NAME": "Aruba",
              "WB_A2": "AW",
              "INCOME_GRP": "2. High income: nonOECD",
              "SOV_A3": "NL1",
              "CONTINENT": "North America",
              "NOTE_ADM0": "Neth.",
              "BRK_A3": "ABW",
              "TYPE": "Country",
              "NAME_LONG": "Aruba"
            }
          },
          {
            "geometry": {
              "type": "MultiPolygon",
              "coordinates": [
                [
                  [
                    -63.037668423999946,
                    18.212958075000028
                  ]
                ]
              ]
            },
            "type": "Feature",
            "properties": {
              "NAME": "Anguilla",
              "WB_A2": "-99",
              "INCOME_GRP": "3. Upper middle income",
              "SOV_A3": "GB1",
              "NOTE_ADM0": "U.K.",
              "BRK_A3": "AIA",
              "TYPE": "Dependency",
              "NAME_LONG": "Anguilla"
            }
          }
        ],
        "output": [
          {
            "geometry": {
              "type": "Polygon",
              "coordinates": [
                [
                  [
                    -69.9969376289999,
                    12.577582098000036
                  ]
                ]
              ]
            },
            "type": "Feature",
            "properties": {
              "NAME": "Aruba",
              "NAME_LONG": "Aruba"
            }
          },
          {
            "geometry": {
              "type": "MultiPolygon",
              "coordinates": [
                [
                  [
                    -63.037668423999946,
                    18.212958075000028
                  ]
                ]
              ]
            },
            "type": "Feature",
            "properties": {
              "NAME": "Anguilla",
              "NAME_LONG": "Anguilla"
            }
          }
        ]
      }
    ],
    "identifier": 29259249
  },
  {
    "context": [
      "When we query an item, we get a very detailed JSON output. ... Is there any way to get a simpler output for the `Items` part? Like this: ...",
      "With `jq` it is easy, but not quite pretty, you can do something like: ... Result will be: `172.16.0.178` ...",
      "Here is an updated and commented version of Jeff Mercado `jq` function to unmarshall DynamoDB output. It will give you the expected output: ... If you save the `DynamoDB` query output to a file, lets say `ddb-query-result.json`, you can execute to get desired result: ... $> jq -f unmarshal_dynamodb.jq ddb-query-result.json",
      "$ jq 'decode_ddb' input.json ... {\n  \"Count\": 1,\n  \"Items\": [\n    {\n      \"Id\": \"app1\",\n      \"Parameters\": {\n        \"nfs#IP\": \"192.17.0.13\",\n        \"maxCount\": 1,\n        \"nfs#defaultPath\": \"/mnt/ebs/\"\n      }\n    }\n  ],\n  \"ScannedCount\": 1,\n  \"ConsumedCapacity\": null\n}",
      "Here is another approach.  This may be a little brutal but it shows the basic idea. ... Sample Run (assuming filter in `filter.jq` and data in `data.json`) ... $ jq -M -f filter.jq data.json ... {\n  \"ConsumedCapacity\": null,\n  \"Count\": 1,\n  \"Items\": [\n    {\n      \"Id\": \"app1\",\n      \"Oldtypes\": { ... },\n      \"Parameters\": { ... }\n    }\n  ],\n  \"ScannedCount\": 1\n}",
      "Here's an updated version of the `jq` solution that can handle null values. ... $> jq -f unmarshal_dynamodb.jq ddb-query-result.json"
    ],
    "utterance": "Transform the verbose AWS DynamoDB CLI query response into a simpler format by decoding type-wrapped attributes to their plain native values, including handling nested structures.",
    "expressions": [
      "def unmarshal_dynamodb:\n  walk( if type == \"object\" and .NULL then . |= null else . end ) |\n  (objects | .S)\n  // (objects | .B)\n  // (objects | .N | strings | tonumber)\n  // (objects | .BOOL)\n  // (objects | .M | objects | with_entries(.value |= unmarshal_dynamodb))\n  // (objects | .L | arrays | map(unmarshal_dynamodb))\n  // (objects | .SS | arrays | map(unmarshal_dynamodb))\n  // (objects | .NS | arrays | map(tonumber))\n  // (objects | .BS | arrays | map(unmarshal_dynamodb))\n  // (objects | with_entries(.value |= unmarshal_dynamodb))\n  // (arrays | map(unmarshal_dynamodb))\n  // .\n  ;\nunmarshal_dynamodb"
    ],
    "data": [
      {
        "input": {
          "Count": 1,
          "Items": [
            {
              "Id": {
                "S": "app1"
              },
              "Parameters": {
                "M": {
                  "nfs": {
                    "M": {
                      "IP": {
                        "S": "172.16.0.178"
                      },
                      "defaultPath": {
                        "S": "/mnt/ebs/"
                      },
                      "key": {
                        "B": "dGhpcyB0ZXh0IGlzIGJhc2U2NC1lbmNvZGVk"
                      },
                      "activated": {
                        "BOOL": true
                      }
                    }
                  },
                  "ws": {
                    "M": {
                      "number": {
                        "N": "5"
                      },
                      "values": {
                        "L": [
                          {
                            "S": "12253456346346"
                          },
                          {
                            "S": "23452353463464"
                          },
                          {
                            "S": "23523453461232"
                          },
                          {
                            "S": "34645745675675"
                          },
                          {
                            "S": "46456745757575"
                          }
                        ]
                      }
                    }
                  }
                }
              },
              "Oldtypes": {
                "typeSS": {
                  "SS": [
                    "foo",
                    "bar",
                    "baz"
                  ]
                },
                "typeNS": {
                  "NS": [
                    "0",
                    "1",
                    "2",
                    "3",
                    "4",
                    "5"
                  ]
                },
                "typeBS": {
                  "BS": [
                    "VGVybWluYXRvcgo=",
                    "VGVybWluYXRvciAyOiBKdWRnbWVudCBEYXkK",
                    "VGVybWluYXRvciAzOiBSaXNlIG9mIHRoZSBNYWNoaW5lcwo=",
                    "VGVybWluYXRvciA0OiBTYWx2YXRpb24K",
                    "VGVybWluYXRvciA1OiBHZW5lc2lzCg=="
                  ]
                }
              }
            }
          ],
          "ScannedCount": 1,
          "ConsumedCapacity": null
        },
        "output": {
          "ConsumedCapacity": null,
          "Count": 1,
          "Items": [
            {
              "Id": "app1",
              "Parameters": {
                "nfs": {
                  "IP": "172.16.0.178",
                  "activated": true,
                  "defaultPath": "/mnt/ebs/",
                  "key": "dGhpcyB0ZXh0IGlzIGJhc2U2NC1lbmNvZGVk"
                },
                "ws": {
                  "number": 5,
                  "values": [
                    "12253456346346",
                    "23452353463464",
                    "23523453461232",
                    "34645745675675",
                    "46456745757575"
                  ]
                }
              },
              "Oldtypes": {
                "typeBS": [
                  "VGVybWluYXRvcgo=",
                  "VGVybWluYXRvciAyOiBKdWRnbWVudCBEYXkK",
                  "VGVybWluYXRvciAzOiBSaXNlIG9mIHRoZSBNYWNoaW5lcwo=",
                  "VGVybWluYXRvciA0OiBTYWx2YXRpb24K",
                  "VGVybWluYXRvciA1OiBHZW5lc2lzCg=="
                ],
                "typeNS": [
                  0,
                  1,
                  2,
                  3,
                  4,
                  5
                ],
                "typeSS": [
                  "foo",
                  "bar",
                  "baz"
                ]
              }
            }
          ],
          "ScannedCount": 1
        }
      }
    ],
    "identifier": 28593471
  }
]