[
  {
    "context": [
      "I would like to exclude object WITHOUT key \"target\", as follow but NOT has:",
      "jq -r \".| select(has(\\\"target\\\"))\"",
      "expected output:",
      "{\n    \"name\":\"XML\",\n    \"good\":false\n}",
      "tried this:",
      "jq -r \" . | del(select(has(\\\"target\\\")))\"",
      "but there are two returned objects, one of them NULL",
      "Select those who do *not* have `target`; that way, you do not use `del`:",
      "jq -r 'select(has(\"target\") | not)'"
    ],
    "utterance": "Return all objects that do not have the key \"target\".",
    "expressions": [
      "select(has(\"target\") | not)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "JSON",
            "good": true,
            "target": "yes"
          },
          {
            "name": "XML",
            "good": false
          }
        ],
        "output": {
          "name": "XML",
          "good": false
        }
      }
    ],
    "identifier": 35199809
  },
  {
    "context": [
      "How to make `jq` treat an input argument as numeric instead of string? In the following example, `CURR_INDEX` is a Bash variable which has array index value that I want to extract.",
      "jq --arg ARG1 $CURR_INDEX '.[$ARG1].patchSets' inputfile.json",
      "jq: error: Cannot index array with string",
      "You can convert it [to a number][1], like this:",
      "jq --arg ARG1 1 '.[$ARG1|tonumber]' <<< '[\"foo\". \"bar\"]'",
      "--arg` always binds the value as a string. You can use `--argjson` (introduced in version 1.5) to treat the argument as a json-encoded value instead.",
      "jq --argjson ARG1 $CURR_INDEX '.[$ARG1].patchSets' inputfile.json",
      "$ jq --argjson ARG1 1 '.[$ARG1]' <<< '[\"foo\", \"bar\"]'\n\"bar\""
    ],
    "utterance": "Extract an array element at a position given by a shell variable that contains a numeric array index passed as an argument.",
    "expressions": [
      ".[$ARG1|tonumber]",
      ".[$ARG1].patchSets",
      ".[$ARG1]"
    ],
    "data": [
      {
        "input": [
          "foo",
          "bar"
        ],
        "output": "bar"
      }
    ],
    "identifier": 35360297
  },
  {
    "context": [
      "but how can I generate the following?\r\n\r\n    Result is: \"b\".",
      "$ echo [{\"a\" : \"b\"}] | jq-win64.exe --raw-output \".[] | \\\"Result is: \\\\\\\"\\\" + .a + \\\"\\\\\\\".\\\"\"\r\n    Result is: \"b\".",
      "You can do this a little cleaner by using string interpolation instead of regular string concatenation.\r\n\r\n    jq -r \".[] | \\\"Result is: \\\\\\\"\\(.a)\\\\\\\".\\\"\"",
      "A hacky workaround with less backslashing could be:\r\n\r\n    jq -r \".[] | \\\"Result is: \\\" + (.a|tojson)\""
    ],
    "utterance": "Output the value prefixed by 'Result is: ', with the value surrounded by double quotes and suffixed by a period.",
    "expressions": [
      ".[] | \"Result is: \\\"\" + .a + \"\\\".\"",
      ".[] | \"Result is: \\\"\\(.a)\\\".\"",
      ".[] | \"Result is: \" + (.a|tojson) + \".\""
    ],
    "data": [
      {
        "input": [
          {
            "a": "b"
          }
        ],
        "output": "Result is: \"b\"."
      }
    ],
    "identifier": 35204397
  },
  {
    "context": [
      "Using jq I would like to test for the occurrence of a particular key value in the JSON below, for example that \"WARNING\" has occurred as a 'severity' value (even once) no matter the amount of objects returned, such that I return a boolean.",
      "As I want to have a single boolean value returned, I've tried to merge the values into a single string or array before using 'contains', but I can't find a way to do this.",
      "Building on your approach, you could, for example, simply write:\n\n    jq '[.events[]|.severity|contains(\"WARNING\")] | any'\n\nOr more succinctly:\n\n    jq 'any(.events[].severity; contains(\"WARNING\"))' "
    ],
    "utterance": "Return true if any element in events has severity equal to \"WARNING\", otherwise false.",
    "expressions": [
      "[.events[] | .severity | contains(\"WARNING\")] | any",
      "any(.events[].severity; contains(\"WARNING\"))"
    ],
    "data": [
      {
        "input": {
          "events": [
            {
              "severity": "WARNING",
              "status": "",
              "time_raised": "1454502910919",
              "data_1": "00000000",
              "data_2": "00000000",
              "data_3": "00000000",
              "register_0": "40000",
              "register_1": "4",
              "register_2": "10",
              "register_3": "0"
            },
            {
              "severity": "ERROR",
              "status": "",
              "time_raised": "1454502840915",
              "data_1": "00000000",
              "data_2": "00000000",
              "data_3": "00000000",
              "register_0": "50000",
              "register_1": "4",
              "register_2": "8",
              "register_3": "0"
            }
          ]
        },
        "output": true
      }
    ],
    "identifier": 35177992
  },
  {
    "context": [
      "How do I convert the number to string so both can be joined?",
      "The jq command has the [tostring][1] function.",
      "jq -r '.[] | [ .string, .number|tostring ] | join(\": \")' <<< '[{ \"number\": 9, \"string\": \"nine\"}, { \"number\": 4, \"string\": \"four\"}]'",
      "An alternative and arguably more intuitive format is:",
      "jq '.[] | .string + \": \" + (.number|tostring)' <<< ...",
      "Worth noting the need for parens around `.number|tostring`.",
      "For such simple case [string interpolation]'s implicit casting to string will do it:",
      ".[] | \"\\( .string ): \\( .number )\""
    ],
    "utterance": "For each object, display the 'string' field followed by ': ', then the 'number' field as a string.",
    "expressions": [
      ".[] | [ .string, .number|tostring ] | join(\": \")",
      ".[] | .string + \": \" + (.number|tostring)",
      ".[] | \"\\(.string): \\(.number)\""
    ],
    "data": [
      {
        "input": [
          {
            "number": 3,
            "string": "three"
          },
          {
            "number": 7,
            "string": "seven"
          }
        ],
        "output": [
          "three: 3",
          "seven: 7"
        ]
      }
    ],
    "identifier": 35365769
  },
  {
    "context": [
      "jq --arg line \"$line\" '\n  .Reservations[].Instances[]\n  | select(contains({Tags: [{Key: \"Name\"}, {Value: $line}]}))\n' describe-instances.json",
      "jq --arg line \"$line\" '.Reservations[].Instances[] | select(contains({Tags: [{Key: \"Name\"}, {Value: \"line\"}]}))' describe-instances.json;"
    ],
    "utterance": "For each value from a list, select all Instances whose Tags include both a Key 'Name' and a Value matching that value.",
    "expressions": [
      "jq --arg line \"$line\" '.Reservations[].Instances[] | select(contains({Tags: [{Key: \"Name\"}, {Value: $line}]}))' describe-instances.json"
    ],
    "identifier": 35376426
  },
  {
    "context": [
      "I wish I could have written something like this:",
      "\"./jq --raw-output --run-cmd-file=cmd.jq\"",
      "where I can just put my command in a file, ship it to compute nodes and call it with an option.",
      "It looks like you somehow missed the `-f FILE` option!"
    ],
    "utterance": "Run a filter command from a separate file instead of specifying it on the command line.",
    "expressions": [
      "jq --raw-output -f cmd.jq"
    ],
    "identifier": 35484244
  },
  {
    "context": [
      "Is there a method or something like a jq script that can obtain a diff for JSON lines formatted files?",
      "The role of jq here is to sort the keys in the objects (without sorting the arrays) and to print them in a standard way, one per line (courtesy of the -c option).",
      "diff <(jq -cf jq-diff.jq FILE1 | sort) <(jq -cf jq-diff.jq FILE2 | sort)",
      "def sortKeys: to_entries | sort | from_entries;\nwalk( if type == \"object\" then sortKeys else . end )"
    ],
    "utterance": "Compare two files, each containing newline-delimited structured objects, and show the full line-by-line differences while preserving the order of items within arrays.",
    "expressions": [
      "def sortKeys: to_entries | sort | from_entries;\nwalk( if type == \"object\" then sortKeys else . end )",
      "jq -cf jq-diff.jq FILE1",
      "diff <(jq -cf jq-diff.jq FILE1 | sort) <(jq -cf jq-diff.jq FILE2 | sort)",
      "diff <(jq -cf jq-diff.jq FILE1) <(jq -cf jq-diff.jq FILE2)"
    ],
    "identifier": 35469941
  },
  {
    "context": [
      "What is the filter to use in order to get the following output?",
      "    {",
      "      \"num_of_vulns\": 2,",
      "      \"lib\": \"libxml2\",",
      "      \"license\": \"permissive\",",
      "      \"vulns\": [\"CVE-2012-0841\", \"CVE-2012-2871\"]",
      "    }",
      "Here is the working filter:",
      "if .[\"vuln-count\"].exact >0  then {",
      "   num_of_vulns: .\"vuln-count\".exact,",
      "   lib: .lib,",
      "   license: .license.type,",
      "   vulns: .vulns | map(select(.exact).vuln.cve)",
      "}  else empty end"
    ],
    "utterance": "Output an object with the number of exact vulnerabilities, the lib, the license type, and an array of CVE codes for vulnerabilities where exact is true.",
    "expressions": [
      "if .[\"vuln-count\"].exact > 0 then {num_of_vulns: .[\"vuln-count\"].exact, lib: .lib, license: .license.type, vulns: .vulns | map(select(.exact).vuln.cve)} else empty end",
      "{num_of_vulns: .\"vuln-count\".exact, lib: .lib, license: .license.type, vulns: .vulns | map(select(.exact).vuln.cve)}"
    ],
    "data": [
      {
        "input": {
          "license": {
            "type": "permissive",
            "url": "http://en.wikipedia.org/wiki/MIT_License",
            "name": "MIT"
          },
          "lib": "libxml2",
          "vuln-count": {
            "exact": 2,
            "total": 3,
            "historical": 1
          },
          "vulns": [
            {
              "exact": false,
              "timestamp-objects": [],
              "vuln": {
                "published-epoch": "1072839600",
                "cvss": 9.3,
                "summary": "libxml2, possibly before 2.5.0.\"",
                "published": "2003-12-31T03:00:00",
                "cve": "CVE-2003-1564",
                "modified": "2008-10-24T01:30:02",
                "modified-epoch": "1224811802"
              }
            },
            {
              "exact": true,
              "timestamp-objects": [
                "libxml2-2.8.0-1.x86_64.cpio:/usr/lib64/libxml2.so.2.8.0"
              ],
              "vuln": {
                "published-epoch": "1356061574",
                "cvss": 5,
                "summary": "libxml2 before 2.8.0 computes hash values.",
                "published": "2012-12-21T03:46:14",
                "cve": "CVE-2012-0841",
                "modified": "2014-01-28T02:42:55",
                "modified-epoch": "1390876975"
              }
            },
            {
              "exact": true,
              "timestamp-objects": [
                "libxml2-2.8.0-1.x86_64.cpio:/usr/lib64/libxml2.so.2.8.0"
              ],
              "vuln": {
                "published-epoch": "1346432101",
                "cvss": 6.8,
                "summary": "libxml2 2.9.0-rc1 and earlier.",
                "published": "2012-08-31T16:55:01",
                "cve": "CVE-2012-2871",
                "modified": "2014-01-28T02:45:36",
                "modified-epoch": "1390877136"
              }
            }
          ]
        },
        "output": {
          "num_of_vulns": 2,
          "lib": "libxml2",
          "license": "permissive",
          "vulns": [
            "CVE-2012-0841",
            "CVE-2012-2871"
          ]
        }
      }
    ],
    "identifier": 35333175
  },
  {
    "context": [
      "I'm looking to create a CSV based on two json arrays (arrays are a reduction of a large jason array with key value pairs)",
      "The issue is, the keys are not always sorted in the same order. For some objects I get:\n\n    Name, Role, Type\n\nand other times:\n\n    Role, Type Name ..",
      "I'm looking for a way to make the output consistent.",
      "For CSV, you might want to fix the order based on a pre-determined array of key names.  In that case, you could use:\n\n    def selectKeys(keys):\n      . as $in | reduce keys[] as $k ({}; . + {($k): $in[$k]})"
    ],
    "utterance": "Output the values of key-value pairs in a consistent, fixed order as rows, regardless of original key order, for CSV generation.",
    "expressions": [
      "def selectKeys(keys): . as $in | reduce keys[] as $k ({}; . + {($k): $in[$k]});\n$keys as $order | [.[] | selectKeys($order) | [.[$order[]]] | @csv]"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "some-server.com",
            "Role": "web server",
            "Type": "production",
            "Service": "apps",
            "Group": "main"
          }
        ],
        "output": [
          "\"some-server.com\",\"web server\",\"production\",\"apps\",\"main\""
        ]
      }
    ],
    "identifier": 35402535
  },
  {
    "context": [
      "I\u2019m trying to get `jq` to parse a JSON structure like:\n  \n    {\n      \"a\" : 1,\n      \"b\" : 2,\n      \"c\" : \"{\\\"id\\\":\\\"9ee ...\\\",\\\"parent\\\":\\\"abc...\\\"}\\n\"\n    }",
      "That is, an element in the JSON is a string with escaped json.",
      "jq has the [`fromjson`](https://stedolan.github.io/jq/manual/v1.5/#Convertto/fromJSON) builtin for this:\n\n    jq '.c | fromjson | .id' myFile.json\n\n`fromjson` was added in version 1.4.",
      "You can use the raw output (-r) that will unescape characters:\n\n    jq -r .c myfile.json | jq .id\n\nADDENDUM: This has the advantage that it works in jq 1.3 and up; indeed, it should work in every version of jq that has the -r option."
    ],
    "utterance": "Extract the id field from escaped JSON stored as a string in the c property, even when c contains an embedded JSON object as a string.",
    "expressions": [
      ".c | fromjson | .id",
      "-r .c | jq .id"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2,
          "c": "{\"id\":\"9ee...\",\"parent\":\"abc...\"}\n"
        },
        "output": "9ee..."
      }
    ],
    "identifier": 35154684
  },
  {
    "context": [
      "The structure I'm seeking looks something like this:\n\n    {\n      \"eth0\":\n            {\n                \"key1\": \"value1\",\n                \"key2\": \"value2\",\n                \"key3\": \"value3\"\n            },\n      \"eth3\":\n            {\n                \"key1\": \"value1\",\n                \"key2\": \"value2\",\n                \"key3\": \"value3\"\n            }\n    }",
      "derived from csv:\n\n    iface,key1,key2,key3\n    eth0,value1,value2,value3\n    eth3,value1,value2,value3",
      "$ jq -R 'split(\",\") as $k |\n    reduce (inputs | split(\",\")) as $r ({};\n        .[$r[0]] = ([range(1;$k|length) | { key: $k[.], value: $r[.] }] | from_entries)\n    )' input.csv",
      "jq -R -n '\n  def objectify(headers): . as $in\n    | reduce range(0; headers|length) as $i\n        ({}; .[headers[$i]] = $in[$i]  );\n\n  ((input|split(\",\"))[1:]) as $headers\n  | [ (inputs|split(\",\")) as $line\n      | { ($line[0]): ($line[1:] | objectify($headers)) } ]\n  | add\n'"
    ],
    "utterance": "Transform CSV rows with interface names and key-value pairs into an object mapping each interface to its corresponding property object, with keys taken from the CSV headers.",
    "expressions": [
      "split(\",\") as $k |\n    reduce (inputs | split(\",\")) as $r ({};\n        .[$r[0]] = ([range(1;$k|length) | { key: $k[.], value: $r[.] }] | from_entries)\n    )",
      "-n '\n  def objectify(headers): . as $in\n    | reduce range(0; headers|length) as $i\n        ({}; .[headers[$i]] = $in[$i]  );\n\n  ((input|split(\",\"))[1:]) as $headers\n  | [ (inputs|split(\",\")) as $line\n      | { ($line[0]): ($line[1:] | objectify($headers)) } ]\n  | add\n'"
    ],
    "data": [
      {
        "input": "iface,key1,key2,key3\neth0,value1,value2,value3\neth3,value1,value2,value3",
        "output": {
          "eth0": {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3"
          },
          "eth3": {
            "key1": "value1",
            "key2": "value2",
            "key3": "value3"
          }
        }
      }
    ],
    "identifier": 35373972
  },
  {
    "context": [
      "I want to sort this array analogous to this SQL `ORDER BY prop1 DESC, prop2 ASC` so I have this result:",
      "Knowing this, and taking into account that the values in your example are numeric, you can just do the following:",
      "$ jq 'sort_by(-.prop1, .prop2)'",
      "SQL `ORDER BY prop1 DESC, prop2 ASC` \u2192 jq `| sort_by(.prop2) | reverse | sort_by(.prop1) | reverse` \u2013 Note, the sorting is specified with properties in the reverse order, and `reverse` is used twice.",
      "Given `prop1` and `prop2` are numeric, the accepted answer (`sort_by(-.prop1, .prop2)`) is much simpler/better."
    ],
    "utterance": "Sort an array of objects first by prop1 in descending order, then by prop2 in ascending order",
    "expressions": [
      "sort_by(-.prop1, .prop2)",
      "sort_by(.prop2) | reverse | sort_by(.prop1) | reverse"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Object 1",
            "prop1": 5,
            "prop2": 2
          },
          {
            "name": "Object 2",
            "prop1": 6,
            "prop2": 4
          },
          {
            "name": "Object 3",
            "prop1": 5,
            "prop2": 3
          }
        ],
        "output": [
          {
            "name": "Object 2",
            "prop1": 6,
            "prop2": 4
          },
          {
            "name": "Object 1",
            "prop1": 5,
            "prop2": 2
          },
          {
            "name": "Object 3",
            "prop1": 5,
            "prop2": 3
          }
        ]
      }
    ],
    "identifier": 35540294
  },
  {
    "context": [
      "I would like to validate the JSON object using [jq][1] using following conditions:\r\n\r\n - *color* has value \"red\"\r\n - *shapes* does not contain value \"round\"",
      "In your case, a correct test would be:\r\n\r\n    (.color == \"red\") and (.shapes|index(\"round\") == null)",
      "jq '(.color == \"red\") and (.shapes|index(\"round\") == null)'",
      "You can simply verify that both tests return true with `all`:\r\n\r\n    jq '[(.[\"color\"] | test(\"red\")),\r\n         (any(.shapes[]; contains(\"round\"))|not)\r\n        ] | all'"
    ],
    "utterance": "Determine if color is \"red\" and shapes does not contain \"round\"; return true or false.",
    "expressions": [
      "(.color == \"red\") and (.shapes|index(\"round\") == null)",
      "[(.[\"color\"] | test(\"red\")), (any(.shapes[]; contains(\"round\"))|not)] | all"
    ],
    "data": [
      {
        "input": {
          "color": "red",
          "shapes": [
            "square",
            "triangle"
          ]
        },
        "output": true
      }
    ],
    "identifier": 35611660
  },
  {
    "context": [
      "I would like to be able to use jq to print the contents of the IP address line based on the \"user\" value.",
      "When what I need is the whole line:\n\n    \"1.2.3.4:25925\" : {\"user\" : \"bob\", \"password\" : \"aaaaaaaa\", \"publicKey\" : \"foirncnqwpnqwopnqrrvn308g9h4b.k\"},",
      "I can't figure out how to build such an expression without knowing the parent object name before hand (each IP address:port will be unique).",
      "You can get an object with all the elements that match your predicate; this would be one way of doing so:\n\n    jq '.interfaces.UDPInterface[0].connectTo | with_entries(select(.value.user | contains(\"bob\")))'",
      "The output for your given input would be:\n\n    {\n      \"1.2.3.4:25925\": {\n        \"user\": \"bob\",\n        \"password\": \"aaaaaaaa\",\n        \"publicKey\": \"foirncnqwpnqwopnqrrvn308g9h4b.k\"\n      }\n    }",
      "Here is a solution which uses tostream, select and foreach to enumerate paths to objects with \"user:\"bob\" and return those objects in the desired format with getpath",
      "toStream | select(length == 2 and .[0][-1] == \"user\" and .[1] == \"bob\") | .[0] ) as $p | { ($p[-2]): getpath($p[:-1]) }"
    ],
    "utterance": "Return the key-value pair from 'connectTo' where the nested object's 'user' field contains 'bob', without knowing the key in advance.",
    "expressions": [
      ".interfaces.UDPInterface[0].connectTo | with_entries(select(.value.user | contains(\"bob\")))",
      "(toStream | select(length == 2 and .[0][-1] == \"user\" and .[1] == \"bob\") | .[0]) as $p | { ($p[-2]): getpath($p[:-1]) }"
    ],
    "data": [
      {
        "input": {
          "interfaces": {
            "UDPInterface": [
              {
                "connectTo": {
                  "1.2.3.4:25925": {
                    "user": "bob",
                    "password": "aaaaaaaa",
                    "publicKey": "foirncnqwpnqwopnqrrvn308g9h4b.k"
                  },
                  "4.3.2.1:24970": {
                    "user": "sam",
                    "password": "bbbbbbbb",
                    "publicKey": "v09ervn4uvr78cweyclfirnfuq3c9pwper.k"
                  },
                  "1.3.4.2:41872": {
                    "user": "betty",
                    "password": "cccccccccc",
                    "publicKey": "crnn497hg3j34f34uvrnfwmnriuhqrmoweje.k"
                  }
                },
                "bind": "0.0.0.0:64660"
              },
              {
                "connectTo": {},
                "bind": "[::]:54887"
              }
            ]
          }
        },
        "output": {
          "1.2.3.4:25925": {
            "user": "bob",
            "password": "aaaaaaaa",
            "publicKey": "foirncnqwpnqwopnqrrvn308g9h4b.k"
          }
        }
      }
    ],
    "identifier": 35515770
  },
  {
    "context": [
      "I was curious if there is a clean way to add line numbers to `jq`'s output while still retaining the coloring of the output.",
      "I have tried piping from `jq` to `cat -n` but unfortunately this removes the coloring which helps a lot when traversing the JSON tree.",
      "Specify the jq -C option explicitly."
    ],
    "utterance": "Display query results line-numbered with color retained.",
    "expressions": [
      "jq -C . input.json | cat -n"
    ],
    "identifier": 35730999
  },
  {
    "context": [
      "I would like to loop through each object in this array, and pick out the value of each key called `AssetId` and output it.",
      "If you want to write the .AssetId information to STDOUT, then one possibility would be as follows: \r\n\r\n    jq -r \".[] | .AssetId\" input.json",
      "You can also do it via this command.\r\n```shell\r\njq \".[].AssetId\" input.json\r\n```",
      "An alternative using `map`:\r\n\r\n    jq \"map ( .AssetId ) | .[]\"",
      "For your case  `jq -r '.[].AssetId'` should work"
    ],
    "utterance": "Return the value of the AssetId field from each object in the input array.",
    "expressions": [
      ".[] | .AssetId",
      ".[].AssetId",
      "map(.AssetId) | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "AssetId": 14462955,
            "Name": "Cultural Item"
          },
          {
            "AssetId": 114385498,
            "Name": "Redspybot"
          },
          {
            "AssetId": 29715011,
            "Name": "American Cowboy"
          },
          {
            "AssetId": 98253651,
            "Name": "Mahem"
          }
        ],
        "output": [
          14462955,
          114385498,
          29715011,
          98253651
        ]
      }
    ],
    "identifier": 35677309
  },
  {
    "context": [
      "Is it possible to efficiently get the first record of a [JSONL][1] file without consuming the entire stream / file?",
      "jq -s '.[0]'",
      "I realize that `head` could be used here to extract the first line, but assume that the file may not use a newline as the record separator and may simply be concatenated objects or arrays.",
      "you could just utilize the [`input`][1] filter to grab the first item.",
      "$ curl -s http://example.org/file.jsonl | jq -n 'input'",
      "You need the null input `-n` to not process the input immediately then `input` just gets one input from the stream.  No need to go through the rest of the input stream."
    ],
    "utterance": "Return only the first top-level object or array from a stream of concatenated objects or arrays, without reading the entire input.",
    "expressions": [
      "jq -n 'input'"
    ],
    "identifier": 35750563
  },
  {
    "context": [
      "Is it possible to apply a recursive transformation to a record to return the same record, but having all `string` values mapped?",
      "For example:\n\n    {\"x\":\"1\", \"a\": {\"b\": 2, \"c\": [\"a\"]}, \"d\": {\"e\": \"z\"}}\n\nwith a mapping of \"add prime\" applied:\n\n    {\"x\":\"1'\", \"a\": {\"b\": 2, \"c\": [\"a'\"]}, \"d\": {\"e\": \"z'\"}}",
      "Yes, use `walk/1`.  It is explained in the [jq manual][1].",
      "You can also do this easily with the recurse operator:\n\n`jq '(.. | strings) += \"'\"'`",
      "Here is a solution which uses **paths/1** to identify string values and updates them with **reduce**, **setpath** and **getpath**\n\n    reduce paths(type == \"string\") as $p (\n        .\n      ; setpath($p; getpath($p) + \"'\")\n    )\n"
    ],
    "utterance": "Append a single quote character to every string value, including those nested within objects and arrays.",
    "expressions": [
      "walk(if type == \"string\" then . + \"'\" else . end)",
      "(.. | strings) += \"'\"",
      "reduce paths(type == \"string\") as $p (. ; setpath($p; getpath($p) + \"'\"))"
    ],
    "data": [
      {
        "input": {
          "x": "1",
          "a": {
            "b": 2,
            "c": [
              "a"
            ]
          },
          "d": {
            "e": "z"
          }
        },
        "output": {
          "x": "1'",
          "a": {
            "b": 2,
            "c": [
              "a'"
            ]
          },
          "d": {
            "e": "z'"
          }
        }
      }
    ],
    "identifier": 35609548
  },
  {
    "context": [
      "so jq \".foo.bar\" returns the \"x1234\" fragment but what I need is the \"url\" value underneath it.",
      "One approach is to use `..`.  For example, provided the input is valid JSON:\n\n    $ jq '.. | .url? | select(.)' input.json\n    \"http://example.com\"\n\nOr equivalently (and easier to type):\n\n    $ jq '.. | .url? // empty' input.json",
      "Assuming `foo` and `bar` are known, you could just do\n```\n.foo.bar[].url\n```\n",
      "Let's say if `bar` is also unknown, then do the following\n```\n.foo[][].url\n```"
    ],
    "utterance": "Retrieve the values of the 'url' properties nested under dynamically named keys beneath '.foo.bar'.",
    "expressions": [
      ".foo.bar[].url",
      ".. | .url? | select(.)",
      ".. | .url? // empty"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": {
              "x1234": {
                "url": "http://example.com"
              }
            }
          }
        },
        "output": "http://example.com"
      },
      {
        "input": {
          "foo": {
            "bar": {
              "x1234": {
                "url": "http://example.com"
              },
              "x1234xxx": {
                "url": "http://example.com/file.zip"
              }
            }
          }
        },
        "output": [
          "http://example.com",
          "http://example.com/file.zip"
        ]
      }
    ],
    "identifier": 35760856
  },
  {
    "context": [
      "The following jq command works on command line:",
      "jq 'select(.name==\"value1:value2\") | .EndDate' test.json",
      "However, if I try to execute same command in my bash script with a variable i.e.",
      "var=\"value1:value2\"",
      "endDateVar=$(jq \"select(.name==\\\"${var}\\\") | .EndDate\" test.json)",
      "error: syntax error, unexpected ':', select(.name==value1:value2) | .EndDate 1 compile error",
      "Here's a reasonable approach, assuming you have a Mac or Linux-like shell:",
      "jq --arg var \"$var\" 'select(.name==$var) | .EndDate' test.json",
      "Your approach can of course also be made to work, e.g.",
      "jq \"select(.name==\\\"${var}\\\") | .EndDate\" test.json"
    ],
    "utterance": "Get the EndDate where the name field matches the variable value 'value1:value2', handling the colon in the string.",
    "expressions": [
      "jq --arg var \"$var\" 'select(.name==$var) | .EndDate' test.json",
      "jq \"select(.name==\\\"${var}\\\") | .EndDate\" test.json"
    ],
    "data": [
      {
        "input": {
          "name": "value1:value2",
          "StartDate": "2015-09-01T04:00:00Z",
          "EndDate": "2016-09-05T09:59:59Z"
        },
        "output": "\"2016-09-05T09:59:59Z\""
      }
    ],
    "identifier": 35785809
  },
  {
    "context": [
      "I am trying to use `jq` to construct a hash in which a key name comes from a variable.",
      "jq --null-input --arg key foobar '{{$key: \"value\"}}'",
      "Use parentheses to evaluate `$key` early as in:\n\n     jq --null-input --arg key foobar '{($key): \"value\"}'",
      "You can do below. The contents of the variable `key` is expanded and returned as a string by the interpolation sequence.\n\n    jq --null-input --arg key foobar '{ \"\\($key)\": \"value\"}'"
    ],
    "utterance": "Construct an object where the key name comes from a variable with the value \"value\".",
    "expressions": [
      "{($key): \"value\"}",
      "{ \"\\($key)\": \"value\"}"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "foobar": "value"
        }
      }
    ],
    "identifier": 35841309
  },
  {
    "context": [
      "Given a JSON file that is wrapped in a _\"results\"_ dictionary, how can I detect the end of the file?",
      "jq '{ \"results\": .results[0:500] }' Foo.json > 0000-0500/Foo.json",
      "I'd recommend using jq to split-up the array into a stream of the JSON objects you want (one per line), and then using some other tool (e.g. awk) to populate the files.  Here's how the first part can be done:",
      "def splitup(n):\n  def _split:\n    if length == 0 then empty\n    else .[0:n], (.[n:] | _split)\n    end;\n  if n == 0 then empty elif n > 0 then _split else reverse|splitup(-n) end;",
      "data | .results | {results: splitup(5) }",
      "$ jq -nc -f splitup.jq\n{\"results\":[0,1,2,3,4]}\n{\"results\":[5,6,7,8,9]}\n{\"results\":[10,11,12,13,14]}\n{\"results\":[15,16,17,18,19]}"
    ],
    "utterance": "Split the array inside the 'results' field of an object into multiple objects, each containing a chunk of 5 elements from the array.",
    "expressions": [
      "def splitup(n):\n  def _split:\n    if length == 0 then empty\n    else .[0:n], (.[n:] | _split)\n    end;\n  if n == 0 then empty elif n > 0 then _split else reverse|splitup(-n) end;\n.results | {results: splitup(5)}"
    ],
    "data": [
      {
        "input": {
          "results": [
            0,
            1,
            2,
            3,
            4,
            5,
            6,
            7,
            8,
            9,
            10,
            11,
            12,
            13,
            14,
            15,
            16,
            17,
            18,
            19
          ]
        },
        "output": [
          {
            "results": [
              0,
              1,
              2,
              3,
              4
            ]
          },
          {
            "results": [
              5,
              6,
              7,
              8,
              9
            ]
          },
          {
            "results": [
              10,
              11,
              12,
              13,
              14
            ]
          },
          {
            "results": [
              15,
              16,
              17,
              18,
              19
            ]
          }
        ]
      }
    ],
    "identifier": 35881458
  },
  {
    "context": [
      "For each object in the array, I want to take the value of the name property, and use it as the property name for the resulting object.",
      "The output I want is:\r\n\r\n    {\r\n      \"Product one\": {\r\n        \"productId\":\"12345\",\r\n        \"itemCode\":\"7037\"\r\n      },\r\n      \"Product two\": {\r\n        \"productId\":\"67890\",\r\n        \"itemCode\":\"9101\"\r\n      },\r\n      \"Product three\": {\r\n        \"productId\":\"111213\",\r\n        \"itemCode\":\"7047\"\r\n      }\r\n    }",
      "The easiest way to convert an array into an object is arguably via the [`from_entries`](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries) function, like so:\r\n\r\n    map({key: .name, value: del(.name)}) | from_entries",
      "The simplest approach here would be to create the three objects in the array and then \"add\" them:\r\n\r\n     map( { (.name): del(.name) } ) | add",
      "Here is a solution using **reduce**:\r\n    \r\n    reduce .[] as $e (\r\n         {}\r\n       ; .[$e.name] = ($e | del(.name))\r\n    )"
    ],
    "utterance": "Transform an array of products into an object using each product's name as the key and the rest of its properties as the value.",
    "expressions": [
      "map({key: .name, value: del(.name)}) | from_entries",
      "map( { (.name): del(.name) } ) | add",
      "reduce .[] as $e ({}; .[$e.name] = ($e | del(.name)))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Product one",
            "productId": "12345",
            "itemCode": "7037"
          },
          {
            "name": "Product two",
            "productId": "67890",
            "itemCode": "9101"
          },
          {
            "name": "Product three",
            "productId": "111213",
            "itemCode": "7047"
          }
        ],
        "output": {
          "Product one": {
            "productId": "12345",
            "itemCode": "7037"
          },
          "Product two": {
            "productId": "67890",
            "itemCode": "9101"
          },
          "Product three": {
            "productId": "111213",
            "itemCode": "7047"
          }
        }
      }
    ],
    "identifier": 35855226
  },
  {
    "context": [
      "How do I write a `jq` command that'll filter out this JSON blob and *print me the IDs of all entries in the array that have isSparse == true?*",
      "If the task is to \"print the IDs of all entries in the array that have isSparse == true\", an appropriate jq filter would be:",
      ".[] | select(.isSparse == true) | .id",
      "As @JeffMercado pointed out, if .isSparse is strictly boolean, then select(.isSparse) would suffice.",
      "map( select(.isSparse == true) | .id ) | unique[]"
    ],
    "utterance": "Print the id values of all objects in the array where isSparse is true.",
    "expressions": [
      ".[] | select(.isSparse == true) | .id",
      ".[] | select(.isSparse) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "something",
            "isSparse": true
          },
          {
            "id": "nothing",
            "isSparse": false
          },
          {
            "id": "another",
            "isSparse": true
          }
        ],
        "output": [
          "something",
          "another"
        ]
      }
    ],
    "identifier": 35904882
  },
  {
    "context": [
      "I'm trying to figure out how to remove an array element from some JSON using jq.",
      "Input:\r\n\r\n    {\r\n      \"blah0\": \"zeroblah\",\r\n      \"Array\": [\r\n        {\r\n          \"blah1\": [\r\n            \"key1:val1\"\r\n          ],\r\n          \"foobar0\": \"barfoo0\",\r\n          \"foobar1\": \"barfoo1\"\r\n        },\r\n        {\r\n          \"blah2\": [\r\n            \"key2:val2\"\r\n          ],\r\n          \"foobar2\": \"barfoo2\",\r\n          \"foobar3\": \"barfoo3\"\r\n        }\r\n      ]\r\n    }",
      "Desired output:\r\n\r\n    {\r\n      \"blah0\": \"zeroblah\",\r\n      \"Array\": [\r\n        {\r\n          \"blah1\": [\r\n            \"key1:val1\"\r\n          ],\r\n          \"foobar0\": \"barfoo0\",\r\n          \"foobar1\": \"barfoo1\"\r\n        }\r\n      ]\r\n    }",
      "In this particular case, the simplest would be:\r\n\r\n    del(.Array[1])",
      "More generally, if you wanted to delete all items in the array except for the first:\r\n\r\n    .Array |= [.[0]]"
    ],
    "utterance": "Remove the second element of the Array property, keeping only the first element.",
    "expressions": [
      "del(.Array[1])",
      ".Array |= [.[0]]"
    ],
    "data": [
      {
        "input": {
          "blah0": "zeroblah",
          "Array": [
            {
              "blah1": [
                "key1:val1"
              ],
              "foobar0": "barfoo0",
              "foobar1": "barfoo1"
            },
            {
              "blah2": [
                "key2:val2"
              ],
              "foobar2": "barfoo2",
              "foobar3": "barfoo3"
            }
          ]
        },
        "output": {
          "blah0": "zeroblah",
          "Array": [
            {
              "blah1": [
                "key1:val1"
              ],
              "foobar0": "barfoo0",
              "foobar1": "barfoo1"
            }
          ]
        }
      }
    ],
    "identifier": 35876490
  },
  {
    "context": [
      "I just need to associate the hostgroup on a single line with all of the host information.",
      "The following commands will get me what I need:\n\n    .data.hostgroups[0].name as $Group | {$Group} + .data.hostgroups[0].hosts[] | [.Group, .name, .time_up, .time_down, .time_unreachable, .scheduled_time_up, .scheduled_time_down, .scheduled_time_unreachable, .time_indeterminate_nodata, .time_indeterminate_notrunning] | @csv",
      "But I've been trying to figure out how to do this in one line.  I have 20 hostgroups, so this is 20 commands in my script.",
      "But when I add an additional field in, for example:\n\n    map(.data.hostgroups | map({Group: .name, Host: .hosts[].name, Uptime: .hosts[].time_up} | [.Group, .Host, .Uptime])) | add[] | @csv\n\nThe output is:\n\n    \"ATL\",\"ATL-SERVER1\",2496629\n    \"ATL\",\"ATL-SERVER1\",2505525\n    \"ATL\",\"ATL-SERVER2\",2496629\n    \"ATL\",\"ATL-SERVER2\",2505525\n    \"LAX\",\"LAX-SERVER1\",2505599\n    \"LAX\",\"LAX-SERVER1\",2505599\n    \"LAX\",\"LAX-SERVER2\",2505599\n    \"LAX\",\"LAX-SERVER2\",2505599\n\nFor every field I add, it basically multiplies them together. And I'm pretty sure I understand why that is, but I'm still trying to figure out how to one line this while avoiding the problem of exponentially combining the results.",
      "$ cat extract.jq\n.data.hostgroups[]\n| .name as $Group\n| .hosts[]\n| [$Group, .name, .time_up, .time_down, .time_unreachable,\n   .scheduled_time_up, .scheduled_time_down, \n   .scheduled_time_unreachable, .time_indeterminate_nodata, \n   .time_indeterminate_notrunning]\n| @csv",
      "$ jq -r -f extract.jq in.json\n\"ATL\",\"ATL-SERVER1\",2496629,8970,0,0,0,0,0,0\n\"ATL\",\"ATL-SERVER2\",2505525,74,0,0,0,0,0,0\n\"LAX\",\"LAX-SERVER1\",2505599,0,0,0,0,0,0,0\n\"LAX\",\"LAX-SERVER2\",2505599,0,0,0,0,0,0,0"
    ],
    "utterance": "Output, for each host in each hostgroup, a CSV line with the hostgroup name, host name, and all host timing fields, without hardcoding hostgroup indices or multiplying fields together.",
    "expressions": [
      ".data.hostgroups[] | .name as $Group | .hosts[] | [$Group, .name, .time_up, .time_down, .time_unreachable, .scheduled_time_up, .scheduled_time_down, .scheduled_time_unreachable, .time_indeterminate_nodata, .time_indeterminate_notrunning] | @csv"
    ],
    "data": [
      {
        "input": {
          "data": {
            "selectors": {},
            "hostgroups": [
              {
                "name": "ATL",
                "hosts": [
                  {
                    "name": "ATL-SERVER1",
                    "time_up": 2496629,
                    "time_down": 8970,
                    "time_unreachable": 0,
                    "scheduled_time_up": 0,
                    "scheduled_time_down": 0,
                    "scheduled_time_unreachable": 0,
                    "time_indeterminate_nodata": 0,
                    "time_indeterminate_notrunning": 0
                  },
                  {
                    "name": "ATL-SERVER2",
                    "time_up": 2505525,
                    "time_down": 74,
                    "time_unreachable": 0,
                    "scheduled_time_up": 0,
                    "scheduled_time_down": 0,
                    "scheduled_time_unreachable": 0,
                    "time_indeterminate_nodata": 0,
                    "time_indeterminate_notrunning": 0
                  }
                ]
              },
              {
                "name": "LAX",
                "hosts": [
                  {
                    "name": "LAX-SERVER1",
                    "time_up": 2505599,
                    "time_down": 0,
                    "time_unreachable": 0,
                    "scheduled_time_up": 0,
                    "scheduled_time_down": 0,
                    "scheduled_time_unreachable": 0,
                    "time_indeterminate_nodata": 0,
                    "time_indeterminate_notrunning": 0
                  },
                  {
                    "name": "LAX-SERVER2",
                    "time_up": 2505599,
                    "time_down": 0,
                    "time_unreachable": 0,
                    "scheduled_time_up": 0,
                    "scheduled_time_down": 0,
                    "scheduled_time_unreachable": 0,
                    "time_indeterminate_nodata": 0,
                    "time_indeterminate_notrunning": 0
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "\"ATL\",\"ATL-SERVER1\",2496629,8970,0,0,0,0,0,0",
          "\"ATL\",\"ATL-SERVER2\",2505525,74,0,0,0,0,0,0",
          "\"LAX\",\"LAX-SERVER1\",2505599,0,0,0,0,0,0,0",
          "\"LAX\",\"LAX-SERVER2\",2505599,0,0,0,0,0,0,0"
        ]
      }
    ],
    "identifier": 35759488
  },
  {
    "context": [
      "I want to select the keys whose value is > 10. I want the output of my `jq` command to return a list containing just the keys that meet this criterion. In the above example, it would return `\"thing_one, thing_four, thing_five\"`. What is the best way to do this?",
      "jq 'to_entries[] | select(.value > 10) | .key'",
      "to_entries[] | select( .value>10 ) | .key",
      "keys[] as $key\n| if .[$key] > 10 then $key else empty end",
      "[paths(.>10)[]] | join(\", \")"
    ],
    "utterance": "Find all keys with values greater than 10 and return them as a comma-separated string in a single output.",
    "expressions": [
      "[to_entries[] | select(.value > 10) | .key] | join(\", \")",
      "keys[] as $key | select(.[$key] > 10) | $key | join(\", \")",
      "[paths(.>10)[]] | join(\", \")"
    ],
    "data": [
      {
        "input": {
          "thing_one": 223,
          "thing_two": 0,
          "thing_three": 0,
          "thing_four": 69,
          "thing_five": 14,
          "thing_six": 0
        },
        "output": "thing_one, thing_four, thing_five"
      }
    ],
    "identifier": 35926285
  },
  {
    "context": [
      "I am specifically looking to remove a grantee when I see `http://acs.amazonaws.com/groups/global/AllUsers`",
      "Here is a jq filter which will remove all the .Grants array elements for which .Grantee.URI is \"http://acs.amazonaws.com/groups/global/AllUsers\":",
      ".Grants |= map( select(.Grantee.URI != \"http://acs.amazonaws.com/groups/global/AllUsers\") )",
      "In this problem the specified grant can also be removed directly with `del`. e.g",
      "del(\n    .Grants[]\n  | select(.Grantee.URI == \"http://acs.amazonaws.com/groups/global/AllUsers\")\n)"
    ],
    "utterance": "Remove entries in Grants array where Grantee.URI equals \"http://acs.amazonaws.com/groups/global/AllUsers\".",
    "expressions": [
      ".Grants |= map( select(.Grantee.URI != \"http://acs.amazonaws.com/groups/global/AllUsers\") )",
      "del(.Grants[] | select(.Grantee.URI == \"http://acs.amazonaws.com/groups/global/AllUsers\"))"
    ],
    "data": [
      {
        "input": {
          "Owner": {
            "DisplayName": "2414218.aws",
            "ID": "xxxxxxxx"
          },
          "Grants": [
            {
              "Grantee": {
                "DisplayName": "2414218.aws",
                "ID": "yyyyyyyyyy"
              },
              "Permission": "FULL_CONTROL"
            },
            {
              "Grantee": {
                "URI": "http://acs.amazonaws.com/groups/global/AllUsers"
              },
              "Permission": "READ"
            }
          ]
        },
        "output": {
          "Owner": {
            "DisplayName": "2414218.aws",
            "ID": "xxxxxxxx"
          },
          "Grants": [
            {
              "Grantee": {
                "DisplayName": "2414218.aws",
                "ID": "yyyyyyyyyy"
              },
              "Permission": "FULL_CONTROL"
            }
          ]
        }
      }
    ],
    "identifier": 36044151
  },
  {
    "context": [
      "If this were the type of file I could hold in memory, and I wanted to select objects that only have batter type \"Chocolate\", I could use:",
      "`cat sample.json | jq '.[] | select(.batters.batter[].type == \"Chocolate\")'`",
      "And I would only get back the full objects with ids `\"0001\"` and `\"0003\"`",
      "But with streaming I know it's different.",
      "Namely, Is it even possible to select whole objects after streaming through their paths and identifying a notable event, or in this case a property value that matches a certain string?",
      "Command:\n\n    $ jq -cn --stream 'fromstream(1|truncate_stream(inputs))' array_of_objects.json | \n      jq 'select(.batters.batter[].type == \"Chocolate\") | .id'\n\nOutput:\n\n    \"0001\"\n    \"0003\"",
      "By the way, it would probably be better to use the following `select`: \n\n    select( any(.batters.batter[]; .type == \"Chocolate\") )"
    ],
    "utterance": "Find all top-level objects in an array where any batter type is \"Chocolate\" and return their id values.",
    "expressions": [
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs))' array_of_objects.json | jq 'select(any(.batters.batter[]; .type == \"Chocolate\")) | .id'",
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs))' array_of_objects.json | jq 'select(.batters.batter[].type == \"Chocolate\") | .id'"
    ],
    "data": [
      {
        "input": [
          {
            "id": "0001",
            "type": "donut",
            "name": "Cake",
            "ppu": 0.55,
            "batters": {
              "batter": [
                {
                  "id": "1001",
                  "type": "Regular"
                },
                {
                  "id": "1002",
                  "type": "Chocolate"
                },
                {
                  "id": "1003",
                  "type": "Blueberry"
                },
                {
                  "id": "1004",
                  "type": "Devil's Food"
                }
              ]
            },
            "topping": [
              {
                "id": "5001",
                "type": "None"
              },
              {
                "id": "5002",
                "type": "Glazed"
              },
              {
                "id": "5005",
                "type": "Sugar"
              },
              {
                "id": "5007",
                "type": "Powdered Sugar"
              },
              {
                "id": "5006",
                "type": "Chocolate with Sprinkles"
              },
              {
                "id": "5003",
                "type": "Chocolate"
              },
              {
                "id": "5004",
                "type": "Maple"
              }
            ]
          },
          {
            "id": "0002",
            "type": "donut",
            "name": "Raised",
            "ppu": 0.55,
            "batters": {
              "batter": [
                {
                  "id": "1001",
                  "type": "Regular"
                }
              ]
            },
            "topping": [
              {
                "id": "5001",
                "type": "None"
              },
              {
                "id": "5002",
                "type": "Glazed"
              },
              {
                "id": "5005",
                "type": "Sugar"
              },
              {
                "id": "5003",
                "type": "Chocolate"
              },
              {
                "id": "5004",
                "type": "Maple"
              }
            ]
          },
          {
            "id": "0003",
            "type": "donut",
            "name": "Old Fashioned",
            "ppu": 0.55,
            "batters": {
              "batter": [
                {
                  "id": "1001",
                  "type": "Regular"
                },
                {
                  "id": "1002",
                  "type": "Chocolate"
                }
              ]
            },
            "topping": [
              {
                "id": "5001",
                "type": "None"
              },
              {
                "id": "5002",
                "type": "Glazed"
              },
              {
                "id": "5003",
                "type": "Chocolate"
              },
              {
                "id": "5004",
                "type": "Maple"
              }
            ]
          }
        ],
        "output": [
          "0001",
          "0003"
        ]
      }
    ],
    "identifier": 35308616
  },
  {
    "context": [
      "I need to change the value of a set of keys (defined in a variable) in a JSON object using jq.",
      "and the following variable: \r\n\r\n    update_keys = [\"bar\", \"baz\"]\r\n\r\nI would like to say 'change the value of the keys in update_keys to X'.",
      ".foo |= with_entries( .value = if ([.key] | inside([\"bar\", \"baz\"])) then \"X\" else .value end )",
      ".foo |= with_entries( . as $in \r\n              | if $update_keys | index($in.key) then .value = \"X\" else empty end)",
      "[\"bar\",\"baz\"] as $update_keys\n| .foo[ $update_keys[] ] = \"X\""
    ],
    "utterance": "Set the value of the keys \"bar\" and \"baz\" inside the \"foo\" object to \"X\", using a variable or array to specify the keys.",
    "expressions": [
      ".foo |= with_entries(.value = if ([.key] | inside([\"bar\", \"baz\"])) then \"X\" else .value end)",
      ".foo |= with_entries(. as $in | if $update_keys | index($in.key) then .value = \"X\" else empty end)",
      "[\"bar\",\"baz\"] as $update_keys | .foo[$update_keys[]] = \"X\""
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": 1,
            "baz": 2,
            "qux": 3
          }
        },
        "output": {
          "foo": {
            "bar": "X",
            "baz": "X",
            "qux": 3
          }
        }
      }
    ],
    "identifier": 36149725
  },
  {
    "context": [
      "I'm trying to export data from consul kv into json with a nested object for each level of depth in consul.",
      "Example json returned from consul:\r\n\r\n    [\r\n      {\r\n        \"LockIndex\": 0,\r\n        \"Key\": \"foobar/testing\",\r\n        \"Flags\": 0,\r\n        \"Value\": \"xxxxx\",\r\n        \"CreateIndex\": 833,\r\n        \"ModifyIndex\": 833\r\n      },\r\n      {\r\n        \"LockIndex\": 0,\r\n        \"Key\": \"foobar/bazbar\",\r\n        \"Flags\": 0,\r\n        \"Value\": \"xxxxx\",\r\n        \"CreateIndex\": 833,\r\n        \"ModifyIndex\": 833\r\n      }\r\n    ]",
      "Desired JSON:\r\n\r\n    [\r\n      {\r\n        \"foobar\": {\r\n          \"testing\": \"xxxxx\",\r\n          \"bazbar\": \"xxxxx\"\r\n        }\r\n      }\r\n    ]",
      "I'm sort of close with `jq '.[] | objects | {Key: .Key | split(\"/\"), Value: .Value}'` but I'm just not understanding how I can recurse based on a split() of .Key and create nested objects.",
      "The following produces the JSON object of interest in the particular case you give, but also provides a reasonable generalization in case there is more than one \"foobar\" prefix:\r\n\r\n    map( . as $o | .Key | split(\"/\") | {(.[0]): {(.[1]): ($o|.Value) }} )\r\n    | reduce .[] as $o\r\n        ( {};\r\n          ($o|keys[0]) as $key | . + { ($key): (.[$key] + $o[$key]) } )",
      "Here is a solution that uses **reduce**, **split** and **setpath**\r\n\r\n    [\r\n      reduce (.[] | [(.Key | split(\"/\")), .Value]) as [$p,$v] (\r\n        {}\r\n      ; setpath($p; $v)\r\n      )\r\n    ]",
      "This simple solution uses `setpath` to handle any depth and works great for parsing Consul KV responses:\r\n\r\n        reduce .[] as $item ({}; setpath($item.Key | split(\"/\"); $item.Value))"
    ],
    "utterance": "Transform an array of objects with 'Key' fields containing slash-delimited paths and 'Value' fields into a nested object structure reflecting the path hierarchy, mapping each final segment to its corresponding value.",
    "expressions": [
      "map( . as $o | .Key | split(\"/\") | {(.[0]): {(.[1]): ($o|.Value) }} ) | reduce .[] as $o ( {}; ($o|keys[0]) as $key | . + { ($key): (.[$key] + $o[$key]) } )",
      "[reduce (.[] | [(.Key | split(\"/\")), .Value]) as [$p,$v] ({}; setpath($p; $v))]",
      "reduce .[] as $item ({}; setpath($item.Key | split(\"/\"); $item.Value))"
    ],
    "data": [
      {
        "input": [
          {
            "LockIndex": 0,
            "Key": "foobar/testing",
            "Flags": 0,
            "Value": "xxxxx",
            "CreateIndex": 833,
            "ModifyIndex": 833
          },
          {
            "LockIndex": 0,
            "Key": "foobar/bazbar",
            "Flags": 0,
            "Value": "xxxxx",
            "CreateIndex": 833,
            "ModifyIndex": 833
          }
        ],
        "output": {
          "foobar": {
            "testing": "xxxxx",
            "bazbar": "xxxxx"
          }
        }
      }
    ],
    "identifier": 36146782
  },
  {
    "context": [
      "I want to use `jq` to parse a `.txt` file with a list of country codes and write them to the value in a JSON object.",
      "my JSON looks like this:\n\n    {\n      \"scsRequestId\": null,\n      \"includeMetadata\": true,\n      \"includeHoldings\": true,\n      \"country\": [],\n      \"region\": [],\n      \"oclcSymbol\": []\n    }",
      "I want the list of country codes to go into the country array.",
      "jq --slurpfile countries test_id.txt '.country=$countries' <myfile.json >newfile.json",
      "When run with your provided inputs, the resulting contents in `newfile.json` are:\n\n    {\n      \"scsRequestId\": null,\n      \"includeMetadata\": true,\n      \"includeHoldings\": true,\n      \"country\": [\n        \"NSC\",\n        \"KZC\",\n        \"KCC\",\n        \"KZL\",\n        \"NZG\",\n        \"VRU\",\n        \"ESM\",\n        \"KZF\",\n        \"SFU\",\n        \"EWF\",\n        \"KQY\",\n        \"KQV\"\n      ],\n      \"region\": [],\n      \"oclcSymbol\": []\n    }"
    ],
    "utterance": "Populate the country array with all values from an external text file containing quoted country codes.",
    "expressions": [
      ".country = $countries"
    ],
    "data": [
      {
        "input": {
          "scsRequestId": null,
          "includeMetadata": true,
          "includeHoldings": true,
          "country": [],
          "region": [],
          "oclcSymbol": []
        },
        "output": {
          "scsRequestId": null,
          "includeMetadata": true,
          "includeHoldings": true,
          "country": [
            "NSC",
            "KZC",
            "KCC",
            "KZL",
            "NZG",
            "VRU",
            "ESM",
            "KZF",
            "SFU",
            "EWF",
            "KQY",
            "KQV"
          ],
          "region": [],
          "oclcSymbol": []
        }
      }
    ],
    "identifier": 36273218
  },
  {
    "context": [
      "How can I access the values of keys like `resolved_title` and `word_count`. They are nested inside an object which is a number, the same as the `id`, which in itself is nested inside `list`.",
      "What I\u2019m intending to do with this data is to only extract the `resolved_title` and `word_count` values for each item and save them to a two-column spreadsheet.",
      "cat <file_with_json> | jq '.list | .[] | .resolved_title, .word_count'",
      "$ cat myfile.json | jq '.list | map({resolved_title: .resolved_title, word_count: .word_count})'",
      "jq \".list[] | {resolved_title, word_count}\" input.json"
    ],
    "utterance": "Extract the resolved_title and word_count values for each item inside the list object.",
    "expressions": [
      ".list | .[] | .resolved_title, .word_count",
      ".list | map({resolved_title: .resolved_title, word_count: .word_count})",
      ".list[] | {resolved_title, word_count}"
    ],
    "data": [
      {
        "input": {
          "complete": 1,
          "error": null,
          "list": {
            "1000055792": {
              "excerpt": "Some Text",
              "favorite": "0",
              "given_title": "Some Title",
              "given_url": "Some URL",
              "has_image": "0",
              "has_video": "0",
              "is_article": "1",
              "is_index": "0",
              "item_id": "1000055792",
              "resolved_id": "1000055792",
              "resolved_title": "Title",
              "resolved_url": "Some URL",
              "sort_id": 700,
              "status": "1",
              "time_added": "1438646514",
              "time_favorited": "0",
              "time_read": "1439025088",
              "time_updated": "1439025090",
              "word_count": "10549"
            },
            "1000102810": {
              "excerpt": "Some Text",
              "favorite": "0",
              "given_title": "Title",
              "given_url": "Some URL",
              "has_image": "1",
              "has_video": "0",
              "is_article": "1",
              "is_index": "0",
              "item_id": "1000102810",
              "resolved_id": "1000102810",
              "resolved_title": "Title",
              "resolved_url": "Resolved URL",
              "sort_id": 650,
              "status": "1",
              "time_added": "1440303789",
              "time_favorited": "0",
              "time_read": "1440320729",
              "time_updated": "1440320731",
              "word_count": "3219"
            }
          }
        },
        "output": [
          {
            "resolved_title": "Title",
            "word_count": "10549"
          },
          {
            "resolved_title": "Title",
            "word_count": "3219"
          }
        ]
      }
    ],
    "identifier": 36235589
  },
  {
    "context": [
      "I want to extract a specific object from custom_variables, given its name.",
      "It almost works; it gets the variable I want when it exists, but when it doesn\u2019t (or if custom_variables itself doesn\u2019t) it will drop the whole top-level object.",
      "How can I just return null if I don\u2019t find that field but still keep the rest of the data?",
      "Use the alternative operator (`//`) to transform a stream of zero elements (such as those which can be generated by `select` or `.[]`) into a value:",
      "jq 'map(\n    {\n        xxx: .xxx, \n        xxx: .xxx, \n        xxx: .xxx, \n        xxx: .custom_variables | .[] | select(.name == \"variable_name\") // null\n    } \n)'",
      "You can, of course, place the alternative operator at a different position to capture the zero-element stream at an earlier or later stage, such as at the object level:\n\n    jq 'map(\n        {\n            xxx: .xxx, \n            xxx: .xxx, \n            xxx: .xxx, \n            xxx: .custom_variables | .[] | select(.name == \"variable_name\")\n        } // {}\n    )'",
      "The following does what you've indicated you want, as best as I can understand your requirements.\n\n    map( if .custom_variables\n         then .custom_variables |= (map(select(.name == \"variable_name\") | .value)\n                                    | .[0]) \n         else .\n         end )"
    ],
    "utterance": "Extract the object from custom_variables with name equal to variable_name, and if not found, include null or keep other data unchanged without dropping the parent object.",
    "expressions": [
      "map({ xxx: .xxx, xxx: .xxx, xxx: .xxx, xxx: (.custom_variables | .[] | select(.name == \"variable_name\") // null) })",
      "map({ xxx: .xxx, xxx: .xxx, xxx: .xxx, xxx: (.custom_variables | .[] | select(.name == \"variable_name\")) } // {})",
      "map(if .custom_variables then .custom_variables |= (map(select(.name == \"variable_name\") | .value) | .[0]) else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "custom_variables": [
              {
                "name": "xxx",
                "value": "xxx"
              },
              {
                "name": "xxx",
                "value": "xxx"
              },
              {
                "name": "variable_name",
                "value": "123"
              }
            ],
            "xxx1": "xxx",
            "xxx2": "xxx",
            "xxx3": "xxx"
          },
          {
            "yyy1": "yyy",
            "yyy2": "yyy",
            "yyy3": "yyy"
          }
        ],
        "output": [
          {
            "custom_variables": "123",
            "xxx1": "xxx",
            "xxx2": "xxx",
            "xxx3": "xxx"
          },
          {
            "yyy1": "yyy",
            "yyy2": "yyy",
            "yyy3": "yyy"
          }
        ]
      }
    ],
    "identifier": 36290459
  },
  {
    "context": [
      "I would like to combine these into one object so that all the Item objects under one name are combined into one array.  Essentially, I would like to produce the following output:",
      "{\r\n  \"Name1\": [\r\n    {\r\n      \"Item1\": \"Val1\",\r\n      \"Item2\": \"Val2\"\r\n    },\r\n    {\r\n      \"Item1\": \"Val3\",\r\n      \"Item2\": \"Val4\"\r\n    }\r\n  ],\r\n  \"Name2\": [\r\n    {\r\n      \"Item1\": \"Val5\",\r\n      \"Item2\": \"Val6\"\r\n    },\r\n    {\r\n      \"Item1\": \"Val7\",\r\n      \"Item2\": \"Val8\"\r\n    }\r\n  ]\r\n}",
      "You need to group the objects by their keys.  You can access the keys if you map the objects as entries.  Then with the group, build out the result objects.",
      "You can use this filter:",
      "    map(to_entries | add)\r\n        | group_by(.key)\r\n        | map({ (.[0].key): map(.value) | add })",
      "The implementation of `group_by/1` requires a sort, so here is an alternative approach that uses a generically useful filter, `addvalues`, that does not require any sorting.",
      "def addvalues:\n  reduce .[] as $o\n    ( {}; reduce ($o|keys[]) as $key\n      ( .; . + {($key): (.[$key] + $o[$key])} ));\n\n\naddvalues",
      "reduce .[] as $i (\n     {}\n   ; reduce ($i|keys[]) as $k (\n          .\n        ; .[$k] += $i[$k]\n     )\n)"
    ],
    "utterance": "Combine an array of single-key objects so all arrays with the same key are concatenated under that key in one object.",
    "expressions": [
      "map(to_entries | add)\n    | group_by(.key)\n    | map({ (.[0].key): map(.value) | add })\n    | add",
      "def addvalues:\n  reduce .[] as $o\n    ( {}; reduce ($o|keys[]) as $key\n      ( .; . + {($key): (.[$key] + $o[$key])} ));\naddvalues",
      "reduce .[] as $i (\n     {}\n   ; reduce ($i|keys[]) as $k (\n          .\n        ; .[$k] += $i[$k]\n     )\n)"
    ],
    "data": [
      {
        "input": [
          {
            "Name1": [
              {
                "Item1": "Val1",
                "Item2": "Val2"
              }
            ]
          },
          {
            "Name1": [
              {
                "Item1": "Val3",
                "Item2": "Val4"
              }
            ]
          },
          {
            "Name2": [
              {
                "Item1": "Val5",
                "Item2": "Val6"
              }
            ]
          },
          {
            "Name2": [
              {
                "Item1": "Val7",
                "Item2": "Val8"
              }
            ]
          }
        ],
        "output": {
          "Name1": [
            {
              "Item1": "Val1",
              "Item2": "Val2"
            },
            {
              "Item1": "Val3",
              "Item2": "Val4"
            }
          ],
          "Name2": [
            {
              "Item1": "Val5",
              "Item2": "Val6"
            },
            {
              "Item1": "Val7",
              "Item2": "Val8"
            }
          ]
        }
      }
    ],
    "identifier": 36066961
  },
  {
    "context": [
      "How can I transform it into the following form using jq?",
      "map( (.arr[]|.x) as $x | {id, \"x\": $x} )",
      "Output:",
      "[",
      "  {",
      "    \"id\": 1,",
      "    \"x\": 1",
      "  },",
      "  {",
      "    \"id\": 1,",
      "    \"x\": 2",
      "  },",
      "  {",
      "    \"id\": 2,",
      "    \"x\": 3",
      "  },",
      "  {",
      "    \"id\": 2,",
      "    \"x\": 4",
      "  }",
      "]",
      "map(del(.arr) + .arr[])"
    ],
    "utterance": "Expand each object so that for every entry in its arr array, produce an object with its id and the value of x from the arr element.",
    "expressions": [
      "map( (.arr[]|.x) as $x | {id, \"x\": $x} )",
      "map(del(.arr) + .arr[])"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "arr": [
              {
                "x": 1
              },
              {
                "x": 2
              }
            ]
          },
          {
            "id": 2,
            "arr": [
              {
                "x": 3
              },
              {
                "x": 4
              }
            ]
          }
        ],
        "output": [
          {
            "id": 1,
            "x": 1
          },
          {
            "id": 1,
            "x": 2
          },
          {
            "id": 2,
            "x": 3
          },
          {
            "id": 2,
            "x": 4
          }
        ]
      }
    ],
    "identifier": 36364858
  },
  {
    "context": [
      "Is there a way to make a nice CSV out of the following JSON code?",
      "But the output is not correct, because if there are several such records then  the keys come out as sorted and permuted. I also tried keys_unsorted, but it didn't resolve the issue.",
      "A small modification to the script you provide in the initial post makes it work. Instead of using .[], I index by the specific key that is saved as variable from `keys_unsorted`. I also added a header to the CSV for convenience:",
      "jq -r '[\"x\", \"y\", \"z\", \"title\", \"year\"],\n  (keys_unsorted[] as $x\n   | .[$x] | keys_unsorted[] as $y\n   | .[$y] | keys_unsorted[] as $z\n   | .[$z] | [$x, $y, $z, .title, .year]) | @csv'",
      "This does provide the output you're looking for (with a header):",
      "\"x\",\"y\",\"z\",\"title\",\"year\"\n\"cod:e1!!@23\",\"typeA\",\"lsk:d##fjd\",\"slkdfjlkdjfd\",\"2014\"\n\"cod:e1!!@23\",\"typeA\",\"sdfdsfsd\",\"slkdfjlkdjfddewfsdfd\",\"2015\"\n\"cod:e1!!@23\",\"Ct@ype\",\"sd$!!fs:$dfds\",\"slkdfjsdfsdfdsfsd\",\"2012\""
    ],
    "utterance": "Extract top three levels of keys, the 'title', and 'year' fields from each nested record into CSV rows, preserving key order.",
    "expressions": [
      "[\"x\", \"y\", \"z\", \"title\", \"year\"],\n  (keys_unsorted[] as $x\n   | .[$x] | keys_unsorted[] as $y\n   | .[$y] | keys_unsorted[] as $z\n   | .[$z] | [$x, $y, $z, .title, .year]) | @csv"
    ],
    "data": [
      {
        "input": {
          "cod:e1!!@23": {
            "typeA": {
              "lsk:d##fjd": {
                "title": "slkdfjlkdjfd",
                "year": "2014"
              },
              "sdfdsfsd": {
                "title": "slkdfjlkdjfddewfsdfd",
                "year": "2015"
              }
            },
            "Ct@ype": {
              "sd$!!fs:$dfds": {
                "title": "slkdfjsdfsdfdsfsd",
                "year": "2012"
              }
            }
          }
        },
        "output": [
          [
            "x",
            "y",
            "z",
            "title",
            "year"
          ],
          [
            "cod:e1!!@23",
            "typeA",
            "lsk:d##fjd",
            "slkdfjlkdjfd",
            "2014"
          ],
          [
            "cod:e1!!@23",
            "typeA",
            "sdfdsfsd",
            "slkdfjlkdjfddewfsdfd",
            "2015"
          ],
          [
            "cod:e1!!@23",
            "Ct@ype",
            "sd$!!fs:$dfds",
            "slkdfjsdfsdfdsfsd",
            "2012"
          ]
        ]
      }
    ],
    "identifier": 35623663
  },
  {
    "context": [
      "For each item, I want to remove the number, Language, and Country keys.",
      "I'm trying to understand if there is a jq way of specifying multiple labels to delete, so I don't have to have multiple map(del()) directives?",
      "$ cat test.json | jq 'map(del(.Country, .number, .Language))'",
      "map( delpaths( [[\"Country\"], [\"number\"], [\"Language\"]] ))",
      "jq 'del( .[] .Country, .[] .number, .[] .Language )' test.json",
      "jq 'del( .[] [\"Country\", \"number\", \"Language\"] )' test.json",
      "jq '[.[] | delpaths( [[\"Country\"], [\"number\"], [\"Language\"]] )]' test.json",
      "del(.[] | .Country, .number, .Language)",
      "map(del(.Country,.number,.Language))\n# Is by definition equivalent to\n[.[] | del(.Country,.number,.Language)]",
      "del(.key1, .key2, ...)\n\nSo don't tear your hair out trying to figure out the syntax work-arounds, assuming your version of jq is reasonably current."
    ],
    "utterance": "Remove the keys named number, Language, and Country from each object in an array.",
    "expressions": [
      "map(del(.Country, .number, .Language))",
      "map( delpaths( [[\"Country\"], [\"number\"], [\"Language\"]] ))",
      "del( .[] .Country, .[] .number, .[] .Language )",
      "del( .[] [\"Country\", \"number\", \"Language\"] )",
      "[.[] | delpaths( [[\"Country\"], [\"number\"], [\"Language\"]] )]",
      "del(.[] | .Country, .number, .Language)",
      "[.[] | del(.Country, .number, .Language)]",
      "del(.Country, .number, .Language)"
    ],
    "data": [
      {
        "input": [
          {
            "label": "US : USA : English",
            "Country": "USA",
            "region": "US",
            "Language": "English",
            "locale": "en",
            "currency": "USD",
            "number": "USD"
          },
          {
            "label": "AU : Australia : English",
            "Country": "Australia",
            "region": "AU",
            "Language": "English",
            "locale": "en",
            "currency": "AUD",
            "number": "AUD"
          },
          {
            "label": "CA : Canada : English",
            "Country": "Canada",
            "region": "CA",
            "Language": "English",
            "locale": "en",
            "currency": "CAD",
            "number": "CAD"
          }
        ],
        "output": [
          {
            "label": "US : USA : English",
            "region": "US",
            "locale": "en",
            "currency": "USD"
          },
          {
            "label": "AU : Australia : English",
            "region": "AU",
            "locale": "en",
            "currency": "AUD"
          },
          {
            "label": "CA : Canada : English",
            "region": "CA",
            "locale": "en",
            "currency": "CAD"
          }
        ]
      }
    ],
    "identifier": 36227245
  },
  {
    "context": [
      "I have a JSON with the following format ... There is always an initial_message, but there may or may not be anything in the array of conversation parts, and that array may have any number of members.",
      "my ideal would be to display\n\n    1234, 567, initial, admin\n    1234, 6789, comment, user\n    1234, 9384, close, admin",
      "Finally, here a filter which uses these features to solve this problem.  [Functions](https://stedolan.github.io/jq/manual/#DefiningFunctions) are used to keep the logic dealing with the initial message and conversation parts separate.",
      "def initial:\n        .id as $id\n      | .initial_message\n      |   .type as $ity\n      |   .id   as $iid\n      |   .author\n      |     .type as $iaty\n      |     \"\\($id), \\($iid), \\($ity), \\($iaty)\"\n    ;\n\ndef parts:\n        .id as $id\n      | .conversation_parts.conversation_parts[]  # note [] here\n      |   .id as $cid\n      |   .part_type as $cpt\n      |   .author\n      |     .type as $caty\n      |     \"\\($id), \\($cid), \\($cpt), \\($caty)\"\n    ;\n\n  initial\n, parts",
      "$ jq -M -r -f filter.jq data.json\n\nwill produce \n\n    1234, 567, initial_message, admin\n    1234, 6789, comment, user\n    1234, 9384, close, admin"
    ],
    "utterance": "Output one CSV line for the initial message, and one line for each conversation part, with each line showing the conversation id, message or part id, type, and author type.",
    "expressions": [
      "def initial:\n  .id as $id\n  | .initial_message\n  | .type as $ity\n  | .id as $iid\n  | .author\n  | .type as $iaty\n  | \"\\($id), \\($iid), \\($ity), \\($iaty)\"\n;\n\ndef parts:\n  .id as $id\n  | .conversation_parts.conversation_parts[]\n  | .id as $cid\n  | .part_type as $cpt\n  | .author\n  | .type as $caty\n  | \"\\($id), \\($cid), \\($cpt), \\($caty)\"\n;\n\ninitial,\nparts"
    ],
    "data": [
      {
        "input": {
          "type": "conversation",
          "id": "1234",
          "created_at": 1425586662,
          "initial_message": {
            "type": "initial_message",
            "id": "567",
            "body": "<p>Testing</p>",
            "author": {
              "type": "admin",
              "id": "9382"
            }
          },
          "conversation_parts": {
            "type": "conversation_part.list",
            "conversation_parts": [
              {
                "type": "conversation_part",
                "id": "6789",
                "part_type": "comment",
                "body": "<p>Good test</p>",
                "created_at": 1425586731,
                "author": {
                  "type": "user",
                  "id": "029384"
                }
              },
              {
                "type": "conversation_part",
                "id": "9384",
                "part_type": "close",
                "body": null,
                "created_at": 1425929944,
                "author": {
                  "type": "admin",
                  "id": "9382"
                }
              }
            ]
          }
        },
        "output": [
          "1234, 567, initial_message, admin",
          "1234, 6789, comment, user",
          "1234, 9384, close, admin"
        ]
      }
    ],
    "identifier": 36185558
  },
  {
    "context": [
      "i need values of country and city as below",
      "CN        Beijing",
      "curl  -s ipinfo.io/0.0.0.0 | jq -r '.country +\"\\t\"+  .city'",
      "$ curl -s ipinfo.io | jq '[.country, .city]'",
      "$ curl -s ipinfo.io | jq '[.country, .city] | @csv'",
      "$ curl -s ipinfo.io | jq -r '[.country, .city] | @csv'"
    ],
    "utterance": "Extract the country and city values and output them as separate columns.",
    "expressions": [
      ".country + \"\t\" + .city",
      "[.country, .city] | @csv"
    ],
    "data": [
      {
        "input": {
          "ip": "0.0.0.0",
          "hostname": "No Hostname",
          "city": "Beijing",
          "region": "Beijing Shi",
          "country": "CN",
          "loc": "39.9289,116.3883",
          "org": "AS55967 Beijing Baidu Netcom Science and Technology Co., Ltd."
        },
        "output": "CN\tBeijing"
      }
    ],
    "identifier": 36428666
  },
  {
    "identifier": 36462955
  },
  {
    "context": [
      "Using jq, I want to get the times of high and low tides for the current day and tomorrow, but when I try this:\r\n\r\n    .result[].type\r\n\r\nBut it gives me an error:",
      "I know I can get the type of tide it is using this:\r\n\r\n    .extremes[].type",
      "and the time of the tide using this:\r\n\r\n    .extremes[].date",
      "So, how do I combine the results together to get an output like this?\r\n\r\n    2016-04-03T10:42+0000 High",
      "\".extremes[] | .date + .type\"",
      "Should give you both the date/time and High/Low tide output for each entry."
    ],
    "utterance": "List every tide event as one line showing its date/time followed by its type, such as '2016-04-03T10:42+0000 High'.",
    "expressions": [
      ".extremes[] | .date + \" \" + .type",
      ".extremes[] | \"\u001b[.date] \u001b[.type]\"",
      ".extremes[] | [.date, .type] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "status": 200,
          "requestLat": "my_latitude",
          "requestLon": "my_longitude",
          "extremes": [
            {
              "dt": 1459680132,
              "date": "2016-04-03T10:42+0000",
              "height": 0.7343567325036922,
              "type": "High"
            },
            {
              "dt": 1459702028,
              "date": "2016-04-03T16:47+0000",
              "height": -0.8438121322770741,
              "type": "Low"
            }
          ]
        },
        "output": [
          "2016-04-03T10:42+0000 High",
          "2016-04-03T16:47+0000 Low"
        ]
      }
    ],
    "identifier": 36386399
  },
  {
    "context": [
      "But how can I get the project name `new` from key `com.docker.compose.project`",
      "I can extract an individual label value like this:\n\n    docker inspect mycontainer |\n    jq -r '[0].Config.Labels[\"com.docker.compose.project\"]'"
    ],
    "utterance": "Extract the value associated with the key com.docker.compose.project from the Labels object in the first element of the container inspection result.",
    "expressions": [
      ".[0].Config.Labels[\"com.docker.compose.project\"]"
    ],
    "data": [
      {
        "input": [
          {
            "Config": {
              "Labels": {
                "com.docker.compose.config-hash": "a804d541a5828f4aaf17df862b650e58ac5bae77b70ff5ebdb2f0f3682326954",
                "com.docker.compose.container-number": "1",
                "com.docker.compose.oneoff": "False",
                "com.docker.compose.project": "postgis",
                "com.docker.compose.service": "postgis",
                "com.docker.compose.version": "1.7.0rc1"
              }
            }
          }
        ],
        "output": "postgis"
      }
    ],
    "identifier": 36439800
  },
  {
    "context": [
      "Using `jq`, you'll need an extra pass to convert from raw text to a workable array but simple:",
      "$ jq -R '. ' myseedips | jq -s '{cassandra:{nodes:map({ip_address:.,type:\"seed\"})}}'",
      "This yields the following:",
      "{",
      "  \"cassandra\": {",
      "    \"nodes\": [",
      "      {",
      "        \"ip_address\": \"10.204.99.15\",",
      "        \"type\": \"seed\"",
      "      },",
      "      {",
      "        \"ip_address\": \"10.204.99.12\",",
      "        \"type\": \"seed\"",
      "      },",
      "      {",
      "        \"ip_address\": \"10.204.99.41\",",
      "        \"type\": \"seed\"",
      "      }",
      "    ]",
      "  }",
      "}",
      "Further to Jeff's answer, please note that the transformation can be accomplished with a single invocation of jq.  If your jq has the `inputs` filter:",
      "jq -Rn '[inputs] | {cassandra:{nodes:map({ip_address:.,type:\"seed\"})}}'",
      "Otherwise:",
      "jq -Rs 'split(\"\\n\") | {cassandra:{nodes:map({ip_address:.,type:\"seed\"})}}' ips.txt"
    ],
    "utterance": "Transform a file containing a list of IP addresses (one per line) into an object with key 'cassandra', whose value is an object with a 'nodes' array, where each array entry is an object with 'ip_address' set to the IP and 'type' set to 'seed'.",
    "expressions": [
      "jq -R '.' myseedips | jq -s '{cassandra:{nodes:map({ip_address:.,type:\"seed\"})}}'",
      "jq -Rn '[inputs] | {cassandra:{nodes:map({ip_address:.,type:\"seed\"})}}'",
      "jq -Rs 'split(\"\\n\") | {cassandra:{nodes:map({ip_address:.,type:\"seed\"})}}' ips.txt"
    ],
    "data": [
      {
        "input": "10.204.99.15\n10.204.99.12\n10.204.99.41\n",
        "output": {
          "cassandra": {
            "nodes": [
              {
                "ip_address": "10.204.99.15",
                "type": "seed"
              },
              {
                "ip_address": "10.204.99.12",
                "type": "seed"
              },
              {
                "ip_address": "10.204.99.41",
                "type": "seed"
              }
            ]
          }
        }
      }
    ],
    "identifier": 36431371
  },
  {
    "context": [
      "I am struggling with the proper jq syntax for pulling out all the names from a curl call that looks like this:",
      "`curl -s -R -D $tmp_fh_header -u $o_user:$o_auth https://api.github.com/repos/mycompany/$repo/commits| jq '[].login'`;",
      "If you need the names for the author of the last commits, you can use:",
      "jq '.[].author.login'",
      "If you need the names for the committer of the last commits, you can use:",
      "jq '.[].committer.login'",
      "or if you need the unique names for that last call:",
      "jq '[.[].committer.login] | unique'"
    ],
    "utterance": "List the logins of all authors or committers from the commit entries, including an option for unique names.",
    "expressions": [
      ".[].author.login",
      ".[].committer.login",
      "[.[].committer.login] | unique"
    ],
    "identifier": 36463450
  },
  {
    "context": [
      "I want to write a jq query that returns each outer object with only the latest firmware object in the `firmwares` array.",
      "But I can't seem to combine the techniques to get my desired output. Can anyone help out?",
      "We're updating it with a filtered version where it the max version is selected.",
      ".[].firmwares |= [ max_by(.version | split(\".\") | map(tonumber)) // empty ]",
      "Here is a solution which uses **reduce** to visit each key of the object and update corresponding `.firmwares` to the latest version",
      "reduce keys[] as $i (\n    .\n  ; .[$i].firmwares |= [max_by(.version)]\n)"
    ],
    "utterance": "For each device, include only the latest firmware entry in its firmwares array, keeping the rest of the device information unchanged.",
    "expressions": [
      "map_values(.firmwares |= [max_by(.version | split(\".\") | map(tonumber))])",
      "reduce keys[] as $i (. ; .[$i].firmwares |= [max_by(.version | split(\".\") | map(tonumber))])"
    ],
    "data": [
      {
        "input": {
          "AppleTV5,3": {
            "firmwares": [
              {
                "version": "9.2",
                "buildid": "13Y234"
              },
              {
                "version": "9.1.1",
                "buildid": "13U717"
              },
              {
                "version": "9.1",
                "buildid": "13U85"
              }
            ],
            "bdid": 52,
            "name": "Apple TV 4 (2015)"
          },
          "AppleTV3,2": {
            "firmwares": [
              {
                "version": "8.4.1",
                "buildid": "12H523"
              },
              {
                "version": "8.3",
                "buildid": "12F69"
              }
            ],
            "bdid": 0,
            "name": "Apple TV 3 (2013)"
          },
          "AppleTV3,1": {
            "firmwares": [
              {
                "version": "8.4.1",
                "buildid": "12H523"
              },
              {
                "version": "8.3",
                "buildid": "12F69"
              },
              {
                "version": "8.2",
                "buildid": "12D508"
              }
            ],
            "bdid": 0,
            "name": "Apple TV 3"
          }
        },
        "output": {
          "AppleTV5,3": {
            "firmwares": [
              {
                "version": "9.2",
                "buildid": "13Y234"
              }
            ],
            "bdid": 52,
            "name": "Apple TV 4 (2015)"
          },
          "AppleTV3,2": {
            "firmwares": [
              {
                "version": "8.4.1",
                "buildid": "12H523"
              }
            ],
            "bdid": 0,
            "name": "Apple TV 3 (2013)"
          },
          "AppleTV3,1": {
            "firmwares": [
              {
                "version": "8.4.1",
                "buildid": "12H523"
              }
            ],
            "bdid": 0,
            "name": "Apple TV 3"
          }
        }
      }
    ],
    "identifier": 36438548
  },
  {
    "context": [
      "What I now need to do is to pull the 'VolumeId', 'Period', 'Start' and 'Finish'. I would like to iterate over these objects put these into 4 bash variables of the same name in a `for` loop.",
      "cat rawjsonfile |jq -r  '.Volumes[]|({VolumeId}+(.Tags|from_entries))|{VolumeId,Period,Start,Finish}|to_entries[]|(.key+\"=\"+.value)'",
      "first  unwind  the array to json units",
      "cat rawjsonfile|jq -r  '.Volumes[]|({VolumeId}+(.Tags|from_entries))'",
      "second choose the fields ",
      "|{VolumeId,Period,Start,Finish}",
      "3.make it to key-value and join them ",
      "|to_entries[]|(.key+\"=\"+.value)"
    ],
    "utterance": "Extract VolumeId, Period, Start, and Finish from each volume object as key-value pairs in the form key=value, one per line.",
    "expressions": [
      ".Volumes[] | ({VolumeId} + (.Tags|from_entries)) | {VolumeId,Period,Start,Finish} | to_entries[] | (.key+\"=\"+.value)"
    ],
    "data": [
      {
        "input": {
          "Volumes": [
            {
              "Attachments": [],
              "Tags": [
                {
                  "Value": "volume1",
                  "Key": "Name"
                },
                {
                  "Value": "00:00",
                  "Key": "Start"
                },
                {
                  "Value": "00:20",
                  "Key": "Finish"
                },
                {
                  "Value": "2",
                  "Key": "Period"
                }
              ],
              "VolumeId": "vol-11111111"
            },
            {
              "Attachments": [],
              "Tags": [
                {
                  "Value": "volume2",
                  "Key": "Name"
                },
                {
                  "Value": "00:00",
                  "Key": "Start"
                },
                {
                  "Value": "00:20",
                  "Key": "Finish"
                },
                {
                  "Value": "2",
                  "Key": "Period"
                }
              ],
              "VolumeId": "vol-22222222"
            },
            {
              "Attachments": [],
              "Tags": [
                {
                  "Value": "volume3",
                  "Key": "Name"
                },
                {
                  "Value": "00:00",
                  "Key": "Start"
                },
                {
                  "Value": "00:20",
                  "Key": "Finish"
                },
                {
                  "Value": "2",
                  "Key": "Period"
                }
              ],
              "VolumeId": "vol-33333333"
            }
          ]
        },
        "output": [
          "VolumeId=vol-11111111",
          "Period=2",
          "Start=00:00",
          "Finish=00:20",
          "VolumeId=vol-22222222",
          "Period=2",
          "Start=00:00",
          "Finish=00:20",
          "VolumeId=vol-33333333",
          "Period=2",
          "Start=00:00",
          "Finish=00:20"
        ]
      }
    ],
    "identifier": 36299028
  },
  {
    "context": [
      "Basicly, i have three objects: actividades, actividades/_text and actividades/_source. I want to create a final json file that have pair actividades and actividades/_text, in the same order that appear in file, i mean, for example:",
      "\"Ciencias Naturales Logro y Autoevaluaci\u00f3n\":\"http://www.domain.com/ArchivosCargados/2016/CUADRO-PRIMER-BIMESTRE-2016-PRIMERO.pdf\"",
      "The key is the `transpose` filter.  The following:\r\n\r\n    .results[0] | [ .\"actividades/_text\", .actividades ] | transpose",
      "To combine these pairs into a single object, tack on:\r\n\r\n    | map({ (.[0]):.[1]} ) | add",
      "To produce the output in the form \"X\":\"Y\" as you also indicated you want, you could use the following invocation:",
      "jq -r  '.results[0]\r\n    | [ .\"actividades/_text\", .actividades ]\r\n    | transpose[]\r\n    | \"\\\"\\(.[0])\\\":\\\"\\(.[1])\\\"\" '"
    ],
    "utterance": "Produce an object mapping each value from actividades/_text to its corresponding value in actividades, preserving their order.",
    "expressions": [
      ".results[0] | [ .\"actividades/_text\", .actividades ] | transpose | map({ (.[0]):.[1] }) | add",
      ".results[0] | [ .\"actividades/_text\", .actividades ] | transpose[] | \"\\\"\\(.[0])\\\":\\\"\\(.[1])\\\"\""
    ],
    "data": [
      {
        "input": {
          "offset": 0,
          "results": [
            {
              "actividades/_text": [
                "Ciencias Naturales Logro y Autoevaluaci\u00f3n",
                "Ciencias Naturales Seres Vivos - Objetos Inertes",
                "Educaci\u00f3n Art\u00edstica Contenidos",
                "Educaci\u00f3n Religiosa Dibujo"
              ],
              "actividades/_source": [
                "/ArchivosCargados/2016/CUADRO-PRIMER-BIMESTRE-2016-PRIMERO.pdf",
                "/ArchivosCargados/2016/Hojita-Seres-Vivos.pdf",
                "/ArchivosCargados/2016/2016-CONTENIDOS-ARTES-PLASTICAS-PRIMARIA-J-T-12345.pdf",
                "/ArchivosCargados/2016/PRIMERO-RELILGION.pdf"
              ],
              "actividades": [
                "http://www.domain.com/ArchivosCargados/2016/CUADRO-PRIMER-BIMESTRE-2016-PRIMERO.pdf",
                "http://www.domain.com/ArchivosCargados/2016/Hojita-Seres-Vivos.pdf",
                "http://www.domain.com/ArchivosCargados/2016/2016-CONTENIDOS-ARTES-PLASTICAS-PRIMARIA-J-T-12345.pdf",
                "http://www.domain.com/ArchivosCargados/2016/PRIMERO-RELILGION.pdf"
              ]
            }
          ],
          "cookies": [
            "ASP.NET_SessionId=\"0vy5tp45alrfik55q3bs24mr\";Path=\"/\";Domain=\"www.domain.com\";Port=\"80\""
          ],
          "connectorVersionGuid": "e35c3b39-301e-4474-b75e-5473963b1852",
          "connectorGuid": "b0fe3dd7-fd92-472b-b197-14d86f91c5fb",
          "pageUrl": "http://www.domain.com/principal.aspx?tbindex=3&tab_codigo=33",
          "outputProperties": [
            {
              "name": "actividades",
              "type": "URL"
            }
          ]
        },
        "output": {
          "Ciencias Naturales Logro y Autoevaluaci\u00f3n": "http://www.domain.com/ArchivosCargados/2016/CUADRO-PRIMER-BIMESTRE-2016-PRIMERO.pdf",
          "Ciencias Naturales Seres Vivos - Objetos Inertes": "http://www.domain.com/ArchivosCargados/2016/Hojita-Seres-Vivos.pdf",
          "Educaci\u00f3n Art\u00edstica Contenidos": "http://www.domain.com/ArchivosCargados/2016/2016-CONTENIDOS-ARTES-PLASTICAS-PRIMARIA-J-T-12345.pdf",
          "Educaci\u00f3n Religiosa Dibujo": "http://www.domain.com/ArchivosCargados/2016/PRIMERO-RELILGION.pdf"
        }
      }
    ],
    "identifier": 35567519
  },
  {
    "context": [
      "I try to using the jq tools (jq-json-processor) in shell script to merge the fields two json.",
      "my expected result",
      "{ \"username\": \"Bob\", \"password\": \"verytrickipwd\", \"windows\": 6, \"doors\": }",
      "the following suffices:",
      "$ jq --argfile override file1.json '. + $override' file2.json",
      "If your jq does not support the --argfile option, the following should suffice:",
      "$ jq -s add file2.json file1.json",
      "Note that in the case of key-name collisions, the contents of the second file (file1.json in this example) will take precedence."
    ],
    "utterance": "Combine two objects from separate files, ensuring all fields from both are present and for overlapping keys, values from the first file override those in the second.",
    "expressions": [
      "jq --argfile override file1.json '. + $override' file2.json",
      "jq -s add file2.json file1.json"
    ],
    "data": [
      {
        "input": [
          {
            "username": "Bob",
            "password": "verytrickipwd",
            "windows": 6
          },
          {
            "username": "",
            "password": "",
            "windows": 6,
            "doors": ""
          }
        ],
        "output": {
          "username": "Bob",
          "password": "verytrickipwd",
          "windows": 6,
          "doors": ""
        }
      }
    ],
    "identifier": 36607970
  },
  {
    "context": [
      "I need to change the value of \"other\" depending on the value of \"age\".",
      "Now, I want the complete json to be output on the terminal, so I can move it to tmp file.",
      ".Actions=([.Actions[] | if .properties.age == \"3\" then .properties.other = \"no-test\" else . end])",
      ".Actions=[.Actions[] | select (.properties.age == \"3\").properties.other = \"no-test\"]"
    ],
    "utterance": "Replace the value of the 'other' field with 'no-test' in each element of Actions where properties.age is \"3\", while outputting the complete object.",
    "expressions": [
      ".Actions = ([.Actions[] | if .properties.age == \"3\" then .properties.other = \"no-test\" else . end])",
      ".Actions = [.Actions[] | select (.properties.age == \"3\").properties.other = \"no-test\"]"
    ],
    "data": [
      {
        "input": {
          "Report": [
            {
              "blah": "..."
            }
          ],
          "Actions": [
            {
              "value": "1",
              "properties": {
                "name": "abc",
                "age": "2",
                "other": "test1"
              }
            },
            {
              "value": "2",
              "properties": {
                "name": "def",
                "age": "3",
                "other": "test2"
              }
            }
          ]
        },
        "output": {
          "Report": [
            {
              "blah": "..."
            }
          ],
          "Actions": [
            {
              "value": "1",
              "properties": {
                "name": "abc",
                "age": "2",
                "other": "test1"
              }
            },
            {
              "value": "2",
              "properties": {
                "name": "def",
                "age": "3",
                "other": "no-test"
              }
            }
          ]
        }
      }
    ],
    "identifier": 36607650
  },
  {
    "context": [
      "cat sample.json |  jq '.Actions[] | select (.properties.age == \"3\") .properties.other = \"no-test\"'",
      "$ jq --arg age \"3\" \\\n'(.Actions[] | select(.properties.age == $age).properties.other) = \"no-test\"' sample.json",
      "jq ... INPUT > INPUT.tmp && mv INPUT.tmp INPUT",
      "jq ... INPUT | sponge INPUT",
      "jq '.Actions=([.Actions[] | if .properties.age == \"3\" then .properties.other = \"no-test\" else . end])' sample.json | sponge sample.json",
      "cat <<< $(jq 'QUERY' sample.json) > sample.json",
      "echo \"$(jq '. + {\"registry-mirrors\": [\"https://docker-mirror\"]}' /etc/docker/daemon.json)\" > /etc/docker/daemon.json",
      "content=$(cat sample.json) && \njq '<your jq script>' <<<$content >sample.json",
      "One is simply to use \"&&\" along the lines of:\n\n    jq ... INPUT > INPUT.tmp && mv INPUT.tmp INPUT",
      "Another is to use the `sponge` utility (part of GNU `moreutils`):\n\n    jq ... INPUT | sponge INPUT",
      "jq does not had `sed -i` like functionality, but all you need to do is pipe it back into a [sponge][2] to the file with `| sponge`"
    ],
    "utterance": "Update all elements in the Actions array where properties.age equals \"3\" by setting properties.other to \"no-test\" and save the modifications to the original file.",
    "expressions": [
      "jq '(.Actions[] | select(.properties.age == \"3\").properties.other) = \"no-test\"' sample.json > sample.json.tmp && mv sample.json.tmp sample.json",
      "jq '.Actions=([.Actions[] | if .properties.age == \"3\" then .properties.other = \"no-test\" else . end])' sample.json | sponge sample.json",
      "content=$(cat sample.json) && jq '(.Actions[] | select(.properties.age == \"3\").properties.other) = \"no-test\"' <<< \"$content\" > sample.json",
      "cat <<< $(jq '(.Actions[] | select(.properties.age == \"3\").properties.other) = \"no-test\"' sample.json) > sample.json"
    ],
    "data": [
      {
        "input": {
          "Actions": [
            {
              "value": "1",
              "properties": {
                "name": "abc",
                "age": "2",
                "other ": "test1"
              }
            },
            {
              "value": "2",
              "properties": {
                "name": "def",
                "age": "3",
                "other": "test2"
              }
            }
          ]
        },
        "output": {
          "Actions": [
            {
              "value": "1",
              "properties": {
                "name": "abc",
                "age": "2",
                "other ": "test1"
              }
            },
            {
              "value": "2",
              "properties": {
                "name": "def",
                "age": "3",
                "other": "no-test"
              }
            }
          ]
        }
      }
    ],
    "identifier": 36565295
  },
  {
    "context": [
      "I have the below input file:",
      "I have inserted `created_at` field.",
      "I have also added lat/long pair based on the condition of the `GeoCoordinate` field exist or not.",
      "How to use `jq` to achieve that?",
      "Conditionally adding the lat/long pair should be simple.  Just check if you have a `GeoCoordinate` value and add the pair.",
      "Your `created_at` property is invalid at that location, so here&#39;s the closest that we can do:",
      "{\n    created_at: now | todate,\n    results: map(\n        if .GeoCoordinate then\n            .loc = (.GeoCoordinate | { lon: .longitude, lat: .latitude })\n        else\n            .\n        end\n    )\n}"
    ],
    "utterance": "Add a top-level created_at field with the current timestamp and, for each object, conditionally add a loc object with lon and lat from GeoCoordinate if it exists.",
    "expressions": [
      "{ created_at: now | todate, results: map(if .GeoCoordinate then .loc = (.GeoCoordinate | { lon: .longitude, lat: .latitude }) else . end) }"
    ],
    "data": [
      {
        "input": [
          {
            "macAddress": "22:00:10:21:ca:54",
            "GeoCoordinate": {
              "latitude": 1.2345,
              "longitude": 123.4567,
              "unit": "DEGREES"
            }
          },
          {
            "macAddress": "44:00:10:21:ca:14"
          },
          {
            "macAddress": "33:00:11:21:ca:54",
            "GeoCoordinate": {
              "latitude": 2.1345544523,
              "longitude": 123.45678,
              "unit": "DEGREES"
            }
          }
        ],
        "output": {
          "created_at": "2016-04-19T20:09:35Z",
          "results": [
            {
              "macAddress": "22:00:10:21:ca:54",
              "GeoCoordinate": {
                "latitude": 1.2345,
                "longitude": 123.4567,
                "unit": "DEGREES"
              },
              "loc": {
                "lon": 123.4567,
                "lat": 1.2345
              }
            },
            {
              "macAddress": "44:00:10:21:ca:14"
            },
            {
              "macAddress": "33:00:11:21:ca:54",
              "GeoCoordinate": {
                "latitude": 2.1345544523,
                "longitude": 123.45678,
                "unit": "DEGREES"
              },
              "loc": {
                "lon": 123.45678,
                "lat": 2.1345544523
              }
            }
          ]
        }
      }
    ],
    "identifier": 36721223
  },
  {
    "context": [
      "I want to delete the following data using JQ or any Linux Tool",
      "- access (including vector, complexity, authentication)",
      "- references: only first or 1 reference",
      "- cvss-time",
      "- vulnerable_configuration_cpe_2_2 (Incluide cpe:/o:apple:apple_tv:9.1, etc)",
      "The following filter for jq >= 1.5 meets your requirements:",
      "del(.access)\n| .references |= [.[0]]\n| del(.\"cvss-time\")\n| del(.vulnerable_configuration_cpe_2_2)"
    ],
    "utterance": "Remove the fields access, cvss-time, and vulnerable_configuration_cpe_2_2, and keep only the first element in references.",
    "expressions": [
      "del(.access) | .references |= [.[0]] | del(.\"cvss-time\") | del(.vulnerable_configuration_cpe_2_2)"
    ],
    "data": [
      {
        "input": {
          "vulnerable_configuration_cpe_2_2": [
            "cpe:/o:apple:apple_tv:9.1",
            "cpe:/o:apple:watchos:2.1",
            "cpe:/o:apple:iphone_os:9.2",
            "cpe:/o:apple:mac_os_x:10.11.2"
          ],
          "vulnerable_configuration": [
            {
              "title": "cpe:2.3:o:apple:apple_tv:9.1",
              "id": "cpe:2.3:o:apple:apple_tv:9.1"
            },
            {
              "title": "cpe:2.3:o:apple:watchos:2.1",
              "id": "cpe:2.3:o:apple:watchos:2.1"
            },
            {
              "title": "cpe:2.3:o:apple:iphone_os:9.2",
              "id": "cpe:2.3:o:apple:iphone_os:9.2"
            },
            {
              "title": "cpe:2.3:o:apple:mac_os_x:10.11.2",
              "id": "cpe:2.3:o:apple:mac_os_x:10.11.2"
            }
          ],
          "summary": "The Disk Images component in Apple iOS before 9.2.1, OS X before 10.11.3, and tvOS before 9.1.1 allows local users to gain privileges or cause a denial of service (memory corruption) via unspecified vectors.",
          "references": [
            "https://support.apple.com/HT206168",
            "https://support.apple.com/HT205732",
            "https://support.apple.com/HT205731",
            "https://support.apple.com/HT205729",
            "http://lists.apple.com/archives/security-announce/2016/Mar/msg00001.html",
            "http://lists.apple.com/archives/security-announce/2016/Jan/msg00005.html",
            "http://lists.apple.com/archives/security-announce/2016/Jan/msg00003.html",
            "http://lists.apple.com/archives/security-announce/2016/Jan/msg00002.html"
          ],
          "Modified": "2016-03-29T19:01:26.810-04:00",
          "Published": "2016-02-01T06:59:01.090-05:00",
          "access": {
            "vector": "LOCAL",
            "complexity": "LOW",
            "authentication": "NONE"
          },
          "cvss": 7.2,
          "cvss-time": "2016-03-29T09:43:55.537-04:00",
          "cwe": "CWE-119",
          "id": "CVE-2016-1717",
          "impact": {
            "integrity": "COMPLETE",
            "confidentiality": "COMPLETE",
            "availability": "COMPLETE"
          }
        },
        "output": {
          "vulnerable_configuration": [
            {
              "title": "cpe:2.3:o:apple:apple_tv:9.1",
              "id": "cpe:2.3:o:apple:apple_tv:9.1"
            },
            {
              "title": "cpe:2.3:o:apple:watchos:2.1",
              "id": "cpe:2.3:o:apple:watchos:2.1"
            },
            {
              "title": "cpe:2.3:o:apple:iphone_os:9.2",
              "id": "cpe:2.3:o:apple:iphone_os:9.2"
            },
            {
              "title": "cpe:2.3:o:apple:mac_os_x:10.11.2",
              "id": "cpe:2.3:o:apple:mac_os_x:10.11.2"
            }
          ],
          "summary": "The Disk Images component in Apple iOS before 9.2.1, OS X before 10.11.3, and tvOS before 9.1.1 allows local users to gain privileges or cause a denial of service (memory corruption) via unspecified vectors.",
          "references": [
            "https://support.apple.com/HT206168"
          ],
          "Modified": "2016-03-29T19:01:26.810-04:00",
          "Published": "2016-02-01T06:59:01.090-05:00",
          "cvss": 7.2,
          "cwe": "CWE-119",
          "id": "CVE-2016-1717",
          "impact": {
            "integrity": "COMPLETE",
            "confidentiality": "COMPLETE",
            "availability": "COMPLETE"
          }
        }
      }
    ],
    "identifier": 36607327
  },
  {
    "context": [
      "I am reading a JSON file:\r\n`{\"key\":\"value with a \\\"quote\\\" inside\"}` and piping this into a while-read loop:",
      "This is the output I see:\r\n\r\n    {\"key\":\"value with a \"quote\" inside\"}",
      "I would like to preserve those escape characters, ...\r\nCould you tell me how can I achieve the following output within a `while read` loop?\r\n\r\n    {\"key\":\"value with a \\\"quote\\\" inside\"}",
      "With the -r switch read does not interpret backslashes."
    ],
    "utterance": "Print an object string so that all original escape characters, such as backslashes before quotes, are preserved in the output.",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": {
          "key": "value with a \\\"quote\\\" inside"
        },
        "output": "{\"key\":\"value with a \\\"quote\\\" inside\"}"
      }
    ],
    "identifier": 36751549
  },
  {
    "context": [
      "However I have the need to additional extract .Attachments.Device. I am looking for output for each array similar to:",
      "However I can&#39;t figure out how to do this without getting an error. The most logical approach for me would be to do something like:",
      "cat json | jq -r '[.Volumes[]|({VolumeId}+(.Attachments|from_entries)+(.Tags|from_entries))|{VolumeId,Finish,Start,Period,DeviceId}]'",
      "However I get the error:",
      "jq: error (at <stdin>:91): Cannot use null (null) as object key",
      "Ultimately, the problem is that you&#39;re using `from_entries` on the `Attachments` array when it wouldn&#39;t work.  `from_entries` takes an array of key/value pair objects to create an object with those values.  However, you don&#39;t have key/value pairs, but objects.  If you&#39;re just trying to combine them, you should use `add`.",
      "Also, there is no property named `DeviceId`, it&#39;s `Device`.  If you want to select the `Device` property and get it as `DeviceId`, you need to provide the correct name.",
      ".Volumes | map(",
      "    ({ VolumeId } + (.Attachments | add) + (.Tags | from_entries))",
      "      | { VolumeId, Finish, Start, Period, DeviceId: .Device }",
      ")"
    ],
    "utterance": "Extract for each volume the fields VolumeId, Finish, Start, Period, and the Device property from Attachments as DeviceId in a new array.",
    "expressions": [
      ".Volumes | map(({ VolumeId } + (.Attachments | add) + (.Tags | from_entries)) | { VolumeId, Finish, Start, Period, DeviceId: .Device })"
    ],
    "data": [
      {
        "input": {
          "Volumes": [
            {
              "Attachments": [
                {
                  "VolumeId": "vol-11111111",
                  "State": "attached",
                  "DeleteOnTermination": false,
                  "Device": "/dev/sdz"
                }
              ],
              "Tags": [
                {
                  "Value": "volume1",
                  "Key": "Name"
                },
                {
                  "Value": "00:00",
                  "Key": "Start"
                },
                {
                  "Value": "00:20",
                  "Key": "Finish"
                },
                {
                  "Value": "2",
                  "Key": "Period"
                }
              ],
              "VolumeId": "vol-11111111"
            },
            {
              "Attachments": [
                {
                  "VolumeId": "vol-22222222",
                  "State": "attached",
                  "DeleteOnTermination": false,
                  "Device": "/dev/sdz"
                }
              ],
              "Tags": [
                {
                  "Value": "volume2",
                  "Key": "Name"
                },
                {
                  "Value": "00:00",
                  "Key": "Start"
                },
                {
                  "Value": "00:20",
                  "Key": "Finish"
                },
                {
                  "Value": "2",
                  "Key": "Period"
                }
              ],
              "VolumeId": "vol-22222222"
            },
            {
              "Attachments": [
                {
                  "VolumeId": "vol-333333333",
                  "State": "attached",
                  "DeleteOnTermination": false,
                  "Device": "/dev/sdz"
                }
              ],
              "Tags": [
                {
                  "Value": "volume3",
                  "Key": "Name"
                },
                {
                  "Value": "00:00",
                  "Key": "Start"
                },
                {
                  "Value": "00:20",
                  "Key": "Finish"
                },
                {
                  "Value": "2",
                  "Key": "Period"
                }
              ],
              "VolumeId": "vol-33333333"
            }
          ]
        },
        "output": [
          {
            "VolumeId": "vol-11111111",
            "Finish": "00:20",
            "Start": "00:00",
            "Period": "2",
            "DeviceId": "/dev/sdz"
          },
          {
            "VolumeId": "vol-22222222",
            "Finish": "00:20",
            "Start": "00:00",
            "Period": "2",
            "DeviceId": "/dev/sdz"
          },
          {
            "VolumeId": "vol-33333333",
            "Finish": "00:20",
            "Start": "00:00",
            "Period": "2",
            "DeviceId": "/dev/sdz"
          }
        ]
      }
    ],
    "identifier": 36393805
  },
  {
    "context": [
      "I need to edit the .description field and remove commas when present.",
      "I am looking for a *jq* way to do it; I could do it at shell level using *sed* or *awk* but I would like to know if it&#39;s possible using jq within the same command I use to generate the CSV.",
      "You can use [`gsub/2`](https://stedolan.github.io/jq/manual/#gsub(regex;string),gsub(regex;string;flags)) to perform the replacements using regular expressions. So for the description part, do the replacement.",
      "(.description | gsub(\",\"; \"\"))"
    ],
    "utterance": "Output all fields as before, but modify the description field to remove all commas from its value.",
    "expressions": [
      ".content[0] | [.name,.id,.resourceTypeRef.label, (.description | gsub(\",\"; \"\")),.status,.catalogItem.label,.owners[0].value,.dateCreated,.costs.leaseRate.cost.amount,.costToDate.amount] | @csv"
    ],
    "data": [
      {
        "input": {
          "content": [
            {
              "@type": "CatalogResource",
              "id": "ccc",
              "iconId": "xxx",
              "resourceTypeRef": {
                "id": "Infrastructure.Virtual",
                "label": "Virtual Machine"
              },
              "name": "name01",
              "description": "this, is, my, problem",
              "status": "ACTIVE",
              "catalogItem": {
                "id": "xxxxx",
                "label": "xxxxx"
              },
              "requestId": "xxxxx",
              "providerBinding": {
                "bindingId": "xxxx",
                "providerRef": {
                  "id": "xxxxx",
                  "label": "xxxxx"
                }
              },
              "owners": [
                {
                  "tenantName": "xxxxx",
                  "ref": "xxxxxxxx",
                  "type": "USER",
                  "value": "xxxxxxxxx"
                }
              ],
              "organization": {
                "tenantRef": "xxxx",
                "tenantLabel": "xxxxxxx",
                "subtenantRef": "xxxxxx",
                "subtenantLabel": "xxxxxxxxx"
              },
              "dateCreated": "2015-10-05T08:58:35.133Z",
              "lastUpdated": "2015-12-03T13:23:54.187Z",
              "hasLease": true,
              "lease": {
                "start": "2015-10-05T08:21:31.000Z"
              },
              "leaseForDisplay": null,
              "hasCosts": true,
              "costs": {
                "leaseRate": {
                  "type": "moneyTimeRate",
                  "cost": {
                    "type": "money",
                    "currencyCode": "GBP",
                    "amount": 99999
                  },
                  "basis": {
                    "type": "timeSpan",
                    "unit": "DAYS",
                    "amount": 1
                  }
                }
              },
              "costToDate": {
                "type": "money",
                "currencyCode": "GBP",
                "amount": 19181
              },
              "totalCost": null,
              "childResources": [],
              "operations": null,
              "forms": {
                "catalogResourceInfoHidden": true,
                "details": {
                  "type": "extension",
                  "extensionId": "xxxxxx",
                  "extensionPointId": null
                }
              },
              "resourceData": {
                "entries": []
              }
            }
          ]
        },
        "output": "\"name01\",\"ccc\",\"Virtual Machine\",\"this is my problem\",\"ACTIVE\",\"xxxxx\",\"xxxxxxxxx\",\"2015-10-05T08:58:35.133Z\",99999,19181"
      }
    ],
    "identifier": 36599040
  },
  {
    "context": [
      "The first array is labels for the datapoints in the second array.",
      "**Sample Input**\n\n    [\n      \"time\",\n      \"guest_nice\", \n      \"guest\",\n      \"steal\",\n      \"softirq\",\n      \"irq\",\n      \"user\",\n      \"system\",\n      \"nice\",\n      \"iowait\"\n    ]\n    [\n      1460728600,\n      0,\n      0,\n      0,\n      0.45731,\n      0,\n      0.25108,\n      11.74702,\n      48.22465,\n      0\n    ]",
      "**Expected Ouput**\n\n{\n      \"time\": \"1460728600\",\n      \"guest_nice\": \"0\",\n      ...\n}",
      "Here is a solution that handles the general case where the first array contains the key names and the following arrays contain values using **transpose** and **from_entries**\n\n      {h:.[0], v:.[1:][]}                        # {h:[keys], v:[values]}\n    | [.h, .v]                                   # [ [keys], [values] ] ...\n    | [ transpose[] | {key:.[0], value:.[1]} ]   # [ {\"key\":key, \"value\":value}, ... ]\n    | from_entries                               # { key:value, key:value, ... }",
      "jq -M -s -c -f filter.jq data.json\n\nproduces\n\n    {\"time\":1460728600,\"guest_nice\":0,\"guest\":0,\"steal\":0,\"softirq\":0.45731,\"irq\":0,\"user\":0.25108,\"system\":11.74702,\"nice\":48.22465,\"iowait\":0}"
    ],
    "utterance": "Create an object for each data array associating each label with its corresponding value using two aligned arrays, the first as keys and the second as values.",
    "expressions": [
      "{h:.[0], v:.[1:][]} | [.h, .v] | [ transpose[] | {key:.[0], value:.[1]} ] | from_entries"
    ],
    "data": [
      {
        "input": [
          [
            "time",
            "guest_nice",
            "guest",
            "steal",
            "softirq",
            "irq",
            "user",
            "system",
            "nice",
            "iowait"
          ],
          [
            1460728600,
            0,
            0,
            0,
            0.45731,
            0,
            0.25108,
            11.74702,
            48.22465,
            0
          ],
          [
            1460728601,
            0,
            0,
            0,
            0.45732,
            0,
            0.25109,
            12.74703,
            49,
            0
          ]
        ],
        "output": [
          {
            "time": 1460728600,
            "guest_nice": 0,
            "guest": 0,
            "steal": 0,
            "softirq": 0.45731,
            "irq": 0,
            "user": 0.25108,
            "system": 11.74702,
            "nice": 48.22465,
            "iowait": 0
          },
          {
            "time": 1460728601,
            "guest_nice": 0,
            "guest": 0,
            "steal": 0,
            "softirq": 0.45732,
            "irq": 0,
            "user": 0.25109,
            "system": 12.74703,
            "nice": 49,
            "iowait": 0
          }
        ]
      }
    ],
    "identifier": 36649328
  },
  {
    "context": [
      "I need to loop through an array (of AWS instance Ids'), then pull tags out and add them into an array using jq.",
      "The output I am looking for is a newly create JSON array:",
      "[ { \"VolumeId\": $VolumeId, \"Tag1\": $Tag1Value, \"Tag2\": $Tag2Value, \"Tag3\": $Tag3Value }, ... ]",
      "Here is an example showing how a stream of values (here, a stream of arrays) can be combined into a JSON array of objects:",
      "jq -s 'map( {VolumeId: .[0], Tag1Value: .[1], Tag2Value: .[2],  Tag3Value: .[3] }) '"
    ],
    "utterance": "Combine multiple arrays where each contains a VolumeId and three tag values into a single array of objects with keys VolumeId, Tag1Value, Tag2Value, and Tag3Value.",
    "expressions": [
      "map( {VolumeId: .[0], Tag1Value: .[1], Tag2Value: .[2],  Tag3Value: .[3] })"
    ],
    "data": [
      {
        "input": [
          [
            "VolumeId1",
            "Tag1Value1",
            "Tag2Value1",
            "Tag3Value1"
          ],
          [
            "VolumeId2",
            "Tag1Value2",
            "Tag2Value2",
            "Tag3Value2"
          ],
          [
            "VolumeId3",
            "Tag1Value3",
            "Tag2Value3",
            "Tag3Value3"
          ]
        ],
        "output": [
          {
            "VolumeId": "VolumeId1",
            "Tag1Value": "Tag1Value1",
            "Tag2Value": "Tag2Value1",
            "Tag3Value": "Tag3Value1"
          },
          {
            "VolumeId": "VolumeId2",
            "Tag1Value": "Tag1Value2",
            "Tag2Value": "Tag2Value2",
            "Tag3Value": "Tag3Value2"
          },
          {
            "VolumeId": "VolumeId3",
            "Tag1Value": "Tag1Value3",
            "Tag2Value": "Tag2Value3",
            "Tag3Value": "Tag3Value3"
          }
        ]
      }
    ],
    "identifier": 36878970
  },
  {
    "context": [
      "Is it possible to query with jq, providing human readable dates e.g. `2016-04-25`. Also I wonder if the other way around possible, to make jq show `published_at` values in human readable form?",
      "First, we can transform the millisecond-precision UNIX dates into second-precision, which is what jq's date functions expect, and then convert that to the human-readable dates you expect:\n\n    .[].published_at |= (. / 1000 | strftime(\"%Y-%m-%d\"))",
      "Then, we select only those elements whose dates match:\n\n    map(select(.published_at == $date))",
      "Lastly, we put it all together, taking the `$date` variable from the command-line:\n\n    jq --arg date \"2016-04-25\" '[].published_at |= (. / 1000 | strftime(\"%Y-%m-%d\")) | map(select(.published_at == $date))' stuff.json"
    ],
    "utterance": "Select all rows where the 'published_at' timestamp falls on 2016-04-25.",
    "expressions": [
      ".[].published_at |= (. / 1000 | strftime(\"%Y-%m-%d\")) | map(select(.published_at == $date))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "f6922fd5-4f97-4113-820e-b45eba0ae236",
            "published_at": 1461624333859,
            "tracking_id": "a85d5ed5-5efa-461b-aae0-beb2098c0ff7"
          },
          {
            "id": "835d412f-5162-440c-937b-7276f22c4eb9",
            "published_at": 1461625249934,
            "tracking_id": "86472ba2-ce5f-400f-b42a-5a0ac155c42c"
          },
          {
            "id": "bc2efcac-67a0-4855-856a-f31ce5e4618e",
            "published_at": 1461625253393,
            "tracking_id": "c005398f-07f8-4a37-b96d-9ab019d586c2"
          }
        ],
        "output": [
          {
            "id": "f6922fd5-4f97-4113-820e-b45eba0ae236",
            "published_at": "2016-04-25",
            "tracking_id": "a85d5ed5-5efa-461b-aae0-beb2098c0ff7"
          },
          {
            "id": "835d412f-5162-440c-937b-7276f22c4eb9",
            "published_at": "2016-04-25",
            "tracking_id": "86472ba2-ce5f-400f-b42a-5a0ac155c42c"
          },
          {
            "id": "bc2efcac-67a0-4855-856a-f31ce5e4618e",
            "published_at": "2016-04-25",
            "tracking_id": "c005398f-07f8-4a37-b96d-9ab019d586c2"
          }
        ]
      }
    ],
    "identifier": 36853202
  },
  {
    "context": [
      "And I want to query it with jq for the hostname, the mac or the IPv6.",
      "$ jq -c --arg hostname \"Antoniusweg12\" \\\n'.nodes[] | select(.nodeinfo.hostname == $hostname)' nodes.json",
      "$ jq -c --arg mac \"aa:bb:cc:dd:ee:ff\" \\\n'.nodes[] | select(.nodeinfo.network.mac == $mac)' nodes.json",
      "$ jq -c --arg ip \"aaaa:bbbb:cccc:dddd::1\" \\\n'.nodes[] | select(.nodeinfo.network.addresses[] == $ip)' nodes.json"
    ],
    "utterance": "Select all node objects where the hostname equals Antoniusweg12, or where the mac address or one of the addresses equals a specified value.",
    "expressions": [
      ".nodes[] | select(.nodeinfo.hostname == \"Antoniusweg12\")",
      ".nodes[] | select(.nodeinfo.network.mac == \"aa:bb:cc:dd:ee:ff\")",
      ".nodes[] | select(.nodeinfo.network.addresses[] == \"aaaa:bbbb:cccc:dddd::1\")"
    ],
    "data": [
      {
        "input": {
          "nodes": {
            "60e327ee58a0": {
              "nodeinfo": {
                "network": {
                  "mesh": {
                    "bat0": {
                      "interfaces": {
                        "wireless": [
                          "<mac-address-removed>"
                        ],
                        "tunnel": [
                          "<mac-address-removed>"
                        ]
                      }
                    }
                  },
                  "mac": "<mac removed>",
                  "addresses": [
                    "<ipv6 removed>",
                    "<ipv6 removed>"
                  ]
                },
                "hardware": {
                  "model": "TP-Link TL-WR841N/ND v10",
                  "nproc": 1
                },
                "software": {
                  "batman-adv": {
                    "compat": 15,
                    "version": "2015.1"
                  },
                  "autoupdater": {
                    "branch": "stable",
                    "enabled": true
                  },
                  "firmware": {
                    "release": "v2016.1+1.0.1",
                    "base": "gluon-v2016.1"
                  },
                  "status-page": {
                    "api": 1
                  },
                  "fastd": {
                    "enabled": true,
                    "version": "v17"
                  }
                },
                "hostname": "Antoniusweg12",
                "system": {
                  "site_code": "ffmsd03"
                },
                "node_id": "60e327ee58a0"
              },
              "lastseen": "2016-04-14T12:39:04",
              "flags": {
                "gateway": false,
                "online": true
              },
              "firstseen": "2016-03-16T15:14:04",
              "statistics": {
                "clients": 1,
                "gateway": "de:ad:be:ef:43:02",
                "rootfs_usage": 0.6041666666666667,
                "loadavg": 0.09,
                "uptime": 1822037.41,
                "memory_usage": 0.8124737210932025,
                "traffic": {
                  "rx": {
                    "packets": 50393821,
                    "bytes": 5061895206
                  },
                  "forward": {
                    "packets": 173,
                    "bytes": 17417
                  },
                  "mgmt_rx": {
                    "packets": 47453745,
                    "bytes": 6623785282
                  },
                  "tx": {
                    "packets": 1205695,
                    "bytes": 173509528,
                    "dropped": 5683
                  },
                  "mgmt_tx": {
                    "packets": 37906725,
                    "bytes": 11475209742
                  }
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 36625131
  },
  {
    "context": [
      "i would like to use the output of jq as input for json2csv (https://github.com/jehiah/json2csv).",
      "By using the following command, i\u00b4m getting the expected output on the screen: `<import5.json jq -c`",
      "`<import5.json jq -c | json2csv value,timestamp -o output.csv` to use the output of jq as input for json2csv.",
      "Try specifying the jq filter explicitly, along the lines of:\n\n    jq -c . INPUTFILE | json2csv ...",
      "or:\n\n    <INPUTFILE jq -c . | json2csv ...",
      "Here is how my input looks like:\n{\n\"One\": \"Result\",\n\"Two\": 3,\n\"three\": 4000,\n},\n{\n\"One\": \"B\",\n\"Two\": 1,\n\"three\": 9088,\n}"
    ],
    "utterance": "Produce compact line-delimited output suitable for piping into another tool by selecting each object from the input.",
    "expressions": [
      ".",
      "-c ."
    ],
    "data": [
      {
        "input": [
          {
            "One": "Result",
            "Two": 3,
            "three": 4000
          },
          {
            "One": "B",
            "Two": 1,
            "three": 9088
          }
        ],
        "output": [
          "{\"One\":\"Result\",\"Two\":3,\"three\":4000}",
          "{\"One\":\"B\",\"Two\":1,\"three\":9088}"
        ]
      }
    ],
    "identifier": 36891006
  },
  {
    "context": [
      "(1). check (using JQ) that a field in the curl response contains $instance and only then write the file.",
      "until [[ $(/usr/bin/jq --raw-output '.server' <<< ${curl}) = $instance ]]",
      "server=$(jq --raw-output '.server' <<<$content)",
      "if [[ $server = \"$instance\" ]]; then"
    ],
    "utterance": "Extract the value of the 'server' field and compare it to 'server1'.",
    "expressions": [
      ".server",
      "jq --raw-output '.server'"
    ],
    "data": [
      {
        "input": {
          "server": "server1",
          "foo": "bar"
        },
        "output": "server1"
      }
    ],
    "identifier": 36941755
  },
  {
    "context": [
      "for the `server`:",
      "$ echo \"$your_json\" | jq --raw-output '.server'",
      "webserver1",
      "For the `url` you need to indicate the block where it lies on. That is, `metadata`:",
      "$ echo \"$your_json\" | jq --raw-output '.metadata.url'",
      "www.google.com",
      "Read the values with one `jq` pass then there's no need to store the json:",
      "read name server url http_port < <(",
      "    curl -sk https://internal.admin.com/app/instance | \\",
      "    jq --raw-output '[.name, .server, .metadata.url, .metadata.http_port] | join(\" \")'",
      ")",
      "eval \"$(jq -M -r '@sh \"server_name=\\(.server) url=\\(.metadata.url)\"' <<< \"$instance_info\")\";"
    ],
    "utterance": "Extract the values of name, server, url, and http_port fields as separate shell variables, with url and http_port from the metadata object.",
    "expressions": [
      ".server",
      ".metadata.url",
      "[.name, .server, .metadata.url, .metadata.http_port] | join(\" \")",
      "@sh \"server_name=\\(.server) url=\\(.metadata.url)\""
    ],
    "data": [
      {
        "input": {
          "basePath": "/install",
          "metadata": {
            "deployed_artifact": "app01",
            "docker": "True",
            "http_port": "7471",
            "url": "www.google.com"
          },
          "name": "app-01",
          "server": "webserver1"
        },
        "output": [
          "name=app-01",
          "server=webserver1",
          "url=www.google.com",
          "http_port=7471"
        ]
      }
    ],
    "identifier": 36887134
  },
  {
    "context": [
      "I\u00b4ve got Json input data, where i need to reformat the timestamp from unix-time to ISO 8601 (to process the file afterwards).",
      "I aim to get the original file with all its information, but reformated timestamp.",
      "With your input:\r\n\r\n     <input.json jq 'map(if .timestamp then .timestamp |= todate else . end)'",
      "the output is:\r\n\r\n    [\r\n      {\r\n        \"channelId\": 9088,\r\n        \"errorCode\": 0,\r\n        \"value\": 0,\r\n        \"timestamp\": \"2016-04-10T03:18:29Z\""
    ],
    "utterance": "Update each object in the top-level array so that, if it has a numeric 'timestamp' field, its value is converted from Unix time to ISO 8601 format, preserving all other data.",
    "expressions": [
      "map(if .timestamp then .timestamp |= todate else . end)",
      "walk(if type == \"object\" and .timestamp then .timestamp |= todate else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "channelId": 9088,
            "errorCode": 0,
            "value": 0,
            "timestamp": 1460258309
          },
          {
            "channelId": 10087,
            "errorCode": 0,
            "value": 1000,
            "timestamp": 1460258294
          },
          {
            "channelId": 10086,
            "errorCode": 0,
            "value": 90,
            "timestamp": 1460258294
          },
          {
            "errorCode": 0,
            "errorLine": ""
          }
        ],
        "output": [
          {
            "channelId": 9088,
            "errorCode": 0,
            "value": 0,
            "timestamp": "2016-04-10T03:18:29Z"
          },
          {
            "channelId": 10087,
            "errorCode": 0,
            "value": 1000,
            "timestamp": "2016-04-10T03:18:14Z"
          },
          {
            "channelId": 10086,
            "errorCode": 0,
            "value": 90,
            "timestamp": "2016-04-10T03:18:14Z"
          },
          {
            "errorCode": 0,
            "errorLine": ""
          }
        ]
      }
    ],
    "identifier": 36916440
  },
  {
    "context": [
      "The variable in question includes a period, I tried just about everything to escape the period && also tried surrounding it in quotes; no go ; this is the variable I'm looking to pull from",
      "\"OPEN.BTC\": {",
      "When a key contains characters that are invalid for identifiers, you'll have to quote the name.",
      ".\"OPEN.BTC\"",
      "Or for older versions of jq, use an index.",
      ".[\"OPEN.BTC\"]",
      "If your key has dots like \"OPEN.BTC\" then your `jq` command should be",
      "curl -s 'https://cryptofresh.com/api/asset/markets?asset=MKR' | jq '.\"OPEN.BTC\"'"
    ],
    "utterance": "Select the object at the top-level key named OPEN.BTC, where the key contains a period.",
    "expressions": [
      ".\"OPEN.BTC\"",
      ".[\"OPEN.BTC\"]"
    ],
    "identifier": 37018393
  },
  {
    "context": [
      "I am trying to parse JSON data into variable format",
      "output should be like \r\n\r\n    a=1\r\n    b=2\r\n    c=3",
      "You can use the following `jq` command:\r\n\r\n    jq -r '.[]|[.Name,.Value]|join(\"=\")' file.json",
      "Since you're only printing out two values, it might just be easier to print out the strings directly.\r\n\r\n    $ jq -r '.[] | \"\\(.Name)=\\(.Value)\"' file.txt"
    ],
    "utterance": "Transform an array of objects with Name and Value keys into lines where each line is Name=Value.",
    "expressions": [
      ".[] | \"\\(.Name)=\\(.Value)\"",
      ".[] | [.Name, .Value] | join(\"=\")"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "a",
            "Value": "1"
          },
          {
            "Name": "b",
            "Value": "2"
          },
          {
            "Name": "c",
            "Value": "3"
          }
        ],
        "output": [
          "a=1",
          "b=2",
          "c=3"
        ]
      }
    ],
    "identifier": 36982666
  },
  {
    "context": [
      "If i change the `end` object to some other name for example `end1`, i can able to filter.",
      "You are evidently using an early version of jq -- perhaps jq 1.3, which is well out-of-date and which has some limitations with respect to the abbreviated syntax: `.foo`.",
      "That is, you would have to write `.[\"end\"]` in jq 1.3, since \"end\" is a keyword (as in: `if ... then ... else ... end`).",
      "In jq 1.4 and jq 1.5, one can write `.end`"
    ],
    "utterance": "Select the top-level object named end.",
    "expressions": [
      ".end",
      ".[\"end\"]"
    ],
    "data": [
      {
        "input": {
          "start": {
            "connected": [
              {
                "socket": 5,
                "local_host": "10.8.0.3",
                "local_port": 36068,
                "remote_host": "10.8.0.2",
                "remote_port": 5201
              }
            ],
            "version": "iperf 3.1.2",
            "system_info": "Linux sid-Vostro-3700 3.13.0-77-generic #121-Ubuntu SMP Wed Jan 20 10:50:42 UTC 2016 x86_64",
            "timestamp": {
              "time": "Fri, 22 Apr 2016 13:08:10 GMT",
              "timesecs": 1461330490
            },
            "connecting_to": {
              "host": "10.8.0.2",
              "port": 5201
            },
            "cookie": "sid-Vostro-3700.1461330486.892347.18",
            "test_start": {
              "protocol": "UDP",
              "num_streams": 1,
              "blksize": 8192,
              "omit": 0,
              "duration": 2,
              "bytes": 0,
              "blocks": 0,
              "reverse": 0
            }
          },
          "intervals": [
            {
              "streams": [
                {
                  "socket": 5,
                  "start": 0,
                  "end": 2.0002,
                  "seconds": 2.0002,
                  "bytes": 253952,
                  "bits_per_second": 1015710.0,
                  "packets": 31,
                  "omitted": false
                }
              ],
              "sum": {
                "start": 0,
                "end": 2.0002,
                "seconds": 2.0002,
                "bytes": 253952,
                "bits_per_second": 1015710.0,
                "packets": 31,
                "omitted": false
              }
            }
          ],
          "end": {
            "streams": [
              {
                "udp": {
                  "socket": 5,
                  "start": 0,
                  "end": 2.0002,
                  "seconds": 2.0002,
                  "bytes": 253952,
                  "bits_per_second": 1015710.0,
                  "jitter_ms": 828.078,
                  "lost_packets": 0,
                  "packets": 24,
                  "lost_percent": 0,
                  "out_of_order": 0
                }
              }
            ],
            "sum": {
              "start": 0,
              "end": 2.0002,
              "seconds": 2.0002,
              "bytes": 253952,
              "bits_per_second": 1015710.0,
              "jitter_ms": 828.078,
              "lost_packets": 0,
              "packets": 24,
              "lost_percent": 0
            },
            "cpu_utilization_percent": {
              "host_total": 7.7914,
              "host_user": 1.09745,
              "host_system": 6.69392,
              "remote_total": 0,
              "remote_user": 0,
              "remote_system": 0
            }
          },
          "test": 0
        },
        "output": {
          "streams": [
            {
              "udp": {
                "socket": 5,
                "start": 0,
                "end": 2.0002,
                "seconds": 2.0002,
                "bytes": 253952,
                "bits_per_second": 1015710.0,
                "jitter_ms": 828.078,
                "lost_packets": 0,
                "packets": 24,
                "lost_percent": 0,
                "out_of_order": 0
              }
            }
          ],
          "sum": {
            "start": 0,
            "end": 2.0002,
            "seconds": 2.0002,
            "bytes": 253952,
            "bits_per_second": 1015710.0,
            "jitter_ms": 828.078,
            "lost_packets": 0,
            "packets": 24,
            "lost_percent": 0
          },
          "cpu_utilization_percent": {
            "host_total": 7.7914,
            "host_user": 1.09745,
            "host_system": 6.69392,
            "remote_total": 0,
            "remote_user": 0,
            "remote_system": 0
          }
        }
      }
    ],
    "identifier": 36795571
  },
  {
    "context": [
      "I have a variable in bash that is an output of Amazon EMR create command;",
      "{ \"ClusterId\": \"j-9YWMBYN98LN7\" }",
      "What I need to do is to extract the value `j-9YWMBYN98LN7` to a new variable",
      "If you want to use `jq`, you can do it this way",
      "ID=`echo ${CLUSTER} | jq -r '.ClusterId'`"
    ],
    "utterance": "Extract the value associated with the key ClusterId when its value is j-9YWMBYN98LN7.",
    "expressions": [
      ".ClusterId",
      ".ClusterId | tostring"
    ],
    "data": [
      {
        "input": {
          "ClusterId": "j-9YWMBYN98LN7"
        },
        "output": "j-9YWMBYN98LN7"
      }
    ],
    "identifier": 37041324
  },
  {
    "context": [
      "\"But then when I ask jq to parse it, it destroys the ID integer:\"",
      "\"My end goal is to be able to get id out and use it to query deeper into an API, but 130597706006447920 != 130597706006447927.\""
    ],
    "utterance": "Extract the id field from an object where the id has a large integer value without losing precision.",
    "expressions": [
      ".[] | .id"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Sliding Door 2",
            "type": "MyAirtightSlideDoor",
            "id": 130597706006447927,
            "properties": {
              "OnOff": "True",
              "ShowInTerminal": "True",
              "ShowInToolbarConfig": "True",
              "ShowOnHUD": "False",
              "Open": "True"
            }
          }
        ],
        "output": 130597706006447927
      }
    ],
    "identifier": 37020974
  },
  {
    "context": [
      "Is there a simple way of converting the repeated keys to an array? So that the file becomes:\n\n    {\n    \t\"a\" : [ {\"key\": \"1\"}, {\"key\": \"3\"}],\n    \t\"b\" : \"2\"\n    }\n\nOr something similar, but which combines the repeated keys into an array (or finds and alternative way to extract the repeated key values).",
      "If your input is really a flat JSON object with primitives as values, this should work:\n\n    jq -s --stream 'group_by(.[0]) | map({\"key\": .[0][0][0], \"value\": map(.[1])}) | from_entries'\n\n    {\n      \"a\": [\n        \"1\",\n        \"3\"\n      ],\n      \"b\": [\n        \"2\"\n      ]\n    }",
      "reduce (.[] | select(length==2)) as $kv ({};\n      $kv[0][0] as $k\n      |$kv[1] as $v\n      | (.[$k]|type) as $t\n      | if $t == \"null\" then .[$k] = $v\n        elif $t == \"array\" then .[$k] += [$v]\n\t    else .[$k] = [ .[$k], $v ]\n\t    end)"
    ],
    "utterance": "Combine all values associated with repeated keys into arrays, preserving the order, so that keys with multiple values are arrays and those with a single value remain as scalars.",
    "expressions": [
      "jq -s --stream 'group_by(.[0]) | map({ (.[0][0][0]): map(.[1]) }) | add'",
      "reduce (.[] | select(length==2)) as $kv ({};\n      $kv[0][0] as $k\n      |$kv[1] as $v\n      | (.[$k]|type) as $t\n      | if $t == \"null\" then .[$k] = $v\n        elif $t == \"array\" then .[$k] += [$v]\n        else .[$k] = [ .[$k], $v ]\n        end)"
    ],
    "data": [
      {
        "input": {
          "a": "3",
          "b": "2"
        },
        "output": {
          "a": [
            "1",
            "3"
          ],
          "b": "2"
        }
      },
      {
        "input": {
          "c": "C",
          "a": "3",
          "b": "1"
        },
        "output": {
          "c": "C",
          "a": [
            "1",
            "3"
          ],
          "b": [
            "2",
            "1"
          ]
        }
      }
    ],
    "identifier": 36956590
  },
  {
    "context": [
      "I need to combine these into one JSON array:",
      "I'm assuming you want to merge all entries that have the same `.VolumeId` into one. To do so, first we `flatten` the array of arrays of objects into an array of objects. Then, we `group_by(.VolumeId)`. Finally, we `map` over each group and `reduce` it by calculating the product of all its elements. The final results looks like this:",
      "jq -s 'flatten | group_by(.VolumeId) | map(reduce .[] as $x ({}; . * $x))' /path/to/file1 /path/to/file2"
    ],
    "utterance": "Combine two arrays of objects from separate files into one array, merging objects that have the same VolumeId so that the resulting object includes all tags from both sources.",
    "expressions": [
      "jq -s 'flatten | group_by(.VolumeId) | map(reduce .[] as $x ({}; . * $x))' /path/to/file1 /path/to/file2"
    ],
    "data": [
      {
        "input": [
          [
            {
              "VolumeId": "vol-xxxxxxx1",
              "Tag1": "Tag1Value",
              "Tag2": "Tag2Value",
              "Tag3": "Tag3Value",
              "Tag4": "Tag4Value",
              "Tag5": "Tag5Value",
              "Tag6": "Tag6Value"
            },
            {
              "VolumeId": "vol-xxxxxxx2",
              "Tag1": "Tag1Value",
              "Tag2": "null",
              "Tag3": "null",
              "Tag4": "Tag4Value",
              "Tag5": "null",
              "Tag6": "Tag6Value"
            },
            {
              "VolumeId": "vol-xxxxxxx3",
              "Tag1": "null",
              "Tag2": "null",
              "Tag3": "null",
              "Tag4": "null",
              "Tag5": "null",
              "Tag6": "null"
            }
          ],
          [
            {
              "VolumeId": "vol-xxxxxxx1",
              "Tag7": "Tag7Value"
            },
            {
              "VolumeId": "vol-xxxxxxx2",
              "Tag7": "Tag7Value"
            },
            {
              "VolumeId": "vol-xxxxxxx3",
              "Tag7": "null"
            }
          ]
        ],
        "output": [
          {
            "VolumeId": "vol-xxxxxxx1",
            "Tag1": "Tag1Value",
            "Tag2": "Tag2Value",
            "Tag3": "Tag3Value",
            "Tag4": "Tag4Value",
            "Tag5": "Tag5Value",
            "Tag6": "Tag6Value",
            "Tag7": "Tag7Value"
          },
          {
            "VolumeId": "vol-xxxxxxx2",
            "Tag1": "Tag1Value",
            "Tag2": "null",
            "Tag3": "null",
            "Tag4": "Tag4Value",
            "Tag5": "null",
            "Tag6": "Tag6Value",
            "Tag7": "Tag7Value"
          },
          {
            "VolumeId": "vol-xxxxxxx3",
            "Tag1": "null",
            "Tag2": "null",
            "Tag3": "null",
            "Tag4": "null",
            "Tag5": "null",
            "Tag6": "null",
            "Tag7": "null"
          }
        ]
      }
    ],
    "identifier": 36880891
  },
  {
    "context": [
      "I wish to filter json file but still keeps the title name with the link so that i can rename the file in the wget command. But I dont have any idea on what structure should I use here. So how can i keep the title to in the filter and use it after?",
      "jq -r '.[] | select (.link[0]!=null) | @sh \"wget -O \\(.title[0]) \\(.link[0])\"' items.json | bash",
      "jq -M -r '\n        .[] \n      | select(.link[0]!=null) \n      | .title[0], .link[0]\n    ' items.json"
    ],
    "utterance": "Select all objects with a non-empty link and extract both the first title and first link from each.",
    "expressions": [
      ".[] | select(.link[0]!=null) | .title[0], .link[0]",
      ".[] | select(.link[0]!=null) | @sh \"wget -O \\(.title[0]) \\(.link[0])\""
    ],
    "data": [
      {
        "input": [
          {
            "title": [
              "bob"
            ],
            "link": [
              "a.b.c"
            ]
          },
          {
            "title": [
              "alice"
            ],
            "link": [
              "d.e.f"
            ]
          },
          {
            "title": [
              "carol"
            ],
            "link": []
          }
        ],
        "output": [
          "bob",
          "a.b.c",
          "alice",
          "d.e.f"
        ]
      }
    ],
    "identifier": 37040055
  },
  {
    "context": [
      "\"And I want to get the substring from task/ and then return just blablabla\"",
      "\"jq 'match(\"^(.*task?)\\/(.*$)\", .) | .captures[1].string | select(.)' <<<\"$json_string\"\"",
      "\"jq 'match(\"(.*task?)\\/(.*$)\").captures[1].string'\"",
      "\"jq -r 'sub(\".*task/\"; \"\")' <<< '\"arn:aws:ecs:eu-west-1:foo:task/blablabla\"'\"",
      "\"jq -r 'sub(\".*:task/(?<x>.*)\"; \"\\(.x)\")' <<< '\"arn:aws:ecs:eu-west-1:foo:task/blablabla\"'\""
    ],
    "utterance": "Extract the part of a string following 'task/' where the input is 'arn:aws:ecs:eu-west-1:foo:task/blablabla', returning 'blablabla'.",
    "expressions": [
      "match(\"^(.*task?)\\/(.*$)\", .) | .captures[1].string | select(.)",
      "match(\"(.*task?)\\/(.*$)\").captures[1].string",
      "sub(\".*task/\"; \"\")",
      "sub(\".*:task/(?<x>.*)\"; \"\\(.x)\")"
    ],
    "data": [
      {
        "input": "arn:aws:ecs:eu-west-1:foo:task/blablabla",
        "output": "blablabla"
      }
    ],
    "identifier": 37328327
  },
  {
    "context": [
      "I am using `jq` but having \"-\" in my json tag make `jq` not compile. I cannot escape it to make it works.",
      "Here is the command:\n\ncurl -X GET -H \"X-AppKey:foo\" \"foo/v2/_status\" | jq '.component-status[]'",
      "You need to enclose in brackets and double quotes:\n\n    jq '.\"component-status\"'",
      "If the key contains special characters, you need to surround it with double quotes like this: '.\"foo$\"'.",
      "From the github issue [Cannot select field if field name has dashes][2]:\n> Currently, that gets parsed as a subtraction. You can always\n> explicitly use strings for when your keys don't fit identifier syntax.",
      "there was a solution, which did the trick - escaping double quotation marks with \\\n\n    jq '.\\\"component-status\\\"'"
    ],
    "utterance": "Select the value of the top-level field named component-status (with a dash in the name).",
    "expressions": [
      ".\"component-status\"",
      ".[\"component-status\"]",
      ".\\\"component-status\\\""
    ],
    "data": [
      {
        "input": {
          "status": "ok",
          "hostname": "0b0b495a46db",
          "component-status": [
            {
              "status-code": 200,
              "component": "Service1",
              "status": "OK"
            },
            {
              "status-code": 200,
              "component": "Service2",
              "status": "OK"
            }
          ]
        },
        "output": [
          {
            "status-code": 200,
            "component": "Service1",
            "status": "OK"
          },
          {
            "status-code": 200,
            "component": "Service2",
            "status": "OK"
          }
        ]
      }
    ],
    "identifier": 37344329
  },
  {
    "context": [
      "The json files that I am processing contain newline characters `\\n` in the value fields.",
      "when I try `jq -r '[.a]|@csv'`, ... The `\\n` character is evaluated.",
      "My desired output in this case is:\n    \"She said: \\\"Yes!\\\"\\n\",\"We said: \\\"Hello!\\\"\\n\"",
      "You'll have to escape the newline characters. ...\n\n    [.a, .b] | map(sub(\"\\n\"; \"\\\\n\")) | @csv\n\nThis would give you\n\n    \"She said: \"\"Yes!\"\"\\n\",\"We said: \"\"Hello!\"\"\\n\"",
      "In case there are multiple `\\n` symbols then using `gsub` instead of `sub` will do the trick."
    ],
    "utterance": "Produce CSV output with fields where newline characters are output as literal \\n sequences, not actual line breaks, preserving embedded double quotes.",
    "expressions": [
      "[.a, .b] | map(sub(\"\\n\"; \"\\\\n\")) | @csv",
      "[.a, .b] | map(gsub(\"\\n\"; \"\\\\n\")) | @csv"
    ],
    "data": [
      {
        "input": {
          "a": "She said: \"Yes!\"\n",
          "b": "We said: \"Hello!\"\n"
        },
        "output": "\"She said: \"\"Yes!\"\"\\n\",\"We said: \"\"Hello!\"\"\\n\""
      }
    ],
    "identifier": 37348865
  },
  {
    "context": [
      "I have a large existing json object and I'd like to add a new key/value to the object where the value can be very large (many K).",
      "Is there a good way to replace `big blob of text` with a shell or jq variable?",
      "bigblob | jq -R --argjson item \"$item\" '$item + {\"readme\": .}'"
    ],
    "utterance": "Add a new key 'readme' with a large value from a shell variable to an existing object.",
    "expressions": [
      "$item + {\"readme\": .}"
    ],
    "data": [
      {
        "input": {
          "a": "a"
        },
        "output": {
          "a": "a",
          "readme": "big blob of text"
        }
      }
    ],
    "identifier": 37353918
  },
  {
    "context": [
      "How do I get the command to output that?\n\n    \"one\": 1\n    \"two\": 2\n    \"three\": 3",
      "$ ... | jq -r '.thing | to_entries[] | \"\\(.key | tojson): \\(.value)\"'",
      "$ echo '{\"thing\":{\"one\":1,\"two\":2,\"three\":3}}' \\\n| jq -r '.thing | keys_unsorted[] as $k | \"\\\"\\($k)\\\": \\(.[$k])\"'"
    ],
    "utterance": "Print all key-value pairs of the 'thing' object as separate lines in the format \"key\": value, without enclosing braces.",
    "expressions": [
      ".thing | to_entries[] | \"\\(.key | tojson): \\(.value)\"",
      ".thing | keys_unsorted[] as $k | \"\\\"\\($k)\\\": \\(.[$k])\""
    ],
    "data": [
      {
        "input": {
          "thing": {
            "one": 1,
            "two": 2,
            "three": 3
          }
        },
        "output": "\"one\": 1\n\"two\": 2\n\"three\": 3"
      }
    ],
    "identifier": 37487740
  },
  {
    "context": [
      "Wondering if its possible to return the parent \"Id\" from the json below while querying the child \"Id\"",
      "Eg. If I query for child id \"abc\" it should return \"parent123\".",
      "The filter:\n\n    .. | objects | select(.Origins.Items[]? | .Id == \"abc\") | .Id\n\nproduces:\n\n    \"parent123\"",
      "You might want to parameterize the filter, e.g.:\n\ndef parent(child):\n .. | objects | select( .Origins.Items[]? | .Id == child) | .Id ;",
      ".DistributionList.Items[]\n| select(.Origins.Items[].Id == \"abc\")\n| .Id"
    ],
    "utterance": "Return the Id of the parent object whose Origins.Items contains a child with Id equal to \"abc\".",
    "expressions": [
      ".. | objects | select(.Origins.Items[]? | .Id == \"abc\") | .Id",
      ".DistributionList.Items[] | select(.Origins.Items[].Id == \"abc\") | .Id"
    ],
    "data": [
      {
        "input": {
          "DistributionList": {
            "Items": [
              {
                "Origins": {
                  "Items": [
                    {
                      "Id": "abc"
                    }
                  ],
                  "Quantity": 1
                },
                "Id": "parent123"
              },
              {
                "Origins": {
                  "Items": [
                    {
                      "Id": "def"
                    }
                  ],
                  "Quantity": 1
                },
                "Id": "parent345"
              }
            ]
          }
        },
        "output": "parent123"
      }
    ],
    "identifier": 37559582
  },
  {
    "context": [
      "Now what I want is to return the md5 value where for example the fileName is \"FOO\".",
      "cat <file>.json | jq -r '.files[] | select(.fileName==\"FOO\") | .md5'",
      "cat <file>.json | jq -r '.files[] | select(.fileName==\"FOO\").md5'",
      "cat <file>.json | jq -r '.files | map(select(.fileName==\"FOO\").md5)'"
    ],
    "utterance": "Return the md5 value for the array element with fileName equal to \"FOO\".",
    "expressions": [
      ".files[] | select(.fileName==\"FOO\") | .md5",
      ".files[] | select(.fileName==\"FOO\").md5",
      ".files | map(select(.fileName==\"FOO\").md5)"
    ],
    "data": [
      {
        "input": {
          "files": [
            {
              "fileName": "FOO",
              "md5": "blablabla"
            },
            {
              "fileName": "BAR",
              "md5": "alaldlafj"
            }
          ]
        },
        "output": "blablabla"
      }
    ],
    "identifier": 37563691
  },
  {
    "context": [
      "However, I'd like to *not* fetch any tarballs that are previews of Ruby or contain something like \"yarv_migration_base\". Is there a way to exclude data using jq?",
      "Filter it out first, then get the first (assuming it's sorted with most recent first).",
      "jq 'map(select(.name != \"yarv_migration_base\" and\n        (.name | contains(\"preview\") | not)\n    ))[0].tarball_url' ruby.json"
    ],
    "utterance": "Return the tarball_url of the first object whose name is not 'yarv_migration_base' and does not contain 'preview'.",
    "expressions": [
      "map(select(.name != \"yarv_migration_base\" and (.name | contains(\"preview\") | not)))[0].tarball_url"
    ],
    "data": [
      {
        "input": [
          {
            "name": "yarv_migration_base",
            "tarball_url": "https://api.github.com/repos/ruby/ruby/tarball/yarv_migration_base"
          },
          {
            "name": "v2_3_1",
            "tarball_url": "https://api.github.com/repos/ruby/ruby/tarball/v2_3_1"
          },
          {
            "name": "v2_3_0_preview2",
            "tarball_url": "https://api.github.com/repos/ruby/ruby/tarball/v2_3_0_preview2"
          }
        ],
        "output": "https://api.github.com/repos/ruby/ruby/tarball/v2_3_1"
      }
    ],
    "identifier": 37501404
  },
  {
    "context": [
      "Is there a jq command to display all the primary keys in the json?",
      "If you want a known value below an unknown property, eg `xxx.hostName`:",
      "% jq -r '[].hostName' my.json",
      "I only care about the `hostname` field. And I would like to extract that out."
    ],
    "utterance": "Extract the value of the hostName field from each top-level object, regardless of the dynamic key names.",
    "expressions": [
      ".[].hostName",
      "-r '.[].hostName'"
    ],
    "data": [
      {
        "input": {
          "20160522201409-jobsv1-1": {
            "vmStateDisplayName": "Ready",
            "servers": {
              "20160522201409 jobs_v1 1": {
                "serverStateDisplayName": "Ready",
                "creationDate": "2016-05-22T20:14:22.000+0000",
                "state": "READY",
                "provisionStatus": "PENDING",
                "serverRole": "ROLE",
                "serverType": "SERVER",
                "serverName": "20160522201409 jobs_v1 1",
                "serverId": 2902
              }
            },
            "isAdminNode": true,
            "creationDate": "2016-05-22T20:14:23.000+0000",
            "totalStorage": 15360,
            "shapeId": "ot1",
            "state": "READY",
            "vmId": 4353,
            "hostName": "20160522201409-jobsv1-1",
            "label": "20160522201409 jobs_v1 ADMIN_SERVER 1",
            "ipAddress": "10.252.159.39",
            "publicIpAddress": "10.252.159.39",
            "usageType": "ADMIN_SERVER",
            "role": "ADMIN_SERVER",
            "componentType": "jobs_v1"
          }
        },
        "output": [
          "20160522201409-jobsv1-1"
        ]
      }
    ],
    "identifier": 37577683
  },
  {
    "identifier": 37668134
  },
  {
    "context": [
      "I want to load this data up into a spreadsheet to be able to filter, group, and audit it.",
      "I\u2019ve been stumped on how to get the nested Tags array flattened into the parent objects such that the intermediate can then be passed to the @csv filter.",
      "The following jq filter produces the requested intermediate output:\r\n\r\n    .Snapshots[] | (. + (.Tags|from_entries)) | del(.Tags)",
      "from_entries converts the array of key-value objects to an object with the given key-value pairs.  This is added to the target object, and finally the \"Tags\" key is removed."
    ],
    "utterance": "Flatten each object in the Snapshots array by merging its Tags array (as key-value pairs) into the parent object and removing the Tags key.",
    "expressions": [
      ".Snapshots[] | (. + (.Tags|from_entries)) | del(.Tags)"
    ],
    "data": [
      {
        "input": {
          "Snapshots": [
            {
              "SnapshotId": "snap-fff",
              "StartTime": "2014-04-01T06:00:13.000Z",
              "VolumeId": "vol-fff",
              "VolumeSize": 50,
              "Description": "desc1",
              "Tags": [
                {
                  "Value": "/dev/sdf",
                  "Key": "device"
                },
                {
                  "Value": "a name",
                  "Key": "Name"
                },
                {
                  "Value": "Internal",
                  "Key": "Customer"
                },
                {
                  "Value": "Demo",
                  "Key": "Environment"
                },
                {
                  "Value": "Brand 1",
                  "Key": "Branding"
                },
                {
                  "Value": "i-fff",
                  "Key": "instance_id"
                }
              ]
            },
            {
              "SnapshotId": "snap-ccc",
              "StartTime": "2014-07-01T05:59:14.000Z",
              "VolumeId": "vol-ccc",
              "VolumeSize": 8,
              "Description": "B Desc",
              "Tags": [
                {
                  "Value": "/dev/sda1",
                  "Key": "device"
                },
                {
                  "Value": "External",
                  "Key": "Customer"
                },
                {
                  "Value": "Production",
                  "Key": "Environment"
                },
                {
                  "Value": "i-ccc",
                  "Key": "instance_id"
                },
                {
                  "Value": "B Brand",
                  "Key": "Branding"
                },
                {
                  "Value": "B Name",
                  "Key": "Name"
                },
                {
                  "Value": "AnotherValue",
                  "Key": "AnotherKey"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "SnapshotId": "snap-fff",
            "StartTime": "2014-04-01T06:00:13.000Z",
            "VolumeId": "vol-fff",
            "VolumeSize": 50,
            "Description": "desc1",
            "device": "/dev/sdf",
            "Name": "a name",
            "Customer": "Internal",
            "Environment": "Demo",
            "Branding": "Brand 1",
            "instance_id": "i-fff"
          },
          {
            "SnapshotId": "snap-ccc",
            "StartTime": "2014-07-01T05:59:14.000Z",
            "VolumeId": "vol-ccc",
            "VolumeSize": 8,
            "Description": "B Desc",
            "device": "/dev/sda1",
            "Customer": "External",
            "Environment": "Production",
            "instance_id": "i-ccc",
            "Branding": "B Brand",
            "Name": "B Name",
            "AnotherKey": "AnotherValue"
          }
        ]
      }
    ],
    "identifier": 37576570
  },
  {
    "context": [
      "I have an object that looks like this: `{\"m\":[\"bad-1\", \"ok\", \"also-ok\", \"bad-2\", \"bad-3\"]}` I would like to keep just the values in `m` that don't start with `bad-`.",
      "reduce .[] as $item ([]; if ($item | test(\"^bad-\")) then .  else . + [$item] end)",
      ".m |= map( select( startswith(\"bad-\") | not ))",
      "produces:\n\n    {\n      \"m\": [\n        \"ok\",\n        \"also-ok\"\n      ]\n    }"
    ],
    "utterance": "Keep only the values in array m that do not start with 'bad-'.",
    "expressions": [
      ".m |= map( select( startswith(\"bad-\") | not ))",
      ".m |= [ .m[] | select((startswith(\"bad-\") | not)) ]",
      ".m |= [ .m[] | select((test(\"^bad-\")) | not) ]"
    ],
    "data": [
      {
        "input": {
          "m": [
            "bad-1",
            "ok",
            "also-ok",
            "bad-2",
            "bad-3"
          ]
        },
        "output": {
          "m": [
            "ok",
            "also-ok"
          ]
        }
      }
    ],
    "identifier": 37704837
  },
  {
    "context": [
      "Wanted output:\r\n\r\n`{\"channel\" : \"profile_type.youtube\"}`",
      "How can I achieve my result using ONLY jq?",
      "{channel: \"\\(.profile_type).\\(.member_key)\"}",
      "$ jq '{channel: \"\\(.profile_type).\\(.member_key)\"}' <<EOF\n    > {\"channel\": \"youtube\", \"profile_type\": \"video\", \"member_key\": \"hello\"}\n    > EOF\n    {\n      \"channel\": \"video.hello\"\n    }"
    ],
    "utterance": "Produce an object with channel set to the concatenation of profile_type, a dot, and member_key.",
    "expressions": [
      "{channel: (.profile_type + \".\" + .member_key)}",
      "{channel: \"\\(.profile_type).\\(.member_key)\"}"
    ],
    "data": [
      {
        "input": {
          "channel": "youtube",
          "profile_type": "video",
          "member_key": "hello"
        },
        "output": {
          "channel": "video.hello"
        }
      }
    ],
    "identifier": 37710718
  },
  {
    "context": [
      "I have a generated file (from amazon CLI) and wish to pull out some of the attributes.",
      "I would like to extract the state, Env and Name .... this should be simple   jq \".[].State\"   ... however the State is nested in an object which isn&#39;t named.",
      "If they&#39;re simply arrays of arrays of the objects you&#39;re interested in, you can flatten it down to just the objects by traversing each of the arrays.  Then get the properties you want.",
      ".[][] | { State, Env, Name }",
      "If you want the three attributes for all objects that have any of them, no matter where the objects occur, you can use `..`.  E.g., for the given input,",
      "jq '.. | objects | select(has(\"State\") or has(\"Env\") or has(\"Name\")) | {State, Env, Name}'"
    ],
    "utterance": "Extract the State, Env, and Name fields from each nested object within arrays of arrays, regardless of object location.",
    "expressions": [
      ".[][] | { State, Env, Name }",
      ".. | objects | select(has(\"State\") or has(\"Env\") or has(\"Name\")) | {State, Env, Name}"
    ],
    "data": [
      {
        "input": [
          [
            {
              "State": "running",
              "Type": "c4.xlarge",
              "ID": "i-somehere",
              "Env": [
                "prd"
              ],
              "Name": [
                "some url here"
              ]
            }
          ],
          [
            {
              "State": "stopped",
              "Type": "c4.xlarge",
              "ID": "i-somehere",
              "Env": [
                "prd"
              ],
              "Name": [
                "some url here"
              ]
            }
          ],
          [
            {
              "State": "running",
              "Type": "c4.2xlarge",
              "ID": "i-somehere",
              "Env": [
                "prd"
              ],
              "Name": [
                "some url here"
              ]
            }
          ]
        ],
        "output": [
          {
            "State": "running",
            "Env": [
              "prd"
            ],
            "Name": [
              "some url here"
            ]
          },
          {
            "State": "stopped",
            "Env": [
              "prd"
            ],
            "Name": [
              "some url here"
            ]
          },
          {
            "State": "running",
            "Env": [
              "prd"
            ],
            "Name": [
              "some url here"
            ]
          }
        ]
      }
    ],
    "identifier": 37396184
  },
  {
    "context": [
      "I want to dig down through an arbitrary number of levels of .nodes/.floating_nodes and pull out .nodes or .floating_nodes that have \"window\" set to non-null.",
      "First, we use the recurse operator, `..`, to recursively iterate through everything. ... we pipe everything to `select(.window != null)`",
      "jq '[.. | .floating_nodes?, .nodes? | .[]? | select(.window != null)]'",
      "If the `window` property can only appear on `node` or `floating_node` objects, you could simplify things by just searching for all objects that have `window` properties.",
      ".. | objects | select(.window != null)",
      "The following has been tested with jq 1.3, 1.4, and 1.5:\n\n    recurse(if type == \"object\" or type == \"array\" then .[] else empty end)\n    | select(type == \"object\")\n    | ( select(.nodes|type == \"array\") | .nodes[]),\n      ( select(.floating_nodes|type == \"array\") | .floating_nodes[])\n    | select( .window != null ) ",
      "Here is a solution which uses **tostream** to scan a stream of [path,value] arrays from the given input.  It then uses **select** to pick out only paths ending in \"window\" and whose corresponding value is not null. ... Finally ... **getpath** to produce a stream of the containing objects.",
      "      ( tostream | select(length == 2 and .[0][-1] == \"window\" and .[1] != null) ) as $p\n    |  getpath($p[0][:-1])"
    ],
    "utterance": "Find all nested nodes or floating_nodes at any depth that have a non-null window property.",
    "expressions": [
      "[.. | .floating_nodes?, .nodes? | .[]? | select(.window != null)]",
      ".. | objects | select(.window != null)",
      "recurse(if type == \"object\" or type == \"array\" then .[] else empty end)\n| select(type == \"object\")\n| ( select(.nodes|type == \"array\") | .nodes[]),\n  ( select(.floating_nodes|type == \"array\") | .floating_nodes[])\n| select( .window != null )",
      "( tostream | select(length == 2 and .[0][-1] == \"window\" and .[1] != null) ) as $p\n|  getpath($p[0][:-1])"
    ],
    "data": [
      {
        "input": {
          "floating_nodes": [],
          "nodes": [
            {
              "floating_nodes": [],
              "nodes": [
                {
                  "floating_nodes": [],
                  "nodes": [
                    {
                      "floating_nodes": [],
                      "nodes": [],
                      "window": null,
                      "name": "__i3_scratch"
                    }
                  ],
                  "window": null,
                  "name": "foobar"
                }
              ],
              "window": null,
              "name": "__i3"
            },
            {
              "floating_nodes": [],
              "nodes": [
                {
                  "floating_nodes": [],
                  "nodes": [],
                  "window": null,
                  "name": "topdock"
                },
                {
                  "floating_nodes": [],
                  "nodes": [
                    {
                      "floating_nodes": [],
                      "nodes": [],
                      "window": 8388613,
                      "name": "16:11 bhepple:.../~ \u2014 Konsole",
                      "rect": {
                        "height": 1061,
                        "width": 1920,
                        "y": 0,
                        "x": 0
                      }
                    }
                  ],
                  "window": null,
                  "name": "1"
                },
                {
                  "floating_nodes": [],
                  "nodes": [
                    {
                      "floating_nodes": [],
                      "nodes": [],
                      "window": 14680070,
                      "name": "i3bar for output VNC-0"
                    }
                  ],
                  "window": null,
                  "name": "bottomdock"
                }
              ],
              "window": null,
              "name": "VNC-0"
            }
          ],
          "window": null,
          "name": "root"
        },
        "output": [
          {
            "floating_nodes": [],
            "nodes": [],
            "window": 8388613,
            "name": "16:11 bhepple:.../~ \u2014 Konsole",
            "rect": {
              "height": 1061,
              "width": 1920,
              "y": 0,
              "x": 0
            }
          },
          {
            "floating_nodes": [],
            "nodes": [],
            "window": 14680070,
            "name": "i3bar for output VNC-0"
          }
        ]
      }
    ],
    "identifier": 37020712
  },
  {
    "context": [
      "As the subject states, my goal is to write an `all_keys` function to extract all keys from an arbitrarily nested json blob, traversing contained arrays and objects as needed, and outputting an array containing the keys, without duplicates.",
      "For instance, given the following input:\n\n    [\n        {\"name\": \"/\", \"children\": [\n          {\"name\": \"/bin\", \"children\": [\n            {\"name\": \"/bin/ls\", \"children\": []},\n            {\"name\": \"/bin/sh\", \"children\": []}]},\n          {\"name\": \"/home\", \"children\": [\n            {\"name\": \"/home/stephen\", \"children\": [\n              {\"name\": \"/home/stephen/jq\", \"children\": []}]}]}]},\n        {\"name\": \"/\", \"children\": [\n          {\"name\": \"/bin\", \"children\": [\n            {\"name\": \"/bin/ls\", \"children\": []},\n            {\"name\": \"/bin/sh\", \"children\": []}]},\n          {\"name\": \"/home\", \"children\": [\n            {\"name\": \"/home/stephen\", \"children\": [\n              {\"name\": \"/home/stephen/jq\", \"children\": []}]}]}]}      \n    ]\n\nThe `all_keys` fuction should produce this output:\n\n    [\n      \"children\",\n      \"name\"\n    ]",
      "A naive approach would just collect all the keys and get the unique values.\n\n    [.. | objects | keys[]] | unique",
      "We could do a little better with this. Since we're trying to determine all the distinct keys, we'd use a hashmap of some sort to be more efficient. Well, we have objects that can act as such.\n\n    reduce (.. | objects | keys[]) as $k ({}; .[$k] = true) | keys",
      "def all_keys:\n  def uniquely(f): reduce f as $x ({}; .[$x] = true) | keys;\n  def rkeys:\n    if type == \"object\" then keys[] as $k | ($k, (.[$k]|rkeys))\n    elif type == \"array\" then .[]|rkeys\n    else empty\n    end;\n  uniquely(rkeys);"
    ],
    "utterance": "Extract all unique keys appearing anywhere in arbitrarily nested data consisting of objects and arrays.",
    "expressions": [
      "[.. | objects | keys[]] | unique",
      "reduce (.. | objects | keys[]) as $k ({}; .[$k] = true) | keys",
      "def all_keys:\n  def uniquely(f): reduce f as $x ({}; .[$x] = true) | keys;\n  def rkeys:\n    if type == \"object\" then keys[] as $k | ($k, (.[$k]|rkeys))\n    elif type == \"array\" then .[]|rkeys\n    else empty\n    end;\n  uniquely(rkeys);"
    ],
    "data": [
      {
        "input": [
          {
            "name": "/",
            "children": [
              {
                "name": "/bin",
                "children": [
                  {
                    "name": "/bin/ls",
                    "children": []
                  },
                  {
                    "name": "/bin/sh",
                    "children": []
                  }
                ]
              },
              {
                "name": "/home",
                "children": [
                  {
                    "name": "/home/stephen",
                    "children": [
                      {
                        "name": "/home/stephen/jq",
                        "children": []
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "name": "/",
            "children": [
              {
                "name": "/bin",
                "children": [
                  {
                    "name": "/bin/ls",
                    "children": []
                  },
                  {
                    "name": "/bin/sh",
                    "children": []
                  }
                ]
              },
              {
                "name": "/home",
                "children": [
                  {
                    "name": "/home/stephen",
                    "children": [
                      {
                        "name": "/home/stephen/jq",
                        "children": []
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          "children",
          "name"
        ]
      }
    ],
    "identifier": 37167676
  },
  {
    "context": [
      "eval \"$3=$(cat $1 | jq '.\"$2\"')\"",
      "jq --arg key \"$2\" '.[$key]' \"$1\"",
      "getJSONParameter() {\n  jq --arg key \"$2\" '.[$key]' \"$1\"\n}",
      "return_value=\"$(getJSONParameter \"etl-without-transformation.json\" \"success_email\")\"",
      "getJSONParamater etl-without-transformation.json  .success_email",
      "return_value=$(cat \"$1\" | jq \"$2\")"
    ],
    "utterance": "Extract the value associated with the key 'success_email' from the file 'etl-without-transformation.json' where the key is supplied as a variable.",
    "expressions": [
      "jq --arg key \"$2\" '.[$key]' \"$1\"",
      "jq \"$2\" \"$1\""
    ],
    "identifier": 37743955
  },
  {
    "context": [
      "with jq, it&#39;s just a matter of slurping all files together:\r\n\r\n    jq -s &#39;.&#39; *.json",
      "ls |xargs -n 10000 -P 8 jq -s &#39;.&#39; &gt;&gt;../jsonparsed\r\n\r\nThis spawn 8 concurrent processes each having 10k arguments and writes to a single jsonfile jsonparsed"
    ],
    "utterance": "Combine millions of individual files, each containing a dict, into a single file containing a list of all dicts.",
    "expressions": [
      "jq -s '.' *.json"
    ],
    "data": [
      {
        "input": [
          {
            "finent": "abc",
            "findeplabel": "lbl"
          },
          {
            "finent": "def",
            "findeplabel": "xyz"
          }
        ],
        "output": [
          {
            "finent": "abc",
            "findeplabel": "lbl"
          },
          {
            "finent": "def",
            "findeplabel": "xyz"
          }
        ]
      }
    ],
    "identifier": 37785825
  },
  {
    "context": [
      "I am trying to update \"image_id\" value in a json structure. Using the below command, how do I change `ami-d8cf5cab` to `ami-a4df7gah`",
      "Use the `|=` operator to assign to a property:",
      "jq -r '.modules[].resources[] | select(.type == \"aws_launch_configuration\") | select(.primary.attributes.name_prefix == \"pmsadmin-lc-\")| .primary.attributes.image_id |= \"ami-a4df7gah\"'"
    ],
    "utterance": "Replace the value of image_id with ami-a4df7gah for resources with type aws_launch_configuration and name_prefix equal to pmsadmin-lc-",
    "expressions": [
      ".modules[].resources[] | select(.type == \"aws_launch_configuration\") | select(.primary.attributes.name_prefix == \"pmsadmin-lc-\") | .primary.attributes.image_id |= \"ami-a4df7gah\""
    ],
    "data": [
      {
        "input": {
          "type": "aws_launch_configuration",
          "primary": {
            "id": "pmsadmin-lc-v47thk6rcrdgza6dujfzjatmju",
            "attributes": {
              "associate_public_ip_address": "false",
              "ebs_block_device.#": "0",
              "ebs_optimized": "false",
              "enable_monitoring": "true",
              "ephemeral_block_device.#": "0",
              "iam_instance_profile": "cog-test-pmsadmin",
              "id": "pmsadmin-lc-v47thk6rcrdgza6dujfzjatmju",
              "image_id": "ami-d8cf5cab",
              "instance_type": "t2.small",
              "key_name": "cog-test-internal",
              "name": "pmsadmin-lc-v47thk6rcrdgza6dujfzjatmju",
              "name_prefix": "pmsadmin-lc-",
              "root_block_device.#": "0",
              "security_groups.#": "4",
              "security_groups.1893851868": "sg-7ee7bf1a",
              "security_groups.2774384192": "sg-e2e7bf86",
              "security_groups.2825850029": "sg-86e6bee2",
              "security_groups.3095009517": "sg-f4e7bf90",
              "spot_price": "",
              "user_data": "ed03ac6642af8c97562b065c0b37f211b58ad0a2"
            }
          }
        },
        "output": {
          "type": "aws_launch_configuration",
          "primary": {
            "id": "pmsadmin-lc-v47thk6rcrdgza6dujfzjatmju",
            "attributes": {
              "associate_public_ip_address": "false",
              "ebs_block_device.#": "0",
              "ebs_optimized": "false",
              "enable_monitoring": "true",
              "ephemeral_block_device.#": "0",
              "iam_instance_profile": "cog-test-pmsadmin",
              "id": "pmsadmin-lc-v47thk6rcrdgza6dujfzjatmju",
              "image_id": "ami-a4df7gah",
              "instance_type": "t2.small",
              "key_name": "cog-test-internal",
              "name": "pmsadmin-lc-v47thk6rcrdgza6dujfzjatmju",
              "name_prefix": "pmsadmin-lc-",
              "root_block_device.#": "0",
              "security_groups.#": "4",
              "security_groups.1893851868": "sg-7ee7bf1a",
              "security_groups.2774384192": "sg-e2e7bf86",
              "security_groups.2825850029": "sg-86e6bee2",
              "security_groups.3095009517": "sg-f4e7bf90",
              "spot_price": "",
              "user_data": "ed03ac6642af8c97562b065c0b37f211b58ad0a2"
            }
          }
        }
      }
    ],
    "identifier": 37699158
  },
  {
    "context": [
      "I want to make sure that output should not have the prefix `cybs/` in it. for example, `cybs/address-api` should just be `address-api`",
      "Just use [`sub`][2]:\r\n\r\n    curl ... | jq -r '.repositories[0:5][] | sub(\"^cybs/\"; \"\")'",
      "Output:\r\n\r\n    centos\r\n    containersol/consul-server\r\n    containersol/mesos-agent\r\n    containersol/mesos-master\r\n    address-api"
    ],
    "utterance": "Remove the prefix 'cybs/' from the beginning of each value in the list of repository names, so values like 'cybs/address-api' become 'address-api'.",
    "expressions": [
      ".repositories[0:5][] | sub(\"^cybs/\"; \"\")"
    ],
    "data": [
      {
        "input": {
          "repositories": [
            "centos",
            "containersol/consul-server",
            "containersol/mesos-agent",
            "containersol/mesos-master",
            "cybs/address-api"
          ]
        },
        "output": [
          "centos",
          "containersol/consul-server",
          "containersol/mesos-agent",
          "containersol/mesos-master",
          "address-api"
        ]
      }
    ],
    "identifier": 37817820
  },
  {
    "context": [
      "I am using the following command to list all the images within my private registry:  \r\n\r\n    curl -s http://internal.private.registry.com/v2/_catalog | jq -r '.repositories[0:2] | to_entries | map( .value )[]'",
      "I am using the following command to list all the tags of a particular image within my private registry:  \r\n\r\n     curl -s GET http://internal.private.registry.com/v2/centos/tags/list | jq -r '.tags | to_entries | map( .value )[]'",
      "jq: error (at <stdin>:1): null (null) has no keys",
      "Is caused by `.` being null. In this case `.` refers to stdin which means that you get no response from `http://internal.private.registry.com/v2/cybs/${line}/tags/list`."
    ],
    "utterance": "Extract all image names from repositories and, for each image, extract the full list of its tags.",
    "expressions": [
      ".repositories[]",
      ".tags[]"
    ],
    "identifier": 37800919
  },
  {
    "context": [
      "Json input:\r\n\r\n    [ \"orange-1234\", \"orange-12345\", \"apple-1234\" ]",
      "Desired output:\r\n\r\n    [ \"orange-1234, \"orange-12345\" ]",
      "Via bash, I would like to use jq to find the values starting or containing orange*",
      "As of jq 1.5, you could do regular expression matching.  So with that, just filter your array.",
      "map(select(test(\"\\\\borange\\\\b\")))",
      "`startswith` and `contains` can do this just fine. Use `select` to filter values by true/false:",
      "map(select(startswith(\"orange\")))",
      "echo '[ \"orange-1234\", \"orange-12345\", \"apple-1234\" ]' | jq 'map(select(test(orange)))'",
      "so here jq is essentially iterating over all elements, and selecting only those which return true for test(orange), which is a regex check"
    ],
    "utterance": "Return all array elements whose value starts with or contains 'orange'.",
    "expressions": [
      "map(select(test(\"orange\")))",
      "map(select(startswith(\"orange\")))",
      "map(select(contains(\"orange\")))"
    ],
    "data": [
      {
        "input": [
          "orange-1234",
          "orange-12345",
          "apple-1234"
        ],
        "output": [
          "orange-1234",
          "orange-12345"
        ]
      }
    ],
    "identifier": 37865259
  },
  {
    "context": [
      "I want to get only `name` values in a variable.",
      "I need only `Dev_ReleaseRollout_Lane-3` `Dev_ReleaseRollout_Lane-latest` `Payments_Dev_Lane-267` in a variable",
      "$ curl ... | jq -r '.[].name'",
      "Dev_ReleaseRollout_Lane-3",
      "Dev_ReleaseRollout_Lane-latest",
      "Payments_Dev_Lane-267",
      "It's fairly simple, `.` is the array, `[].name` take name from each element in the array. `-r` is raw output.",
      "If the cURL output is actually as mentioned above the following will work:",
      "jq -rRs '\"[\\(.)]\" | fromjson[].name' file.json"
    ],
    "utterance": "Extract all values of the 'name' key from each object in an array.",
    "expressions": [
      "jq -r '.[].name'",
      "jq -rRs '\"[\\(.)]\" | fromjson[].name'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Dev_ReleaseRollout_Lane-3",
            "inRegistry": true,
            "hashMismatch": false,
            "inNotary": false
          },
          {
            "name": "Dev_ReleaseRollout_Lane-latest",
            "inRegistry": true,
            "hashMismatch": false,
            "inNotary": false
          },
          {
            "name": "Payments_Dev_Lane-267",
            "inRegistry": true,
            "hashMismatch": false,
            "inNotary": false
          }
        ],
        "output": [
          "Dev_ReleaseRollout_Lane-3",
          "Dev_ReleaseRollout_Lane-latest",
          "Payments_Dev_Lane-267"
        ]
      }
    ],
    "identifier": 37823145
  },
  {
    "context": [
      "So here i want add \"Putrequest\" and \"Item\" attributes to each item of the array.. So i want the output like this:",
      "Assuming you actually got valid JSON the following jq expression might work for you:",
      "jq 'map_values(map({\"PutRequest\": { \"Item\": .}}))' file.json"
    ],
    "utterance": "Wrap each object of the arrays at the top-level object under the keys \"PutRequest\" and \"Item\" so that every array element becomes {\"PutRequest\": {\"Item\": <original object>}}.",
    "expressions": [
      "map_values(map({\"PutRequest\": { \"Item\": .}}))"
    ],
    "data": [
      {
        "input": {
          "Helloo": [
            {
              "AlbumTitle": {
                "S": "Famous"
              },
              "SongTitle": {
                "S": "Call Me Today"
              },
              "Artist": {
                "S": "No One You Know"
              }
            },
            {
              "AlbumTitle": {
                "S": "Famous1"
              },
              "SongTitle": {
                "S": "Call Me Today1"
              },
              "Artist": {
                "S": "No One You Know11"
              }
            }
          ],
          "Music": [
            {
              "Album": {
                "S": "Pop Songs"
              },
              "Production": {
                "S": "X-series"
              },
              "Song": {
                "S": "Once upon"
              },
              "Artist": {
                "S": "XYZ"
              }
            }
          ]
        },
        "output": {
          "Helloo": [
            {
              "PutRequest": {
                "Item": {
                  "AlbumTitle": {
                    "S": "Famous"
                  },
                  "SongTitle": {
                    "S": "Call Me Today"
                  },
                  "Artist": {
                    "S": "No One You Know"
                  }
                }
              }
            },
            {
              "PutRequest": {
                "Item": {
                  "AlbumTitle": {
                    "S": "Famous1"
                  },
                  "SongTitle": {
                    "S": "Call Me Today1"
                  },
                  "Artist": {
                    "S": "No One You Know11"
                  }
                }
              }
            }
          ],
          "Music": [
            {
              "PutRequest": {
                "Item": {
                  "Album": {
                    "S": "Pop Songs"
                  },
                  "Production": {
                    "S": "X-series"
                  },
                  "Song": {
                    "S": "Once upon"
                  },
                  "Artist": {
                    "S": "XYZ"
                  }
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 37807074
  },
  {
    "context": [
      "What I am trying to achieve is output that looks like\n\n    [\n      {\n        name: \"foo\",\n        category: \"thefoocategory\"\n      },\n      {\n        name: \"bar\",\n        category: \"thebarcategory\"\n      }\n    ]",
      "I am able to extract the names quite easily with `jq ' .things | .[] | .name'`",
      "I can also extract the categories with `jq ' .things | .[] | .params | .[] | select(.key == \"category\") | .value'`",
      "But I have not been able to combine them.",
      "This was actually relatively straight forward:\n\n    .things | .[] | {name: .name, category: .params | .[] | select(.key==\"category\") | .value }",
      "Your `params` almost looks like key/value entries, so you could create an object out of them by passing the array to `from_entries`.  So to combine everything, you merely need to do this:\n\n    .things | map({name} + (.params | from_entries))"
    ],
    "utterance": "Produce an array of objects, each containing the name and the category value from each item in the things array, where category is the value from params with key equal to \"category\".",
    "expressions": [
      ".things | .[] | {name: .name, category: .params | .[] | select(.key==\"category\") | .value }",
      ".things | map({name} + {category: (.params | map(select(.key==\"category\")) | .[0].value)})"
    ],
    "data": [
      {
        "input": {
          "things": [
            {
              "name": "foo",
              "params": [
                {
                  "type": "t1",
                  "key": "key1",
                  "value": "val1"
                },
                {
                  "type": "t1",
                  "key": "category",
                  "value": "thefoocategory"
                }
              ]
            },
            {
              "name": "bar",
              "params": [
                {
                  "type": "t1",
                  "key": "key1",
                  "value": "val1"
                },
                {
                  "type": "t1",
                  "key": "category",
                  "value": "thebarcategory"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "foo",
            "category": "thefoocategory"
          },
          {
            "name": "bar",
            "category": "thebarcategory"
          }
        ]
      }
    ],
    "identifier": 37864617
  },
  {
    "context": [
      "Summarised, I want a JSON array I can iterate over that will give me an InstanceID, tags on that instance and a _single_ volume. You will notice that each instance has 3 volumes attached (could be more, or less). I\u2019d like to be able to iterate over each one individually.",
      "The following jq filter produces a stream of JSON objects as requested.",
      "If you really need a JSON array, then simply wrap the entire expression in square brackets.",
      ".Reservations[] | .Instances[]\n| { InstanceId }\n  + (.BlockDeviceMappings[]\n     | { DeviceName,\n         \"VolumeId\": .Ebs.VolumeId } )\n  + (.Tags\n     | { \"TAG1\": ( map( select(.Value == \"TAG1\"))[] | .Key),\n         \"TAG2\": ( map( select(.Value == \"TAG2\"))[] | .Key) } )"
    ],
    "utterance": "Output one object for each block device mapping in every instance, including InstanceId, DeviceName, VolumeId, and the values of the TAG1 and TAG2 tags from the instance's tags.",
    "expressions": [
      ".Reservations[] | .Instances[]\n| { InstanceId }\n  + (.BlockDeviceMappings[]\n     | { DeviceName,\n         \"VolumeId\": .Ebs.VolumeId } )\n  + (.Tags\n     | { \"TAG1\": ( map( select(.Value == \"TAG1\"))[] | .Key),\n         \"TAG2\": ( map( select(.Value == \"TAG2\"))[] | .Key) } )"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "OwnerId": "xx",
              "ReservationId": "xx",
              "Groups": [],
              "Instances": [
                {
                  "Monitoring": {
                    "State": "xx"
                  },
                  "PublicDnsName": "",
                  "Platform": "xx",
                  "State": {
                    "Code": "xx",
                    "Name": "xx"
                  },
                  "EbsOptimized": "xx",
                  "LaunchTime": "xx",
                  "PrivateIpAddress": "xx",
                  "ProductCodes": [],
                  "VpcId": "xx",
                  "StateTransitionReason": "",
                  "InstanceId": "i-11111111",
                  "ImageId": "xx",
                  "PrivateDnsName": "xx",
                  "KeyName": "xx",
                  "SecurityGroups": [
                    {
                      "GroupName": "xx",
                      "GroupId": "xx"
                    },
                    {
                      "GroupName": "xx",
                      "GroupId": "xx"
                    }
                  ],
                  "ClientToken": "xx",
                  "SubnetId": "xx",
                  "InstanceType": "xx",
                  "NetworkInterfaces": [
                    {
                      "Status": "xx",
                      "MacAddress": "xx",
                      "SourceDestCheck": "xx",
                      "VpcId": "xx",
                      "Description": "xx",
                      "NetworkInterfaceId": "xx",
                      "PrivateIpAddresses": [
                        {
                          "PrivateDnsName": "xx",
                          "Primary": "xx",
                          "PrivateIpAddress": "xx"
                        }
                      ],
                      "PrivateDnsName": "xx",
                      "Attachment": {
                        "Status": "xx",
                        "DeviceIndex": "xx",
                        "DeleteOnTermination": "xx",
                        "AttachmentId": "xx",
                        "AttachTime": "xx"
                      },
                      "Groups": [
                        {
                          "GroupName": "xx",
                          "GroupId": "xx"
                        },
                        {
                          "GroupName": "xx",
                          "GroupId": "xx"
                        }
                      ],
                      "SubnetId": "xx",
                      "OwnerId": "xx",
                      "PrivateIpAddress": "xx"
                    }
                  ],
                  "SourceDestCheck": "xx",
                  "Placement": {
                    "Tenancy": "xx",
                    "GroupName": "xx",
                    "AvailabilityZone": "xx"
                  },
                  "Hypervisor": "xx",
                  "BlockDeviceMappings": [
                    {
                      "DeviceName": "/dev/sda1",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": "xx",
                        "VolumeId": "vol-1111111a",
                        "AttachTime": "xx"
                      }
                    },
                    {
                      "DeviceName": "xvdf",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": "xx",
                        "VolumeId": "vol-1111111b",
                        "AttachTime": "xx"
                      }
                    },
                    {
                      "DeviceName": "xvdg",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": "xx",
                        "VolumeId": "vol-11111111c",
                        "AttachTime": "xx"
                      }
                    }
                  ],
                  "Architecture": "xx",
                  "RootDeviceType": "xx",
                  "RootDeviceName": "xx",
                  "VirtualizationType": "hvm",
                  "Tags": [
                    {
                      "Value": "TAG1",
                      "Key": "VALUE1"
                    },
                    {
                      "Value": "TAG2",
                      "Key": "VALUE2"
                    },
                    {
                      "Value": "TAG3",
                      "Key": "VALUE3"
                    },
                    {
                      "Value": "TAG4",
                      "Key": "VALUE4"
                    },
                    {
                      "Value": "TAG5",
                      "Key": "VALUE5"
                    },
                    {
                      "Value": "TAG6",
                      "Key": "Value6"
                    }
                  ],
                  "AmiLaunchIndex": "xx"
                }
              ]
            },
            {
              "OwnerId": "xx",
              "ReservationId": "xx",
              "Groups": [],
              "Instances": [
                {
                  "Monitoring": {
                    "State": "xx"
                  },
                  "PublicDnsName": "",
                  "Platform": "xx",
                  "State": {
                    "Code": "xx",
                    "Name": "xx"
                  },
                  "EbsOptimized": "xx",
                  "LaunchTime": "xx",
                  "PrivateIpAddress": "xx",
                  "ProductCodes": [],
                  "VpcId": "xx",
                  "StateTransitionReason": "",
                  "InstanceId": "i-22222222",
                  "ImageId": "xx",
                  "PrivateDnsName": "xx",
                  "KeyName": "xx",
                  "SecurityGroups": [
                    {
                      "GroupName": "xx",
                      "GroupId": "xx"
                    },
                    {
                      "GroupName": "xx",
                      "GroupId": "xx"
                    }
                  ],
                  "ClientToken": "xx",
                  "SubnetId": "xx",
                  "InstanceType": "xx",
                  "NetworkInterfaces": [
                    {
                      "Status": "xx",
                      "MacAddress": "xx",
                      "SourceDestCheck": "xx",
                      "VpcId": "xx",
                      "Description": "xx",
                      "NetworkInterfaceId": "xx",
                      "PrivateIpAddresses": [
                        {
                          "PrivateDnsName": "xx",
                          "Primary": "xx",
                          "PrivateIpAddress": "xx"
                        }
                      ],
                      "PrivateDnsName": "xx",
                      "Attachment": {
                        "Status": "xx",
                        "DeviceIndex": "xx",
                        "DeleteOnTermination": "xx",
                        "AttachmentId": "xx",
                        "AttachTime": "xx"
                      },
                      "Groups": [
                        {
                          "GroupName": "xx",
                          "GroupId": "xx"
                        },
                        {
                          "GroupName": "xx",
                          "GroupId": "xx"
                        }
                      ],
                      "SubnetId": "xx",
                      "OwnerId": "xx",
                      "PrivateIpAddress": "xx"
                    }
                  ],
                  "SourceDestCheck": "xx",
                  "Placement": {
                    "Tenancy": "xx",
                    "GroupName": "xx",
                    "AvailabilityZone": "xx"
                  },
                  "Hypervisor": "xx",
                  "BlockDeviceMappings": [
                    {
                      "DeviceName": "/dev/sda1",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": "xx",
                        "VolumeId": "vol-2222222a",
                        "AttachTime": "xx"
                      }
                    },
                    {
                      "DeviceName": "/dev/sdb",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": "xx",
                        "VolumeId": "vol-2222222b",
                        "AttachTime": "xx"
                      }
                    },
                    {
                      "DeviceName": "/dev/sdc",
                      "Ebs": {
                        "Status": "attached",
                        "DeleteOnTermination": "xx",
                        "VolumeId": "vol-2222222c",
                        "AttachTime": "xx"
                      }
                    }
                  ],
                  "Architecture": "xx",
                  "RootDeviceType": "xx",
                  "RootDeviceName": "xx",
                  "VirtualizationType": "hvm",
                  "Tags": [
                    {
                      "Value": "TAG1",
                      "Key": "VALUE1"
                    },
                    {
                      "Value": "TAG2",
                      "Key": "VALUE2"
                    },
                    {
                      "Value": "TAG3",
                      "Key": "VALUE3"
                    },
                    {
                      "Value": "TAG4",
                      "Key": "VALUE4"
                    },
                    {
                      "Value": "TAG5",
                      "Key": "VALUE5"
                    },
                    {
                      "Value": "TAG6",
                      "Key": "Value6"
                    }
                  ],
                  "AmiLaunchIndex": "xx"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "InstanceId": "i-11111111",
            "DeviceName": "/dev/sda1",
            "VolumeId": "vol-1111111a",
            "TAG1": "VALUE1",
            "TAG2": "VALUE2"
          },
          {
            "InstanceId": "i-11111111",
            "DeviceName": "xvdf",
            "VolumeId": "vol-1111111b",
            "TAG1": "VALUE1",
            "TAG2": "VALUE2"
          },
          {
            "InstanceId": "i-11111111",
            "DeviceName": "xvdg",
            "VolumeId": "vol-11111111c",
            "TAG1": "VALUE1",
            "TAG2": "VALUE2"
          },
          {
            "InstanceId": "i-22222222",
            "DeviceName": "/dev/sda1",
            "VolumeId": "vol-2222222a",
            "TAG1": "VALUE1",
            "TAG2": "VALUE2"
          },
          {
            "InstanceId": "i-22222222",
            "DeviceName": "/dev/sdb",
            "VolumeId": "vol-2222222b",
            "TAG1": "VALUE1",
            "TAG2": "VALUE2"
          },
          {
            "InstanceId": "i-22222222",
            "DeviceName": "/dev/sdc",
            "VolumeId": "vol-2222222c",
            "TAG1": "VALUE1",
            "TAG2": "VALUE2"
          }
        ]
      }
    ],
    "identifier": 36613420
  },
  {
    "context": [
      "I\u2019d like to flatten a nested json object,  e.g. `{\"a\":{\"b\":1}}` to `{\"a.b\":1}` in order to digest it in solr.",
      "You can also use the following jq command to flatten nested JSON objects in this manner:\n\n    [paths(values) as $path | {\"key\": $path | join(\".\"), \"value\": getpath($path)}] | from_entries",
      "This is just a variant of Santiago's jq:\n\n    . as $in \n    | reduce leaf_paths as $path ({};\n         . + { ($path | map(tostring) | join(\".\")): $in | getpath($path) })",
      "As @hraban mentioned, `leaf_paths` does not work as expected (furthermore, it is deprecated). `leaf_paths` is equivalent to `paths(scalars)`, it returns the paths of any values for which `scalars` returns a truthy value. `scalars` returns its input value if it is a scalar, or `null` otherwise. The problem with that is that `null` and `false` are not truthy values, so they will be removed from the output. The following code _does_ work, by checking the type of the values directly:\n\n    . as $in\n         | reduce paths(type != \"object\" and type != \"array\") as $path ({};\n              . + { ($path | map(tostring) | join(\".\")): $in | getpath($path) })\n",
      "Here is a solution that uses **tostream**, **select**, **join**, **reduce** and **setpath**\n\n      reduce ( tostream | select(length==2) | .[0] |= [join(\".\")] ) as [$p,$v] (\n         {}\n         ; setpath($p; $v)\n      )"
    ],
    "utterance": "Flatten each nested object so that every leaf value is represented as a top-level key with dot notation indicating its path.",
    "expressions": [
      "[paths(values) as $path | {\"key\": $path | join(\".\"), \"value\": getpath($path)}] | from_entries",
      ". as $in | reduce leaf_paths as $path ({}; . + { ($path | map(tostring) | join(\".\")): $in | getpath($path) })",
      ". as $in | reduce paths(type != \"object\" and type != \"array\") as $path ({}; . + { ($path | map(tostring) | join(\".\")): $in | getpath($path) })",
      "reduce ( tostream | select(length==2) | .[0] |= [join(\".\")] ) as [$p,$v] ({} ; setpath($p; $v))"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": 1
          }
        },
        "output": {
          "a.b": 1
        }
      },
      {
        "input": {
          "a": {
            "b": [
              0,
              1,
              2
            ]
          }
        },
        "output": {
          "a.b.0": 0,
          "a.b.1": 1,
          "a.b.2": 2
        }
      }
    ],
    "identifier": 37540717
  }
]