[
  {
    "context": [
      "how could get all table values in one command?",
      "$ jq '.data[\"foo\", \"bar\"][].table' foo.json",
      "$ jq '.data | .foo, .bar | .[].table' foo.json",
      "$ jq '.data[][].table' foo.json"
    ],
    "utterance": "List all values from the table fields under both foo and bar arrays inside the data object.",
    "expressions": [
      ".data[\"foo\", \"bar\"][].table",
      ".data | .foo, .bar | .[].table",
      ".data[][].table"
    ],
    "data": [
      {
        "input": {
          "data": {
            "foo": [
              {
                "table": "aaa"
              },
              {
                "table": "bbb"
              }
            ],
            "bar": [
              {
                "table": "ccc"
              },
              {
                "table": "ddd"
              }
            ]
          }
        },
        "output": [
          "aaa",
          "bbb",
          "ccc",
          "ddd"
        ]
      }
    ],
    "identifier": 51709799
  },
  {
    "context": [
      "I'm trying to print all VpcId's using jq but I can't find the right way to do it.",
      "aws ec2 describe-vpcs | jq -r '.Vpcs | .[] | .VpcId'",
      ".. | .VpcId? // empty",
      ".Vpcs | .[] | .VpcId can be abbreviated to .Vpcs[].VpcId"
    ],
    "utterance": "Extract all values of the VpcId field from the Vpcs list in the response.",
    "expressions": [
      ".Vpcs | .[] | .VpcId",
      ".Vpcs[].VpcId",
      ".. | .VpcId? // empty"
    ],
    "data": [
      {
        "input": {
          "Vpcs": [
            {
              "VpcId": "vpc-1f0e197d"
            },
            {
              "VpcId": "vpc-36b5585d"
            }
          ]
        },
        "output": [
          "vpc-1f0e197d",
          "vpc-36b5585d"
        ]
      }
    ],
    "identifier": 51696480
  },
  {
    "context": [
      "I have a json with 3 equal lists:",
      "I'm trying to extract from each list the elements with the same index:",
      "el11 el21 el31",
      "You can use the `transpose` function for this. For example,",
      "$ jq -r '[.value[]] | transpose[] | join (\" \")' tmp.json",
      "el11 el21 el31",
      "el12 el22 el32",
      "el13 el23 el33",
      "el14 el24 el34"
    ],
    "utterance": "Extract elements with the same index from multiple lists and print each group as a space-separated string, one per line.",
    "expressions": [
      "[.value[]] | transpose[] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "value": {
            "list1": [
              "el11",
              "el12",
              "el13",
              "el14"
            ],
            "list2": [
              "el21",
              "el22",
              "el23",
              "el24"
            ],
            "list3": [
              "el31",
              "el32",
              "el33",
              "el34"
            ]
          }
        },
        "output": [
          "el11 el21 el31",
          "el12 el22 el32",
          "el13 el23 el33",
          "el14 el24 el34"
        ]
      }
    ],
    "identifier": 51735996
  },
  {
    "context": [
      "I'm using `jq` to catch the \"VpcId\" if .Tags[].Value==Product-Production but no matter what I try, I can't get the right syntax, how can it be achieved?",
      "jq '.Vpcs[] | select( .Tags[].Value| contains(\"Product-Production\")) | .VpcId'"
    ],
    "utterance": "Retrieve the VpcId for any VPC where any tag's Value is 'Product-Production'.",
    "expressions": [
      ".Vpcs[] | select(.Tags[].Value | contains(\"Product-Production\")) | .VpcId"
    ],
    "data": [
      {
        "input": {
          "Vpcs": [
            {
              "VpcId": "vpc-1f0e197d",
              "InstanceTenancy": "default",
              "Tags": [
                {
                  "Value": "Product-Production",
                  "Key": "Name"
                }
              ],
              "CidrBlockAssociationSet": [
                {
                  "AssociationId": "vpc-cidr-assoc-f3c5509a",
                  "CidrBlock": "172.19.0.0/16",
                  "CidrBlockState": {
                    "State": "associated"
                  }
                }
              ],
              "State": "available",
              "DhcpOptionsId": "dopt-37fd5550",
              "CidrBlock": "172.19.0.0/16",
              "IsDefault": false
            },
            {
              "VpcId": "vpc-xxxxxxx",
              "InstanceTenancy": "default",
              "Tags": [
                {
                  "Value": "Other",
                  "Key": "Name"
                }
              ]
            }
          ]
        },
        "output": "vpc-1f0e197d"
      }
    ],
    "identifier": 51703572
  },
  {
    "context": [
      "The end result I am looking for is something that looks like this (with or without the new encapsulating [] (preferably without) but each row being on the same line.. and as a bonus would be a unique line identifier.",
      "The raw being something like the following:",
      "The output being currently with my existing command string (minus the @csv) like:",
      "To add line-numbers, the following helper function would be a good way to go:",
      "def tocsv(s):\n  foreach s as $line (0; .+1; [.] + $line)\n  | map(tostring) # for robustness\n  | @csv ;",
      "And then:",
      "tocsv(inputs\n      | [.timestamp, .level, .message]\n        + ( .result | [.TransactionID, .TimeStamp, .Status] ))",
      "This assumes your jq has `inputs` and that you include `-n` as a command-line option."
    ],
    "utterance": "Produce one line of CSV per log entry, including timestamp, level, message, TransactionID, TimeStamp, Status fields, and a unique line number.",
    "expressions": [
      "def tocsv(s): foreach s as $line (0; .+1; [.] + $line) | map(tostring) | @csv; tocsv(inputs | [.timestamp, .level, .message] + (.result | [.TransactionID, .TimeStamp, .Status]))"
    ],
    "data": [
      {
        "input": {
          "result": {
            "TransactionID": "ac710dc0-8aa4-11e8-a08c-0d98209bb4f5",
            "TimeStamp": "2018-07-18T12:07:33.082-04:00",
            "SourceSystem": "SOUP",
            "Status": "Accepted"
          },
          "level": "info",
          "message": "SOAP createServiceRequest ack recieved & is successful.",
          "timestamp": "2018-07-18T16:07:33.047Z"
        },
        "output": "\"0\",\"2018-07-18T16:07:33.047Z\",\"info\",\"SOAP createServiceRequest ack recieved & is successful.\",\"ac710dc0-8aa4-11e8-a08c-0d98209bb4f5\",\"2018-07-18T12:07:33.082-04:00\",\"Accepted\""
      }
    ],
    "identifier": 51729347
  },
  {
    "context": [
      "the same example, except using \"name\" instead of \"key\" does not:",
      "$ echo '[{\"name\":\"a\", \"value\":1}, {\"name\":\"b\", \"value\":2}]' | jq from_entries",
      "jq: error (at <stdin>:1): Cannot use null (null) as object key",
      "you will either have to upgrade your jq, or use a workaround, such as:",
      "map(with_entries(if .key == \"name\" then .key = \"key\" else . end)) | from_entries",
      "or more generically:",
      "def from_entries(key; value):\n  map( {(key): value} ) | add | . // {} ;\n \nfrom_entries(.name; .value)"
    ],
    "utterance": "Convert an array of objects with 'name' and 'value' fields into an object mapping each name to its value.",
    "expressions": [
      "map({ (.name): .value }) | add",
      "def from_entries(key; value): map({ (.[key]): .[value] }) | add | . // {};\nfrom_entries(\"name\"; \"value\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "a",
            "value": 1
          },
          {
            "name": "b",
            "value": 2
          }
        ],
        "output": {
          "a": 1,
          "b": 2
        }
      }
    ],
    "identifier": 51757559
  },
  {
    "context": [
      "`jq '.fieldOne |= . * 3 | .fieldTwo |= . * 3 | ...'`",
      "`jq '(.fieldOne | .fieldTwo | ...) |= . * 3'`",
      "Thanks to the magic of jq, you could just write: (.fieldOne, .fieldTwo) |= .*3",
      "multiop([\"fieldOne\", \"fieldTwo\"]; . * 3)"
    ],
    "utterance": "Multiply the values of both 'fieldOne' and 'fieldTwo' by 3 in a single operation.",
    "expressions": [
      "(.fieldOne, .fieldTwo) |= .*3",
      "def multiop($fields; f): if $fields|length == 0 then . else .[$fields[0]] |= f | multiop($fields[1:]; f) end; multiop([\"fieldOne\", \"fieldTwo\"]; . * 3)"
    ],
    "identifier": 51787648
  },
  {
    "context": [
      "I am attempting to call just \"com:Status\" and \"com:TransactionID\" but it either gives me a syntax error (INVALID_CHARACTER) or turns out no data \"null\" with everything I have tried.",
      "The following at least doesn't error, but it doesn't output the values, just \"NULL\" for the two elements containing the \":\" in their name..",
      "But what I need is: \n\n   \"Response\",\"5e5b1750-7be7-11e8-886a-838029aca397\",\"Success\""
    ],
    "utterance": "Extract the values of the keys 'com:TransactionID' and 'com:Status' from the 'Header' object of 'UpdateResponseMessage', returning them in an array with the string 'Response' as the first element.",
    "expressions": [
      ".UpdateResponseMessage.Header | [\"Response\", .[\"com:TransactionID\"], .[\"com:Status\"]]"
    ],
    "data": [
      {
        "input": {
          "UpdateResponseMessage": {
            "Header": {
              "com:TransactionID": "5e5b1750-7be7-11e8-886a-838029aca397",
              "com:TimeStamp": "2018-06-29T21:57:08.549Z",
              "com:SourceSystem": "Call",
              "com:Status": "Success"
            }
          },
          "level": "info",
          "message": "UpdateResponseMessage being sent.",
          "timestamp": "2018-06-29T21:57:08.549Z"
        },
        "output": [
          "Response",
          "5e5b1750-7be7-11e8-886a-838029aca397",
          "Success"
        ]
      }
    ],
    "identifier": 51760871
  },
  {
    "context": [
      "When a \"filename\" value occurs just once in the document, the \"type\" value will only depend on the \"dir\" value: \"dir\" == \"foo\" --> \"type\" = 0 and \"dir\" == \"bar\" --> \"type\" = 1",
      "When a \"filename\" value exists both in \"foo\" and also in \"bar\" directories, \"type\" must have value == 2, like here:",
      "The \"dir\" value will always be limited to the two possible alternatives of \"foo\" or \"bar\" values and will never be null.",
      "jq ' ([.[] | { (.filename): {(.dir): true} }] | reduce .[] as $item ({}; . * $item)) as $seen |\nmap(\n  if $seen[.filename][\"foo\"] and $seen[.filename][\"bar\"] then\n    .type = 2\n  elif $seen[.filename][\"bar\"] then\n    .type = 1\n  else\n    .type = 0\n  end\n) '",
      "[group_by(.filename)[]\n | (map(.dir) \n    | unique\n    | if length>1 then length\n      elif .[0] == \"foo\" then 0\n      elif .[0] == \"bar\" then 1\n      else .[0]          # just in case\n      end) as $type\n    | (.[] + {type: $type} ) ]",
      "(reduce .[] as $x ({}; .[$x.filename] += [$x.dir])\n | map_values(unique)) as $dirs\n| map( $dirs[.filename] as $d\n       | .type |= if $d|length > 1 then 2\n                  elif $d[0] == \"bar\" then 1\n                  else 0\n                  end)"
    ],
    "utterance": "For each object, set the value of \"type\" to 2 if its filename is present in both \"foo\" and \"bar\" directories, else to 0 if the dir is \"foo\" or 1 if the dir is \"bar\".",
    "expressions": [
      "([.[] | { (.filename): {(.dir): true} }] | reduce .[] as $item ({}; . * $item)) as $seen |\nmap(\n  if $seen[.filename][\"foo\"] and $seen[.filename][\"bar\"] then\n    .type = 2\n  elif $seen[.filename][\"bar\"] then\n    .type = 1\n  else\n    .type = 0\n  end\n)",
      "[group_by(.filename)[]\n | (map(.dir) \n    | unique\n    | if length>1 then length\n      elif .[0] == \"foo\" then 0\n      elif .[0] == \"bar\" then 1\n      else .[0]\n      end) as $type\n    | (.[] + {type: $type} ) ]",
      "(reduce .[] as $x ({}; .[$x.filename] += [$x.dir])\n | map_values(unique)) as $dirs\n| map( $dirs[.filename] as $d\n       | .type |= if $d|length > 1 then 2\n                  elif $d[0] == \"bar\" then 1\n                  else 0\n                  end)"
    ],
    "data": [
      {
        "input": [
          {
            "filename": "a",
            "dir": "foo",
            "type": "unknown"
          },
          {
            "filename": "b",
            "dir": "foo",
            "type": "unknown"
          },
          {
            "filename": "c",
            "dir": "bar",
            "type": "unknown"
          },
          {
            "filename": "a",
            "dir": "bar",
            "type": "unknown"
          }
        ],
        "output": [
          {
            "filename": "a",
            "dir": "foo",
            "type": 2
          },
          {
            "filename": "b",
            "dir": "foo",
            "type": 0
          },
          {
            "filename": "c",
            "dir": "bar",
            "type": 1
          },
          {
            "filename": "a",
            "dir": "bar",
            "type": 2
          }
        ]
      }
    ],
    "identifier": 51684565
  },
  {
    "context": [
      "I have an array which has a nested array, say tagNames, I want to select all item which tagNames contains \"auto-test\" exactly, not \"auto-test2\".",
      "So far, I am using\n\n    jq  '[ .servers[] | select(.tagNames | contains([\"auto-test\"])) ]'\n\nI got two records, but I just want the first one.",
      "So I want this:\n\n    [\n      {\n        \"id\": 1,\n        \"tagNames\": [\n          \"auto-test\",\n          \"xxx\"\n        ]\n      }\n    ]",
      "You shouldn't use `contains/1` as it will not work the way you might expect it, particularly if you're dealing with strings.",
      "You'll want to write out your conditions checking any and all tags against your criteria.",
      "[.servers[] | select(any(.tagNames[]; . == \"auto-test\") and all(.tagNames[]; . != \"auto-test2\"))]",
      "One way would be to use `index/1`, e.g.\n\n    .servers[]\n    | select( .tagNames | index(\"auto-test\"))",
      "This produces:\n\n    {\"id\":1,\"tagNames\":[\"auto-test\",\"xxx\"]}",
      "If you want that wrapped in an array, you could (for example) wrap the filter above in square brackets.",
      "jq '.servers[] | first(select(.tagNames[]==\"auto-test\"))' file"
    ],
    "utterance": "Select all items where tagNames contains the value auto-test exactly, not auto-test2.",
    "expressions": [
      "[.servers[] | select(any(.tagNames[]; . == \"auto-test\") and all(.tagNames[]; . != \"auto-test2\"))]",
      "[.servers[] | select(.tagNames | index(\"auto-test\"))]",
      "[.servers[] | select(.tagNames[] == \"auto-test\")]"
    ],
    "data": [
      {
        "input": {
          "servers": [
            {
              "id": 1,
              "tagNames": [
                "auto-test",
                "xxx"
              ]
            },
            {
              "id": 2,
              "tagNames": [
                "auto-test2",
                "xxxx"
              ]
            }
          ]
        },
        "output": [
          {
            "id": 1,
            "tagNames": [
              "auto-test",
              "xxx"
            ]
          }
        ]
      }
    ],
    "identifier": 51783807
  },
  {
    "context": [
      "I'm trying to create a json file from a string with the following format:\r\n\r\n    string=\"key1=value1,key2=value2\"\r\n\r\nIs there a way to create a json using jq by specifying the `=` and `,` symbols as separators for the keys and values?",
      "The output I'm looking for would be:\r\n\r\n    {\"key1\": \"value1\", \"key2\u201d :\u201dvalue2\"}",
      "jq -Rc '\r\nsplit(\",\")\r\n| [.[] | match( \"([^=]*)=(.*)\" )]\r\n| reduce .[].captures as $item ({}; .[$item[0].string]=$item[1].string)\r\n' <<<\"$string\"",
      "jq -R 'split(\",\")\r\n       | map( index(\"=\") as $i | {(.[0:$i]) : .[$i+1:]})\r\n       | add' <<< \"$string\"",
      "echo -n \"key1=value1,key2=value2\" | \\\r\njq -csR '[split(\",\")[]|split(\"=\") | {(.[0]): .[1]}]|add'"
    ],
    "utterance": "Convert a string formatted as key1=value1,key2=value2 into an object mapping each key to its value, using ',' as a pair separator and '=' as a key-value separator.",
    "expressions": [
      "jq -Rc 'split(\",\") | [.[] | match(\"([^=]*)=(.*)\")] | reduce .[].captures as $item ({}; .[$item[0].string]=$item[1].string)' <<< \"$string\"",
      "jq -R 'split(\",\") | map(index(\"=\") as $i | {(.[0:$i]) : .[$i+1:]}) | add' <<< \"$string\"",
      "jq -csR '[split(\",\")[]|split(\"=\") | {(.[0]): .[1]}]|add'"
    ],
    "data": [
      {
        "input": "key1=value1,key2=value2",
        "output": {
          "key1": "value1",
          "key2": "value2"
        }
      }
    ],
    "identifier": 51793855
  },
  {
    "context": [
      "I have the following json\n\n    {\n        \"version\" : \"0.1.2\",\n        \"basePath\" : \"/\"\n    }\n\nand the desired output is \n\n    {\n        \"version\" : \"0.1.2\",\n        \"basePath\" : \"beta1\"\n    }",
      "Is there a way to assign the string to the `basePath` key?",
      "Good news! Your proposed solution is just missing a pair of parentheses.  Also, there is no need for `$version`.  That is, this will do it:\n\n    .basePath = (.version | split(\".\")\n                 | if .[0] == \"0\" then \"beta\"+ .[1] else .[0] end)"
    ],
    "utterance": "Set the 'basePath' key to 'beta' plus the second part of 'version' if the first part is '0', otherwise set it to the first part.",
    "expressions": [
      ".basePath = (.version | split(\".\") | if .[0] == \"0\" then \"beta\" + .[1] else .[0] end)"
    ],
    "data": [
      {
        "input": {
          "version": "0.1.2",
          "basePath": "/"
        },
        "output": {
          "version": "0.1.2",
          "basePath": "beta1"
        }
      }
    ],
    "identifier": 51837624
  },
  {
    "context": [
      "I want to get the 'RQBTYFE86MFC3oL' value by doing a query for 'Nightmode'.",
      "jq '.[] | select(.name == \"Nightmode\")'",
      "A simple way to determine the key name(s) corresponding to values satisfying a certain condition is to use `to_entries`, as explained in the jq manual.",
      "to_entries[] | select(.value.name == \"Nightmode\") | .key",
      "with the result:\n\n    \"RQBTYFE86MFC3oL\""
    ],
    "utterance": "Find the key whose associated object has a 'name' field equal to 'Nightmode'.",
    "expressions": [
      "to_entries[] | select(.value.name == \"Nightmode\") | .key"
    ],
    "data": [
      {
        "input": {
          "RQBTYFE86MFC3oL": {
            "name": "Nightmode",
            "lights": [
              "1",
              "2",
              "3",
              "4",
              "5",
              "7",
              "8",
              "9",
              "10",
              "11"
            ],
            "owner": "kvovodUUfn2vlby9h9okdDhv8SrTzkBFjk6kPz2v",
            "recycle": false,
            "locked": false,
            "appdata": {
              "version": 1,
              "data": "QSXCj_r01_d99"
            },
            "picture": "",
            "lastupdated": "2018-08-08T03:21:39",
            "version": 2
          }
        },
        "output": "RQBTYFE86MFC3oL"
      }
    ],
    "identifier": 51796573
  },
  {
    "context": [
      "I have some JSON input looks like:",
      "I'd like to use jq to convert it into something like:",
      "All you need is a nested `to_entries[]` transformation and build the JSON on top of it.",
      "jq '[ to_entries[] |           { \"name\": .key,             \"count\": [ .value | to_entries[] | { \"type\": .key, \"number\": .value } ]          }        ]' json"
    ],
    "utterance": "Transform a mapping of names to type-number pairs into an array where each item has the name and a list of type-number objects.",
    "expressions": [
      "[ to_entries[] | { \"name\": .key, \"count\": [ .value | to_entries[] | { \"type\": .key, \"number\": .value } ] } ]"
    ],
    "data": [
      {
        "input": {
          "name1": {
            "type1": 1,
            "type2": 2
          },
          "name2": {
            "type2": 3,
            "type3": 4
          }
        },
        "output": [
          {
            "name": "name1",
            "count": [
              {
                "type": "type1",
                "number": 1
              },
              {
                "type": "type2",
                "number": 2
              }
            ]
          },
          {
            "name": "name2",
            "count": [
              {
                "type": "type2",
                "number": 3
              },
              {
                "type": "type3",
                "number": 4
              }
            ]
          }
        ]
      }
    ],
    "identifier": 51840448
  },
  {
    "context": [
      "I am currently trying to use jq to do this, but I'm having issues getting it to output the result to a file using pretty printing.",
      "When I tried using the output to directly write to a file (instead of first storing it in environment variables), the file was overwritten with a blank file:",
      "jq 'del(.definitions.foo)' ./src.swagger.json > ./src.swagger.json",
      "Yes - you cannot reliably use shell redirection to read and write the same file in the way you are expecting.  That's just the way things are :-(",
      "One way is to use `sponge`.  (On a Mac, you could install it using `brew install moreutils`.)"
    ],
    "utterance": "Remove the key .definitions.foo and write the formatted result to the same file, preserving pretty printing.",
    "expressions": [
      "jq 'del(.definitions.foo)' src.swagger.json | sponge src.swagger.json"
    ],
    "identifier": 51853509
  },
  {
    "identifier": 51887566
  },
  {
    "context": [
      "Currently, I manage to get the values by [.[keys[] | select(contains(\"VMIMAGE\"))]] but the key names, i.e. CP-COMPUTEENGINE-VMIMAGE-F1-MICRO aren't present in the result. How do I get it?",
      "Using your query as a model, this can most easily be accomplished using a query of the form with_entries( select(...) ), e.g.:",
      ".gcp_price_list | with_entries( select(.key|contains(\"VMIMAGE\")))"
    ],
    "utterance": "Return all key-value pairs whose key contains 'VMIMAGE', preserving the original keys in the result.",
    "expressions": [
      ".gcp_price_list | with_entries(select(.key | contains(\"VMIMAGE\")))"
    ],
    "identifier": 51869431
  },
  {
    "context": [
      "Given:\r\n \r\n       [{\r\n        \"customer.name\":\"malinda\",\r\n        \"customer.details\":\"test123\"\r\n        }]",
      "Using jq, get the value of \"customer.name\".",
      "echo '[{ \"customer.name\":\"malinda\", \"customer.details\":\"test123\" }]' | \r\n  jq '.[].\"customer.name\"'",
      "echo '[{ \"customer.name\":\"malinda\", \"customer.details\":\"test123\" }]' |\r\n  jq -r '.[].\"customer.name\"'",
      "Since the dot `.` is neither alphanumeric nor an underscore, you need to quote the key name."
    ],
    "utterance": "Retrieve the value of the key named 'customer.name' from an array of objects where key names contain dots.",
    "expressions": [
      ".[].\"customer.name\""
    ],
    "data": [
      {
        "input": [
          {
            "customer.name": "malinda",
            "customer.details": "test123"
          }
        ],
        "output": [
          "malinda"
        ]
      }
    ],
    "identifier": 51873886
  },
  {
    "context": [
      "I manage to get the list of keys, but can't make it a list to pass into `unique`.",
      "I'd like to get a list of zone names, i.e.\n\n    \"asia\"\n    \"asia-east\"\n    \"asia-northeast\"\n    \"asia-south1\"\n    \"asia-southeast\"\n    \"australia\"\n    \"australia-southeast1\"",
      "An only-jq solution:\n\n    .gcp_price_list\n    | del(.sustained_use_base,.sustained_use_tiers)\n    | [.[] | keys_unsorted[]]\n    | unique[]",
      "cat data.json \\\n| jq '.gcp_price_list | del(.sustained_use_base,.sustained_use_tiers) | .[] | keys[]' \\\n| uniq"
    ],
    "utterance": "List all unique zone names found as object keys within each entry of gcp_price_list, ignoring keys like 'cores', 'memory', and excluding 'sustained_use_base' and 'sustained_use_tiers'.",
    "expressions": [
      ".gcp_price_list | del(.sustained_use_base,.sustained_use_tiers) | [.[] | keys_unsorted[]] | unique[]",
      ".gcp_price_list | del(.sustained_use_base,.sustained_use_tiers) | .[] | keys[] | unique"
    ],
    "identifier": 51854685
  },
  {
    "context": [
      "I have a json file with key and the value is a json with key value pair. I would like to filter and extract the key based on the inner key value pair.",
      "Example json data:",
      "{\n    \"key1\": {\n      \"filterkey\": \"filtervalue\",\n      \"key1\": \"value1\"\n    },\n    \"key2\": {\n      \"key1\": \"value1\",\n      \"key2\": \"value2\"\n    }\n}",
      "Filter: \"filterkey\": \"filtervalue\"",
      "expected output: \"key1\"",
      "to_entries[]\n| if .value.filterkey == \"filtervalue\" then .key else empty end",
      "to_entries[]\n| select(.value.filterkey == \"filtervalue\" )\n| .key"
    ],
    "utterance": "Return the top-level key whose value contains the pair filterkey equal to filtervalue.",
    "expressions": [
      "to_entries[] | select(.value.filterkey == \"filtervalue\") | .key",
      "to_entries[] | if .value.filterkey == \"filtervalue\" then .key else empty end"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "filterkey": "filtervalue",
            "key1": "value1"
          },
          "key2": {
            "key1": "value1",
            "key2": "value2"
          }
        },
        "output": "key1"
      }
    ],
    "identifier": 51853545
  },
  {
    "context": [
      "What I want to do is to have a loop going to parse the below json, and poll the individual user data (agentId, agentName, agentState, and agentState Duration based on each id) to InfluxDB using the bottom curls.",
      "Save the data below as the following variables:\n\n    jsonAgentId=\"id\"\n    jsonAgentName=\"agentName\"\n    jsonAgentState=\"agentState\"\n    jsonAgentStateDuration=\"agentStateDuration\"",
      "You could extract the wanted field using `jq` and assign values to `bash` variables:\n\n    <file jq -r '.VoiceCSQDetailsStats | [ .agentId,.agentName,.agentState,.agentStateDuration ] | @tsv' \\\n    | while IFS=$'\\t' read jsonAgentId jsonAgentName jsonAgentState jsonAgentStateDuration; do\n        echo -e \"jsonAgentId=${jsonAgentId}\\njsonAgentName=${jsonAgentName}\\njsonAgentState=${jsonAgentState}\\njsonAgentStateDuration=${jsonAgentStateDuration}\\n\";\n    done",
      "Starting Simple: Just get an object with the data you want\n\n```\n$ jq -c '.VoiceCSQDetailsStats | { id: .agentId, name: .agentName, state: .agentState, stateDuration: .agentStateDuration } | select(.id and .name and .state and .stateDuration)' < eptesicus.json\n{\"id\":\"muser\",\"name\":\"My User\",\"state\":\"Not Ready\",\"stateDuration\":982761}\n{\"id\":\"yuser\",\"name\":\"Your User\",\"state\":\"Talking\",\"stateDuration\":626160}\n{\"id\":\"euser\",\"name\":\"Everyones User\",\"state\":\"Ready\",\"stateDuration\":203631}\n{\"id\":\"duser\",\"name\":\"Dumb User\",\"state\":\"Not Ready\",\"stateDuration\":175342}\n{\"id\":\"fuser\",\"name\":\"Foolish User\",\"state\":\"Not Ready\",\"stateDuration\":1057520}\n{\"id\":\"druser\",\"name\":\"Drug User\",\"state\":\"Talking ( from CSQ: NOCHelpdesk )\",\"stateDuration\":167914}\n```"
    ],
    "utterance": "Extract agentId, agentName, agentState, and agentStateDuration for each user in the array as tab-separated values.",
    "expressions": [
      ".VoiceCSQDetailsStats | [ .agentId, .agentName, .agentState, .agentStateDuration ] | @tsv",
      ".VoiceCSQDetailsStats | { id: .agentId, name: .agentName, state: .agentState, stateDuration: .agentStateDuration } | select(.id and .name and .state and .stateDuration)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "muser",
            "operation": "UPDATE",
            "VoiceCSQDetailsStats": {
              "agentId": "muser",
              "agentName": "My User",
              "agentState": "Not Ready",
              "skillGroup": "",
              "agentStateDuration": 982761,
              "reason": "Break",
              "AgentVoiceCSQNames": [
                {
                  "agentVoiceCSQName": "Dispatcher"
                },
                {
                  "agentVoiceCSQName": "NOCEscalation"
                },
                {
                  "agentVoiceCSQName": "NOCHelpdesk"
                }
              ]
            }
          },
          {
            "id": "yuser",
            "operation": "UPDATE",
            "VoiceCSQDetailsStats": {
              "agentId": "yuser",
              "agentName": "Your User",
              "agentState": "Talking",
              "skillGroup": "",
              "agentStateDuration": 626160,
              "reason": "",
              "AgentVoiceCSQNames": [
                {
                  "agentVoiceCSQName": "Dispatcher"
                },
                {
                  "agentVoiceCSQName": "NOCHelpdesk"
                }
              ]
            }
          }
        ],
        "output": [
          "muser\tMy User\tNot Ready\t982761",
          "yuser\tYour User\tTalking\t626160"
        ]
      }
    ],
    "identifier": 51732540
  },
  {
    "context": [
      "I would like to have as result: \r\n\r\n    \"TRANSLATION1\" = \"text1\";\r\n    \"TRANSLATION2\" = \"text2\";\r\n    \"TRANSLATION3.SUBTRANS1\" = \"subtranslation1\";\r\n    \"TRANSLATION3.SUBTRANS2\" = \"subtranslation2\";",
      "One approach would be to use `tostream`:\r\n\r\n    tostream\r\n    | select(length==2)\r\n    | (.[0] | join(\".\")) as $k\r\n    | .[1] as $v\r\n    | \"\\\"\\($k)\\\" = \\\"\\($v)\\\";\"",
      "If your jq does not have `tostream`\r\n\r\n    paths as $path\r\n    | getpath($path) \r\n    | strings\r\n    | \"\\\"\\($path|join(\".\"))\\\" = \\\"\\(.)\\\";\""
    ],
    "utterance": "Flatten a nested object to produce lines in the format \"KEY1.KEY2\" = \"value\"; for each string value, where the path is joined by periods.",
    "expressions": [
      "tostream | select(length==2) | (.[0] | join(\".\")) as $k | .[1] as $v | \"\\\"\\($k)\\\" = \\\"\\($v)\\\";\"",
      "paths as $path | getpath($path) | strings | \"\\\"\\($path|join(\".\"))\\\" = \\\"\\(.)\\\";\""
    ],
    "data": [
      {
        "input": {
          "TRANSLATION1": "text1",
          "TRANSLATION2": "text2",
          "TRANSLATION3": {
            "SUBTRANS1": "subtranslation1",
            "SUBTRANS2": "subtranslation2"
          }
        },
        "output": [
          "\"TRANSLATION1\" = \"text1\";",
          "\"TRANSLATION2\" = \"text2\";",
          "\"TRANSLATION3.SUBTRANS1\" = \"subtranslation1\";",
          "\"TRANSLATION3.SUBTRANS2\" = \"subtranslation2\";"
        ]
      }
    ],
    "identifier": 51924988
  },
  {
    "context": [
      "I would like to use `jq` first to get the values sorted in descending order of length:",
      "Then I would like to use `jq` again to swap properties for values _(it can drop duplicate properties, that's okay):",
      "[.[]] | sort_by(length) | reverse[]",
      "with_entries(.key as $k | .key=.value | .value=$k )",
      "to_entries\n| map(.key as $k | .key=.value | .value=$k )\n| sort_by(.key|length)\n| reverse\n| from_entries"
    ],
    "utterance": "Produce an array of all property values sorted by descending length, and swap the keys and values in the object so values become keys and keys become values.",
    "expressions": [
      "[.[]] | sort_by(length) | reverse[]",
      "with_entries(.key as $k | .key=.value | .value=$k )",
      "to_entries | map(.key as $k | .key=.value | .value=$k ) | sort_by(.key|length) | reverse | from_entries"
    ],
    "data": [
      {
        "input": {
          "root_path": "/www",
          "core_path": "/www/wp",
          "content_path": "/www/content",
          "vendor_path": "/www/vendor"
        },
        "output": [
          "/www/content",
          "/www/vendor",
          "/www/wp",
          "/www"
        ]
      },
      {
        "input": {
          "root_path": "/www",
          "core_path": "/www/wp",
          "content_path": "/www/content",
          "vendor_path": "/www/vendor"
        },
        "output": {
          "/www": "root_path",
          "/www/wp": "core_path",
          "/www/content": "content_path",
          "/www/vendor": "vendor_path"
        }
      }
    ],
    "identifier": 51914316
  },
  {
    "context": [
      "if I gave an argument of `commercial` I'd like it to return:\n\n    commercial-team@domain.com\n\n    commercial-updates@domain.com",
      "jq --arg key commercial '.[$key].google_groups | .[] | .[1]' file",
      "Use `jq -r` to output in \"raw\" format (lose the double quotes).",
      "jq -r --arg key \"$key\" '.[$key].google_groups | .[] | .[1]' file",
      "If, on the other hand, `commercial` was just a fixed string, then you could simplify:\n\n    jq -r '.commercial.google_groups | .[] | .[1]' file",
      "jq -r --arg key \"$key\" '.[$key].google_groups[][] | select(test(\"@\"))' department_groups.json"
    ],
    "utterance": "List all email addresses for the google_groups of the commercial department.",
    "expressions": [
      ".commercial.google_groups | .[] | .[1]",
      ".[$key].google_groups | .[] | .[1]",
      ".[$key].google_groups[][] | select(test(\"@\"))"
    ],
    "data": [
      {
        "input": {
          "legal": {
            "google_groups": [
              [
                "Legal",
                "legal@domain.com"
              ],
              [
                "Legal Team",
                "legal-team@domain.com"
              ],
              [
                "Compliance Checks",
                "compliance@domain.com"
              ]
            ],
            "samba_groups": ""
          },
          "commercial": {
            "google_groups": [
              [
                "Commercial Team",
                "commercial-team@domain.com"
              ],
              [
                "Commercial Updates",
                "commercial-updates@domain.com"
              ]
            ],
            "samba_groups": ""
          },
          "technology": {
            "google_groups": [
              [
                "Technology",
                "technology@domain.com"
              ],
              [
                "Incidents",
                "incidents@domain.com"
              ]
            ],
            "samba_groups": ""
          }
        },
        "output": [
          "commercial-team@domain.com",
          "commercial-updates@domain.com"
        ]
      }
    ],
    "identifier": 51943101
  },
  {
    "context": [
      "jq --arg text \"$<file.html>\" '.content.text=$text' file.json >newfile.json",
      "jq --slurpfile texts <(jq -Rs file.html) '.content.text=$texts[0]' file.json >newfile.json",
      ".content.text=($text | @html)"
    ],
    "utterance": "Insert the contents of an HTML file into the content.text field of a file, optionally escaping for HTML entities.",
    "expressions": [
      ".content.text = $text",
      ".content.text = ($text | @html)",
      ".content.text = $texts[0]"
    ],
    "data": [
      {
        "input": {
          "entityType": "document",
          "content": {
            "type": "text/html",
            "text": "ENCODED HTML FILE CONTENT AS A STRING"
          },
          "type": "document",
          "subject": "Document Title",
          "visibility": "place",
          "parent": "https://<URL>/api/core/v3/places/1579"
        },
        "output": {
          "entityType": "document",
          "content": {
            "type": "text/html",
            "text": "<html lang=\"en\">\n<body>\n<h1 id=\"example\">Sample file</h1>\n    <p>Sample text</p>\n<table>\n    <thead>\n        <tr class=\"header\">\n\n    etc."
          },
          "type": "document",
          "subject": "Document Title",
          "visibility": "place",
          "parent": "https://<URL>/api/core/v3/places/1579"
        }
      }
    ],
    "identifier": 51953147
  },
  {
    "context": [
      "What I want is \r\n\r\n`\"\\\"ebsvolume\\\";,\\\"gtest\\\";,\\\"vol-999999999999\\\";,\\\"g-test-acct\\\";,\\\"12345678912\\\";,\\\"ap-southeast-2c\\\";,\\\"ap-southeast-2\\\";,998.56,167.7,0,\\\"2018-08-16T22:00:00Z\\\";,\\\"io1\\\";,\\\"in-use\\\";,180,2000,500,\\\"2018-08-08T22:00:00Z\\\";,\\\"i-086f957ee\\\";,\n\\\"Rightsize\\\";,\n\\\"Rightsize\\\";,\n\\\"Rightsize\\\";\"`\r\n\r\nSo not entirely sure how to deal with the array inside the \"recommendations\" section in jq, I think it might be called unflattening?",
      "You can try this:\r\n\r\n    jq '.result[] | [ flatten[] | try(.action) // . ] | @csv' file\r\n    \"\\\"ebsvolume\\\";,\\\"gtest\\\";,\\\"vol-999999999999\\\";,\\\"g-test-acct\\\";,\\\"12345678912\\\";,\\\"ap-southeast-2c\\\";,\\\"ap-southeast-2\\\";,998.56,167.7,0,\\\"2018-08-16T22:00:00Z\\\";,\\\"io1\\\";,\\\"in-use\\\";,180,2000,500,\\\"2018-08-08T22:00:00Z\\\";,\\\"i-086f957ee\\\";,\n\\\"Rightsize\\\";,\n\\\"Rightsize\\\";,\n\\\"Rightsize\\\";\""
    ],
    "utterance": "Output each element's fields, followed by each recommendation's action, all as a single CSV row with recommendations in separate fields.",
    "expressions": [
      ".result[] | [ flatten[] | try(.action) // . ] | @csv"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "service": "ebsvolume",
              "name": "gtest",
              "resourceIdentifier": "vol-999999999999",
              "accountName": "g-test-acct",
              "vendorAccountId": "12345678912",
              "availabilityZone": "ap-southeast-2c",
              "region": "ap-southeast-2",
              "effectiveHourly": 998.56,
              "totalSpend": 167.7,
              "idle": 0,
              "lastSeen": "2018-08-16T22:00:00Z",
              "volumeType": "io1",
              "state": "in-use",
              "volumeSize": 180,
              "iops": 2000,
              "throughput": 500,
              "lastAttachedTime": "2018-08-08T22:00:00Z",
              "lastAttachedId": "i-086f957ee",
              "recommendations": [
                {
                  "action": "Rightsize",
                  "preferenceOrder": 2,
                  "risk": 0,
                  "savingsPct": 91,
                  "savings": 189.05,
                  "volumeType": "gp2",
                  "volumeSize": 120
                },
                {
                  "action": "Rightsize",
                  "preferenceOrder": 4,
                  "risk": 0,
                  "savingsPct": 97,
                  "savings": 166.23,
                  "volumeType": "gp2",
                  "volumeSize": 167
                },
                {
                  "action": "Rightsize",
                  "preferenceOrder": 6,
                  "risk": 0,
                  "savingsPct": 91,
                  "savings": 111.77,
                  "volumeType": "gp2",
                  "volumeSize": 169
                }
              ]
            }
          ]
        },
        "output": "\"ebsvolume\",\"gtest\",\"vol-999999999999\",\"g-test-acct\",\"12345678912\",\"ap-southeast-2c\",\"ap-southeast-2\",998.56,167.7,0,\"2018-08-16T22:00:00Z\",\"io1\",\"in-use\",180,2000,500,\"2018-08-08T22:00:00Z\",\"i-086f957ee\",\"Rightsize\",\"Rightsize\",\"Rightsize\""
      }
    ],
    "identifier": 51944541
  },
  {
    "context": [
      "I wanted to use jq to go through the file and create a new file every 100000 records.",
      "$ jq -nc --stream 'fromstream(1|truncate_stream(inputs))' large_file.json |",
      "split -dl 100000 -additional-suffix=.json - part"
    ],
    "utterance": "Split a file containing about 2.1 million records into multiple files, each holding 100000 records.",
    "expressions": [
      "jq -nc --stream 'fromstream(1|truncate_stream(inputs))' large_file.json | split -dl 100000 -additional-suffix=.json - part"
    ],
    "identifier": 51956550
  },
  {
    "context": [
      "i want to figure out how to do it with jq when i have array in my tsv:",
      "name    age    pets\nTim    15    cats,dogs\nJoe    11    rabbits,birds",
      "ideal JSON:",
      "[\n {\n  name: \"Tim\",\n  age: \"15\",\n  pet:[\"cats\",\"dogs\"]\n },\n  name: \"Joe\",\n  age: \"11\",\n  pet:[\"rabbits\",\"birds\"]\n }, ...\n]",
      "cat file.tsv | jq -s  --slurp --raw-input --raw-output 'split(\"\\n\") | .[1:-1] | map(split(\"\\t\")) |\n        map({\"name\": .[0],\n             \"age\": .[1],\n             \"pet\": .[2]})'",
      "and the output the the above command is:",
      "{\n name: \"Tim\",\n age: \"15\",\n pet:\"cats,dogs\"\n},\n name: \"Joe\",\n age: \"11\",\n pet:\"rabbits,birds\"\n}",
      "Like this:",
      "jq -rRs 'split(\"\\n\")[1:-1] |\n         map([split(\"\\t\")[]|split(\",\")] | {\n                 \"name\":.[0],\n                 \"age\":.[1],\n                 \"pet\":.[2]\n             }\n    )' input.tsv",
      "In case the name includes any commas, I'd go with the following, which also avoids having to \"slurp\" the input:",
      "inputs\n| split(\"\\t\")\n| {name: .[0], age: .[1], pet: .[2]}\n| .pet |= split(\",\")",
      "To skip the header, simply invoke jq with the -R option, e.g. like this:",
      "jq -R -f program.jq input.tsv"
    ],
    "utterance": "Convert TSV data where one column contains comma-separated lists into an array of objects, with the list column parsed as an actual array of strings.",
    "expressions": [
      "jq -rRs 'split(\"\\n\")[1:-1] |\n         map(split(\"\\t\")) |\n         map({\"name\": .[0], \"age\": .[1], \"pet\": (.[2]|split(\",\")) })' input.tsv",
      "[inputs | split(\"\\t\") | {name: .[0], age: .[1], pet: (.[2] | split(\",\")) } ]"
    ],
    "data": [
      {
        "input": "name\tage\tpets\nTim\t15\tcats,dogs\nJoe\t11\trabbits,birds\n",
        "output": [
          {
            "name": "Tim",
            "age": "15",
            "pet": [
              "cats",
              "dogs"
            ]
          },
          {
            "name": "Joe",
            "age": "11",
            "pet": [
              "rabbits",
              "birds"
            ]
          }
        ]
      }
    ],
    "identifier": 51929141
  },
  {
    "context": [
      "How can we convert the file like the following?",
      "You can use the `jq`'s [`walk()`](https://stedolan.github.io/jq/manual/#walk(f)) builtin to recursively walk the JSON values, check their [`type`](https://stedolan.github.io/jq/manual/#type)s and convert the numbers [`tostring()`](https://stedolan.github.io/jq/manual/#tostring).",
      "jq 'walk(if type == \"number\" then tostring else . end)' input.json",
      "jq 'include \"./builtin\"; walk(if type == \"number\" then tostring else . end)' input.json > output.json"
    ],
    "utterance": "Convert all integer values in a data structure to strings, while leaving non-integer attributes unchanged.",
    "expressions": [
      "walk(if type == \"number\" then tostring else . end)",
      "include \"./builtin\"; walk(if type == \"number\" then tostring else . end)"
    ],
    "data": [
      {
        "input": {
          "name": [
            "James",
            "Alek",
            "Bob"
          ],
          "age": [
            35,
            25,
            23
          ]
        },
        "output": {
          "name": [
            "James",
            "Alek",
            "Bob"
          ],
          "age": [
            "35",
            "25",
            "23"
          ]
        }
      }
    ],
    "identifier": 51965607
  },
  {
    "context": [
      "I have json code and need to filter it by the value of the attribute *DNSName*. The filter must be case insensitive.",
      "I now want some bash code to filter this result for the record with the DNSName property value *MY-LB2-9876556789.us-west-2.elb.amazonaws.com*, and need the entire LoadBalancer object back as a result.",
      "Update:\r\nThis solution works, but is not case insensitive:\r\n\r\n    aws elbv2 describe-load-balancers --region=us-west-2 | jq -c '.LoadBalancers[] | select(.DNSName | contains(\"MY-LB2\"))'",
      "Update:\r\nThis solution seems to work even better:\r\n\r\n    aws elbv2 describe-load-balancers --region=us-west-2 | jq -c '.LoadBalancers[] | select(.DNSName | match(\"my-lb2\";\"i\"))'",
      "You probably should be using `test/2` rather than `match/2`, but in either case, since the problem description calls for\r\ncase-insensitive equality, you would use an anchored regex:\r\n\r\n    .LoadBalancers[]\r\n    | select(.DNSName | test(\"^my-lb2-9876556789.us-west-2.elb.amazonaws.com$\";\"i\"))",
      "With the caveat that `ascii_upcase` only translates ASCII characters, it might be more efficient to use it:\r\n \r\n     .LoadBalancers[]\r\n     | select(.DNSName | ascii_upcase == \"MY-LB2-9876556789.US-WEST-2.ELB.AMAZONAWS.COM\")"
    ],
    "utterance": "Return the LoadBalancer object whose DNSName equals MY-LB2-9876556789.us-west-2.elb.amazonaws.com, ignoring case.",
    "expressions": [
      ".LoadBalancers[] | select(.DNSName | test(\"^my-lb2-9876556789.us-west-2.elb.amazonaws.com$\"; \"i\"))",
      ".LoadBalancers[] | select(.DNSName | ascii_upcase == \"MY-LB2-9876556789.US-WEST-2.ELB.AMAZONAWS.COM\")"
    ],
    "data": [
      {
        "input": {
          "LoadBalancers": [
            {
              "IpAddressType": "ipv4",
              "VpcId": "vpc-abcdabcd",
              "LoadBalancerArn": "arn:aws:elasticloadbalancing:us-west-2:000000000000:loadbalancer/app/MY-LB1/a00000000000000a",
              "State": {
                "Code": "active"
              },
              "DNSName": "MY-LB1-123454321.us-west-2.elb.amazonaws.com",
              "SecurityGroups": [
                "sg-00100100",
                "sg-01001000",
                "sg-10010001"
              ],
              "LoadBalancerName": "MY-LB1",
              "CreatedTime": "2018-01-01T00:00:00.000Z",
              "Scheme": "internet-facing",
              "Type": "application",
              "CanonicalHostedZoneId": "ZZZZZZZZZZZZZ",
              "AvailabilityZones": [
                {
                  "SubnetId": "subnet-17171717",
                  "ZoneName": "us-west-2a"
                },
                {
                  "SubnetId": "subnet-27272727",
                  "ZoneName": "us-west-2c"
                },
                {
                  "SubnetId": "subnet-37373737",
                  "ZoneName": "us-west-2b"
                }
              ]
            },
            {
              "IpAddressType": "ipv4",
              "VpcId": "vpc-abcdabcd",
              "LoadBalancerArn": "arn:aws:elasticloadbalancing:us-west-2:000000000000:loadbalancer/app/MY-LB2/b00000000000000b",
              "State": {
                "Code": "active"
              },
              "DNSName": "MY-LB2-9876556789.us-west-2.elb.amazonaws.com",
              "SecurityGroups": [
                "sg-88818881"
              ],
              "LoadBalancerName": "MY-LB2",
              "CreatedTime": "2018-01-01T00:00:00.000Z",
              "Scheme": "internet-facing",
              "Type": "application",
              "CanonicalHostedZoneId": "ZZZZZZZZZZZZZ",
              "AvailabilityZones": [
                {
                  "SubnetId": "subnet-54545454",
                  "ZoneName": "us-west-2a"
                },
                {
                  "SubnetId": "subnet-64646464",
                  "ZoneName": "us-west-2c"
                },
                {
                  "SubnetId": "subnet-74747474",
                  "ZoneName": "us-west-2b"
                }
              ]
            }
          ]
        },
        "output": {
          "IpAddressType": "ipv4",
          "VpcId": "vpc-abcdabcd",
          "LoadBalancerArn": "arn:aws:elasticloadbalancing:us-west-2:000000000000:loadbalancer/app/MY-LB2/b00000000000000b",
          "State": {
            "Code": "active"
          },
          "DNSName": "MY-LB2-9876556789.us-west-2.elb.amazonaws.com",
          "SecurityGroups": [
            "sg-88818881"
          ],
          "LoadBalancerName": "MY-LB2",
          "CreatedTime": "2018-01-01T00:00:00.000Z",
          "Scheme": "internet-facing",
          "Type": "application",
          "CanonicalHostedZoneId": "ZZZZZZZZZZZZZ",
          "AvailabilityZones": [
            {
              "SubnetId": "subnet-54545454",
              "ZoneName": "us-west-2a"
            },
            {
              "SubnetId": "subnet-64646464",
              "ZoneName": "us-west-2c"
            },
            {
              "SubnetId": "subnet-74747474",
              "ZoneName": "us-west-2b"
            }
          ]
        }
      }
    ],
    "identifier": 51718102
  },
  {
    "context": [
      "I want to get all top-level attribute keys returned which are either `restricted == false` or don't have the `restricted` subattribute.",
      "`jq \"to_entries[] | select(.value.restricted|not) | .key\"`",
      "If a string array is desired as result... then the following expression can be used:\r\n\r\n    jq \"to_entries | map(select(.value.restricted|not).key)\""
    ],
    "utterance": "Return all top-level keys whose value either does not contain the subattribute 'restricted' or where 'restricted' is false.",
    "expressions": [
      "to_entries[] | select(.value.restricted|not) | .key",
      "to_entries | map(select(.value.restricted|not).key)"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "restricted": true
          },
          "bar": {
            "restricted": false
          },
          "baz": {}
        },
        "output": [
          "bar",
          "baz"
        ]
      }
    ],
    "identifier": 51968246
  },
  {
    "context": [
      "I need those individual objects returned as elements of an array.",
      ".[] | select(.Key == \"app\"), select(.Key == \"app_env\"), select(.Key == \"sbu\")",
      "[.[] | select(.Key == \"app\" or .Key == \"app_env\" or .Key == \"sbu\")]",
      "map(select(.Key == \"app\" or .Key == \"app_env\" or .Key == \"sbu\"))",
      "map(select(.Key == (\"app\", \"app_env\", \"sbu\")))"
    ],
    "utterance": "Return an array of all objects where Key is either \"app\", \"app_env\", or \"sbu\".",
    "expressions": [
      "[.[] | select(.Key == \"app\" or .Key == \"app_env\" or .Key == \"sbu\")]",
      "map(select(.Key == \"app\" or .Key == \"app_env\" or .Key == \"sbu\"))",
      "map(select(.Key == (\"app\", \"app_env\", \"sbu\")))"
    ],
    "data": [
      {
        "input": [
          {
            "Key": "base_ami",
            "Value": "ami-46d003ac"
          },
          {
            "Key": "app",
            "Value": "amibuild"
          },
          {
            "Key": "sbu",
            "Value": "IT"
          },
          {
            "Key": "base_ami_image_location",
            "Value": "123456789012/amazon-linux"
          },
          {
            "Key": "app_env",
            "Value": "dev"
          },
          {
            "Key": "Name",
            "Value": "amazon-linux"
          },
          {
            "Key": "jenkins_build_id",
            "Value": "24"
          },
          {
            "Key": "os_type",
            "Value": "linux"
          },
          {
            "Key": "version",
            "Value": "1.0.24"
          }
        ],
        "output": [
          {
            "Key": "app",
            "Value": "amibuild"
          },
          {
            "Key": "sbu",
            "Value": "IT"
          },
          {
            "Key": "app_env",
            "Value": "dev"
          }
        ]
      }
    ],
    "identifier": 51970546
  },
  {
    "context": [
      "I have got as far as this so far but can't get it over the line:",
      "jq -c '.mappings = (.mappings[] | [.])' mappings.json |",
      "I'd recommend printing the id on one line, and the corresponding object on the next. For example:",
      "jq -c '.mappings[] | .id, .' mappings.json |"
    ],
    "utterance": "Extract each object from the top-level array and output its id and full object on consecutive lines.",
    "expressions": [
      ".mappings[] | .id, .",
      "jq -c '.mappings[] | .id, .' mappings.json"
    ],
    "data": [
      {
        "input": {
          "mappings": [
            {
              "id": "bcf3559f-7ff7-406b-a4f1-6d3e9ac00e63",
              "name": "Hellow world 2",
              "request": {
                "url": "/hello-world-2",
                "method": "POST"
              },
              "response": {
                "status": 200,
                "body": "\nBody content for stub 3\n\n",
                "headers": {}
              },
              "uuid": "bcf3559f-7ff7-406b-a4f1-6d3e9ac00e63",
              "persistent": true,
              "priority": 5
            },
            {
              "id": "9086b24f-4f5e-465a-bbe5-73bbfb82cd5c",
              "name": "Hello world",
              "request": {
                "url": "/hello-world",
                "method": "ANY"
              },
              "response": {
                "status": 200,
                "body": "Hi!"
              },
              "uuid": "9086b24f-4f5e-465a-bbe5-73bbfb82cd5c"
            }
          ]
        },
        "output": [
          "bcf3559f-7ff7-406b-a4f1-6d3e9ac00e63",
          {
            "id": "bcf3559f-7ff7-406b-a4f1-6d3e9ac00e63",
            "name": "Hellow world 2",
            "request": {
              "url": "/hello-world-2",
              "method": "POST"
            },
            "response": {
              "status": 200,
              "body": "\nBody content for stub 3\n\n",
              "headers": {}
            },
            "uuid": "bcf3559f-7ff7-406b-a4f1-6d3e9ac00e63",
            "persistent": true,
            "priority": 5
          },
          "9086b24f-4f5e-465a-bbe5-73bbfb82cd5c",
          {
            "id": "9086b24f-4f5e-465a-bbe5-73bbfb82cd5c",
            "name": "Hello world",
            "request": {
              "url": "/hello-world",
              "method": "ANY"
            },
            "response": {
              "status": 200,
              "body": "Hi!"
            },
            "uuid": "9086b24f-4f5e-465a-bbe5-73bbfb82cd5c"
          }
        ]
      }
    ],
    "identifier": 51970861
  },
  {
    "context": [
      "There are coordinates within an array that are divided up between multiple GeoJSON `MultiLineString` structures. I would like to consolidate all the coordinates, maintaining them in their own array, under one single MultiLineString structure. How do i do this with `jq` ?",
      "The key to a simple solution is to recognize that the combined \"coordinates\" array can be computed by the filter:\r\n\r\n    [.features[] | .geometry | .coordinates[]] \r\n",
      "Let&#39;s call this array `$combined`.  A solution can then be obtained by updating `.features`, like so:\r\n\r\n    .features = [.features[0] | (.geometry.coordinates = $combined)]\r\n",
      "A complete solution is thus:\r\n\r\n    [.features[].geometry.coordinates[]] as $combined\r\n    | .features = [.features[0] | (.geometry.coordinates = $combined)]\r\n",
      "This can be further simplified using the `|=` operator:\r\n\r\n    [.features[].geometry.coordinates[]] as $combined\r\n    | .features |= [.[0] | (.geometry.coordinates = $combined)]"
    ],
    "utterance": "Consolidate all coordinates arrays from multiple MultiLineString features under a single MultiLineString feature, preserving each line as an individual array.",
    "expressions": [
      "[.features[].geometry.coordinates[]] as $combined | .features = [.features[0] | (.geometry.coordinates = $combined)]",
      "[.features[].geometry.coordinates[]] as $combined | .features |= [.[0] | (.geometry.coordinates = $combined)]"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "crs": {
            "type": "name",
            "properties": {
              "name": "urn:ogc:def:crs:OGC:1.3:CRS84"
            }
          },
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiLineString",
                "coordinates": [
                  [
                    [
                      -82.61915267041314,
                      29.568340757283536,
                      0.0
                    ],
                    [
                      -82.61914718819897,
                      29.568355832670516,
                      0.0
                    ],
                    [
                      -82.60755897501859,
                      29.58029920482901,
                      0.0
                    ]
                  ]
                ]
              }
            },
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiLineString",
                "coordinates": [
                  [
                    [
                      -82.61915267041351,
                      29.568340757283536,
                      0.0
                    ],
                    [
                      -82.61949068348949,
                      29.568318912277654,
                      0.0
                    ],
                    [
                      -82.62934868863105,
                      29.569000553128618,
                      0.0
                    ]
                  ]
                ]
              }
            },
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiLineString",
                "coordinates": [
                  [
                    [
                      -82.62934868863105,
                      29.569000553128618,
                      0.0
                    ],
                    [
                      -82.62943243076478,
                      29.568922074598046,
                      0.0
                    ],
                    [
                      -82.62306516791354,
                      29.56611193045412,
                      0.0
                    ]
                  ]
                ]
              }
            },
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiLineString",
                "coordinates": [
                  [
                    [
                      -82.61803992319366,
                      29.56365743690482,
                      0.0
                    ],
                    [
                      -82.6183061118613,
                      29.56533602800019,
                      0.0
                    ],
                    [
                      -82.61915267041367,
                      29.56834075728364,
                      0.0
                    ]
                  ]
                ]
              }
            },
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiLineString",
                "coordinates": [
                  [
                    [
                      -82.62306516791385,
                      29.566111930454156,
                      0.0
                    ],
                    [
                      -82.61875885644903,
                      29.563742939021793,
                      0.0
                    ],
                    [
                      -82.61821286221002,
                      29.563577318475456,
                      0.0
                    ]
                  ]
                ]
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "crs": {
            "type": "name",
            "properties": {
              "name": "urn:ogc:def:crs:OGC:1.3:CRS84"
            }
          },
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiLineString",
                "coordinates": [
                  [
                    [
                      -82.61915267041314,
                      29.568340757283536,
                      0.0
                    ],
                    [
                      -82.61914718819897,
                      29.568355832670516,
                      0.0
                    ],
                    [
                      -82.60755897501859,
                      29.58029920482901,
                      0.0
                    ]
                  ],
                  [
                    [
                      -82.61915267041351,
                      29.568340757283536,
                      0.0
                    ],
                    [
                      -82.61949068348949,
                      29.568318912277654,
                      0.0
                    ],
                    [
                      -82.62934868863105,
                      29.569000553128618,
                      0.0
                    ]
                  ],
                  [
                    [
                      -82.62934868863105,
                      29.569000553128618,
                      0.0
                    ],
                    [
                      -82.62943243076478,
                      29.568922074598046,
                      0.0
                    ],
                    [
                      -82.62306516791354,
                      29.56611193045412,
                      0.0
                    ]
                  ],
                  [
                    [
                      -82.61803992319366,
                      29.56365743690482,
                      0.0
                    ],
                    [
                      -82.6183061118613,
                      29.56533602800019,
                      0.0
                    ],
                    [
                      -82.61915267041367,
                      29.56834075728364,
                      0.0
                    ]
                  ],
                  [
                    [
                      -82.62306516791385,
                      29.566111930454156,
                      0.0
                    ],
                    [
                      -82.61875885644903,
                      29.563742939021793,
                      0.0
                    ],
                    [
                      -82.61821286221002,
                      29.563577318475456,
                      0.0
                    ]
                  ]
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 51951847
  },
  {
    "context": [
      "# This line (for the Bash variable) doesn\u2019t...see end of question for result:",
      "jq --arg variable \"$subject\" '.subject=$variable' file.json > file-1.json",
      "The result is that `content.text` is populated, while `subject` is printed literally as the variable I attempted to code.",
      "{  \"content\": {    \"text\": \"Is populated; works great\"  },  \"subject\": \"$subject\",}",
      "You can call file-a.sh with an argument:",
      "./file-a.sh \"This is my subject\"",
      "and within file-a.sh you can access the argument as:",
      "jq --arg variable \"$1\" '.subject=$variable' file.json > file-1.json"
    ],
    "utterance": "Set the subject field to the value of a Bash variable in the JSON data.",
    "expressions": [
      "jq --arg variable \"$subject\" '.subject=$variable' file.json > file-1.json",
      "jq --arg variable \"$1\" '.subject=$variable' file.json > file-1.json"
    ],
    "data": [
      {
        "input": {
          "content": {
            "text": "Is populated; works great"
          },
          "subject": ""
        },
        "output": {
          "content": {
            "text": "Is populated; works great"
          },
          "subject": "abc"
        }
      }
    ],
    "identifier": 52012535
  },
  {
    "context": [
      "And I have some number `X`, let's say 5 in this case.",
      "I want to produce the following object in jq:\n\n    {\n      \"foo\": 2,\n      \"bar\": 2,\n      \"baz\": 1,\n    }",
      "This is the number 5 divided up equally across the elements of the array, with the remainder being distributed to the elements at the beginning of the ring.",
      "The following worked for me with passing `--argjson count $X` and feeding the array as my input.",
      "def ceil(v): -(-v | floor);",
      "def objectify(n): {key: .[0], value: ceil(($count - .[1])/n)};",
      "length as $n | [., keys] | [transpose[] | objectify($n)] | from_entries"
    ],
    "utterance": "Distribute the number 5 as evenly as possible among [\"foo\", \"bar\", \"baz\"], with the larger shares going to earlier elements if there is a remainder.",
    "expressions": [
      ". as $arr\n| length as $len\n| [\n    .[]\n    | . as $i\n    | {\n        ($i): (\n          if ($arr | index($i)) < ($x % $len) then\n            ($x / $len) + 1\n          else\n            $x / $len\n          end\n          | floor\n        )\n      }\n  ]\n| add",
      "def ceil(v): -(-v | floor);\ndef objectify(n): {key: .[0], value: ceil(($count - .[1])/n)};\nlength as $n | [., keys] | [transpose[] | objectify($n)] | from_entries"
    ],
    "data": [
      {
        "input": [
          "foo",
          "bar",
          "baz"
        ],
        "output": {
          "foo": 2,
          "bar": 2,
          "baz": 1
        }
      }
    ],
    "identifier": 51992570
  },
  {
    "context": [
      "Trying to get unique values stored in items array for each group. somehow it&#39;s always mixed...",
      "My JSON looks like this:",
      "Desired result is the following:",
      "{\r\n  \"id\": \"transmission\",\r\n  \"value\": [\r\n    \"manualni\",\r\n    \"automaticka\",\r\n  ]\r\n}\r\n{\r\n  \"id\": \"vat\",\r\n  \"value\": [\r\n    \"ne\",\r\n    \"ano\"\r\n  ]\r\n}",
      "Tried with this filter on command line:\r\n| jq '{id: .groups[].group, value: [.groups[].items[].item]}'",
      "Which results in the above mentioned mixed up result:",
      "{\r\n  \"id\": \"transmission\",\r\n  \"value\": [\r\n    \"manualni\",\r\n    \"automaticka\",\r\n    \"ne\",\r\n    \"ano\"\r\n  ]\r\n}\r\n{\r\n  \"id\": \"vat\",\r\n  \"value\": [\r\n    \"manualni\",\r\n    \"automaticka\",\r\n    \"ne\",\r\n    \"ano\"\r\n  ]\r\n}",
      "Any idea how to receive the uniquified values here? Thanks in advance!",
      "This gets the desired result.",
      "jq '.groups[] | {\"id\": .group, \"value\": [.items[].item]}'"
    ],
    "utterance": "For each group, extract its name and an array of all item names belonging only to that group.",
    "expressions": [
      ".groups[] | {\"id\": .group, \"value\": [.items[].item]}"
    ],
    "data": [
      {
        "input": {
          "start": 1534425916,
          "stop": 1535030716,
          "groups": [
            {
              "group": "transmission",
              "data": {
                "events": 665762
              },
              "items": [
                {
                  "item": "manualni",
                  "data": {
                    "events": 389158
                  }
                },
                {
                  "item": "automaticka",
                  "data": {
                    "events": 276604
                  }
                }
              ]
            },
            {
              "group": "vat",
              "data": {
                "events": 671924
              },
              "items": [
                {
                  "item": "ne",
                  "data": {
                    "events": 346221
                  }
                },
                {
                  "item": "ano",
                  "data": {
                    "events": 325703
                  }
                }
              ]
            }
          ]
        },
        "output": [
          {
            "id": "transmission",
            "value": [
              "manualni",
              "automaticka"
            ]
          },
          {
            "id": "vat",
            "value": [
              "ne",
              "ano"
            ]
          }
        ]
      }
    ],
    "identifier": 51987063
  },
  {
    "context": [
      "What I'd like do to is extract the whole object from that json that contain a key named \"time\" or \"*time*\". I've found solutions related, however they just brings the key and not the whole object.",
      "So, basically, I need to get not only the time key, i need to get the whole object that the key \"time\" belongs. (like the examples)",
      "Is there a way to do it?",
      "If your jq has `walk`, and if your computer has enough memory:\r\n\r\n    walk(if type == \"object\" \r\n         then if has(\"time\") then . else empty end\r\n         else . end )"
    ],
    "utterance": "Return all objects that have a key named \"time\", including the entire object content.",
    "expressions": [
      "walk(if type == \"object\" then if has(\"time\") then . else empty end else . end )"
    ],
    "data": [
      {
        "input": {
          "events": [
            {
              "time": -762,
              "type": "chatwheel",
              "key": "156",
              "slot": 1,
              "player_slot": 1
            },
            {
              "type": "nop",
              "slot": 2
            },
            {
              "time": 888,
              "type": "building_kill",
              "unit": "npc_knight",
              "key": "npc_goodguys_tower1",
              "slot": 7,
              "player_slot": 130
            },
            {
              "other": {
                "time": 681,
                "type": "obs_left_log",
                "key": "[132, 124]",
                "slot": 0,
                "x": 132,
                "y": 124,
                "z": 130,
                "entityleft": true,
                "ehandle": 5014545,
                "player_slot": 0
              }
            },
            {
              "purchase_log": [
                {
                  "time": -89,
                  "key": "orb_of_venom"
                },
                {
                  "time": -89,
                  "key": "tango"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "time": -762,
            "type": "chatwheel",
            "key": "156",
            "slot": 1,
            "player_slot": 1
          },
          {
            "time": 888,
            "type": "building_kill",
            "unit": "npc_knight",
            "key": "npc_goodguys_tower1",
            "slot": 7,
            "player_slot": 130
          },
          {
            "time": 681,
            "type": "obs_left_log",
            "key": "[132, 124]",
            "slot": 0,
            "x": 132,
            "y": 124,
            "z": 130,
            "entityleft": true,
            "ehandle": 5014545,
            "player_slot": 0
          },
          {
            "time": -89,
            "key": "orb_of_venom"
          },
          {
            "time": -89,
            "key": "tango"
          }
        ]
      }
    ],
    "identifier": 51991463
  },
  {
    "context": [
      "I want to extract the \"host\" and \"ip\" value and add them in a comma separated values file. Each record in a line as follows: \r\n\r\na.com,1.2.2.3\r\nb.com,2.5.0.4\r\nc.com,9.17.6.7",
      "cat test.json | jq -r '.[] | [.host, .ip] | @csv'",
      "$ cat test.json | jq -r '.[] | [ .host, .ip ] | @csv' | sed 's/\"//g'\r\na.com,1.2.2.3\r\nb.com,2.5.0.4\r\nc.com,9.17.6.7"
    ],
    "utterance": "Extract the values of 'host' and 'ip' from each entry and format them as comma-separated values, one pair per line.",
    "expressions": [
      ".[] | [.host, .ip] | @csv",
      ".[] | [ .host, .ip ] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "host": "a.com",
            "ip": "1.2.2.3",
            "port": 8,
            "name": "xyz"
          },
          {
            "host": "b.com",
            "ip": "2.5.0.4",
            "port": 3,
            "name": "xyz"
          },
          {
            "host": "c.com",
            "ip": "9.17.6.7",
            "port": 4,
            "name": "xyz"
          }
        ],
        "output": [
          "\"a.com\",\"1.2.2.3\"",
          "\"b.com\",\"2.5.0.4\"",
          "\"c.com\",\"9.17.6.7\""
        ]
      }
    ],
    "identifier": 52012899
  },
  {
    "context": [
      "I am trying to write a jq filter to give me the same schema output but with only a subset of the members array e.g. all the \"smith\"s",
      "jq '.members |= map(select(.ln == \"smith\"))'",
      "It updates .members, selecting only objects with .ln == smith"
    ],
    "utterance": "Select only the entries where the last name is smith from the members array, preserving the rest of the structure.",
    "expressions": [
      ".members |= map(select(.ln == \"smith\"))"
    ],
    "data": [
      {
        "input": {
          "base": "abc",
          "members": [
            {
              "fn": "maurice",
              "ln": "hickey"
            },
            {
              "fn": "john",
              "ln": "smith"
            },
            {
              "fn": "robin",
              "ln": "smith"
            }
          ],
          "date": "2018-08-26"
        },
        "output": {
          "base": "abc",
          "members": [
            {
              "fn": "john",
              "ln": "smith"
            },
            {
              "fn": "robin",
              "ln": "smith"
            }
          ],
          "date": "2018-08-26"
        }
      }
    ],
    "identifier": 52027546
  },
  {
    "context": [
      "So i wanted to add few line under *props* using following command but its getting failed :",
      "`sudo knife node edit  fqdn -c /etc/chef/client.rb |jq \u2018.props |= . + { \"ParameterKey\": \"Foo4\", \"ParameterValue\": \"Bar4\" }\u2019 `",
      "The `props` key is nested under `normal` so you would need `.normal.props` or similar."
    ],
    "utterance": "Add {\"ParameterKey\": \"Foo4\", \"ParameterValue\": \"Bar4\"} to the 'props' object located inside 'normal'.",
    "expressions": [
      ".normal.props |= . + { \"ParameterKey\": \"Foo4\", \"ParameterValue\": \"Bar4\" }"
    ],
    "data": [
      {
        "input": {
          "name": "test",
          "chef_environment": "standard_chef_environment",
          "normal": {
            "httpd": {
              "fips_mode_enable": "false"
            },
            "enable_fips_mode": false,
            "props": {}
          }
        },
        "output": {
          "name": "test",
          "chef_environment": "standard_chef_environment",
          "normal": {
            "httpd": {
              "fips_mode_enable": "false"
            },
            "enable_fips_mode": false,
            "props": {
              "ParameterKey": "Foo4",
              "ParameterValue": "Bar4"
            }
          }
        }
      }
    ],
    "identifier": 52020292
  },
  {
    "context": [
      "I have a script bash with JQ, but do not know how to perform the query to get the following result: \r\n\r\nconversationId(1),participantId(1),participantName(1),sessionId(1)\r\nconversationId(1),participantId(2),participantName(2),sessionId(2)\r\nconversationId(1),participantId(3),participantName(3),sessionId(3)\r\nconversationId(2),participantId(4),participantName(4),sessionId(4)\r\n.\r\n.\r\n.\r\nconversationId(n),participantId(n),participantName(n),sessionId(n)",
      "With your input, the following filter:\r\n \r\n\r\n    .conversations[]\r\n    | [.conversationId]\r\n      + (.participants[] | [.participantId, .participantName])\r\n\r\n\r\nproduces:\r\n\r\n    [\r\n      \"cxx-cccc-4444-9999-b11111111\",\r\n      \"2aaaa-1555-4590-99aa-4yyyyyyy\",\r\n      null\r\n    ]"
    ],
    "utterance": "Return each session as a row listing conversationId, participantId, participantName, and sessionId.",
    "expressions": [
      ".conversations[] | .participants[] | .sessions[] | [ .conversationId, .participantId, .participantName, .sessionId ]"
    ],
    "data": [
      {
        "input": {
          "conversations": [
            {
              "conversationId": "cxx-cccc-4444-9999-b11111111",
              "conversationStart": "2016-06-5T00:10:15.412Z",
              "conversationEnd": "2016-06-5T00:11:19.447Z",
              "participants": [
                {
                  "participantId": "2aaaa-1555-4590-99aa-4yyyyyyy",
                  "userId": "91111-7rrrr-4000-aqaa-23232323",
                  "purpose": "user",
                  "sessions": [
                    {
                      "mediaType": "voice",
                      "sessionId": "1111111-aaaa-4009-9000-488888",
                      "ani": "sip:user+localhost.com@localhost",
                      "direction": "outbound",
                      "dnis": "tel:+1111110000",
                      "edgeId": "e3e3e3-4\u00aa4q-4b4b-9792-95959595",
                      "segments": [
                        {
                          "segmentStart": "2016-06-15T00:10:15.412Z",
                          "segmentEnd": "2016-06-15T00:10:10.485Z",
                          "segmentType": "contacting",
                          "conference": false
                        },
                        {
                          "segmentStart": "2016-06-15T00:10:10.485Z",
                          "segmentEnd": "2016-06-15T00:10:10.522Z",
                          "segmentType": "dialing",
                          "conference": false
                        },
                        {
                          "segmentStart": "2016-06-15T00:20:10.522Z",
                          "segmentEnd": "2016-06-15T00:11:09.436Z",
                          "disconnectType": "client",
                          "segmentType": "interact",
                          "conference": false
                        }
                      ]
                    }
                  ]
                },
                {
                  "participantId": "e9e9e9-d777-4a4a-8989-aeaeaeaeae",
                  "participantName": "Namek, Sayayin",
                  "purpose": "ivr",
                  "sessions": [
                    {
                      "mediaType": "voice",
                      "sessionId": "262626-6000-4cdd-a511-fafafafa",
                      "ani": "sip:goku%localhost.com@localhost",
                      "direction": "inbound",
                      "edgeId": "e3e3e3e3-4abc-4abc-9700-95959595",
                      "remoteNameDisplayable": "Namek, Sayayin",
                      "segments": [
                        {
                          "segmentStart": "2016-06-15T00:10:10.510Z",
                          "segmentEnd": "2016-06-15T00:10:10.521Z",
                          "segmentType": "system",
                          "conference": false
                        },
                        {
                          "segmentStart": "2016-06-15T00:10:20.521Z",
                          "segmentEnd": "2016-06-15T00:11:39.447Z",
                          "disconnectType": "peer",
                          "segmentType": "ivr",
                          "conference": false
                        }
                      ]
                    }
                  ]
                }
              ]
            },
            {
              "conversationId": "09090909-6b60-8888-xxxx-9yyyyyyyy",
              "conversationStart": "2016-06-15T00:11:38.867Z",
              "conversationEnd": "2016-06-15T01:54:55.744Z",
              "participants": [
                {
                  "participantId": "xxxc-cccc1-4123-7777-343434343e",
                  "userId": "9qwer-7zxc-40df-aghj-2323232323",
                  "purpose": "user",
                  "sessions": [
                    {
                      "mediaType": "voice",
                      "sessionId": "101010-0faz-4xxx-yyyy-4419441",
                      "ani": "sip:goku+localhost.com@localhost",
                      "direction": "outbound",
                      "dnis": "tel:+11112222333",
                      "edgeId": "nenene1-qwer-tyui-9000-9595gggh",
                      "segments": [
                        {
                          "segmentStart": "2016-06-15T00:11:18.867Z",
                          "segmentEnd": "2016-06-15T00:11:42.637Z",
                          "segmentType": "contacting",
                          "conference": false
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          [
            "cxx-cccc-4444-9999-b11111111",
            "2aaaa-1555-4590-99aa-4yyyyyyy",
            null,
            "1111111-aaaa-4009-9000-488888"
          ],
          [
            "cxx-cccc-4444-9999-b11111111",
            "e9e9e9-d777-4a4a-8989-aeaeaeaeae",
            "Namek, Sayayin",
            "262626-6000-4cdd-a511-fafafafa"
          ],
          [
            "09090909-6b60-8888-xxxx-9yyyyyyyy",
            "xxxc-cccc1-4123-7777-343434343e",
            null,
            "101010-0faz-4xxx-yyyy-4419441"
          ]
        ]
      }
    ],
    "identifier": 51737608
  },
  {
    "context": [
      "I need the output in json, but grouped by floor, like this;",
      "So all floor1 rooms are in their own json grouping, then floor2 rooms etc.",
      "If you then run that script and pipe it into `jq` (where JQ is just used for pretty-printing the output on your screen ; it is not really required) you will see:",
      "$ python test.py | jq .",
      "{\n  \"floor1\": {\n    \"room2\": [\n      \"2people\"\n    ],\n    \"room3\": [\n      \"3people\"\n    ],\n    \"room1\": [\n      \"note1\",\n      \"note2\",\n      \"note3\"\n    ]\n  },\n  \"floor2\": {\n    \"room4\": [\n      \"6people\",\n      \"projector\"\n    ],\n    \"room5\": [\n      \"3people\",\n      \"projector\"\n    ]\n  },\n  \"floor3\": {\n    \"room6\": [\n      \"1person\"\n    ]\n  }\n}"
    ],
    "utterance": "Group the rooms by floor so that all rooms belonging to the same floor are together.",
    "expressions": [
      "."
    ],
    "data": [
      {
        "input": {
          "floor1": {
            "room2": [
              "2people"
            ],
            "room3": [
              "3people"
            ],
            "room1": [
              "note1",
              "note2",
              "note3"
            ]
          },
          "floor2": {
            "room4": [
              "6people",
              "projector"
            ],
            "room5": [
              "3people",
              "projector"
            ]
          },
          "floor3": {
            "room6": [
              "1person"
            ]
          }
        },
        "output": {
          "floor1": {
            "room2": [
              "2people"
            ],
            "room3": [
              "3people"
            ],
            "room1": [
              "note1",
              "note2",
              "note3"
            ]
          },
          "floor2": {
            "room4": [
              "6people",
              "projector"
            ],
            "room5": [
              "3people",
              "projector"
            ]
          },
          "floor3": {
            "room6": [
              "1person"
            ]
          }
        }
      }
    ],
    "identifier": 52016697
  },
  {
    "context": [
      "I want to produce output in the following format:\n\na.com,1.2.2.3,part1,part\nb.com,2.5.0.4,part1,par2\nc.com,9.17.6.7,part1,part2\n\nThe problem is the key `\"info`\" is a single key, but I want to divide two pieces of information separated by tab separately. How to do this?",
      "This is my jq command to parse the file:\n\n    cat input.json | jq -r '.[] | \"\\(.host),\\(.ip),\\(.info)\"' > result.txt",
      "I think `info` value is seperated by four-spaces, not by tabs because raw tab character is not allowed in JSON and jq raises an error when there is an invalid character in input. If I'm not wrong, this command should do what you want\n\n    jq -r '.[] | (.info | split(\"    \")[0:2] | join(\",\")) as $info | \"\\(.host),\\(.ip),\\($info)\"' input.json > result.txt"
    ],
    "utterance": "Extract the host, ip, and the first two space-separated sections from the info field as a comma-separated list for each element in the array.",
    "expressions": [
      ".[] | (.info | split(\"    \")[0:2] | join(\",\")) as $info | \"\\(.host),\\(.ip),\\($info)\""
    ],
    "data": [
      {
        "input": [
          {
            "host": "a.com",
            "ip": "1.2.2.3",
            "port": 8,
            "name": "xyz",
            "info": "part1    part2    part3    part4"
          },
          {
            "host": "b.com",
            "ip": "2.5.0.4",
            "port": 3,
            "name": "xyz",
            "info": "part1    part2    part3    part4"
          },
          {
            "host": "c.com",
            "ip": "9.17.6.7",
            "port": 4,
            "name": "xyz",
            "info": "part1    part2    part3    part4"
          }
        ],
        "output": [
          "a.com,1.2.2.3,part1,part2",
          "b.com,2.5.0.4,part1,part2",
          "c.com,9.17.6.7,part1,part2"
        ]
      }
    ],
    "identifier": 52015757
  },
  {
    "context": [
      "To be clear: it concerns a string translation like:\r\n\r\n    \"0x4162634b6c6d\" -> \"AbcKlm\"\r\n",
      "Then to use it, strip out any non-hex characters and pass the string in.\r\n\r\n    .[2:] | decode_hex\r\n",
      "def decode_hex:\r\n    (\"0123456789abcdef\"|split(\"\")|with_entries({key:.value, value:.key})) as $hex_map |\r\n    def decode_nybble: $hex_map[ascii_downcase];\r\n    def decode_byte: (.[0:1]|decode_nybble * 16) + (.[1:2]|decode_nybble);\r\n    def pairs: range(0;length;2) as $i | .[$i:$i+2];\r\n    [pairs|decode_byte] | implode;",
      ".[2:] | decode_hex"
    ],
    "utterance": "Convert a string like \"0x4162634b6c6d\" to its ASCII representation \"AbcKlm\", using a filter that strips the \"0x\" prefix and decodes each hex pair.",
    "expressions": [
      "def decode_hex:\n    (\"0123456789abcdef\"|split(\"\")|with_entries({key:.value, value:.key})) as $hex_map |\n    def decode_nybble: $hex_map[ascii_downcase];\n    def decode_byte: (.[0:1]|decode_nybble * 16) + (.[1:2]|decode_nybble);\n    def pairs: range(0;length;2) as $i | .[$i:$i+2];\n    [pairs|decode_byte] | implode;",
      ".[2:] | decode_hex"
    ],
    "data": [
      {
        "input": "0x4162634b6c6d",
        "output": "AbcKlm"
      }
    ],
    "identifier": 52024621
  },
  {
    "context": [
      "How do I use jq to convert that array of Key/Values into a single line like so:",
      "Key=role,Value=ui_tester Key=environment,Value=test_env Key=Name,Value=tester",
      "Use this for your jq filter:",
      "[.Tags[] | select(.Key | contains(\":aws:\") | not) | \"Key=\\(.Key),Value=\\(.Value)\"] | join(\" \")"
    ],
    "utterance": "Convert the array of tag objects, excluding those with ':aws:' in the Key, to a single space-separated line in the form Key=role,Value=ui_tester Key=environment,Value=test_env Key=Name,Value=tester.",
    "expressions": [
      "[.Tags[] | select(.Key | contains(\":aws:\") | not) | \"Key=\\(.Key),Value=\\(.Value)\"] | join(\" \")"
    ],
    "data": [
      {
        "input": [
          {
            "ResourceType": "instance",
            "ResourceId": "i-0f1da295d8343635b",
            "Value": "tester",
            "Key": "Name"
          },
          {
            "ResourceType": "instance",
            "ResourceId": "i-0f1da295d8343635b",
            "Value": "test_env",
            "Key": "environment"
          },
          {
            "ResourceType": "instance",
            "ResourceId": "i-0f1da295d8343635b",
            "Value": "ui_tester",
            "Key": "role"
          }
        ],
        "output": "Key=Name,Value=tester Key=environment,Value=test_env Key=role,Value=ui_tester"
      }
    ],
    "identifier": 52028615
  },
  {
    "context": [
      "if jq -e '.list | length == 0' >/dev/null; then \n   break\nfi <<< \"$contents\"",
      "### Empty page\n\n    {\n      \"itemsPerPage\" : 100,\n      \"list\" : [ ],\n      \"startIndex\" : 500\n    }"
    ],
    "utterance": "Check if the list array is empty and use that as a signal to stop processing further pages.",
    "expressions": [
      ".list | length == 0"
    ],
    "data": [
      {
        "input": {
          "itemsPerPage": 100,
          "list": [],
          "startIndex": 500
        },
        "output": true
      },
      {
        "input": {
          "itemsPerPage": 100,
          "links": {
            "next": "https://<url>/api/core/v3/places?sort=titleAsc&count=100&startIndex=200"
          },
          "list": [
            {
              "id": 1
            },
            {
              "id": 2
            }
          ]
        },
        "output": false
      }
    ],
    "identifier": 52087680
  },
  {
    "context": [
      "However, in a more generic script, I won't know the name of the broker (which is \"broker1\" here); is there some way I can wildcard the key like this: `\"org.apache.activemq.artemis:broker=\\\"*\\\"\"` ?",
      "The best way to match wildcards on key names is by using `with_entries` or `to_entries`.",
      ".value | to_entries[] | select(.key | test(\"^org.apache.activemq.artemis:broker=\\\".*\\\"\")) | .value"
    ],
    "utterance": "Retrieve all entries under .value with keys starting with 'org.apache.activemq.artemis:broker=\"', regardless of broker name.",
    "expressions": [
      ".value | to_entries[] | select(.key | test(\"^org.apache.activemq.artemis:broker=\\\\\".*\\\\\"\")) | .value"
    ],
    "identifier": 52093635
  },
  {
    "context": [
      "So it's going to list all the folders in `/reports/dt=2018-08-27` and get only `_stats.json` and pass that through `jq` from `hadoop -cat` and get only `.duration` from the json. Which in the end I get the result like this.\n\n    1211789 1211789 373585 495379 1211789\n\nBut I would like the command to sum all those numbers together to become `4504331`",
      "Another option (and one that works even if not all your durations are integers) is to make your `jq` code do the work:\n\n    jq -n '[inputs | .duration] | reduce .[] as $num (0; .+$num)' <<<\"$sample_data\"\n\n...properly emits as output:\n\n    4504331",
      "the simplest solution is the `add` filter:\n\n    jq '[.duration] | add'\n\nthe `[` brackets `]` are needed around the value to sum because `add` sums the values of an _array_, not a stream. (for stream summation, you would need a more sophisticated solution, e.g. using `reduce`, as detailed in other answers.)",
      "From a combination of other answers.\n\n```bash\n$ jq -n '[inputs | .duration] | add' <<< \"$sample_data\"\n\n# 4504331\n```"
    ],
    "utterance": "Sum all values of the 'duration' property extracted from multiple objects in a stream.",
    "expressions": [
      "[.duration] | add",
      "[inputs | .duration] | reduce .[] as $num (0; .+$num)",
      "[inputs | .duration] | add",
      "map(.duration) | add",
      "[.[].duration] | add"
    ],
    "data": [
      {
        "input": [
          {
            "duration": 1211789
          },
          {
            "duration": 1211789
          },
          {
            "duration": 373585
          },
          {
            "duration": 495379
          },
          {
            "duration": 1211789
          }
        ],
        "output": 4504331
      }
    ],
    "identifier": 52065570
  },
  {
    "context": [
      "json output",
      "[\n  {\n    \"nick\": \"alt\",\n    \"total\": \"53687091200\",\n    \"used\": \"7885201595\",\n    \"free\": \"45801889605\"\n  }\n]\n[\n  {\n    \"nick\": \"main\",\n    \"total\": \"214748364800\",\n    \"used\": \"87240914483\",\n    \"free\": \"127507450317\"\n  }\n]",
      "What should be",
      "[\n  {\n    \"nick\": \"alt\",\n    \"total\": \"53687091200\",\n    \"used\": \"7885201595\",\n    \"free\": \"45801889605\"\n  },\n  {\n    \"nick\": \"main\",\n    \"total\": \"214748364800\",\n    \"used\": \"87240914483\",\n    \"free\": \"127507450317\"\n  }\n]",
      "Needed to pipe the loop into jq",
      "done < .accounts  | jq --slurp --raw-input 'split(\"\\n\")[:-1] | map([ split(\" \")[] ]) | map({\n\tnick: .[6],\n\ttotal: .[1],\n\tused: .[3],\n\tfree: .[5]\n\t})'"
    ],
    "utterance": "Combine multiple individual arrays of account stats into a single array containing all objects.",
    "expressions": [
      "jq --slurp --raw-input 'split(\"\\n\")[:-1] | map([ split(\" \")[] ]) | map({nick: .[6], total: .[1], used: .[3], free: .[5]})'"
    ],
    "data": [
      {
        "input": "[\n  {\n    \"nick\": \"alt\",\n    \"total\": \"53687091200\",\n    \"used\": \"7885201595\",\n    \"free\": \"45801889605\"\n  }\n]\n[\n  {\n    \"nick\": \"main\",\n    \"total\": \"214748364800\",\n    \"used\": \"87240914483\",\n    \"free\": \"127507450317\"\n  }\n]",
        "output": [
          {
            "nick": "alt",
            "total": "53687091200",
            "used": "7885201595",
            "free": "45801889605"
          },
          {
            "nick": "main",
            "total": "214748364800",
            "used": "87240914483",
            "free": "127507450317"
          }
        ]
      }
    ],
    "identifier": 52087737
  },
  {
    "context": [
      "I would have thought I could use this command to get the CommandID string:\r\n\r\n    ... | jq -r '.Command[].CommandID'",
      "But that gives me this error:\r\n\r\n     jq: error (at <stdin>:33): Cannot index string with string \"CommandID\"",
      "The value of the `\"Command\"` key is not a list; it's simply another object that has `CommandID` as a key. You just want\r\n\r\n    ... | jq -r '.Command.CommandID'",
      "If you require the value of CommandId change your jq to 'jq .Command.CommandId'"
    ],
    "utterance": "Extract the value of CommandId from the Command object at the top level of the structure.",
    "expressions": [
      ".Command.CommandId",
      ".Command.CommandID"
    ],
    "data": [
      {
        "input": {
          "Command": {
            "CommandId": "7312718d-2327-43g4-bffc-093a0901a13c",
            "DocumentName": "AWS-RunPatchBaseline",
            "Comment": "",
            "ExpiresAfter": 1535382731.286,
            "Parameters": {
              "Operation": [
                "Install"
              ]
            },
            "InstanceIds": [
              "i-xxxxxxxxx"
            ],
            "Targets": [],
            "RequestedDateTime": 1535378531.286,
            "Status": "Pending",
            "StatusDetails": "Pending",
            "OutputS3BucketName": "ssm",
            "OutputS3KeyPrefix": "",
            "MaxConcurrency": "50",
            "MaxErrors": "1",
            "TargetCount": 1,
            "CompletedCount": 0,
            "ErrorCount": 0,
            "ServiceRole": "",
            "NotificationConfig": {
              "NotificationArn": "",
              "NotificationEvents": [],
              "NotificationType": ""
            }
          }
        },
        "output": "7312718d-2327-43g4-bffc-093a0901a13c"
      }
    ],
    "identifier": 52041260
  },
  {
    "context": [
      "I'm working on jq filtering and output of results to output into another program that accepts a JSON payload.",
      "The original JSON from AWS was an array of objects, why can't I get back a valid array of objects?",
      "You can wrap the entire jq expression into square brackets to make it collect the filter output into an array (documented in [Array construction section](https://stedolan.github.io/jq/manual/#Arrayconstruction:[])):",
      "'[ .Snapshots[] | select(.Description | contains(\"myorg-database-b\")) ]'",
      "results in:",
      "[",
      "  {",
      "    \"Description\": \"myorg-database-b redacted\",",
      "    \"Encrypted\": false,",
      "    \"VolumeId\": \"vol-23456\",",
      "    \"State\": \"completed\",",
      "    \"VolumeSize\": 500,",
      "    \"StartTime\": \"2018-08-28T19:01:18.000Z\",",
      "    \"Progress\": \"100%\",",
      "    \"OwnerId\": \"12345678\",",
      "    \"SnapshotId\": \"snap-5535\"",
      "  },",
      "  {",
      "    \"Description\": \"myorg-database-b redacted\",",
      "    \"Encrypted\": false,",
      "    \"VolumeId\": \"vol-23456\",",
      "    \"State\": \"completed\",",
      "    \"VolumeSize\": 500,",
      "    \"StartTime\": \"2018-08-28T19:01:18.000Z\",",
      "    \"Progress\": \"100%\",",
      "    \"OwnerId\": \"12345678\",",
      "    \"SnapshotId\": \"snap-5535\"",
      "  }",
      "]"
    ],
    "utterance": "Extract all objects from the Snapshots array where Description contains \"myorg-database-b\", and output them as a valid array suitable for programmatic consumption.",
    "expressions": [
      "[ .Snapshots[] | select(.Description | contains(\"myorg-database-b\")) ]"
    ],
    "data": [
      {
        "input": {
          "Snapshots": [
            {
              "Description": "myorg-database-b redacted",
              "Encrypted": false,
              "VolumeId": "vol-23456",
              "State": "completed",
              "VolumeSize": 500,
              "StartTime": "2018-08-28T19:01:18.000Z",
              "Progress": "100%",
              "OwnerId": "12345678",
              "SnapshotId": "snap-5535"
            },
            {
              "Description": "myorg-database-b redacted",
              "Encrypted": false,
              "VolumeId": "vol-23456",
              "State": "completed",
              "VolumeSize": 500,
              "StartTime": "2018-08-28T19:01:18.000Z",
              "Progress": "100%",
              "OwnerId": "12345678",
              "SnapshotId": "snap-5535"
            }
          ]
        },
        "output": [
          {
            "Description": "myorg-database-b redacted",
            "Encrypted": false,
            "VolumeId": "vol-23456",
            "State": "completed",
            "VolumeSize": 500,
            "StartTime": "2018-08-28T19:01:18.000Z",
            "Progress": "100%",
            "OwnerId": "12345678",
            "SnapshotId": "snap-5535"
          },
          {
            "Description": "myorg-database-b redacted",
            "Encrypted": false,
            "VolumeId": "vol-23456",
            "State": "completed",
            "VolumeSize": 500,
            "StartTime": "2018-08-28T19:01:18.000Z",
            "Progress": "100%",
            "OwnerId": "12345678",
            "SnapshotId": "snap-5535"
          }
        ]
      }
    ],
    "identifier": 52067816
  },
  {
    "context": [
      "how do i use a JQ query in curl to get the envname by passing 1111",
      "I'm assuming you mean to get all `EnvName` values that contains a certain value under `Stores`",
      ".EnvMappings[] | select(any(.Stores[]; . == \"1111\")).EnvName"
    ],
    "utterance": "Extract the EnvName for entries where the Stores array contains the value \"1111\".",
    "expressions": [
      ".EnvMappings[] | select(any(.Stores[]; . == \"1111\")).EnvName"
    ],
    "data": [
      {
        "input": {
          "EnvMappings": [
            {
              "EnvName": "lab",
              "Stores": [
                "1111",
                "2222"
              ]
            }
          ]
        },
        "output": "lab"
      }
    ],
    "identifier": 52154931
  },
  {
    "context": [
      "But I only want a subset of that JSON, so I used jq-1.5-1",
      "`mediainfo *.mp3 --output=JSON |  jq '. | {duration: .media.track[0].Duration, pubDate: .media.track[0].File_Modified_Date_Local, url: .media.\"@ref\"}'`",
      "Great, except there's no `,` between the elements, the whole lot isn't wrapped in [], and of course, while I can fudge that part, if I join the output, I get a trailing comma.",
      "What's the proper jq way of doing this, please?",
      "You can use the `--slurp` option:",
      "combined with a `map` to run your filter on each element of the array: `jq -s 'map({duration: .media.track[0].Duration, pubDate: .media.track[0].File_Modified_Date_Local, url: .media.\"@ref\"})'`",
      "Then the output will still be an array."
    ],
    "utterance": "Extract for each input file an array of objects containing only duration, pubDate, and url fields.",
    "expressions": [
      "jq -s 'map({duration: .media.track[0].Duration, pubDate: .media.track[0].File_Modified_Date_Local, url: .media.\"@ref\"})'"
    ],
    "data": [
      {
        "input": [
          {
            "media": {
              "@ref": "openingmusic.mp3",
              "track": [
                {
                  "@type": "General",
                  "Duration": "17.789",
                  "Encoded_Library": "LAME3.98r",
                  "File_Modified_Date_Local": "2020-01-01 10:00:00"
                },
                {
                  "@type": "Audio",
                  "Format": "MPEG Audio",
                  "Encoded_Library_Settings": "-m s -V 2 -q 3 -lowpass 18.6 --vbr-old -b 32"
                }
              ]
            }
          },
          {
            "media": {
              "@ref": "background.mp3",
              "track": [
                {
                  "@type": "General",
                  "Duration": "55.234",
                  "File_Modified_Date_Local": "2020-01-01 12:00:00"
                },
                {
                  "@type": "Audio"
                }
              ]
            }
          }
        ],
        "output": [
          {
            "duration": "17.789",
            "pubDate": "2020-01-01 10:00:00",
            "url": "openingmusic.mp3"
          },
          {
            "duration": "55.234",
            "pubDate": "2020-01-01 12:00:00",
            "url": "background.mp3"
          }
        ]
      }
    ],
    "identifier": 52118539
  },
  {
    "context": [
      "The value of `andres` in your json is an array of arrays, but you're accessing it as if it was an array of objects. You would have to flatten the arrays first (or index into) to access the objects. Then from those objects, you will want to map the values you want as csv as an array of values.",
      "$ jq -r '\n.andres[][] | [.id, .email, .username, .password, .name, .address, .ip_address, .phone] | @csv\n' < backup.json > backup.csv",
      "You may want to add some headers to your output as well.",
      "$ jq -r '\n[\"id\", \"email\", \"username\", \"password\", \"name\", \"address\", \"ip_address\", \"phone\"] as $headers\n    | $headers, (.andres[][] | [.[$headers[]]]) | @csv\n' < backup.json > backup.csv"
    ],
    "utterance": "Extract the fields id, email, username, password, name, address, ip_address, and phone from each object inside nested arrays under the andres key and output each as a CSV row, optionally including a header row.",
    "expressions": [
      ".andres[][] | [.id, .email, .username, .password, .name, .address, .ip_address, .phone] | @csv",
      "[\"id\", \"email\", \"username\", \"password\", \"name\", \"address\", \"ip_address\", \"phone\"] as $headers | $headers, (.andres[][] | [.[$headers[]]]) | @csv"
    ],
    "data": [
      {
        "input": {
          "andres": [
            [
              {
                "id": 1,
                "email": "email@email.com",
                "username": "test1",
                "password": "password",
                "name": "Dummy Account",
                "address": "123 st road",
                "ip_address": "0.0.0.0",
                "phone": "123-123-1234"
              },
              {
                "id": 2,
                "email": "email2@email.com",
                "username": "test2",
                "password": "password",
                "name": "Dummy Account",
                "address": "123 st road",
                "ip_address": "0.0.0.0",
                "phone": "123-123-1234"
              }
            ]
          ]
        },
        "output": [
          "1,\"email@email.com\",\"test1\",\"password\",\"Dummy Account\",\"123 st road\",\"0.0.0.0\",\"123-123-1234\"",
          "2,\"email2@email.com\",\"test2\",\"password\",\"Dummy Account\",\"123 st road\",\"0.0.0.0\",\"123-123-1234\""
        ]
      }
    ],
    "identifier": 52125879
  },
  {
    "context": [
      "I want to extract the objects as if by `.users[]`, but using the streaming parser (`jq --stream`). That is, I want my output to be as follows:\r\n\r\n    {\"ageRangeMin\":21,\"age_range\":{\"min\":21},\"gender\":\"male\"}\r\n\t{\"ageRangeMin\":22,\"age_range\":{\"min\":20},\"gender\":\"male\"}",
      "$ jq --stream -nc 'fromstream(2|truncate_stream(inputs | select(.[0][:1] == [\"users\"])))'",
      "$ jq -nc --stream '\r\n  fromstream(inputs|select(.[0][0] == \"users\"))|.[][]' input.json"
    ],
    "utterance": "Extract each object under the 'users' key as a separate output, using the streaming parser.",
    "expressions": [
      "jq --stream -nc 'fromstream(2|truncate_stream(inputs | select(.[0][:1] == [\"users\"])))'",
      "jq -nc --stream 'fromstream(inputs|select(.[0][0] == \"users\"))|.[][]'"
    ],
    "data": [
      {
        "input": {
          "userActivities": {
            "-L3ATRosRd-bDgSmX75Z": {
              "deviceId": "60ee32c2fae8dcf0",
              "dow": "Friday"
            }
          },
          "users": {
            "0GTDyAepIjcKMB1XulHCYLXylFS2": {
              "ageRangeMin": 21,
              "age_range": {
                "min": 21
              },
              "gender": "male"
            },
            "0GTDyAepIjcKMB1S2": {
              "ageRangeMin": 22,
              "age_range": {
                "min": 20
              },
              "gender": "male"
            }
          }
        },
        "output": [
          {
            "ageRangeMin": 21,
            "age_range": {
              "min": 21
            },
            "gender": "male"
          },
          {
            "ageRangeMin": 22,
            "age_range": {
              "min": 20
            },
            "gender": "male"
          }
        ]
      }
    ],
    "identifier": 52144470
  },
  {
    "context": [
      "Attempts to index with a variable:",
      ">txid=$(cat temp.json | jq 'keys' | jq .[1] | tr -d '\"')",
      ">cat temp.json | jq .$txid",
      "jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at <top-level>, line 1:",
      ".43906c7227610cd58a1c95714e4f79cd46e0d98ae3f4214f1b2cf325b628b70e",
      ">cat temp.json | jq '.$txid'",
      "jq: error: try .[\"field\"] instead of .field for unusually named fields at <top-level>, line 1:",
      "The desired output is simply",
      ">cat temp.json | jq '.'\"43906c7227610cd58a1c95714e4f79cd46e0d98ae3f4214f1b2cf325b628b70e\"''",
      "{",
      "        \"size\": 256,",
      "        \"fee\": 0.00008328,",
      "        \"modifiedfee\": 0.00008328,",
      "        \"time\": 1535906461,",
      "        \"height\": 539665",
      "      }",
      "If what you want is .\"xxx\" as argument, then use \".\\\"$txid\\\"\".",
      "If you drop the tr -d '\"', \".$txid\" may even be enough."
    ],
    "utterance": "Access an object property whose key is a string variable in the shell, where the key contains unusual or non-alphanumeric characters.",
    "expressions": [
      ".[\"$txid\"]",
      ".\"$txid\""
    ],
    "data": [
      {
        "input": {
          "bccc26321e360ae5fde94aac81eef7c7270bbfd90de0787d0e5b45be4b21ce53": {
            "size": 189,
            "fee": 6.78e-06,
            "modifiedfee": 6.78e-06,
            "time": 1535906461,
            "height": 539665
          },
          "43906c7227610cd58a1c95714e4f79cd46e0d98ae3f4214f1b2cf325b628b70e": {
            "size": 256,
            "fee": 8.328e-05,
            "modifiedfee": 8.328e-05,
            "time": 1535906461,
            "height": 539665
          }
        },
        "output": {
          "size": 256,
          "fee": 8.328e-05,
          "modifiedfee": 8.328e-05,
          "time": 1535906461,
          "height": 539665
        }
      }
    ],
    "identifier": 52139494
  },
  {
    "context": [
      "I want to put a filter on localDate i.e. select only those arrays where localDate = '2009-01-01'.",
      "Append this filter:",
      "select(.localDate == \"2009-01-01\")",
      "So your modified command becomes:",
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs | select(.[0][] == \"userActivities\") | del(.[0][0]))) | select(.localDate == \"2009-01-01\")'"
    ],
    "utterance": "Select objects where the field localDate equals '2009-01-01'.",
    "expressions": [
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs | select(.[0][] == \"userActivities\") | del(.[0][0]))) | select(.localDate == \"2009-01-01\")'"
    ],
    "data": [
      {
        "input": {
          "userActivities": {
            "-----P9E3PJB5bTO1xrO": {
              "aaid": "84dae6bd-cb3a-409c-9940-844f035b5fc7",
              "callsign": "2day",
              "deviceId": "1b771f137d1bc6ea",
              "dow": "Thursday",
              "downloadFlag": "N",
              "email": "ckcafeandcatering@gmail.com",
              "emailSha256": "6ab0992297a9478be9ae7ff26d811b1116c45a0c819ff1c9628c9b7ca4ec4129",
              "event": "streamStop",
              "firebaseUID": "anvlMojJFvQEvMXQW6GeRzLKCIA2",
              "halfHourFull": "10h1",
              "liveFlag": "Y",
              "localDate": "1970-01-01",
              "localHalfHour": 1,
              "login": "google",
              "minutesSinceMidnight": 601,
              "quarterHourFull": "10q1",
              "stationName": "2DayFM104.1"
            },
            "-GuGCJDEprMKczAMDUj8": {
              "deviceId": "399a649c6cee6209",
              "dow": "Thursday",
              "downloadFlag": "N",
              "event": "streamStart",
              "halfHourFull": "18h1",
              "liveFlag": "Y",
              "localDate": "2009-01-01",
              "localHalfHour": 1,
              "minutesSinceMidnight": 1080,
              "quarterHourFull": "18q1",
              "stationName": "hit 105",
              "streamListenMethod": "Headphones",
              "timestampLocal": "2009-01-01T18:00:33.679+10:00",
              "timestampUTC": "2009-01-01T08:00:33.679Z"
            }
          }
        },
        "output": {
          "deviceId": "399a649c6cee6209",
          "dow": "Thursday",
          "downloadFlag": "N",
          "event": "streamStart",
          "halfHourFull": "18h1",
          "liveFlag": "Y",
          "localDate": "2009-01-01",
          "localHalfHour": 1,
          "minutesSinceMidnight": 1080,
          "quarterHourFull": "18q1",
          "stationName": "hit 105",
          "streamListenMethod": "Headphones",
          "timestampLocal": "2009-01-01T18:00:33.679+10:00",
          "timestampUTC": "2009-01-01T08:00:33.679Z"
        }
      }
    ],
    "identifier": 52142442
  },
  {
    "context": [
      "If I rewrite just fields `time`, `ancestorcount` and `descendantcount` from this JSON into a CSV I should get:",
      "jq -r '.[] | [.time, .descendantcount, .ancestorcount] | @csv' <tempST.json >tempOutput.csv"
    ],
    "utterance": "Extract the values of the fields time, ancestorcount, and descendantcount from each object in an array and write them as comma-separated values, one record per line.",
    "expressions": [
      ".[] | [.time, .descendantcount, .ancestorcount] | @csv",
      "-r '.[] | [.time, .descendantcount, .ancestorcount] | @csv'"
    ],
    "identifier": 52175703
  },
  {
    "context": [
      "You can't use `--arg` in that way. The value of a `--arg` is a string, not a jq filter expression. If you do `--arg p .properties`, then `$p` will contain the string `.properties`, it won't be evaluated as a program.",
      "If I understand you correctly, you're getting sidetracked by thinking you need to set up a variable in `jq`, instead of just letting the shell do an expansion: \n\n    % foo='.properties'\n    % jq -r -c  \"$foo\" sample.json \n\noutput: \n\n    {\"type\":{\"description\":\"Type\"}}",
      "Since jq does not have an \u201ceval\u201d function, the appropriate way to specify a path programmatically in jq is using a JSON array in conjunction with jq\u2019s `getpath` and `setpath` built-ins, as appropriate.\n\nThus in your case you could use the -\u2014argjson command-line option to pass in the path of interest, e.g. \n\n    -\u2014argson p '[\"properties\"]'\n\nand your jq program would use `getpath($p)`."
    ],
    "utterance": "Retrieve the value at the 'properties' key, allowing the property path to be specified programmatically from the shell.",
    "expressions": [
      "$foo",
      "getpath($p)"
    ],
    "data": [
      {
        "input": {
          "type": "object",
          "description": "Contains information",
          "properties": {
            "type": {
              "description": "Type"
            }
          }
        },
        "output": {
          "type": {
            "description": "Type"
          }
        }
      }
    ],
    "identifier": 52173556
  },
  {
    "context": [
      "I want to find name==\"weather\" and change checked from \"true\" to \"false\"",
      "jq '[.[].discoveredEntities[] |= if (.name==\"weather\") then (.checked = \"false\") else . end]'\\\n    ./test.json",
      "(.[].discoveredEntities[] | select(.name == \"weather\").checked) = false",
      "map( .discoveredEntities |=\n        map(if .name == \"weather\" then .checked = false else . end))",
      "Note that it is evidently more appropriate to use `false` here rather than `\"false\"`."
    ],
    "utterance": "Set the checked property to false for all objects with name equal to weather inside the discoveredEntities array.",
    "expressions": [
      "[.[].discoveredEntities[] |= if (.name==\"weather\") then (.checked = false) else . end]",
      "(.[].discoveredEntities[] | select(.name == \"weather\").checked) = false",
      "map(.discoveredEntities |= map(if .name == \"weather\" then .checked = false else . end))"
    ],
    "data": [
      {
        "input": [
          {
            "originalSourceId": null,
            "sourceConnection": {
              "id": null,
              "version": null,
              "properties": [
                {
                  "id": null,
                  "version": null
                }
              ],
              "name": "POSTGRESQL",
              "businessName": null
            },
            "checked": true,
            "newlyAdded": false,
            "discoveredEntities": [
              {
                "name": "weather",
                "checked": true,
                "checkedBeforeEdit": false,
                "storeFieldsAsStrings": false
              },
              {
                "name": "weather_2",
                "checked": true,
                "checkedBeforeEdit": false,
                "storeFieldsAsStrings": false
              }
            ],
            "defaultLevel": "MANAGED"
          }
        ],
        "output": [
          {
            "originalSourceId": null,
            "sourceConnection": {
              "id": null,
              "version": null,
              "properties": [
                {
                  "id": null,
                  "version": null
                }
              ],
              "name": "POSTGRESQL",
              "businessName": null
            },
            "checked": true,
            "newlyAdded": false,
            "discoveredEntities": [
              {
                "name": "weather",
                "checked": false,
                "checkedBeforeEdit": false,
                "storeFieldsAsStrings": false
              },
              {
                "name": "weather_2",
                "checked": true,
                "checkedBeforeEdit": false,
                "storeFieldsAsStrings": false
              }
            ],
            "defaultLevel": "MANAGED"
          }
        ]
      }
    ],
    "identifier": 52170924
  },
  {
    "context": [
      "How do I pass a *variable* argument to JQ program that will be used as a filter.",
      "Since by default --arg passes the argument as a a string wrapped with quotes the same cannot be used to apply a filter.",
      "If you&#39;re simply accessing a property of the input, you have a couple of ways using simple indexing or using `getpath/1` for nested paths.",
      "$ jq --arg p 'properties' '.[$p]' input.json",
      "$ jq --argjson path '[\"foo\",\"bar\"]' 'getpath($path)' input.json"
    ],
    "utterance": "Access a dynamic property or nested path where the property or path is supplied as a variable argument.",
    "expressions": [
      ".[$p]",
      "getpath($path)"
    ],
    "data": [
      {
        "input": {
          "properties": {
            "type": {
              "description": "Type.",
              "type": "string",
              "p-enum": [
                {
                  "value": "IND",
                  "description": "Ind."
                },
                {
                  "value": "PROP",
                  "description": "Prop."
                }
              ]
            }
          }
        },
        "output": {
          "type": {
            "description": "Type.",
            "type": "string",
            "p-enum": [
              {
                "value": "IND",
                "description": "Ind."
              },
              {
                "value": "PROP",
                "description": "Prop."
              }
            ]
          }
        }
      },
      {
        "input": {
          "foo": {
            "bar": 42
          }
        },
        "output": 42
      }
    ],
    "identifier": 52174288
  },
  {
    "context": [
      "I want to obtain:\r\n\r\n    a,1,foo\r\n    b,2,bar\r\n    c,3,zebra",
      "Why would need `paste` and other bunch of shell utils, when you can do it all it in `jq`\r\n\r\n    jq -r 'to_entries[] | \"\\(.key),\\(.value | .number),\\(.value | .word)\"' json"
    ],
    "utterance": "Output each top-level key together with its nested number and word values, separated by commas, in row-major format.",
    "expressions": [
      "jq -r 'to_entries[] | \"\\(.key),\\(.value | .number),\\(.value | .word)\"' example.json"
    ],
    "data": [
      {
        "input": {
          "a": {
            "number": 1,
            "word": "foo"
          },
          "b": {
            "number": 2,
            "word": "bar"
          },
          "c": {
            "number": 3,
            "word": "zebra"
          }
        },
        "output": [
          "a,1,foo",
          "b,2,bar",
          "c,3,zebra"
        ]
      }
    ],
    "identifier": 52188321
  },
  {
    "context": [
      "Need to strip out \"/path/user_management/\" and set the remaining as the key, and use Value for value.",
      ".Parameters[] | \"\\(.Name)|\\(.Value)\""
    ],
    "utterance": "Extract each object's Value and use the portion of Name after the last slash as the key.",
    "expressions": [
      ".Parameters[] | \"\u001b[22m\\(.Name | split(\"/\") | .[-1])|\\(.Value)\u001b[22m\""
    ],
    "data": [
      {
        "input": {
          "Parameters": [
            {
              "Name": "/path/user_management/api_key",
              "Type": "SecureString",
              "Value": "1234",
              "Version": 1
            },
            {
              "Name": "/path/user_management/api_secret",
              "Type": "SecureString",
              "Value": "5678",
              "Version": 1
            }
          ]
        },
        "output": [
          "api_key|1234",
          "api_secret|5678"
        ]
      }
    ],
    "identifier": 52187776
  },
  {
    "context": [
      "$ itVersion=$(jq --arg test \"${it}\" '[\"${test}\"]' <<< $jsonVar);",
      "$itVersion should now have the value of \"server-test\" but is null",
      "I suggest you use the following :",
      "itVersion=$(jq --arg test \"${it}\" '.[$test]' test-config.json)"
    ],
    "utterance": "Retrieve the value of a key where the key name is stored in a shell variable whose value is 'server-test'.",
    "expressions": [
      ".[$test]"
    ],
    "data": [
      {
        "input": {
          "server-test": "xxx",
          "server2-test": "xxx",
          "server3-test": "xxx"
        },
        "output": "xxx"
      }
    ],
    "identifier": 52205484
  },
  {
    "context": [
      "I would like to remove all keys that start with \"hide\". Important to note that the keys may be nested at many levels.",
      "I\u2019d like to see the answer using a regex, although I recognise that in my example a simple contains would suffice.",
      "delpaths([paths | select(.[-1] | strings | startswith(\"hide\"))])",
      "delpaths([paths | select(.[-1] | strings | test(\"^hide\"; \"i\"))])",
      "A straightforward approach to the problem is to use walk in conjunction with with_entries, e.g.",
      "walk(if type == \"object\" then with_entries(select(.key | test(\"^hide\") | not)) else . end)"
    ],
    "utterance": "Remove all keys that start with 'hide' at any depth in the structure.",
    "expressions": [
      "delpaths([paths | select(.[-1] | strings | startswith(\"hide\"))])",
      "delpaths([paths | select(.[-1] | strings | test(\"^hide\"; \"i\"))])",
      "walk(if type == \"object\" then with_entries(select(.key | test(\"^hide\") | not)) else . end)"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2,
          "hideA": 3,
          "c": {
            "d": 4,
            "hide4": 5
          }
        },
        "output": {
          "a": 1,
          "b": 2,
          "c": {
            "d": 4
          }
        }
      },
      {
        "input": {
          "a": 1,
          "b": 2,
          "hideA": 3,
          "c": {
            "d": 4,
            "hide4": 5
          },
          "e": null,
          "f": "hiya",
          "g": false,
          "h": [
            {
              "i": 343.232,
              "hide9": "private",
              "so_smart": true
            }
          ]
        },
        "output": {
          "a": 1,
          "b": 2,
          "c": {
            "d": 4
          },
          "e": null,
          "f": "hiya",
          "g": false,
          "h": [
            {
              "i": 343.232,
              "so_smart": true
            }
          ]
        }
      }
    ],
    "identifier": 52184815
  },
  {
    "context": [
      "How can I extract these binary values to file in bash? Is it possible using `jq`?",
      "jq's -r command-line option converts a JSON string to its \"raw\" form, so to convert the string in `.bytes`, you could pipe the JSON to:",
      "    jq -r .bytes"
    ],
    "utterance": "Extract the value of the .bytes field containing binary data and write it to a file, preserving the binary content.",
    "expressions": [
      ".bytes",
      "-r .bytes"
    ],
    "data": [
      {
        "input": {
          "bytes": "\u0000\u0000\u0000\u0000\u0002\u0000\u0000\u0000\u0002@ol\u0000\u0000\u0000\u0000\u0000@f\u00b8\u0000\u0000\u0000\u0000\u0000@o\u00a6\u0000\u0000\u0000\u0000\u0000@f\u00fa\u0000\u0000\u0000\u0000\u0000"
        }
      }
    ],
    "identifier": 52214571
  },
  {
    "context": [
      "curl -G  https://api.github.com/search/repositories?q=language:Java+stars:%3E=500+library+java+in:readme \\\n | jq \".items[] | {name, description, language, watchers_count, html_url}\" > parsedOutput1.txt",
      "It was a paging problem, as presented in the documentation, the api only gives you 30 items per request, so you need to add some code to include all the pages.",
      "curl -G  $URL \\\n | jq \".items[] | {name, description, language, watchers_count, html_url}\" >> parsedOutput1.txt"
    ],
    "utterance": "For each repository matching the search, extract the fields: name, description, language, watchers_count, and html_url.",
    "expressions": [
      ".items[] | {name, description, language, watchers_count, html_url}"
    ],
    "identifier": 52228774
  },
  {
    "context": [
      "How might I consolidate this array of `elements`\u2026",
      "[ { \"category\": \"a\", \"comment\": \"the repetition, oh my\", \"element_foo\": 1, \"element_bar\": 10 }, { \"category\": \"a\", \"comment\": \"the repetition, oh my\", \"element_foo\": 2, \"element_bar\": 20 } ],",
      "\u2026into this array of `categories` containing arrays of `elements`?",
      "[ { \"category\": \"a\", \"comment\": \"the repetition, oh my\", \"elements\": [ { \"foo\": 1, \"bar\": 10 }, { \"foo\": 2, \"bar\": 20 } ] } ]",
      "Group the objects by category and comment, then map the groupings as you'd like:",
      "group_by({ category, comment }) | map({ category: .[0].category, comment: .[0].comment, elements: map({ foo: .element_foo, bar: .element_bar }) })"
    ],
    "utterance": "Group objects by category and comment, collecting their foo and bar values in an elements array under each group.",
    "expressions": [
      "group_by({ category, comment }) | map({ category: .[0].category, comment: .[0].comment, elements: map({ foo: .element_foo, bar: .element_bar }) })"
    ],
    "data": [
      {
        "input": [
          {
            "category": "a",
            "comment": "the repetition, oh my",
            "element_foo": 1,
            "element_bar": 10
          },
          {
            "category": "a",
            "comment": "the repetition, oh my",
            "element_foo": 2,
            "element_bar": 20
          }
        ],
        "output": [
          {
            "category": "a",
            "comment": "the repetition, oh my",
            "elements": [
              {
                "foo": 1,
                "bar": 10
              },
              {
                "foo": 2,
                "bar": 20
              }
            ]
          }
        ]
      }
    ],
    "identifier": 52206321
  },
  {
    "context": [
      "I am looking to take the following json example:\n\n        [{\n      \t\t\"Name\": \"Test1\",\n      \t\t\"Version\": \"5.0.1\",\n      \t\t\"source\": \"source\"\n      \t},\n      \t{\n      \t\t\"Name\": \"Test2\",\n      \t\t\"Version\": \"2.0.11\",\n      \t\t\"source\": \"source\"\n      \t},\n      \t{\n      \t\t\"Name\": \"Test3\",\n      \t\t\"Version\": \"2.1.2\",\n      \t\t\"source\": \"source\"\n      \t}]\n\nand convert it to:\n\n     {\n      \t\"packages\": [\n            {\n      \t\t\t\"Name\": \"Test1\",\n      \t\t\t\"Version\": \"5.0.1\",\n      \t\t\t\"source\": \"source\"\n      \t\t},\n      \t\t{\n      \t\t\t\"Name\": \"Test2\",\n      \t\t\t\"Version\": \"2.0.11\",\n      \t\t\t\"source\": \"source\"\n      \t\t},\n      \t\t{\n      \t\t\t\"Name\": \"Test3\",\n      \t\t\t\"Version\": \"2.1.2\",\n      \t\t\t\"source\": \"source\"\n      \t\t}\n      \t]\n      }",
      "just do this\n\n    jq '{ packages : . }' input.json",
      "The filter you need in this case is simply `{packages: .}`:"
    ],
    "utterance": "Wrap the input array under an object with key packages.",
    "expressions": [
      "{ packages: . }"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "Test1",
            "Version": "5.0.1",
            "source": "source"
          },
          {
            "Name": "Test2",
            "Version": "2.0.11",
            "source": "source"
          },
          {
            "Name": "Test3",
            "Version": "2.1.2",
            "source": "source"
          }
        ],
        "output": {
          "packages": [
            {
              "Name": "Test1",
              "Version": "5.0.1",
              "source": "source"
            },
            {
              "Name": "Test2",
              "Version": "2.0.11",
              "source": "source"
            },
            {
              "Name": "Test3",
              "Version": "2.1.2",
              "source": "source"
            }
          ]
        }
      }
    ],
    "identifier": 52190190
  },
  {
    "context": [
      "But i want to get 4 that is the amount of items in the vector.",
      "echo \"$j\" | jq '.Names | .names | length'",
      "Output:\n4"
    ],
    "utterance": "Return the number of items in the 'names' array under the 'Names' object.",
    "expressions": [
      ".Names | .names | length"
    ],
    "data": [
      {
        "input": {
          "Names": {
            "names": [
              "marry",
              "jason",
              "frank",
              "kelly"
            ]
          }
        },
        "output": 4
      }
    ],
    "identifier": 52244763
  },
  {
    "context": [
      "My problem is that when I replace the key with $mykey I get this error:",
      "$ jq -n --arg greeting world --arg mykey hello '{($mykey):$greeting}'",
      "{\n  \"hello\": \"world\"\n}"
    ],
    "utterance": "Create an object with a key from a variable and assign it a value from another variable, both provided as arguments.",
    "expressions": [
      "{($mykey):$greeting}"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "hello": "world"
        }
      }
    ],
    "identifier": 52231558
  },
  {
    "context": [
      "if ( .[].cores == \"shared\" ) then\n            .[].cores = 0.5 \n        end",
      "if ( .[].cores == \"shared\" ) then\n            .[].cores = 0.5 \n        else .[].cores = .[].cores end",
      "It looks as though you want:\n\n    .gcp_price_list\n    | .\"CP-COMPUTEENGINE-OS\"\n    | map_values(\n        if .cores == \"shared\" \n        then .cores = 0.5 \n        else . end )",
      ".gcp_price_list.\"CP-COMPUTEENGINE-OS\" |= \n  map_values(\n    if ( .cores == \"shared\" ) then\n        .cores = 0.5 \n    else . end\n  )"
    ],
    "utterance": "Replace all values of 'cores' equal to 'shared' with 0.5 within the 'CP-COMPUTEENGINE-OS' object inside 'gcp_price_list'.",
    "expressions": [
      ".gcp_price_list | .\"CP-COMPUTEENGINE-OS\" | map_values(if .cores == \"shared\" then .cores = 0.5 else . end)",
      ".gcp_price_list.\"CP-COMPUTEENGINE-OS\" |= map_values(if .cores == \"shared\" then .cores = 0.5 else . end)"
    ],
    "identifier": 52251370
  },
  {
    "context": [
      "I need to obtain only the objects using `storege_plugin: \"s3v8\"` and that in the \"quoted\" value object of `storage_endpoint` the key `signature_version` is `2`",
      ".[] | select((.store_plugin == \"s3v8\" and .store_endpoint != null) and (.store_endpoint | fromjson | .signature_version == \"2\") )"
    ],
    "utterance": "Select all objects where store_plugin is \"s3v8\" and the signature_version inside the parsed store_endpoint string equals \"2\".",
    "expressions": [
      ".[] | select((.store_plugin == \"s3v8\" and .store_endpoint != null) and (.store_endpoint | fromjson | .signature_version == \"2\") )"
    ],
    "data": [
      {
        "input": [
          {
            "uuid": "2e08c71c-56af-4c1d-9677-0aad7bf38536",
            "name": "img-s3",
            "summary": "",
            "retention_name": "month",
            "retention_uuid": "beae2f1a-10e9-4b53-b9b1-baf823624ff2",
            "expiry": 2678400,
            "schedule_name": "daily",
            "schedule_uuid": "baca1a64-b506-4789-83c8-653573f2b99f",
            "schedule_when": "daily 2am",
            "paused": false,
            "store_uuid": "d91fd7b6-4c39-4f73-aa44-8ec55f52da65",
            "store_name": "default",
            "store_plugin": "s3v8",
            "store_endpoint": "{\"access_key_id\":\"xxxx\",\"bucket\":\"images-c4\",\"s3_host\":\"s3.amazon.com\",\"secret_access_key\":\"yyy\",\"signature_version\":\"2\",\"skip_ssl_validation\":true}",
            "target_uuid": "991c7aa2-cdd3-4f90-bb28-1431c99f8fc8",
            "target_name": "sc-asd",
            "target_plugin": "mysql",
            "target_endpoint": "{\"mysql_database\":\"users\",\"mysql_host\":\"10.10.22.49\",\"mysql_password\":\"password\",\"mysql_port\":\"3306\",\"mysql_user\":\"user\"}",
            "agent": "127.0.0.1:3030"
          },
          {
            "uuid": "abcd",
            "store_plugin": "s3v8",
            "store_endpoint": "{\"signature_version\":\"1\"}"
          },
          {
            "uuid": "efgh",
            "store_plugin": "other",
            "store_endpoint": "{\"signature_version\":\"2\"}"
          }
        ],
        "output": [
          {
            "uuid": "2e08c71c-56af-4c1d-9677-0aad7bf38536",
            "name": "img-s3",
            "summary": "",
            "retention_name": "month",
            "retention_uuid": "beae2f1a-10e9-4b53-b9b1-baf823624ff2",
            "expiry": 2678400,
            "schedule_name": "daily",
            "schedule_uuid": "baca1a64-b506-4789-83c8-653573f2b99f",
            "schedule_when": "daily 2am",
            "paused": false,
            "store_uuid": "d91fd7b6-4c39-4f73-aa44-8ec55f52da65",
            "store_name": "default",
            "store_plugin": "s3v8",
            "store_endpoint": "{\"access_key_id\":\"xxxx\",\"bucket\":\"images-c4\",\"s3_host\":\"s3.amazon.com\",\"secret_access_key\":\"yyy\",\"signature_version\":\"2\",\"skip_ssl_validation\":true}",
            "target_uuid": "991c7aa2-cdd3-4f90-bb28-1431c99f8fc8",
            "target_name": "sc-asd",
            "target_plugin": "mysql",
            "target_endpoint": "{\"mysql_database\":\"users\",\"mysql_host\":\"10.10.22.49\",\"mysql_password\":\"password\",\"mysql_port\":\"3306\",\"mysql_user\":\"user\"}",
            "agent": "127.0.0.1:3030"
          }
        ]
      }
    ],
    "identifier": 52220633
  },
  {
    "context": [
      "I need to convert this JSON to a TSV format.",
      "Then I want to convert it to tsv which are consist of below column:\r\n\r\n    event, timestamp, tags, _id, msisdn, method, url, timeTaken, channelID, pid ",
      "You just have to construct an array of atomic values.  Since `.tags` is not atomic, in the following I&#39;ll assume (as suggested by @chepner) that we can use `.tags|join(&quot;,&quot;)`, though you might want to use something else, such as `.tags|@csv`:",
      "[.event, .timestamp, (.tags | join(\",\"))]\r\n    + (.data|[._id, .msisdn, .method, .url, .timeTaken, .channelID])\r\n    + [.pid]\r\n    | @tsv"
    ],
    "utterance": "Extract the fields event, timestamp, tags (comma-separated), _id, msisdn, method, url, timeTaken, channelID, and pid as tab-separated values.",
    "expressions": [
      "[.event, .timestamp, (.tags | join(\",\"))] + (.data|[._id, .msisdn, .method, .url, .timeTaken, .channelID]) + [.pid] | @tsv"
    ],
    "data": [
      {
        "input": {
          "event": "log",
          "timestamp": 1535306331840,
          "tags": [
            "info"
          ],
          "data": {
            "_id": "A301180827005852329209020",
            "msisdn": "6282134920902",
            "method": "get",
            "url": "/api/tcash/balance",
            "timeTaken": 32,
            "channelID": "UX"
          },
          "pid": 7920
        },
        "output": "log\t1535306331840\tinfo\tA301180827005852329209020\t6282134920902\tget\t/api/tcash/balance\t32\tUX\t7920"
      }
    ],
    "identifier": 52256178
  },
  {
    "context": [
      "I have the following jq code snippet:\r\n\r\nhttps://jqplay.org/s/QzOttRHoz1",
      "I want to loop each element from the result array using bash such as the pseudo code shows:\r\n\r\n    #!/bin/bash\r\n    foreach result\r\n      print \"My name is {name}, I'm {age} years old\"\r\n      print \"--\"",
      "The result would be:\r\n\r\n    My name is A, I'm 1 years old.\r\n    ---\r\n    My name is B, I'm 2 years old.\r\n    ---\r\n    My name is C, I'm 3 years old.\r\n    ---",
      "Saving the json:\r\n\r\n    {\r\n        \"Names\": [\r\n            { \"Name\": \"A\", \"Age\": \"1\" },\r\n            { \"Name\": \"B\", \"Age\": \"2\" },\r\n            { \"Name\": \"C\", \"Age\": \"3\" }\r\n        ]\r\n    }\r\n\r\nas /tmp/input.txt I can run:\r\n\r\n    </tmp/input.txt jq --raw-output 'foreach .Names[] as $name ([];[];$name | .Name, .Age )' \\",
      "If you rather have:\r\n\r\n    [\"A\",\"1\"]\r\n    [\"B\",\"2\"]\r\n    [\"C\",\"3\"]",
      "Note that foreach .Names[] as $name ([];[];$name | .Name, .Age )\r\n can be simplified to:\r\n\r\n    .Names[] | ( .Name, .Age )\r\n\r\nor even in this specific case to:\r\n\r\n    .Names[][]"
    ],
    "utterance": "Output for each element in the Names array with the corresponding Name and Age fields in order, to be processed individually in a shell loop.",
    "expressions": [
      ".Names[] | .Name, .Age",
      ".Names[] | [ .Name, .Age ]",
      ".Names[][]"
    ],
    "data": [
      {
        "input": {
          "Names": [
            {
              "Name": "A",
              "Age": "1"
            },
            {
              "Name": "B",
              "Age": "2"
            },
            {
              "Name": "C",
              "Age": "3"
            }
          ]
        },
        "output": [
          "A",
          "1",
          "B",
          "2",
          "C",
          "3"
        ]
      },
      {
        "input": {
          "Names": [
            {
              "Name": "A",
              "Age": "1"
            },
            {
              "Name": "B",
              "Age": "2"
            },
            {
              "Name": "C",
              "Age": "3"
            }
          ]
        },
        "output": [
          [
            "A",
            "1"
          ],
          [
            "B",
            "2"
          ],
          [
            "C",
            "3"
          ]
        ]
      }
    ],
    "identifier": 52284745
  },
  {
    "context": [
      "So how would I sum all the `avg_amount` fields in the following snippet (ideally without hardcoding each `.buckets.[]`)?",
      "After fixing your JSON, the query:\r\n\r\n    jq '[.. | objects | .avg_amount] | add'\r\n\r\nyields `1099`.",
      "(This query is robust w.r.t. the existence of the key \"avg_amount\" as `add` handles `null` as 0.)"
    ],
    "utterance": "Sum all values of avg_amount fields at any nesting depth without specifying the path to each.",
    "expressions": [
      "[.. | objects | .avg_amount] | add"
    ],
    "data": [
      {
        "input": [
          {
            "buckets": [
              {
                "buckets": [
                  {
                    "buckets": [
                      {
                        "avg_amount": 25
                      }
                    ],
                    "destination": "Apple"
                  },
                  {
                    "buckets": [
                      {
                        "avg_amount": 74
                      }
                    ],
                    "destination": "Google"
                  }
                ],
                "vendor_name": "Vendor Bee"
              },
              {
                "buckets": [
                  {
                    "buckets": [
                      {
                        "avg_amount": 1000
                      }
                    ],
                    "destination": ""
                  }
                ],
                "vendor_name": ""
              }
            ],
            "company_id": 1
          }
        ],
        "output": 1099
      }
    ],
    "identifier": 52321830
  },
  {
    "context": [
      "I need to put a filter on \"localDate\" field in jq stream such that the output looks like the following JSON as:",
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs | select(.[0][] == \"userActivities\"))) | with_entries(select(.value.localDate==\"2018-01-19\")) ' input.json",
      "output: ",
      "{\"L3ATRosRdbDgSmX75Z\":{\"deviceId\":\"60ee32c2fae8dcf0\",\"dow\":\"Friday\",\"localDate\":\"2018-01-19\"}}"
    ],
    "utterance": "Filter userActivities to retain only entries where localDate equals \"2018-01-19\".",
    "expressions": [
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs | select(.[0][] == \"userActivities\"))) | with_entries(select(.value.localDate==\"2018-01-19\"))'"
    ],
    "data": [
      {
        "input": {
          "userActivities": {
            "L3ATRosRdbDgSmX75Z": {
              "deviceId": "60ee32c2fae8dcf0",
              "dow": "Friday",
              "localDate": "2018-01-19"
            },
            "L3ATSFGrpAYRkIIKqrh": {
              "deviceId": "60ee32c2fae8dcf0",
              "dow": "Friday",
              "localDate": "2018-01-20"
            }
          }
        },
        "output": {
          "L3ATRosRdbDgSmX75Z": {
            "deviceId": "60ee32c2fae8dcf0",
            "dow": "Friday",
            "localDate": "2018-01-19"
          }
        }
      }
    ],
    "identifier": 52324497
  },
  {
    "context": [
      "I would need to extract information based on the galaxy/system/position.",
      "For example, having a script with the proper filters in it and execute something like that :",
      "./parser --galaxy=1 --system=22 --position=3",
      "And it would give me :",
      "ID : 123456",
      "Name : Example1",
      "Activity : 27",
      "The following should be sufficient to get you on your way.",
      ".Result[]",
      "| select(.Coordinate | (.Galaxy==$galaxy and .System==$system and .Position==$position))",
      "jq -f so-galaxy.jq --argjson galaxy 1 --argjson system 22 --argjson position 3 galaxy.json",
      "If you want the output to be in `key: value` format, simply add -r to the command-line options, and append the following to the jq filter:",
      "| to_entries[]",
      "| \"\\(.key): \\(.value)\""
    ],
    "utterance": "Extract all objects with Coordinate.Galaxy=1, Coordinate.System=22, and Coordinate.Position=3, and output their fields in key: value format.",
    "expressions": [
      ".Result[] | select(.Coordinate | (.Galaxy==$galaxy and .System==$system and .Position==$position))",
      ".Result[] | select(.Coordinate | (.Galaxy==$galaxy and .System==$system and .Position==$position)) | to_entries[] | \"\\(.key): \\(.value)\""
    ],
    "data": [
      {
        "input": {
          "Status": "ok",
          "Code": 200,
          "Message": "",
          "Result": [
            {
              "ID": 123456,
              "Activity": 27,
              "Name": "Example1",
              "Coordinate": {
                "Galaxy": 1,
                "System": 22,
                "Position": 3
              },
              "Administrator": false,
              "Inactive": false,
              "Vacation": false,
              "HonorableTarget": false,
              "Debris": {
                "Metal": 0,
                "Crystal": 0,
                "RecyclersNeeded": 0
              },
              "Moon": null,
              "Player": {
                "ID": 111111,
                "Name": "foo",
                "Rank": 4
              },
              "Alliance": null
            },
            {
              "ID": 223344,
              "Activity": 17,
              "Name": "Example2",
              "Coordinate": {
                "Galaxy": 3,
                "System": 44,
                "Position": 5
              },
              "Administrator": false,
              "Inactive": false,
              "Vacation": false,
              "StrongPlayer": false,
              "HonorableTarget": false,
              "Debris": {
                "Metal": 0,
                "Crystal": 0,
                "RecyclersNeeded": 0
              },
              "Moon": null,
              "Player": {
                "ID": 765432,
                "Name": "Player 2",
                "Rank": 3
              },
              "Alliance": null
            }
          ]
        },
        "output": [
          "ID: 123456",
          "Activity: 27",
          "Name: Example1",
          "Coordinate: {\"Galaxy\":1,\"System\":22,\"Position\":3}",
          "Administrator: false",
          "Inactive: false",
          "Vacation: false",
          "HonorableTarget: false",
          "Debris: {\"Metal\":0,\"Crystal\":0,\"RecyclersNeeded\":0}",
          "Moon: null",
          "Player: {\"ID\":111111,\"Name\":\"foo\",\"Rank\":4}",
          "Alliance: null"
        ]
      }
    ],
    "identifier": 52305343
  },
  {
    "context": [
      "Can I get any clue to insert bash variable into JSON template?  I guess I am not doing correctly using `jq` here:\n\n`JSON=$(cat template.json | jq --arg NUMBER \"$NUMBER\" '.' )`",
      "the functionality for making the substitution is encapsulated in the following definition:\n\ndef resolve(s; value):\n  .My_Table |= map(.PutRequest.Item.type.S |= \n     sub(\"-\" + s + \"-\"; \"-\" + (value|tostring) + \"-\" ));",
      "So, to generate the desired output for a single substitution of \"$NUMBER\" by \"1\", one would write:\n\nresolve(\"\\\\$NUMBER\"; 1)",
      "If the template is intended to be used with `jq`, it should be changed to work correctly, rather than trying to force `jq` to work with substandard input.\n\n{\n    \"My_Table\":[{\n        \"PutRequest\":{\"Item\":{\"type\":{\"S\":\"test-\\($NUMBER)-Type_A\"},\"name\":{ ...",
      "Now something like your original attempt will work correctly. (Name your template `template.jq` to emphasize that it is not actually valid JSON.)\n\nfor ((counter=1 ; counter<2 ;counter++ ))\ndo\n  JSON=$(jq -n -f template.jq --arg NUMBER \"$counter\")\n  echo \"$JSON\"\n  #aws dynamodb batch-write-item --request-items \"${JSON}\"\ndone"
    ],
    "utterance": "Substitute the variable NUMBER with its value (such as 1) in all type.S fields where the string contains test-$NUMBER-Type_X, producing output with the correct value in place.",
    "expressions": [
      "def resolve(s; value): .My_Table |= map(.PutRequest.Item.type.S |= sub(\"-\" + s + \"-\"; \"-\" + (value|tostring) + \"-\" )); resolve(\"\\\\$NUMBER\"; 1)",
      "jq -n -f template.jq --arg NUMBER \"$counter\""
    ],
    "data": [
      {
        "input": {
          "My_Table": [
            {
              "PutRequest": {
                "Item": {
                  "type": {
                    "S": "test-$NUMBER-Type_A"
                  },
                  "name": 0
                }
              }
            }
          ]
        },
        "output": {
          "My_Table": [
            {
              "PutRequest": {
                "Item": {
                  "type": {
                    "S": "test-1-Type_A"
                  },
                  "name": 0
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 52252781
  },
  {
    "context": [
      "How can I get the output:\r\n\r\n    +18459939294\r\n    +12018986776\r\n    +12120098763",
      "`numbers` is an object, not just a array of keys. Just get the (unsorted) keys from that object.",
      ".data.numbers | keys_unsorted[]"
    ],
    "utterance": "List all the phone number keys present under data.numbers.",
    "expressions": [
      ".data.numbers | keys_unsorted[]"
    ],
    "data": [
      {
        "input": {
          "page_size": 3,
          "data": {
            "numbers": {
              "+18459939294": {
                "state": "in_service",
                "features": [
                  "e911",
                  "outbound_cnam",
                  "inbound_cnam"
                ],
                "features_allowed": [],
                "features_denied": []
              },
              "+12018986776": {
                "state": "in_service",
                "features": [],
                "features_allowed": [],
                "features_denied": []
              },
              "+12120098763": {
                "state": "in_service",
                "features": [],
                "features_allowed": [],
                "features_denied": []
              }
            },
            "casquade_quantity": 3
          },
          "revision": "79807405987349087540983759804",
          "timestamp": "2018-09-14T17:07:49",
          "version": "x.x.x",
          "node": "aojflksajflkmaMmiaonfsd",
          "request_id": "-098230-49823049-82309",
          "status": "success"
        },
        "output": [
          "+18459939294",
          "+12018986776",
          "+12120098763"
        ]
      }
    ],
    "identifier": 52336715
  },
  {
    "identifier": 52388153
  },
  {
    "context": [
      "textb=&quot;\\n 1 \\n 2 \\n 3 \\n 4&quot;",
      "Why jq add and extra \"\\\"?  What i m going wrong?",
      "`\\n` does not mean linefeed/newline in a bash double quoted string. It&#39;s just backslash+lowercase n.",
      "If you use linefeeds instead of backslashes and Ns, they will encode the way you want:",
      "textb=$'\n1\n2\n3\n4'",
      "jq -n --arg textb \"$textb\" '.\"the string is:\" = $textb'"
    ],
    "utterance": "Create an object with a key whose value is a string containing actual newlines from a bash variable.",
    "expressions": [
      ".\"the string is:\" = $textb"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "the string is:": "\n1\n2\n3\n4"
        }
      }
    ],
    "identifier": 52376815
  },
  {
    "context": [
      "I have a foo.json and I want to update AAA to AAA-MY-SUFFIX.",
      "Basically, I want to get the current value (AAA), and then add a suffix to it.",
      "But I want to APPEND a suffix to the existing value, not completely replace it.",
      "cat tags.json | jq '(.[] | select(.Key == \"role\") | .Value) |= (. + \"- MY_SUFFIX\")'",
      "You could simply replace `.Value + \"-MY_SUFFIX\"` by . + \"-MY_SUFFIX\"",
      "Or better yet, use `+=`, as in:  `... += \"-MY_SUFFIX\"`",
      "Personally, I'd use the filter: map(if .Key == \"role\" then .Value += \"-MY_SUFFIX\" else . end)",
      "(Actually, the stated requirements would accord better with using the suffix `\"-MY-SUFFIX\"` :-)"
    ],
    "utterance": "Append the suffix -MY-SUFFIX to the Value field of the object in the array where Key equals role.",
    "expressions": [
      "(.[] | select(.Key == \"role\") | .Value) |= (. + \"-MY-SUFFIX\")",
      "(.[] | select(.Key == \"role\") | .Value) |= (. + \"-MY_SUFFIX\")",
      "map(if .Key == \"role\" then .Value += \"-MY-SUFFIX\" else . end)",
      "map(if .Key == \"role\" then .Value += \"-MY_SUFFIX\" else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "Key": "Name",
            "Value": "awesome"
          },
          {
            "Key": "role",
            "Value": "AAA"
          }
        ],
        "output": [
          {
            "Key": "Name",
            "Value": "awesome"
          },
          {
            "Key": "role",
            "Value": "AAA-MY-SUFFIX"
          }
        ]
      }
    ],
    "identifier": 52372349
  },
  {
    "identifier": 52391547
  },
  {
    "context": [
      "I want to put a filter on localDate values such that localDate in 2018-01-20 or localDate in \"2018-01-21\" such that the output look like.\r\n\r\n    {\"userActivities\":{\"L3ATRosRdbDgSmX75Z\":{\"deviceId\":\"60ee32c2fae8dcf0\",\"dow\":\"Friday\",\"localDate\":\"2018-01-20\"},\"L3ATSFGrpAYRkIIKqrh\":{\"deviceId\":\"60ee32c2fae8dcf0\",\"dow\":\"Friday\",\"localDate\":\"2018-01-21\"}}}",
      "Otherwise, I'd go with:\r\n\r\n    def add(s): reduce s as $x (null; .+$x);\r\n\r\n    {\"userActivities\": add(\r\n        atomize(1|truncate_stream(inputs | select(.[0][0] == \"userActivities\")))\r\n        | select( .[].localDate ==\"2018-01-20\" or .[].localDate == \"2018-01-21\") ) }"
    ],
    "utterance": "Filter userActivities to retain only items with localDate equal to \"2018-01-20\" or \"2018-01-21\" while preserving the original nested structure.",
    "expressions": [
      "def atomize(s):\n  fromstream(foreach s as $in ( {previous:null, emit: null};\n      if ($in | length == 2) and ($in|.[0][0]) != .previous and .previous != null\n      then {emit: [[.previous]], previous: $in|.[0][0]}\n      else { previous: ($in|.[0][0]), emit: null}\n      end;\n      (.emit // empty), $in) ) ;\ndef add(s): reduce s as $x (null; .+$x);\n{\"userActivities\": add(\n    atomize(1|truncate_stream(inputs | select(.[0][0] == \"userActivities\")))\n    | select( .[].localDate ==\"2018-01-20\" or .[].localDate == \"2018-01-21\") ) }"
    ],
    "data": [
      {
        "input": {
          "userActivities": {
            "L3ATRosRdbDgSmX75Z": {
              "deviceId": "60ee32c2fae8dcf0",
              "dow": "Friday",
              "localDate": "2018-01-20"
            },
            "L3ATSFGrpAYRkIIKqrh": {
              "deviceId": "60ee32c2fae8dcf0",
              "dow": "Friday",
              "localDate": "2018-01-21"
            },
            "L3AVHvmReBBPNGluvHl": {
              "deviceId": "60ee32c2fae8dcf0",
              "dow": "Friday",
              "localDate": "2018-01-22"
            },
            "L3AVIcqaDpZxLf6ispK": {
              "deviceId": "60ee32c2fae8dcf0",
              "dow": "Friday",
              "localDate": "2018-01-19"
            }
          }
        },
        "output": {
          "userActivities": {
            "L3ATRosRdbDgSmX75Z": {
              "deviceId": "60ee32c2fae8dcf0",
              "dow": "Friday",
              "localDate": "2018-01-20"
            },
            "L3ATSFGrpAYRkIIKqrh": {
              "deviceId": "60ee32c2fae8dcf0",
              "dow": "Friday",
              "localDate": "2018-01-21"
            }
          }
        }
      }
    ],
    "identifier": 52326989
  },
  {
    "context": [
      "But if I store the output of the function call in a variable, I get an error:",
      "echo $servers | jq .",
      "# jq can not process this",
      "parse error: Invalid string: control characters from U+0000 through",
      "This issue roots in existence of \\r\\n in the string.",
      "Pipe the string into tr '\\r\\n' ' ':",
      "servers=$(getServers)",
      "echo $servers | tr '\\r\\n' ' ' | jq ."
    ],
    "utterance": "Query structured data that contains carriage return and newline characters by removing them before processing.",
    "expressions": [
      "echo $servers | tr '\\r\\n' ' ' | jq ."
    ],
    "identifier": 52399819
  },
  {
    "context": [
      "I need to replace server_url ( **application_server.com** ) to a different value say (**application2_server.com**)",
      "jq '.servers[].server_url=\"application2_server.com\"' file"
    ],
    "utterance": "Replace all values of server_url with application2_server.com under servers array.",
    "expressions": [
      ".servers[].server_url = \"application2_server.com\""
    ],
    "data": [
      {
        "input": {
          "servers": [
            {
              "server_type": "application_server",
              "server_url": "application_server.com"
            },
            {
              "server_type": "relay_server",
              "server_url": "application_server.com"
            }
          ]
        },
        "output": {
          "servers": [
            {
              "server_type": "application_server",
              "server_url": "application2_server.com"
            },
            {
              "server_type": "relay_server",
              "server_url": "application2_server.com"
            }
          ]
        }
      }
    ],
    "identifier": 52404988
  },
  {
    "context": [
      "i need to extract from  .json line 12   and  extract the id from .json.ml",
      "id=$(cat ${fname}.ml | jq -r \".| .id \" )",
      "id=$(jq -r .id \"${fname}\" )"
    ],
    "utterance": "Extract the value of the id field from the .ml file.",
    "expressions": [
      ".id",
      ".[\"id\"]"
    ],
    "data": [
      {
        "input": {
          "id": "MLA745474956",
          "site_id": "MLA"
        },
        "output": "MLA745474956"
      }
    ],
    "identifier": 52409207
  },
  {
    "context": [
      "I want to concatenate the key-value pairs from Resources element, and output on single line as:",
      "60a0490c,AutoScaling=AWS::STS::AssumedRole#AWS::IAM::Role=arn:aws:iam:autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling",
      "It creates new entry for each key-value pair, I want it to be on single line with different delimeter (#)",
      "jq ' .EventId + \",\" + ([(.Resources[] | join(\"=\"))] | join(\"#\"))' -r file"
    ],
    "utterance": "Concatenate the EventId and all Resources key-value pairs as key=value joined by #, separated from EventId by a comma, on a single line.",
    "expressions": [
      ".EventId + \",\" + ([(.Resources[] | \"\u007f{.ResourceName}={.ResourceType}\")] | join(\"#\"))",
      ".EventId + \",\" + (.Resources | map(\"\u007f{.ResourceName}={.ResourceType}\") | join(\"#\"))"
    ],
    "data": [
      {
        "input": {
          "EventId": "60a0490c",
          "Resources": [
            {
              "ResourceType": "AWS::STS::AssumedRole",
              "ResourceName": "AutoScaling"
            },
            {
              "ResourceType": "AWS::IAM::Role",
              "ResourceName": "arn:aws:iam:autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling"
            }
          ]
        },
        "output": "60a0490c,AutoScaling=AWS::STS::AssumedRole#arn:aws:iam:autoscaling.amazonaws.com/AWSServiceRoleForAutoScaling=AWS::IAM::Role"
      }
    ],
    "identifier": 52384260
  },
  {
    "context": [
      "The below is what I would like to be returned from my initial jq query but just unsure how I get this specific data returned.",
      "{ \n  \"1\" : {\n           \"album\": \"Album Title\",\n           \"href\": \"/bhangra/album/view/2842847/title-of-album/\",\n\t\t   \"artist\": \"Artist Name\",\n\t\t   \"date\": \"September 08, 2018\"\n  },\n  \"2\" : {\n           \"album\": \"Album1 Title\",\n           \"href\": \"/bhangra/album/view/2842847/title-of-album/\",\n\t\t   \"artist\": \"Artist1 Name\",\n\t\t   \"date\": \"September 08, 2018\"\n  },\n  \"3\" : {\n           \"album\": \"Album2 Title\",\n           \"href\": \"/bhangra/album/view/2842847/title-of-album/\",\n\t\t   \"artist\": \"Artist2 Name\",\n\t\t   \"date\": \"September 09, 2018\"\n  }\n}",
      "one way to solve the problem of tagging the objects with sequentially-numbered keys is to use the following function:\n\ndef tag(s):\n  reduce s as $x ({n:0, o:{}} ;\n    .n += 1\n    | .o += { (.n|tostring): $x})\n  | .o;",
      "So the task now is to produce a stream of the desired objects.",
      "{date: first(.. | objects | select(.tag == \"time\" and has(\"text\")) | .text)} as $date\n| tag(.. \n      | objects\n      | select(has(\"title\") and (has(\"children\")|not) and .title == \"Album Title\")\n      + $date )"
    ],
    "utterance": "Return each album, artist, href, and date as numbered objects, indexed by 1, 2, 3, combining data for each album into an object with keys album, artist, href, and date.",
    "expressions": [
      "def tag(s): reduce s as $x ({n:0, o:{}} ; .n += 1 | .o += { (.n|tostring): $x}) | .o; {date: first(.. | objects | select(.tag == \"time\" and has(\"text\")) | .text)} as $date | tag(.. | objects | select(has(\"title\") and (has(\"children\")|not) and .title == \"Album Title\") + $date )"
    ],
    "identifier": 52264863
  },
  {
    "context": [
      "Given a json file in the format as :\n\n    [\n      {\n        \"name\" : \"A\",\n        \"value\" : \"4\"\n      },\n      {\n        \"name\" : \"B\",\n        \"value\" : \"2\"\n      },\n      {\n        \"name\" : \"C\",\n        \"value\" : {\n          \"X\": \"Something\",\n          \"Y\": \"Else\"\n        }\n      }\n    ]\n\nHow would I convert it to something like this using jq:\n\n    {\n      \"A\": \"4\",\n      \"B\": \"2\",\n      \"C\": {\n        \"X\": \"Something\",\n        \"Y\": \"Else\"\n      }\n    }",
      "I did come close using ` jq 'map( { (.name): .value } )` but that still leaves each object in its separate braces instead of having them all together.",
      "Using your approach, simply add `add` to your filter:\n\n    map( { (.name): .value } ) | add",
      "This happens to be the exact use case for `from_entries`",
      "$ echo '[\n  {\n    \"name\" : \"A\",\n    \"value\" : \"4\"\n  },\n  {\n    \"name\" : \"B\",\n    \"value\" : \"2\"\n  },\n  {\n    \"name\" : \"C\",\n    \"value\" : {\n      \"X\": \"Something\",\n      \"Y\": \"Else\"\n    }\n  }\n]' | jq 'from_entries'",
      "> `from_entries` accepts key, Key, name, Name, value and Value as keys.\n\nSo `name` works just fine, here."
    ],
    "utterance": "Convert an array of objects, each with fields 'name' and 'value', into an object whose keys are the 'name' values and whose values are the corresponding 'value' fields.",
    "expressions": [
      "map({ (.name): .value }) | add",
      "from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "name": "A",
            "value": "4"
          },
          {
            "name": "B",
            "value": "2"
          },
          {
            "name": "C",
            "value": {
              "X": "Something",
              "Y": "Else"
            }
          }
        ],
        "output": {
          "A": "4",
          "B": "2",
          "C": {
            "X": "Something",
            "Y": "Else"
          }
        }
      }
    ],
    "identifier": 52303570
  },
  {
    "context": [
      "I two variables as the Date and Artist Name, and I am trying to pull back the ArtistLink depending on the variables.",
      "we could write:",
      "< test.json jq -r --arg testdate \"$testdate\" --arg testname \"$testname\" '\n        .[]\n        | select((.Date == $testdate) and (.ArtistName | contains($testname)))\n        | .AlbumLink '"
    ],
    "utterance": "Retrieve the AlbumLink for items where Date equals a given value and ArtistName contains a given string.",
    "expressions": [
      ".[] | select((.Date == $testdate) and (.ArtistName | contains($testname))) | .AlbumLink"
    ],
    "data": [
      {
        "input": [
          {
            "AlbumTitle": "Name Of Album",
            "AlbumLink": "/album/link/id/1/album-name/",
            "ArtistName": "Artist Name",
            "Date": "September 14, 2018"
          },
          {
            "AlbumTitle": "Name Of Album",
            "AlbumLink": "/album/link/id/2/album-name/",
            "ArtistName": "Artist Name",
            "Date": "September 13, 2018"
          }
        ],
        "output": "/album/link/id/2/album-name/"
      }
    ],
    "identifier": 52429120
  },
  {
    "context": [
      "I need to get 'name' element based on search results for that specific entry",
      "$ jq --arg arg1 'var4' '.regions | if (to_entries[].value.domains[$arg1]) then to_entries[].value.name else empty end' json.txt",
      "I want the result to only fetch\n\n    \"City 2\"",
      ".regions | to_entries[] | if .value.domains[$arg1] then .value.name else empty end",
      ".regions | to_entries[] | .value | select(.domains[$arg1]) | .name"
    ],
    "utterance": "Return the name of the region whose domains contain a specific key, such as 'var4'.",
    "expressions": [
      ".regions | to_entries[] | if .value.domains[$arg1] then .value.name else empty end",
      ".regions | to_entries[] | .value | select(.domains[$arg1]) | .name"
    ],
    "data": [
      {
        "input": {
          "regions": {
            "var1": {
              "name": "City 1",
              "domains": {
                "var3": {
                  "Owner": "Joe"
                }
              }
            },
            "var2": {
              "name": "City 2",
              "domains": {
                "var4": {
                  "Owner": "Brown"
                }
              }
            }
          }
        },
        "output": "City 2"
      }
    ],
    "identifier": 52428038
  },
  {
    "context": [
      "My requirement is to find records where key name is `dev` and then print the id key.",
      "jq '.data[] | select(.name == \"dev\") | .id' file"
    ],
    "utterance": "Find entries where name is \"dev\" and print their id values.",
    "expressions": [
      ".data[] | select(.name == \"dev\") | .id"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "34c4s5f7-175f-480a-adff-d8d0bef4e8c4",
              "name": "test",
              "organizationId": "7er337a-714c-4043-90b1-6a4e7we82d87",
              "isProduction": false,
              "type": "test",
              "clientId": "6d4720062eab494c45ewedaa78de1"
            },
            {
              "id": "4856a92-9e46-4430-aac7-6ed8674569f",
              "name": "dev",
              "organizationId": "7er337a-714c-4043-90b1-6a4e7we82d87",
              "isProduction": false,
              "type": "sandbox",
              "clientId": "bs34dea7749494daa8deert908bcd9"
            }
          ],
          "total": 2
        },
        "output": "4856a92-9e46-4430-aac7-6ed8674569f"
      }
    ],
    "identifier": 52437569
  },
  {
    "context": [
      "I'd like to replace the tokens in `text` with the variables defined in `ma`. Input JSON:\r\n\r\n    {\r\n        \"ma\":{\r\n            \"a\":\"1\",\r\n            \"b\":\"2\",\r\n            \"c\":\"3\"\r\n        },\r\n        \"mb\":{\r\n            \"a\":\"11\"\r\n        },\r\n        \"text\":\"https://ph.com?a={a}&b={b}\"\r\n    }\r\n\r\nDesired result: `https://ph.com?a=1&b=2`",
      "Extra credit, how can I have `mb` variables take precedence over `ma` variables so that my resulting text is: `https://ph.com?a=11&b=2` ?",
      "def format($map): gsub(\"\\\\{(?<key>[^}]+)\\\\}\"; \"\\($map[.key])\");",
      ".ma as $map | .text | format($map)",
      "(.ma * .mb) as $map | .text | format($map)"
    ],
    "utterance": "Replace the {a} and {b} tokens in the text property with corresponding values from ma, and optionally have mb take precedence over ma for conflicts.",
    "expressions": [
      "def format($map): gsub(\"\\\\{(?<key>[^}]+)\\\\}\"; \"\\($map[.key])\"); .ma as $map | .text | format($map)",
      "def format($map): gsub(\"\\\\{(?<key>[^}]+)\\\\}\"; \"\\($map[.key])\"); (.ma * .mb) as $map | .text | format($map)"
    ],
    "data": [
      {
        "input": {
          "ma": {
            "a": "1",
            "b": "2",
            "c": "3"
          },
          "mb": {
            "a": "11"
          },
          "text": "https://ph.com?a={a}&b={b}"
        },
        "output": "https://ph.com?a=1&b=2"
      },
      {
        "input": {
          "ma": {
            "a": "1",
            "b": "2",
            "c": "3"
          },
          "mb": {
            "a": "11"
          },
          "text": "https://ph.com?a={a}&b={b}"
        },
        "output": "https://ph.com?a=11&b=2"
      }
    ],
    "identifier": 52429459
  },
  {
    "context": [
      "I would like to trasform it adding a property to the `something` object, using the value from the `name` property of the parent, like:",
      "Which jq expression can do this?",
      ".array |= map(.something.NEW_PROPERTY = .name)",
      ".array[] |= (.something.NEW_PROPERTY = .name)"
    ],
    "utterance": "Add a property NEW_PROPERTY to each something object inside array, where the value is set to the parent object's name property.",
    "expressions": [
      ".array |= map(.something.NEW_PROPERTY = .name)",
      ".array[] |= (.something.NEW_PROPERTY = .name)"
    ],
    "data": [
      {
        "input": {
          "first": {
            "second": "A"
          },
          "array": [
            {
              "name": "AAA",
              "something": {
                "hola": "hi"
              }
            },
            {
              "name": "BBB",
              "something": {
                "hola": "hi"
              }
            }
          ]
        },
        "output": {
          "first": {
            "second": "A"
          },
          "array": [
            {
              "name": "AAA",
              "something": {
                "hola": "hi",
                "NEW_PROPERTY": "AAA"
              }
            },
            {
              "name": "BBB",
              "something": {
                "hola": "hi",
                "NEW_PROPERTY": "BBB"
              }
            }
          ]
        }
      }
    ],
    "identifier": 52441157
  },
  {
    "context": [
      "I have two json inputs and I want [jq][1] to build a new json copying the elements from the 2nd array to the **corresponding position** in the 1st",
      "expected result:",
      "[ {\"foo\": \"foo1\", \"bar\": \"bar1\", \"baz\": \"baz1\"}, {\"foo\": \"foo2\", \"bar\": \"bar2\", \"baz\": \"baz2\"}, {\"foo\": \"foo3\", \"bar\": \"bar3\", \"baz\": \"baz3\"} ]",
      "assuming the file `merge.jq` contains:\n\n    .[1][0] as $two\n    | .[0]\n    | reduce range(0; length) as $i (.;\n        .[$i].baz = $two[$i] )",
      "assuming `merge.jq` contains:\n\n    reduce range(0; length) as $i (.; \n      .[$i].baz = $two[0][$i] )"
    ],
    "utterance": "For each object in the first input array, add a new field 'baz' whose value comes from the corresponding element in the second input array.",
    "expressions": [
      ".[1][0] as $two | .[0] | reduce range(0; length) as $i (. ; .[$i].baz = $two[$i])",
      "reduce range(0; length) as $i (. ; .[$i].baz = $two[0][$i])"
    ],
    "data": [
      {
        "input": [
          [
            {
              "foo": "foo1",
              "bar": "bar1"
            },
            {
              "foo": "foo2",
              "bar": "bar2"
            },
            {
              "foo": "foo3",
              "bar": "bar3"
            }
          ],
          [
            [
              "baz1",
              "baz2",
              "baz3"
            ]
          ]
        ],
        "output": [
          {
            "foo": "foo1",
            "bar": "bar1",
            "baz": "baz1"
          },
          {
            "foo": "foo2",
            "bar": "bar2",
            "baz": "baz2"
          },
          {
            "foo": "foo3",
            "bar": "bar3",
            "baz": "baz3"
          }
        ]
      }
    ],
    "identifier": 52446068
  },
  {
    "context": [
      "I want to loop through that array, take each object, and append it to a new file based on a field in the object (in this case, the state name).",
      "I want to filter it out to a file for each state.",
      "I'm using an existing JQ expression to filter for only the data I actually need:",
      "{ fipscode: .fipscode, level: .level, polid: .polid, polnum: .polnum, precinctsreporting: .precinctsreporting, precinctsreportingpct: .precinctsreportingpct, precinctstotal: .precinctstotal, raceid: .raceid, runoff: .runoff, statepostal: .statepostal, votecount: .votecount, votepct: .votepct, winner: .winner }",
      "As output, I would expect to have a `Arizona.json` containing only the item(s) from that state, and also filtered to remove unwanted fields:",
      "Here's a simple solution piggybacking on what you started with:",
      "< master.json jq -cn --stream 'fromstream(1|truncate_stream(inputs))' | jq -cr '.statename, { fipscode, level, polid, polnum, precinctsreporting, precinctsreportingpct, precinctstotal, raceid, runoff, statepostal, votecount, votepct, winner }' | while read -r statename && read -r object do echo \"$object\" >> \"$statename.json\" done",
      "With your [original] sample data, the above produces Arizona.json, Florida.json, and Oklahoma.json"
    ],
    "utterance": "For each object, extract only the specified fields and write it to a file named after the object's state name, grouping all objects of a given state into the corresponding file.",
    "expressions": [
      ".[] | [.statename, { fipscode, level, polid, polnum, precinctsreporting, precinctsreportingpct, precinctstotal, raceid, runoff, statepostal, votecount, votepct, winner }] | @tsv",
      ".[] | { fipscode, level, polid, polnum, precinctsreporting, precinctsreportingpct, precinctstotal, raceid, runoff, statepostal, votecount, votepct, winner }"
    ],
    "data": [
      {
        "input": [
          {
            "ballotorder": 2,
            "candidateid": "9718",
            "delegatecount": 0,
            "description": null,
            "electiondate": "2018-08-28",
            "electtotal": 0,
            "electwon": 0,
            "fipscode": null,
            "first": "Doug",
            "id": "3015-polid-64364-state-AZ-1",
            "incumbent": true,
            "initialization_data": false,
            "is_ballot_measure": false,
            "last": "Ducey",
            "lastupdated": "2018-08-30T00:01:38.897Z",
            "level": "state",
            "national": true,
            "officeid": "G",
            "officename": "Governor",
            "party": "GOP",
            "polid": "64364",
            "polnum": "5554",
            "precinctsreporting": 1488,
            "precinctsreportingpct": 0.9993000000000001,
            "precinctstotal": 1489,
            "raceid": "3015",
            "racetype": "Primary",
            "racetypeid": "R",
            "reportingunitid": "state-AZ-1",
            "reportingunitname": null,
            "runoff": false,
            "seatname": null,
            "seatnum": null,
            "statename": "Arizona",
            "statepostal": "AZ",
            "test": false,
            "uncontested": false,
            "votecount": 355455,
            "votepct": 0.705493,
            "winner": true
          },
          {
            "ballotorder": 2,
            "candidateid": "21689",
            "delegatecount": 0,
            "description": null,
            "electiondate": "2018-08-28",
            "electtotal": 0,
            "electwon": 0,
            "fipscode": null,
            "first": "Ron",
            "id": "10046-polid-62557-state-FL-1",
            "incumbent": false,
            "initialization_data": false,
            "is_ballot_measure": false,
            "last": "DeSantis",
            "lastupdated": "2018-08-29T19:29:50.367Z",
            "level": "state",
            "national": true,
            "officeid": "G",
            "officename": "Governor",
            "party": "GOP",
            "polid": "62557",
            "polnum": "13918",
            "precinctsreporting": 5968,
            "precinctsreportingpct": 1.0,
            "precinctstotal": 5968,
            "raceid": "10046",
            "racetype": "Primary",
            "racetypeid": "R",
            "reportingunitid": "state-FL-1",
            "reportingunitname": null,
            "runoff": false,
            "seatname": null,
            "seatnum": null,
            "statename": "Florida",
            "statepostal": "FL",
            "test": false,
            "uncontested": false,
            "votecount": 913997,
            "votepct": 0.564728,
            "winner": true
          },
          {
            "ballotorder": 2,
            "candidateid": "45555",
            "delegatecount": 0,
            "description": null,
            "electiondate": "2018-08-28",
            "electtotal": 0,
            "electwon": 0,
            "fipscode": null,
            "first": "Rex",
            "id": "38538-polid-67011-state-OK-1",
            "incumbent": false,
            "initialization_data": false,
            "is_ballot_measure": false,
            "last": "Lawhorn",
            "lastupdated": "2018-08-29T02:44:44.610Z",
            "level": "state",
            "national": true,
            "officeid": "G",
            "officename": "Governor",
            "party": "Lib",
            "polid": "67011",
            "polnum": "40784",
            "precinctsreporting": 1951,
            "precinctsreportingpct": 1.0,
            "precinctstotal": 1951,
            "raceid": "38538",
            "racetype": "Runoff",
            "racetypeid": "L",
            "reportingunitid": "state-OK-1",
            "reportingunitname": null,
            "runoff": false,
            "seatname": null,
            "seatnum": null,
            "statename": "Oklahoma",
            "statepostal": "OK",
            "test": false,
            "uncontested": false,
            "votecount": 379,
            "votepct": 0.409287,
            "winner": false
          }
        ],
        "output": [
          {
            "fipscode": null,
            "level": "state",
            "polid": "64364",
            "polnum": "5554",
            "precinctsreporting": 1488,
            "precinctsreportingpct": 0.9993000000000001,
            "precinctstotal": 1489,
            "raceid": "3015",
            "runoff": false,
            "statepostal": "AZ",
            "votecount": 355455,
            "votepct": 0.705493,
            "winner": true
          }
        ]
      }
    ],
    "identifier": 52391042
  },
  {
    "context": [
      "On the other hand, I find `jq` a lot easier to work with. This should yield the same results as json.",
      "$ aws-cli ... | jq '[.Reservations[].Instances[] |\n    { InstanceId, type: .InstanceType } +\n    (.BlockDeviceMappings[] | {\n        Devicename: .DeviceName,\n        Persistence_on: .Ebs.DeleteOnTermination,\n        Status: .Ebs.Status,\n        Volume_id: .Ebs.VolumeId\n    })\n]'"
    ],
    "utterance": "Return an array where each object combines an instance's InstanceId and InstanceType with each of its block device's DeviceName, DeleteOnTermination, Status, and VolumeId.",
    "expressions": [
      "[.Reservations[].Instances[] | { InstanceId, type: .InstanceType } + (.BlockDeviceMappings[] | { Devicename: .DeviceName, Persistence_on: .Ebs.DeleteOnTermination, Status: .Ebs.Status, Volume_id: .Ebs.VolumeId })]"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Groups": [],
              "Instances": [
                {
                  "AmiLaunchIndex": 0,
                  "ImageId": "ami-2a7d75c0",
                  "InstanceId": "i-099569e17a368446b",
                  "InstanceType": "t2.micro",
                  "KeyName": "ar_ecs_key",
                  "LaunchTime": "2018-08-18T17:59:49.000Z",
                  "Monitoring": {
                    "State": "disabled"
                  },
                  "Placement": {
                    "AvailabilityZone": "eu-west-1c",
                    "GroupName": "",
                    "Tenancy": "default"
                  },
                  "PrivateDnsName": "ip-172-31-46-99.eu-west-1.compute.internal",
                  "PrivateIpAddress": "172.31.46.99",
                  "ProductCodes": [],
                  "PublicDnsName": "ec2-34-245-58-217.eu-west-1.compute.amazonaws.com",
                  "PublicIpAddress": "34.245.58.217",
                  "State": {
                    "Code": 16,
                    "Name": "running"
                  },
                  "StateTransitionReason": "",
                  "SubnetId": "subnet-3407646f",
                  "VpcId": "vpc-24ddec43",
                  "Architecture": "x86_64",
                  "BlockDeviceMappings": [
                    {
                      "DeviceName": "/dev/sda1",
                      "Ebs": {
                        "AttachTime": "2018-08-18T17:59:49.000Z",
                        "DeleteOnTermination": true,
                        "Status": "attached",
                        "VolumeId": "vol-0d9f4ab048e7999b7"
                      }
                    }
                  ],
                  "ClientToken": "",
                  "EbsOptimized": false,
                  "EnaSupport": true,
                  "Hypervisor": "xen",
                  "NetworkInterfaces": [
                    {
                      "Association": {
                        "IpOwnerId": "amazon",
                        "PublicDnsName": "ec2-34-245-58-217.eu-west-1.compute.amazonaws.com",
                        "PublicIp": "34.245.58.217"
                      },
                      "Attachment": {
                        "AttachTime": "2018-08-18T17:59:49.000Z",
                        "AttachmentId": "eni-attach-0bbfc61bf0a6729ad",
                        "DeleteOnTermination": true,
                        "DeviceIndex": 0,
                        "Status": "attached"
                      },
                      "Description": "",
                      "Groups": [
                        {
                          "GroupName": "default",
                          "GroupId": "sg-98ce7ee3"
                        }
                      ],
                      "Ipv6Addresses": [],
                      "MacAddress": "0a:df:58:fe:e5:d2",
                      "NetworkInterfaceId": "eni-02dcc4cbc45726b77",
                      "OwnerId": "300746241447",
                      "PrivateDnsName": "ip-172-31-46-99.eu-west-1.compute.internal",
                      "PrivateIpAddress": "172.31.46.99",
                      "PrivateIpAddresses": [
                        {
                          "Association": {
                            "IpOwnerId": "amazon",
                            "PublicDnsName": "ec2-34-245-58-217.eu-west-1.compute.amazonaws.com",
                            "PublicIp": "34.245.58.217"
                          },
                          "Primary": true,
                          "PrivateDnsName": "ip-172-31-46-99.eu-west-1.compute.internal",
                          "PrivateIpAddress": "172.31.46.99"
                        }
                      ],
                      "SourceDestCheck": true,
                      "Status": "in-use",
                      "SubnetId": "subnet-3407646f",
                      "VpcId": "vpc-24ddec43"
                    }
                  ],
                  "RootDeviceName": "/dev/sda1",
                  "RootDeviceType": "ebs",
                  "SecurityGroups": [
                    {
                      "GroupName": "default",
                      "GroupId": "sg-98ce7ee3"
                    }
                  ],
                  "SourceDestCheck": true,
                  "Tags": [
                    {
                      "Key": "webserver",
                      "Value": "production"
                    }
                  ],
                  "VirtualizationType": "hvm"
                }
              ],
              "OwnerId": "300746241447",
              "ReservationId": "r-047aab5e090b741af"
            }
          ]
        },
        "output": [
          {
            "InstanceId": "i-099569e17a368446b",
            "type": "t2.micro",
            "Devicename": "/dev/sda1",
            "Persistence_on": true,
            "Status": "attached",
            "Volume_id": "vol-0d9f4ab048e7999b7"
          }
        ]
      }
    ],
    "identifier": 51935775
  }
]