[
  {
    "context": [
      "I need to filter json data based on specific values, and based on that filter edit other values and increment others",
      "here is the expected the result",
      "{\r\n  \"x-ID.0\": {\r\n    \"_file.m3u.name\": \"filename.ext\",\r\n    \"name\": \"CHANNEL1 HD\",\r\n    \"logo\": \"CHANNEL1.png\",\r\n    \"x-channelID\": \"100\"\r\n  },\r\n   \"x-ID.4\": {\r\n    \"_file.m3u.name\": \"filename.ext\",\r\n    \"name\": \"CHANNEL1 SD\",\r\n    \"logo\": \"CHANNEL1.png\",\r\n    \"x-channelID\": \"101\"\r\n  }\r\n}",
      "You can use the following :",
      "to_entries | map(select(.value.name|strings|contains(\"CHANNEL1\"))) | [foreach .[] as $keyvalue (99; .+1; { key: $keyvalue.key, value: ($keyvalue.value + {\"x-channelID\": .})})] | from_entries"
    ],
    "utterance": "Filter objects whose name contains CHANNEL1, and for those, update name (removing the last word), set logo to 'CHANNEL1.png', and assign consecutive x-channelID values starting from 100.",
    "expressions": [
      "to_entries | map(select(.value.name|strings|contains(\"CHANNEL1\"))) | [foreach .[] as $keyvalue (99; .+1; { key: $keyvalue.key, value: ($keyvalue.value + {\"x-channelID\": (tostring), \"name\": ($keyvalue.value.name|sub(\" HD TV$\"; \" HD\")|sub(\" SD$\"; \" SD\")), \"logo\": \"CHANNEL1.png\"})})] | from_entries"
    ],
    "data": [
      {
        "input": {
          "x-ID.0": {
            "_file.name": "filename.ext",
            "name": "CHANNEL1 HD TV",
            "logo": "file.png",
            "x-channelID": "726"
          },
          "x-ID.2": {
            "_file.m3u.name": "filename.ext",
            "name": "CHANNEL2",
            "logo": "file.png",
            "x-channelID": "106"
          },
          "x-ID.3": {
            "_file.m3u.name": "filename.ext",
            "name": "CHANNEL3 SD",
            "logo": "file.png",
            "x-channelID": "236"
          },
          "x-ID.4": {
            "_file.m3u.name": "filename.ext",
            "name": "CHANNEL1 SD",
            "logo": "file.png",
            "x-channelID": "726"
          },
          "x-ID.5": {
            "_file.m3u.name": "filename.ext",
            "name": "CHANNEL2 HD",
            "logo": "file.png",
            "x-channelID": "726"
          }
        },
        "output": {
          "x-ID.0": {
            "_file.m3u.name": "filename.ext",
            "name": "CHANNEL1 HD",
            "logo": "CHANNEL1.png",
            "x-channelID": "100"
          },
          "x-ID.4": {
            "_file.m3u.name": "filename.ext",
            "name": "CHANNEL1 SD",
            "logo": "CHANNEL1.png",
            "x-channelID": "101"
          }
        }
      }
    ],
    "identifier": 58763507
  },
  {
    "context": [
      "But that returns string and I need to iterate through received array. What I need to do with these values: 1. Get pairs; 2. Change Unix TimeStamp to readable one; 3. Save in CSV. How can I extract get the array as the output?",
      "You could do all of it in `jq`, e.g.:",
      "jq -r '.data.result[].values | .[] | .[0] |= strftime(\"%Y-%m-%d %H:%M\") | @csv'",
      "\"2019-11-11 06:11\",\"36380.58030773418\""
    ],
    "utterance": "For each pair in all result values, convert the Unix timestamp to a readable date and output both values as CSV rows.",
    "expressions": [
      ".data.result[].values | .[] | .[0] |= strftime(\"%Y-%m-%d %H:%M\") | @csv"
    ],
    "data": [
      {
        "input": {
          "status": "success",
          "data": {
            "resultType": "matrix",
            "result": [
              {
                "metric": {
                  "container_name": "name1"
                },
                "values": [
                  [
                    1573452693.024,
                    "36380.58030773418"
                  ],
                  [
                    1573452707.024,
                    "51397.82785694454"
                  ],
                  [
                    1573452721.024,
                    "38711.55804872829"
                  ],
                  [
                    1573452735.024,
                    "47801.74418514242"
                  ],
                  [
                    1573452749.024,
                    "42140.81258908656"
                  ]
                ]
              }
            ]
          }
        },
        "output": [
          "\"2019-11-11 06:11\",\"36380.58030773418\"",
          "\"2019-11-11 06:11\",\"51397.82785694454\"",
          "\"2019-11-11 06:12\",\"38711.55804872829\"",
          "\"2019-11-11 06:12\",\"47801.74418514242\"",
          "\"2019-11-11 06:12\",\"42140.81258908656\""
        ]
      }
    ],
    "identifier": 58799674
  },
  {
    "context": [
      "JQ command to extract [FAILS]\n```\njq -r '.Objects[]\n  | select(.ObjectElementName | test(\"ABC\"))\n  | [.ObjectElementName,.ObjectNested,.ObjectElementUnit]\n  |@csv' input.json\n```",
      "Output CSV required (or variation, so long as ObjectNested appears into a single column in CSV)\n```\nObjectElementName,ObjectNested,ObjectElementUnit\n\"Test ABC 1\",\"0:0\",\"2\"\n\"Test ABC 2\",\"0:15,1:20\",\"5\"\n```",
      "With `keys_unsorted` and string interpolation, it's easy to turn `ObjectNested` into the form you desired:\n```\n.Objects[] | select(.ObjectElementName | index(\"ABC\")) | [\n    .ObjectElementName,\n    ([.ObjectNested | keys_unsorted[] as $k | \"\\($k):\\(.[$k])\"] | join(\",\")),\n    .ObjectElementUnit\n] | @csv\n```"
    ],
    "utterance": "Extract all objects whose ObjectElementName contains 'ABC', outputting their ObjectElementName, ObjectElementUnit, and ObjectNested rendered as a single comma-separated string of key:value pairs.",
    "expressions": [
      ".Objects[] | select(.ObjectElementName | index(\"ABC\")) | [\n    .ObjectElementName,\n    ([.ObjectNested | keys_unsorted[] as $k | \"\\($k):\\(.[$k])\"] | join(\",\")),\n    .ObjectElementUnit\n] | @csv"
    ],
    "data": [
      {
        "input": {
          "Other": [],
          "Objects": [
            {
              "ObjectElementName": "Test 123",
              "ObjectElementArray": [],
              "ObjectNested": {
                "0": 20,
                "1": 10.5
              },
              "ObjectElementUnit": "1"
            },
            {
              "ObjectElementName": "Test ABC 1",
              "ObjectElementArray": [],
              "ObjectNested": {
                "0": 0
              },
              "ObjectElementUnit": "2"
            },
            {
              "ObjectElementName": "Test ABC 2",
              "ObjectElementArray": [],
              "ObjectNested": {
                "0": 15,
                "1": 20
              },
              "ObjectElementUnit": "5"
            }
          ],
          "Language": "en-US"
        },
        "output": [
          "\"Test ABC 1\",\"0:0\",\"2\"",
          "\"Test ABC 2\",\"0:15,1:20\",\"5\""
        ]
      }
    ],
    "identifier": 58994950
  },
  {
    "context": [
      "aws ec2 describe-security-groups | jq '.SecurityGroups[]| \"\\(.GroupId)\"'",
      "Add the `-r` flag to the `jq` call to get raw output (which removes the quotes around output)",
      "result=$(aws ec2 describe-security-groups | jq -r '.SecurityGroups[].GroupId')",
      "jq -r '.SecurityGroups[] | .GroupId'"
    ],
    "utterance": "Extract all SecurityGroup GroupId values as separate lines.",
    "expressions": [
      ".SecurityGroups[] | .GroupId",
      ".SecurityGroups[].GroupId"
    ],
    "identifier": 58803249
  },
  {
    "context": [
      "Given your sample input this should do it:\n```\nmap(.timestamp |= .[:10])\n```",
      "If this looks oversimplifying, take a look at [jq's date manipulation builtins](https://stedolan.github.io/jq/manual/#Dates); you **probably** don't need an external tool here.",
      "jq  '[.[]  | .timestamp |= (sub(\"\\.[0-9]+Z$\"; \"Z\")  | fromdate | strftime(\"%Y-%m-%d\"))]' time.json",
      "produces \n[\n  {\n    \"timestamp\": \"2019-01-01\"\n  },\n  {\n    \"timestamp\": \"2019-01-02\"\n  },\n  {\n    \"timestamp\": \"2019-01-02\"\n  }\n]\n",
      "The sub is because jq does *not* support milliseconds by default.  So in order to use the built in datetime functions you have to drop the milliseconds.",
      "jq --argjson update \"$(jq -r '.[] | .timestamp' input.json |\n    while read r ; do\n      date --date=\"$r\" \"+%Y-%m-%d\" \n    done |\n    jq -nR [inputs] )\" '\n      reduce range(0;$update|length) as $i (.;\n        .[$i].timestamp = $update[$i])\n    ' input.json"
    ],
    "utterance": "Convert each object's timestamp from an ISO timestamp with milliseconds to only the date part in YYYY-MM-DD format.",
    "expressions": [
      "map(.timestamp |= .[:10])",
      "[.[] | .timestamp |= (sub(\"\\.[0-9]+Z$\"; \"Z\") | fromdate | strftime(\"%Y-%m-%d\"))]"
    ],
    "data": [
      {
        "input": [
          {
            "timestamp": "2019-01-01T10:00:00.000Z"
          },
          {
            "timestamp": "2019-01-02T10:00:00.000Z"
          },
          {
            "timestamp": "2019-01-02T10:00:00.000Z"
          }
        ],
        "output": [
          {
            "timestamp": "2019-01-01"
          },
          {
            "timestamp": "2019-01-02"
          },
          {
            "timestamp": "2019-01-02"
          }
        ]
      }
    ],
    "identifier": 58786238
  },
  {
    "context": [
      "I would like as output this same json, but with the nested objects in `.[].records[].releases[].parties` flattened, so the desired output should be:",
      "if you want to replace only a sub part you can use `|=`  instead of `|` , just after `.parties`",
      "So i think this will achieve your goal :",
      ".[].records[].releases[].parties |= \n  (. as $ho \n   | reduce paths(scalars) as $path ({};\n       . + {($path | map(tostring) | join(\".\")):\n             $ho | getpath($path)}))"
    ],
    "utterance": "Flatten each object in the parties array at the path .[].records[].releases[].parties so that each scalar value is mapped to a key with its path, replacing each parties array with the resulting flattened object, and keep the rest of the structure unchanged.",
    "expressions": [
      ".[].records[].releases[].parties |= (. as $ho | reduce paths(scalars) as $path ({}; . + {($path | map(tostring) | join(\".\")) : $ho | getpath($path)}))"
    ],
    "data": [
      {
        "input": {
          "k1": "v1",
          "k2": "v2",
          "k3": "v3",
          "k4": [],
          "records": [
            {
              "kk1": "vv1",
              "kk2": [
                "vv2"
              ],
              "releases": [
                {
                  "kkk1": "vvv1"
                },
                {
                  "parties": [
                    {
                      "name": "value",
                      "kkkk1": "value"
                    },
                    {
                      "name": "value",
                      "kkkk1": "value"
                    }
                  ]
                }
              ],
              "kk4": "vv4",
              "kk5": "vv5"
            },
            {
              "kk1": "o_vv1",
              "kk2": [
                "o_vv2"
              ],
              "releases": [
                {
                  "kkk1": "o_vvv1"
                },
                {
                  "parties": [
                    {
                      "name": "o_value",
                      "kkkk1": "o_value"
                    },
                    {
                      "name": "o_value",
                      "kkkk1": "o_value"
                    }
                  ]
                }
              ],
              "kk4": "o_vv4",
              "kk5": "o_vv5"
            }
          ],
          "k6": "v6"
        },
        "output": {
          "k1": "v1",
          "k2": "v2",
          "k3": "v3",
          "k4": [],
          "records": [
            {
              "kk1": "vv1",
              "kk2": [
                "vv2"
              ],
              "releases": [
                {
                  "kkk1": "vvv1"
                },
                {
                  "parties.0.name": "value",
                  "parties.0.kkkk1": "value",
                  "parties.1.name": "value",
                  "parties.1.kkkk1": "value"
                }
              ],
              "kk4": "vv4",
              "kk5": "vv5"
            },
            {
              "kk1": "o_vv1",
              "kk2": [
                "o_vv2"
              ],
              "releases": [
                {
                  "kkk1": "o_vvv1"
                },
                {
                  "parties.0.name": "o_value",
                  "parties.0.kkkk1": "o_value",
                  "parties.1.name": "o_value",
                  "parties.1.kkkk1": "o_value"
                }
              ],
              "kk4": "o_vv4",
              "kk5": "o_vv5"
            }
          ],
          "k6": "v6"
        }
      }
    ],
    "identifier": 58914494
  },
  {
    "context": [
      "Ultimately the key/value for a missing `priceDimension` should be omitted alltogetger as shown below. How to do that?",
      "Try this,\r\n\r\n    .priceDimensions |= {\r\n         ufrontFee: .[] | select(.unit == \"Quantity\").USD,\r\n         hourFee:   .[] | select(.unit == \"Hrs\").USD\r\n    } | delpaths([path(..?) as $p | select(getpath($p) == null) | $p])",
      "I have found this solution:\r\n\r\n```\r\n.priceDimensions |=\r\n  ({ ufrontFee: .[] | select(.unit == \"Quantity\").USD } // null)\r\n  +\r\n  ({ hourFee:   .[] | select(.unit == \"Hrs\").USD } // null)\r\n```",
      "using a custom function I can write it a little bit shorter:\r\n\r\ndef optional_cost($k; $cmp):\r\n    { ($k): .[] | select(.unit == $cmp).USD } // null;\r\n    \r\n.priceDimensions |=\r\n    optional_cost(\"ufrontFee\"; \"Quantity\")\r\n    + optional_cost(\"hourFee\"; \"Hrs\")"
    ],
    "utterance": "Transform the priceDimensions object so that only present entries with unit == \"Quantity\" (as ufrontFee) and unit == \"Hrs\" (as hourFee) are included, omitting missing keys entirely.",
    "expressions": [
      ".priceDimensions |= {\n     ufrontFee: .[] | select(.unit == \"Quantity\").USD,\n     hourFee:   .[] | select(.unit == \"Hrs\").USD\n} | delpaths([path(..?) as $p | select(getpath($p) == null) | $p])",
      ".priceDimensions |=\n  ({ ufrontFee: .[] | select(.unit == \"Quantity\").USD } // null)\n  +\n  ({ hourFee:   .[] | select(.unit == \"Hrs\").USD } // null)",
      "def optional_cost($k; $cmp):\n    { ($k): .[] | select(.unit == $cmp).USD } // null;\n\n.priceDimensions |=\n    optional_cost(\"ufrontFee\"; \"Quantity\")\n    + optional_cost(\"hourFee\"; \"Hrs\")"
    ],
    "data": [
      {
        "input": {
          "priceDimensions": {
            "222FSQ7X57S9DN65.NQ3QZPMQV9.2TG2D8R56U": {
              "unit": "Quantity",
              "description": "Upfront Fee",
              "USD": "493999"
            },
            "222FSQ7X57S9DN65.NQ3QZPMQV9.6YS6EN2CT7": {
              "unit": "Hrs",
              "description": "...",
              "USD": "0.0000000000"
            }
          },
          "foo": "bar",
          "bla": "blub"
        },
        "output": {
          "priceDimensions": {
            "ufrontFee": "493999",
            "hourFee": "0.0000000000"
          },
          "foo": "bar",
          "bla": "blub"
        }
      },
      {
        "input": {
          "priceDimensions": {
            "222FSQ7X57S9DN65.NQ3QZPMQV9.6YS6EN2CT7": {
              "unit": "Hrs",
              "description": "...",
              "USD": "0.0000000000"
            }
          },
          "foo": "bar",
          "bla": "blub"
        },
        "output": {
          "priceDimensions": {
            "hourFee": "0.0000000000"
          },
          "foo": "bar",
          "bla": "blub"
        }
      },
      {
        "input": {
          "priceDimensions": {},
          "foo": "bar",
          "bla": "blub"
        },
        "output": {
          "priceDimensions": {},
          "foo": "bar",
          "bla": "blub"
        }
      }
    ],
    "identifier": 58814098
  },
  {
    "context": [
      "if a key exists in the second object, I'd like to use it to override values in the first.",
      "In the first example, the second object does not contain a \"foo\" key, so the override does not happen.  In the 2nd example, the second object does contain \"foo\", so the value is changed.",
      "With `-n` flag specified on the command line this should do the trick:",
      "reduce inputs as $in (input; . * ($in.foo // {}))"
    ],
    "utterance": "Recursively override values using the contents of the 'foo' key from each subsequent object if it exists.",
    "expressions": [
      "reduce inputs as $in (input; . * ($in.foo // {}))"
    ],
    "data": [
      {
        "input": [
          {
            "a": "value"
          },
          {
            "bar": {
              "a": "override"
            }
          }
        ],
        "output": {
          "a": "value"
        }
      },
      {
        "input": [
          {
            "a": "value"
          },
          {
            "foo": {
              "a": "override"
            }
          }
        ],
        "output": {
          "a": "override"
        }
      }
    ],
    "identifier": 58964432
  },
  {
    "context": [
      "My question is: How can I pass an integer to this command and remove these many names, starting from the most recent created (bottom)?",
      "`jq 'sort_by(.properties.creationTime) | .[-4:] | .[].name'`",
      "Where -4 is the amount of names to display starting from the bottom.",
      "slicing should work:",
      "jq 'sort_by(.properties.creationTime) | .[-1:]'"
    ],
    "utterance": "Select a specified number of names from the end of objects sorted by creationTime, starting with the most recent.",
    "expressions": [
      "sort_by(.properties.creationTime) | .[-N:] | .[].name"
    ],
    "data": [
      {
        "input": [
          {
            "content": null,
            "deleted": false,
            "metadata": null,
            "name": "name/windows-2016-osDisk.170b8936-d66d-4139-a409-26f4e9d354fe.vhd",
            "properties": {
              "appendBlobCommittedBlockCount": null,
              "blobTier": "P10",
              "blobTierChangeTime": null,
              "blobTierInferred": true,
              "blobType": "PageBlob",
              "contentLength": 136367309312,
              "contentRange": null,
              "contentSettings": {
                "cacheControl": null,
                "contentDisposition": null,
                "contentEncoding": null,
                "contentLanguage": null,
                "contentMd5": "-0q970378r08==",
                "contentType": "application/octet-stream"
              },
              "copy": {
                "completionTime": null,
                "id": null,
                "progress": null,
                "source": null,
                "status": null,
                "statusDescription": null
              },
              "creationTime": "2019-11-21T08:34:33+00:00",
              "deletedTime": null,
              "etag": "0237502375",
              "lastModified": "2019-11-21T08:34:33+00:00",
              "lease": {
                "duration": null,
                "state": "available",
                "status": "unlocked"
              },
              "pageBlobSequenceNumber": null,
              "remainingRetentionDays": null,
              "sequenceNumber": 1,
              "serverEncrypted": true
            },
            "snapshot": null
          },
          {
            "content": null,
            "deleted": false,
            "metadata": null,
            "name": "name/windows-2019-osDisk.f122fb3c-0edb-42a8-b98c-56657b447f15.vhd",
            "properties": {
              "appendBlobCommittedBlockCount": null,
              "blobTier": "P10",
              "blobTierChangeTime": null,
              "blobTierInferred": true,
              "blobType": "PageBlob",
              "contentLength": 136367309312,
              "contentRange": null,
              "contentSettings": {
                "cacheControl": null,
                "contentDisposition": null,
                "contentEncoding": null,
                "contentLanguage": null,
                "contentMd5": "0237502375/hKOg==",
                "contentType": "application/octet-stream"
              },
              "copy": {
                "completionTime": null,
                "id": null,
                "progress": null,
                "source": null,
                "status": null,
                "statusDescription": null
              },
              "creationTime": "2019-11-21T08:35:03+00:00",
              "deletedTime": null,
              "etag": "20397520i3h523",
              "lastModified": "2019-11-21T08:35:03+00:00",
              "lease": {
                "duration": null,
                "state": "available",
                "status": "unlocked"
              },
              "pageBlobSequenceNumber": null,
              "remainingRetentionDays": null,
              "sequenceNumber": 1,
              "serverEncrypted": true
            },
            "snapshot": null
          }
        ],
        "output": [
          "name/windows-2016-osDisk.170b8936-d66d-4139-a409-26f4e9d354fe.vhd",
          "name/windows-2019-osDisk.f122fb3c-0edb-42a8-b98c-56657b447f15.vhd"
        ]
      }
    ],
    "identifier": 59073347
  },
  {
    "context": [
      "I need to write a bash script that combine all json files into one big valid json.",
      "a very simple way is :",
      "    jq -s 'flatten' $target/*/*.json > $merged_json",
      "an alternative ( in the case you need to use `|` ) :",
      "    cat $target/*/*.json | jq -s 'flatten' > $merged_json",
      "or if too many files",
      "    find $target/* -name \\*json cat {} |  jq -s 'flatten' > $merged_json"
    ],
    "utterance": "Combine all files inside all subdirectories into a single merged array containing all their contents.",
    "expressions": [
      "jq -s 'flatten' $target/*/*.json",
      "cat $target/*/*.json | jq -s 'flatten'",
      "find $target/* -name \\*json -exec cat {} + | jq -s 'flatten'"
    ],
    "identifier": 58892884
  },
  {
    "context": [
      "Use JQ to parse JSON array of objects, using select to match specified key-value in the object element, then convert to CSV.",
      "jq -r '.Objects[] | select(.ObjectElementName | contains(\"ABC\"))'",
      "**Output needed in this format, so CSV conversion can be executed**\n```\nin2csv -f json --key Objects > output.csv\n```",
      "**Output CSV required**\n```\nObjectElementName,ObjectElementUnit\nTest ABC 1,2\nTest ABC 2,5\n```",
      "If you want CSV, you should probably use jq's `@csv` filter, which essentially guarantees valid CSV output.",
      "jq -r '\n  [\"ObjectElementName\",\"ObjectElementUnit\"],\n  (.Objects[]\n   | select(.ObjectElementName | test(\"ABC\"))\n   | [.ObjectElementName,.ObjectElementUnit] )\n  | @csv' input.json"
    ],
    "utterance": "Extract all objects where ObjectElementName contains 'ABC' and output their ObjectElementName and ObjectElementUnit fields as CSV.",
    "expressions": [
      "[\"ObjectElementName\",\"ObjectElementUnit\"], (.Objects[] | select(.ObjectElementName | test(\"ABC\")) | [.ObjectElementName,.ObjectElementUnit]) | @csv"
    ],
    "data": [
      {
        "input": {
          "Other": [],
          "Objects": [
            {
              "ObjectElementName": "Test 123",
              "ObjectElementArray": [],
              "ObjectElementUnit": "1"
            },
            {
              "ObjectElementName": "Test ABC 1",
              "ObjectElementArray": [],
              "ObjectElementUnit": "2"
            },
            {
              "ObjectElementName": "Test ABC 2",
              "ObjectElementArray": [],
              "ObjectElementUnit": "5"
            }
          ],
          "Language": "en-US"
        },
        "output": "\"ObjectElementName\",\"ObjectElementUnit\"\n\"Test ABC 1\",\"2\"\n\"Test ABC 2\",\"5\""
      }
    ],
    "identifier": 58985676
  },
  {
    "context": [
      "I am trying to write a shell script to transform the following data for elasticsearch's bulk api:",
      "I am trying to transform it to the following:",
      "There is still no need for a shell loop.",
      "jq -c '.[] | ({\"index\":{}}, [.])'  input.json"
    ],
    "utterance": "Output each object as an index operation followed by the object in a list, for all elements in the top-level array.",
    "expressions": [
      ".[] | ({\"index\":{}}, [.])"
    ],
    "data": [
      {
        "input": [
          {
            "codeId": "111",
            "association": [
              {
                "associationId": 123,
                "businessUnitsAssociationId": 1,
                "financialBusinessUnits": "DCS",
                "businessApprovalLimit": [
                  {
                    "businessApprovalLimitApprovalLimitId": 1,
                    "itemMinAmount": "0.00",
                    "itemMaxAmount": "0.00"
                  },
                  {
                    "businessApprovalLimitApprovalLimitId": 2,
                    "itemMinAmount": "0.00",
                    "itemMaxAmount": "0.00"
                  },
                  {
                    "businessApprovalLimitApprovalLimitId": 3,
                    "itemMinAmount": "0.00",
                    "itemMaxAmount": "0.00"
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "index": {}
          },
          [
            {
              "codeId": "111",
              "association": [
                {
                  "associationId": 123,
                  "businessUnitsAssociationId": 1,
                  "financialBusinessUnits": "DCS",
                  "businessApprovalLimit": [
                    {
                      "businessApprovalLimitApprovalLimitId": 1,
                      "itemMinAmount": "0.00",
                      "itemMaxAmount": "0.00"
                    },
                    {
                      "businessApprovalLimitApprovalLimitId": 2,
                      "itemMinAmount": "0.00",
                      "itemMaxAmount": "0.00"
                    },
                    {
                      "businessApprovalLimitApprovalLimitId": 3,
                      "itemMinAmount": "0.00",
                      "itemMaxAmount": "0.00"
                    }
                  ]
                }
              ]
            }
          ]
        ]
      }
    ],
    "identifier": 58904838
  },
  {
    "context": [
      "i want to list available ios simulators as in below format ( iOS version should take from JSON key )",
      "You could use contains combined with substrings to perform the extraction but using `capture/1` here could simplify the process.",
      "Here&#39;s one way you could do it:\r\n\r\n    $ xcrun ... | jq &#39;.devices | to_entries[]\r\n      | (.key | capture(&quot;com\\\\.apple\\\\.CoreSimulator\\\\.SimRuntime\\\\.iOS-(?&lt;version&gt;.+)&quot;)) as {$version}\r\n      | .value[] | {name: &quot;\\(.name) (\\($version|sub(&quot;-&quot;; &quot;.&quot;)))&quot;, udid}&#39;"
    ],
    "utterance": "List all available simulators with their name and udid, appending the extracted iOS version from the key as (X.Y) to the name.",
    "expressions": [
      ".devices | to_entries[] | (.key | capture(\"com\\.apple\\.CoreSimulator\\.SimRuntime\\.iOS-(?<version>.+)\")) as {$version} | .value[] | {name: \"\\(.name) (\\($version|sub(\"-\"; \".\")))\", udid}"
    ],
    "data": [
      {
        "input": {
          "devices": {
            "com.apple.CoreSimulator.SimRuntime.iOS-11-4": [
              {
                "state": "Shutdown",
                "isAvailable": true,
                "name": "iPhone 5s",
                "udid": "FB6B3F7F-E6CD-4F64-8EC4-6C07C86A25C8"
              },
              {
                "state": "Shutdown",
                "isAvailable": true,
                "name": "iPhone 6 Plus",
                "udid": "768AE0B3-F77A-4DF4-8198-74CB2D598D19"
              }
            ],
            "com.apple.CoreSimulator.SimRuntime.iOS-13-2": [
              {
                "state": "Shutdown",
                "isAvailable": true,
                "name": "iPhone 8",
                "udid": "71E02A7B-BCBB-45D8-8638-E5381B420406"
              }
            ]
          }
        },
        "output": [
          {
            "name": "iPhone 5s (11.4)",
            "udid": "FB6B3F7F-E6CD-4F64-8EC4-6C07C86A25C8"
          },
          {
            "name": "iPhone 6 Plus (11.4)",
            "udid": "768AE0B3-F77A-4DF4-8198-74CB2D598D19"
          },
          {
            "name": "iPhone 8 (13.2)",
            "udid": "71E02A7B-BCBB-45D8-8638-E5381B420406"
          }
        ]
      }
    ],
    "identifier": 58806843
  },
  {
    "context": [
      "the following jq prints `5317139\tCCC/C=C\\\\1/C2=C(C3C(O3)CC2)C(=O)O1`.",
      "But there are two `\\` before the first `1`. Is it wrong, should three be just one `\\`? How to get the correct number of backslash?",
      "The extra backslash in the output is the result of the request to produce TSV, since \"\\\" has a special role to play in jq's TSV (e.g. \"\\t\" signifies the tab character).",
      "By contrast, consider:\n\n    jq -r '\n      .PropertyTable.Properties\n      | .[]\n      | [.CID, .IsomericSMILES]\n      | join(\"\\t\")' smiles.json\n    5317139\tCCC/C=C\\1/C2=C(C3C(O3)CC2)C(=O)O1"
    ],
    "utterance": "Output the CID and IsomericSMILES fields separated by a tab, displaying the backslash characters in IsomericSMILES as a single literal backslash instead of a double backslash.",
    "expressions": [
      ".PropertyTable.Properties | .[] | [.CID, .IsomericSMILES] | join(\"\t\")"
    ],
    "data": [
      {
        "input": {
          "PropertyTable": {
            "Properties": [
              {
                "CID": 5317139,
                "IsomericSMILES": "CCC/C=C\\1/C2=C(C3C(O3)CC2)C(=O)O1"
              }
            ]
          }
        },
        "output": "5317139\tCCC/C=C\\1/C2=C(C3C(O3)CC2)C(=O)O1"
      }
    ],
    "identifier": 58696467
  },
  {
    "context": [
      "curl -s http://api.icndb.com/jokes/random/3 | jq '.[] | .joke'",
      "jq: error (at <stdin>:0): Cannot index string with string \"joke\"",
      "curl -s http://api.icndb.com/jokes/random/3 | jq '.value[].joke'",
      "works fine here."
    ],
    "utterance": "Extract all joke texts from the response of the API at http://api.icndb.com/jokes/random/3.",
    "expressions": [
      ".value[].joke"
    ],
    "identifier": 59115978
  },
  {
    "context": [
      "How can remove `add` and `update` from the title value before output?",
      "Use `sub`, e.g.:",
      ".[]\n| \"\\(.id) \\(.title|sub(\"^(add|update) *\";\"\")\")"
    ],
    "utterance": "Output id and title for each item, but with 'add' or 'update' removed from the start of the title before displaying it.",
    "expressions": [
      ".[] | \"\\(.id) \\(.title|sub(\"^(add|update) *\";\"\"))\""
    ],
    "data": [
      {
        "input": [
          {
            "id": 338899730,
            "title": "add AOT mode default to version 9 upgrade doc"
          },
          {
            "id": 338868666,
            "title": "update jiali's info on collaborator page of angular.io"
          }
        ],
        "output": [
          "338899730 AOT mode default to version 9 upgrade doc",
          "338868666 jiali's info on collaborator page of angular.io"
        ]
      }
    ],
    "identifier": 58801982
  },
  {
    "context": [
      "i am only interested in `admin-devices-block-master` and i want to convert the timestamp `1516717768514` in as `strflocaltime(\"%Y-%m-%d %I:%M%p\")`",
      "so it should just return:\n\n```\n\"admin-devices-block-master\",1516717768514\n```",
      "strflocaltime need jq version 1.6 , thanks to @oliv to remark it .",
      "jq '.ts|=( ./1000|strflocaltime(\"%Y-%m-%d %I:%M%p\")) '"
    ],
    "utterance": "Return the function name 'admin-devices-block-master' and the corresponding timestamp, formatting the timestamp using strflocaltime(\"%Y-%m-%d %I:%M%p\")",
    "expressions": [
      ".logStreams[] | select(.logStreamName | contains(\"admin-devices-block-master\")) | [\"admin-devices-block-master\", (.lastEventTimestamp / 1000 | strflocaltime(\"%Y-%m-%d %I:%M%p\"))] | @csv"
    ],
    "data": [
      {
        "input": {
          "logStreams": [
            {
              "arn": "aws:logs:eu-west-1:****:log-group:/aws/lambda/admin-devices-block-master:log-stream:2018/01/23/[$LATEST]64965367852942f490305cb8707d81b4",
              "logStreamName": "2018/01/23/[$LATEST]64965367852942f490305cb8707d81b4",
              "lastEventTimestamp": 1516717768514
            }
          ]
        },
        "output": "\"admin-devices-block-master\",\"2018-01-23 05:49PM\""
      }
    ],
    "identifier": 58699093
  },
  {
    "context": [
      "What JQ input can group the same field names for the following JSON?",
      "I would like to output like below:\n{\n  \"dados\": {\n    \"cor\": [\n      {\n        \"cdCor\": \"SEM\",\n        ...",
      "Here's one way to use the --stream option to reshape the input so that the output remains a single JSON object.",
      "jq -n --stream -f reshape.jq  input.json",
      "def augmentpath($path; $value):\n  getpath($path) as $v\n  | setpath($path; $v + [$value]);\n\nreduce (inputs | select(length==2)) as $pv\n  ({}; augmentpath($pv[0]; $pv[1]) )"
    ],
    "utterance": "Group all objects under fields with the same name at each nesting level so that repeated keys become arrays of objects, e.g., multiple 'cor' entries are grouped as a 'cor' array.",
    "expressions": [
      "def augmentpath($path; $value):\n  getpath($path) as $v\n  | setpath($path; $v + [$value]);\n\nreduce (inputs | select(length==2)) as $pv\n  ({}; augmentpath($pv[0]; $pv[1]) )"
    ],
    "data": [
      {
        "input": {
          "dados": {
            "cor": {
              "cdCor": "SM",
              "dsCor": "MADEIRAS"
            },
            "grade": {
              "cdGrade": "4",
              "dsGrade": "PADRAO",
              "itemGrade": {
                "cdTamanho": 137,
                "dsTamanho": "13A14ANOS"
              }
            },
            "tipoClassificacao": {
              "cdTipoclas": 5,
              "dsTipoclas": "MARCA",
              "classificacao": {
                "cdClassificacao": "326",
                "dsClassificacao": "DEL RIO"
              }
            }
          }
        },
        "output": {
          "dados": {
            "cor": [
              {
                "cdCor": "SEM",
                "dsCor": "."
              },
              {
                "cdCor": "RS",
                "dsCor": "ROSE"
              },
              {
                "cdCor": "CB",
                "dsCor": "SAVCHUMBO"
              },
              {
                "cdCor": "KA",
                "dsCor": "KHAKI"
              },
              {
                "cdCor": "SM",
                "dsCor": "MADEIRAS"
              }
            ],
            "grade": [
              {
                "cdGrade": "3",
                "dsGrade": "SEM TAMANHO",
                "itemGrade": [
                  {
                    "cdTamanho": 1,
                    "dsTamanho": "."
                  }
                ]
              },
              {
                "cdGrade": "4",
                "dsGrade": "PADRAO",
                "itemGrade": [
                  {
                    "cdTamanho": 1,
                    "dsTamanho": "PP"
                  },
                  {
                    "cdTamanho": 5,
                    "dsTamanho": "GG"
                  },
                  {
                    "cdTamanho": 137,
                    "dsTamanho": "13A14ANOS"
                  }
                ]
              }
            ],
            "tipoClassificacao": [
              {
                "cdTipoclas": 3,
                "dsTipoclas": "MODELO"
              },
              {
                "cdTipoclas": 2,
                "dsTipoclas": "ARTIGO"
              },
              {
                "cdTipoclas": 1,
                "dsTipoclas": "DEPART"
              },
              {
                "cdTipoclas": 5,
                "dsTipoclas": "MARCA"
              }
            ],
            "classificacao": [
              {
                "cdClassificacao": "960",
                "dsClassificacao": "FMO"
              },
              {
                "cdClassificacao": "326",
                "dsClassificacao": "DEL RIO"
              }
            ]
          }
        }
      }
    ],
    "identifier": 58886281
  },
  {
    "context": [
      "I would like to extract elements that does not contains the string \"To Do\" as label.",
      ".[] | select(.labels | index(\"To Do\") | not) | \"\\(.id) -- \\(.title) -- \\(.labels)\"",
      "| select( all(.labels[]; . != \"To Do\"))"
    ],
    "utterance": "Select all elements whose labels array does not include the string \"To Do\".",
    "expressions": [
      ".[] | select(.labels | index(\"To Do\") | not)",
      ".[] | select(all(.labels[]; . != \"To Do\"))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "title": "Task A",
            "labels": [
              "Low",
              "To Do"
            ]
          },
          {
            "id": 2,
            "title": "Task B",
            "labels": [
              "Medium",
              "Done"
            ]
          },
          {
            "id": 3,
            "title": "Task C",
            "labels": [
              "High",
              "To Do"
            ]
          }
        ],
        "output": [
          {
            "id": 2,
            "title": "Task B",
            "labels": [
              "Medium",
              "Done"
            ]
          }
        ]
      }
    ],
    "identifier": 58942852
  },
  {
    "context": [
      "I wanted to extract the `password` field in the above example.",
      "Hopefully it can only focus on the `password` attribute in `module.rds` module only.",
      "jq '.resources[] | select(.module == \"module.rds\") | .instances[].attributes.password'",
      "If you don't know exactly where password will be, this is a way of finding it.",
      "jq '.resources[] | select(.module == \"module.rds\") | .. | .password? | values'"
    ],
    "utterance": "Extract the password attribute for all instances where the module field equals module.rds.",
    "expressions": [
      ".resources[] | select(.module == \"module.rds\") | .instances[].attributes.password",
      ".resources[] | select(.module == \"module.rds\") | .. | .password? | values"
    ],
    "data": [
      {
        "input": {
          "version": 4,
          "terraform_version": "0.12.9",
          "serial": 2,
          "lineage": "ba56cc3e-71fd-1488-e6fb-3136f4630e70",
          "outputs": {},
          "resources": [
            {
              "module": "module.rds.module.reports_cpu_warning",
              "mode": "managed",
              "type": "datadog_monitor",
              "name": "alert",
              "each": "list",
              "provider": "module.rds.provider.datadog",
              "instances": []
            },
            {
              "module": "module.rds.module.reports_lag_warning",
              "mode": "managed",
              "type": "datadog_monitor",
              "name": "alert",
              "each": "list",
              "provider": "module.rds.provider.datadog",
              "instances": []
            },
            {
              "module": "module.rds.module.cross_region_replica_lag_alert",
              "mode": "managed",
              "type": "datadog_monitor",
              "name": "alert",
              "each": "list",
              "provider": "module.rds.provider.datadog",
              "instances": []
            },
            {
              "module": "module.rds",
              "mode": "managed",
              "type": "aws_db_instance",
              "name": "master",
              "provider": "provider.aws",
              "instances": [
                {
                  "schema_version": 0,
                  "attributes": {
                    "address": "dev-database.123456.us-east-8.rds.amazonaws.com",
                    "allocated_storage": 10,
                    "password": "",
                    "performance_insights_enabled": false,
                    "tags": {
                      "env": "development"
                    },
                    "timeouts": {
                      "create": "6h",
                      "delete": "6h",
                      "update": "6h"
                    },
                    "timezone": "",
                    "username": "admin",
                    "vpc_security_group_ids": [
                      "sg-1234"
                    ]
                  },
                  "private": ""
                }
              ]
            }
          ]
        },
        "output": [
          ""
        ]
      }
    ],
    "identifier": 59079708
  },
  {
    "context": [
      "I want to retrieve all elements in [...] from all \"stringStats\" lists.",
      "I succeeded with a jq query to retrieve all elements but I don't know how to filter and iterate from a specific kind of list.",
      "If you need as array format use the below,\r\n\r\n    [.datasets[].features[].stringStats // empty ]",
      "If you need as objects use the below,\r\n\r\n    .datasets[].features[].stringStats // empty",
      "Here is an approach using [`recursive descent ..`](https://stedolan.github.io/jq/manual/#RecursiveDescent:..), [`optional object identifier .?`](https://stedolan.github.io/jq/manual/#OptionalObjectIdentifier-Index:.foo?) and [`values`](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars)\r\n```\r\n.. | .stringStats? | values\r\n```"
    ],
    "utterance": "Retrieve all elements inside every stringStats object that appears in features arrays under datasets.",
    "expressions": [
      ".datasets[].features[].stringStats // empty",
      "[.datasets[].features[].stringStats // empty]",
      ".. | .stringStats? | values"
    ],
    "data": [
      {
        "input": {
          "datasets": [
            {
              "features": [
                {
                  "name": "aaa",
                  "stringStats": {
                    "someList": [
                      1,
                      2,
                      3
                    ],
                    "foo": "bar"
                  },
                  "type": "STRING"
                },
                {
                  "name": "bbb",
                  "numStats": {
                    "otherList": [
                      4,
                      5
                    ]
                  },
                  "type": "FLOAT"
                },
                {
                  "name": "ccc",
                  "stringStats": {
                    "someList": [
                      6,
                      7
                    ],
                    "foo": "baz"
                  },
                  "type": "STRING"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "someList": [
              1,
              2,
              3
            ],
            "foo": "bar"
          },
          {
            "someList": [
              6,
              7
            ],
            "foo": "baz"
          }
        ]
      }
    ],
    "identifier": 58714054
  },
  {
    "context": [
      "I want to print the internal IP of all nodes in the same line separated by a space using `jq` in k8s. How can I do this?",
      "for space separated internal-ips:",
      "kubectl get nodes -o json | jq '.items[].status.addresses[] | select(.type==\"InternalIP\") | .address' | tr -d '\"' | tr '\\n' ' '"
    ],
    "utterance": "Print the InternalIP values of all nodes in a single line separated by spaces.",
    "expressions": [
      ".items[].status.addresses[] | select(.type==\"InternalIP\") | .address"
    ],
    "identifier": 58732218
  },
  {
    "context": [
      "However, I would like to receive from the curl only the following value(appears at the end of the response, under \"key\" within the JSON response part): test_project-4044",
      "`curl -g -H \"Content-Type: application/json\" \"http://real_path/rest/api/2/search?jql=cf[10804]~${real_value}&maxResults=2&fields=id,key\" -u \"test_user:test_pass\") | jq -r '.issues[0].key'`",
      "Given the example json from your question, passed to `jq -r '.issues[0].key'`, it produces the following output:",
      "test_project-4044"
    ],
    "utterance": "Extract the key of the first issue in the issues array from the API response.",
    "expressions": [
      ".issues[0].key"
    ],
    "data": [
      {
        "input": {
          "expand": "names,schema",
          "startAt": 0,
          "maxResults": 2,
          "total": 1,
          "issues": [
            {
              "expand": "operations,versionedRepresentations,editmeta,changelog,renderedFields",
              "id": "574719",
              "self": "real_path/rest/api/2/issue/574719",
              "key": "test_project-4044"
            }
          ]
        },
        "output": "test_project-4044"
      }
    ],
    "identifier": 59047584
  },
  {
    "context": [
      "I want to find the longest title with `jq`.",
      "Is it possible to directly get the argmax?",
      "Yes, you can use `max_by` like:",
      "max_by(.title | length).title",
      "or,",
      "map(.title) | max_by(length)"
    ],
    "utterance": "Find the movie with the longest title.",
    "expressions": [
      "max_by(.title | length).title",
      "map(.title) | max_by(length)"
    ],
    "identifier": 58679123
  },
  {
    "context": [
      "I would like to retrieve the ```pointURL``` of the following JSON via ```jq```.",
      "how can I get the **pointURL\": \"http://10.1.1.64:21138\"** ?",
      "Try this though. \n```\njq '.configuration.encd | .[] | .ServerURL.ServerURLSpecific.primaryPoint.pointURL'\n```",
      ".configuration | fromjson | .encd[0].ServerURL.ServerURLSpecific.primaryPoint.pointURL"
    ],
    "utterance": "Select the primaryPoint.pointURL value within configuration.encd[0].ServerURL.ServerURLSpecific.",
    "expressions": [
      ".configuration | fromjson | .encd[0].ServerURL.ServerURLSpecific.primaryPoint.pointURL",
      ".configuration.encd | .[] | .ServerURL.ServerURLSpecific.primaryPoint.pointURL"
    ],
    "data": [
      {
        "input": {
          "id": "b8e07db15f30",
          "configuration": "{\r\n  \"encd\": [\r\n    {\r\n      \"name\": \"hello\",\r\n      \"raiseOnError\": true,\r\n      \"type\": \"version3\",\r\n      \"encdpecific\": {\r\n        \"apiURL\": \"http://172.29.32.32/new/rest\",\r\n        \"apiURLB\": \"http://172.29.32.32/new/rest\",\r\n        \"IDname\": 92,\r\n        \"startno\": 5000,\r\n        \"support\": true\r\n      },\r\n      \"ServerURL\": {\r\n        \"type\": \"ServerNEW\",\r\n        \"ServerURLSpecific\": {\r\n          \"primaryPoint\": {\r\n            \"pointURL\": \"http://10.1.1.64:21138/{{id:hello}}/hello.txt\",\r\n            \"ServerNEWAPI\": \"https://api.example.com/hello/api1\",\r\n            \"ServerNEWAPIKey\": \"6d0a0a8d-6fb9-4f14-a72e\",\r\n            \"filePath\": \"/\",\r\n            \"create\": true,\r\n            \"liveName\": \"hello.txt\",\r\n            \"livedlived\": \"hello.txt\"\r\n          },\r\n          \"secondaryPoint\": {\r\n            \"pointURL\": \"http://10.1.1.65:21139/{{id:hello}}/hello.txt\",\r\n            \"ServerNEWAPI\": \"https://api.example.com/hello/api2\",\r\n            \"ServerNEWAPIKey\": \"6d0a0a8d-6fb9-4f14-a72e\",\r\n            \"filePath\": \"/\",\r\n            \"create\": true,\r\n            \"liveName\": \"hello.txt\",\r\n            \"livedlived\": \"hello.txt\"\r\n          }\r\n        }\r\n      },\r\n      \"outputUrls\": [\r\n        {\r\n          \"protocol\": \"newtype\",\r\n          \"newthroughUrl\": \"https://new.example.com/{{id:hello}}/hello.txt/.txt\",\r\n          \"originPrimaryUrl\": \"http://10.1.1.64:21138/{{id:hello}}/hello.txt/.txt\",\r\n          \"liveOriginSecondaryUrl\": \"http://10.1.1.65:21139/{{id:hello}}/hello.txt/.txt\",\r\n          \"throughUrl\": \"https://api.example.com/{{id:hello}}/hello.txt/.txt\"\r\n        },\r\n        {\r\n          \"protocol\": \"VIEW\",\r\n          \"newthroughUrl\": \"https://new.example.com/{{id:hello}}/hello.txt/.txt\",\r\n          \"originPrimaryUrl\": \"http://10.1.1.64:21138/{{id:hello}}/hello.txt/.txt\",\r\n          \"liveOriginSecondaryUrl\": \"http://10.1.1.65:21139/{{id:hello}}/hello.txt/.txt\",\r\n          \"throughUrl\": \"https://api.example.com/{{id:hello}}/hello.txt/.txt\"\r\n        },\r\n        {\r\n          \"protocol\": \"otherprot\",\r\n          \"newthroughUrl\": \"https://new.example.com/{{id:hello}}/hello.txt/man\",\r\n          \"originPrimaryUrl\": \"http://10.1.1.64:21138/{{id:hello}}/hello.txt/man\",\r\n          \"liveOriginSecondaryUrl\": \"http://10.1.1.65:21139/{{id:hello}}/hello.txt/man\",\r\n          \"throughUrl\": \"https://api.example.com/{{id:hello}}/hello.txt/man\"\r\n        },\r\n        {\r\n          \"protocol\": \"LLL\",\r\n          \"newthroughUrl\": \"https://new.example.com/{{id:hello}}/hello.txt/.fram\",\r\n          \"originPrimaryUrl\": \"http://10.1.1.64:21138/{{id:hello}}/hello.txt/.fram\",\r\n          \"liveOriginSecondaryUrl\": \"http://10.1.1.65:21139/{{id:hello}}/hello.txt/.fram\",\r\n          \"throughUrl\": \"https://api.example.com/{{id:hello}}/hello.txt/.fram\"\r\n        }\r\n      ]\r\n    }\r\n  ]\r\n}",
          "name": "hello",
          "refID": "hello"
        },
        "output": "http://10.1.1.64:21138/{{id:hello}}/hello.txt"
      }
    ],
    "identifier": 59105638
  },
  {
    "context": [
      "I\u2019m trying to get the parents as top row so \"address, amenity_groups, check_in_time, check_out_time\" and then if there's a json inside those it's just a flat json text in the csv.",
      "[.address, .amenity_groups, .check_in_time, .check_out_time]\n| map(tostring)\n| @csv",
      "With your stream of JSON objects, you could (for example) use it like this with the -s command-line option:\nmap({address, amenity_groups, check_in_time, check_out_time})\n| json2csv"
    ],
    "utterance": "Convert an array of objects, extracting address, amenity_groups, check_in_time, and check_out_time as CSV columns, with nested fields represented as stringified JSON or flattened.",
    "expressions": [
      "[.address, .amenity_groups, .check_in_time, .check_out_time] | map(tostring) | @csv",
      "map({address, amenity_groups, check_in_time, check_out_time}) | json2csv"
    ],
    "data": [
      {
        "input": [
          {
            "address": "140 Ancien Chemin De Berre, Lambesc",
            "amenity_groups": [
              {
                "amenities": [
                  "Garden",
                  "Terrace"
                ],
                "group_name": "General"
              }
            ],
            "check_in_time": "16:00:00",
            "check_out_time": "10:00:00"
          }
        ],
        "output": "\"140 Ancien Chemin De Berre, Lambesc\",\"[{\\\"amenities\\\":[\\\"Garden\\\",\\\"Terrace\\\"],\\\"group_name\\\":\\\"General\\\"}]\",\"16:00:00\",\"10:00:00\""
      }
    ],
    "identifier": 59061607
  },
  {
    "context": [
      "When i try to use this JQ it works with String feilds , but with Numberic Feild as key its not working.",
      "jq: error (at <stdin>:25): Cannot use number (1) as object key",
      "Keys must be strings, so numerical values that you want to use as keys will have to be converted, which can be done using `tostring`, as in:",
      ".ideas[]\n| { (.id | tostring): .ideaID }"
    ],
    "utterance": "Create an object mapping each id to its corresponding ideaID, ensuring id is used as a string key.",
    "expressions": [
      ".ideas | map({ (.id|tostring): .ideaID }) | add"
    ],
    "data": [
      {
        "input": {
          "ideas": [
            {
              "id": 3,
              "ideaID": 499,
              "ideaName": "Apples & Bananas",
              "preference_order": 1,
              "_links": {
                "self": {
                  "href": "/ideaProfile/api/v3/idea/3"
                }
              }
            },
            {
              "id": 5,
              "ideaID": 500,
              "ideaName": "Oranges and Peach",
              "preference_order": 1,
              "_links": {
                "self": {
                  "href": "/ideaProfile/api/v3/idea/3"
                }
              }
            }
          ]
        },
        "output": {
          "3": 499,
          "5": 500
        }
      }
    ],
    "identifier": 58827533
  },
  {
    "context": [
      "I have a JSON string and am trying to remove all the special characters\r\n(i.e. those defined by the regex `[!@#$%^\u2019&amp;*(),.?&quot;:{}|&lt;&gt;]`)\r\nfrom it.",
      "Some of the jq expressions I&#39;ve tried are as follows:\r\nsub(&quot;[!@#$%^\u2019&amp;*(),.?&quot;:{}|&lt;&gt;]&quot;; &quot;&quot;) ...",
      "The final working solution:\r\n\ntags: (.title\n      | sub(\"([!@#$%^\u2019&*(),.?|])\"; \"\"; \"g\")\n      | split(\" \")\n",
      "and, escaping the apostrophes or single quotes (if needed):\n\ntags: (.title\n      | sub(\"([!@#$%^\u2019';&*(),.?|])\"; \"\"; \"g\")\n      | split(\" \")\n"
    ],
    "utterance": "Remove all characters matching [!@#$%^\u2019';&*(),.?|] from the value of the .title field and split the result by spaces.",
    "expressions": [
      ".title | sub(\"([!@#$%^\u2019&*(),.?|])\"; \"\"; \"g\") | split(\" \")",
      ".title | sub(\"([!@#$%^\u2019';&*(),.?|])\"; \"\"; \"g\") | split(\" \")"
    ],
    "identifier": 58899481
  },
  {
    "context": [
      "I have some curl get, receiving array from it. At the same time I have some local json file with some data already saved. I need to combine those.",
      "curl GET -G 'url' | jq --argjson arr1 '[.articles[] | { title: .title, description: .description, author: .author, content: .content }]' --argjson arr2 'seeds.json' -n '$arr1 + $arr2 | group_by(.title) | map(.[-1])' > seeds.json",
      "You should aim for something like the following:",
      "curl GET -G 'url' |\n    jq --argfile arr2 seeds.json '\n       [.articles[] \n        | { title, description, author, content}] as $arr1\n       | $arr1 + $arr2\n       | group_by(.title) \n       | map(.[-1])' "
    ],
    "utterance": "Combine an array of articles from a web request with a local file array, merge by title keeping the latest entry for each title.",
    "expressions": [
      "[.articles[] | { title, description, author, content }] as $arr1 | $arr1 + $arr2 | group_by(.title) | map(.[-1])"
    ],
    "identifier": 58896539
  },
  {
    "context": [
      "I have 2 JSON files with the following structure",
      "I want to merge them and get the output like this",
      "Here is one way to do it:",
      "def mergePlugin($plugin):",
      "if .[$plugin.Name]",
      "then .[$plugin.Name].Installation += $plugin.Installation",
      "else .[$plugin.Name] = $plugin",
      "end;",
      "{",
      "  \"Plugins\": (",
      "    map(.Plugins)",
      "    | add",
      "    | reduce .[] as $plugin ({}; mergePlugin($plugin))",
      "    | to_entries | map(.value)",
      "  )",
      "}",
      "jq -s -f mergePlugins.jq File*.json"
    ],
    "utterance": "Merge two files by combining Plugins with the same Name key so that Installations are concatenated, resulting in a single array of Plugins each with all Installations from both files.",
    "expressions": [
      "def mergePlugin($plugin):\n  if .[$plugin.Name]\n  then .[$plugin.Name].Installation += $plugin.Installation\n  else .[$plugin.Name] = $plugin\n  end;\n\n{\n  \"Plugins\": (\n    map(.Plugins)\n    | add\n    | reduce .[] as $plugin ({}; mergePlugin($plugin))\n    | to_entries | map(.value)\n  )\n}"
    ],
    "data": [
      {
        "input": [
          {
            "Plugins": [
              {
                "Name": "Plugin A",
                "Installation": [
                  {
                    "Version": "1.0",
                    "Server": "abc"
                  }
                ]
              },
              {
                "Name": "Plugin B",
                "Installation": [
                  {
                    "Version": "2.0",
                    "Server": "abc"
                  }
                ]
              },
              {
                "Name": "Plugin C",
                "Installation": [
                  {
                    "Version": "2.0",
                    "Server": "abc"
                  }
                ]
              }
            ]
          },
          {
            "Plugins": [
              {
                "Name": "Plugin A",
                "Installation": [
                  {
                    "Version": "1.1",
                    "Server": "xyz"
                  }
                ]
              },
              {
                "Name": "Plugin B",
                "Installation": [
                  {
                    "Version": "2.0",
                    "Server": "xyz"
                  }
                ]
              }
            ]
          }
        ],
        "output": {
          "Plugins": [
            {
              "Name": "Plugin A",
              "Installation": [
                {
                  "Version": "1.0",
                  "Server": "abc"
                },
                {
                  "Version": "1.1",
                  "Server": "xyz"
                }
              ]
            },
            {
              "Name": "Plugin B",
              "Installation": [
                {
                  "Version": "2.0",
                  "Server": "abc"
                },
                {
                  "Version": "2.0",
                  "Server": "xyz"
                }
              ]
            },
            {
              "Name": "Plugin C",
              "Installation": [
                {
                  "Version": "2.0",
                  "Server": "abc"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 59104389
  },
  {
    "context": [
      "What I need to do is get a list of `FunctionArn` values for functions that use a specific layer.",
      "aws lambda list-functions | jq '.Functions[] | select(.Layers[] | contains(\"layer2\"))'",
      "From elements of `Functions`, select ones that have a `Layers` key whose value -an array- contains at least one object having `layer2` as a substring in its `Arn` field -a string-, and extract their `FunctionArn`s. E.g:",
      "Functions[] | select(has(\"Layers\") and any(.Layers[].Arn; index(\"layer2\"))) | .FunctionArn"
    ],
    "utterance": "Return the FunctionArn values for all functions that reference a layer whose Arn contains the substring \"layer2\".",
    "expressions": [
      ".Functions[] | select(has(\"Layers\") and any(.Layers[].Arn; index(\"layer2\"))) | .FunctionArn"
    ],
    "data": [
      {
        "input": {
          "Functions": [
            {
              "TracingConfig": {
                "Mode": "PassThrough"
              },
              "FunctionArn": "arn:aws:lambda:eu-west-2:000000000000:function:function-1"
            },
            {
              "Layers": [
                {
                  "CodeSize": 11359101,
                  "Arn": "arn:aws:lambda:eu-west-2:000000000000:layer:layer1:12"
                }
              ],
              "TracingConfig": {
                "Mode": "PassThrough"
              },
              "FunctionArn": "arn:aws:lambda:eu-west-2:000000000000:function:function-2"
            },
            {
              "Layers": [
                {
                  "CodeSize": 11359101,
                  "Arn": "arn:aws:lambda:eu-west-2:000000000000:layer:layer1:12"
                },
                {
                  "CodeSize": 11359101,
                  "Arn": "arn:aws:lambda:eu-west-2:000000000000:layer:layer2:5"
                }
              ],
              "TracingConfig": {
                "Mode": "PassThrough"
              },
              "FunctionArn": "arn:aws:lambda:eu-west-2:000000000000:function:function-3"
            }
          ]
        },
        "output": [
          "arn:aws:lambda:eu-west-2:000000000000:function:function-3"
        ]
      }
    ],
    "identifier": 59124696
  },
  {
    "context": [
      "The output of the jq script is in the form of `xyz123@gmail.com= password1234`. The Kubernates Secret is not liking the @ sign in output.I want the output like `'xyz123@gmail.com' = 'password1234'` (with quotes).",
      "... jq -r '.SecretString | to_entries[] | \"'\"'\"'\\(.key)'\"'\"'=\\(.value)'\"'\"''",
      ".SecretString | to_entries[] | \"\\(squot(.key))=\\(squot(.value))\"",
      "jq -rn '{\"key\": \"xyz123@gmail.com\", \"value\": \"password1234\"}\n  | \"\\(.key|@sh)=\\(.value|@sh)\" '",
      "Output\n    'xyz123@gmail.com'='password1234'"
    ],
    "utterance": "Produce lines where both key and value are wrapped in single quotes, separated by =, such as 'xyz123@gmail.com'='password1234'.",
    "expressions": [
      ".SecretString | to_entries[] | \"'\\(.key)'='\\(.value)'\"",
      ".SecretString | to_entries[] | \"\\(squot(.key))=\\(squot(.value))\"",
      ".SecretString | to_entries[] | \"\\(.key|@sh)=\\(.value|@sh)\""
    ],
    "data": [
      {
        "input": {
          "SecretString": {
            "xyz123@gmail.com": "password1234"
          }
        },
        "output": "'xyz123@gmail.com'='password1234'"
      }
    ],
    "identifier": 58754148
  },
  {
    "context": [
      "I have some JSON (truncated) that is output from Elasticsearch's built-in health status.",
      "I'm trying to find every instance of \"read_only_allow_delete\". These instances may be nested at different levels in the JSON or under different objects. I'd like to show the full path and value (like this):",
      "gl-system-events_1.settings.index.block.read_only_allow_delete: true",
      "jq '.. | objects | select(.read_only_allow_delete)'",
      "If you stream the data in, you can get a sequence path/value pairs. You could then filter by the paths.",
      "$ jq <input.json --stream 'select(length == 2 and .[0][-1] == \"read_only_allow_delete\")'",
      "Here's one solution, which produces a stream of [$path, $value] arrays, where $path is the full path shown as an array, and $value is the corresponding value:",
      "paths as $path | getpath($path) as $v | select($path[-1] == \"read_only_allow_delete\" ) | [$path, $v]",
      "If you really want the ambiguous output, simply tack on:",
      "| \"\\($path|join(\".\")): \\($v)\""
    ],
    "utterance": "Find all instances of keys named 'read_only_allow_delete', showing their full path within the structure and their value.",
    "expressions": [
      "--stream 'select(length == 2 and .[0][-1] == \"read_only_allow_delete\")'",
      "paths as $path | getpath($path) as $v | select($path[-1] == \"read_only_allow_delete\" ) | [$path, $v]",
      "paths as $path | getpath($path) as $v | select($path[-1] == \"read_only_allow_delete\" ) | \"\\($path|join(\".\")): \\($v)\""
    ],
    "data": [
      {
        "input": {
          "gl-system-events_1": {
            "settings": {
              "index": {
                "refresh_interval": "1s",
                "number_of_shards": "4",
                "blocks": {
                  "read_only_allow_delete": "true"
                }
              }
            }
          }
        },
        "output": [
          [
            [
              "gl-system-events_1",
              "settings",
              "index",
              "blocks",
              "read_only_allow_delete"
            ],
            "true"
          ]
        ]
      }
    ],
    "identifier": 58721912
  },
  {
    "context": [
      "How can I select the parent `hostvars` entry for each child `activedirectory_devops.hosts` entry?",
      "The following jq query does exactly that:",
      "```\n.activedirectory_devops.hosts[] as $host\n| ._meta.hostvars[$host]\n```"
    ],
    "utterance": "Get the entry from hostvars for each element in activedirectory_devops.hosts.",
    "expressions": [
      ".activedirectory_devops.hosts[] as $host | ._meta.hostvars[$host]"
    ],
    "data": [
      {
        "input": {
          "_meta": {
            "hostvars": {
              "foo_423d1fe9-d964-d45e-ec69-2565589deae6": {
                "ansible_host": "192.168.0.1",
                "config.cpuHotAddEnabled": true,
                "config.cpuHotRemoveEnabled": false,
                "config.hardware.numCPU": 4,
                "config.instanceUuid": "503d1a90-8b07-4b33-2648-5d1f9330e5f7",
                "config.name": "devops-dal13-bc1",
                "config.template": false,
                "guest.guestId": "windows9Server64Guest",
                "guest.guestState": "running",
                "guest.hostName": "foo.company.com",
                "guest.ipAddress": "192.168.0.1",
                "inventory_dir": "/ansible/inventories",
                "inventory_file": "/ansible/inventories/vcsa2.vmware.yml",
                "name": "foo",
                "runtime.maxMemoryUsage": 16384
              },
              "bar_420b8b36-fffe-6f29-3e32-0ce9aa0d0ad3": {
                "config.cpuHotAddEnabled": false,
                "config.cpuHotRemoveEnabled": false
              }
            }
          },
          "activedirectory_devops": {
            "hosts": [
              "foo_423d1fe9-d964-d45e-ec69-2565589deae6",
              "bar_420b8b36-fffe-6f29-3e32-0ce9aa0d0ad3"
            ]
          }
        },
        "output": [
          {
            "ansible_host": "192.168.0.1",
            "config.cpuHotAddEnabled": true,
            "config.cpuHotRemoveEnabled": false,
            "config.hardware.numCPU": 4,
            "config.instanceUuid": "503d1a90-8b07-4b33-2648-5d1f9330e5f7",
            "config.name": "devops-dal13-bc1",
            "config.template": false,
            "guest.guestId": "windows9Server64Guest",
            "guest.guestState": "running",
            "guest.hostName": "foo.company.com",
            "guest.ipAddress": "192.168.0.1",
            "inventory_dir": "/ansible/inventories",
            "inventory_file": "/ansible/inventories/vcsa2.vmware.yml",
            "name": "foo",
            "runtime.maxMemoryUsage": 16384
          },
          {
            "config.cpuHotAddEnabled": false,
            "config.cpuHotRemoveEnabled": false
          }
        ]
      }
    ],
    "identifier": 58671912
  },
  {
    "context": [
      "What I would like to do is simply display the `server` yet still return the `ip` and `user`.",
      "select _t in $(echo ${_servers} | jq -c '.[]');",
      "And what I would like it to show instead:",
      "1) server1",
      "2) server2",
      "3) server3",
      "jq -rc '.[] | \"\\(.server) \\(.)\"' <<< \"$_servers\"",
      "jq -rc '.[] | \"\\(.server) \\(.ip) \\(.user)\"' <<< \"$_servers\""
    ],
    "utterance": "List only the server names for selection, but retain access to each server's ip and user fields after selection.",
    "expressions": [
      ".[] | .server",
      ".[] | \"\u007f(.server) \u007f(.)\""
    ],
    "data": [
      {
        "input": [
          {
            "server": "server1",
            "ip": "10.0.0.1",
            "user": "root"
          },
          {
            "server": "server2",
            "ip": "10.0.0.2",
            "user": "ubuntu"
          },
          {
            "server": "server3",
            "ip": "192.168.4.112",
            "user": "ec2-user"
          }
        ],
        "output": [
          "server1",
          "server2",
          "server3"
        ]
      }
    ],
    "identifier": 59054536
  },
  {
    "context": [
      "I would like to sort using the value of the `sequence` tag in the nested `tags` array so that the output looks like this:",
      "`from_entries` converts an array of key-value pairs to an object, you can use it with `sort_by` like this:\n```\n.result |= sort_by(.tags | from_entries | .sequence)\n```"
    ],
    "utterance": "Sort the array so that elements are ordered by the value of their nested tag with key equal to \"sequence\".",
    "expressions": [
      ".result |= sort_by(.tags | from_entries | .sequence)"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "name": "ct-1",
              "tags": [
                {
                  "key": "service_name",
                  "value": "BaseCT"
                },
                {
                  "key": "sequence",
                  "value": "bb"
                }
              ]
            },
            {
              "name": "ct-2",
              "tags": [
                {
                  "key": "service_name",
                  "value": "BaseCT"
                },
                {
                  "key": "sequence",
                  "value": "aa"
                }
              ]
            }
          ]
        },
        "output": {
          "result": [
            {
              "name": "ct-2",
              "tags": [
                {
                  "key": "service_name",
                  "value": "BaseCT"
                },
                {
                  "key": "sequence",
                  "value": "aa"
                }
              ]
            },
            {
              "name": "ct-1",
              "tags": [
                {
                  "key": "service_name",
                  "value": "BaseCT"
                },
                {
                  "key": "sequence",
                  "value": "bb"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 58665496
  },
  {
    "context": [
      "I need to extract duration, from the following key / value pair, `{\"Key\":\"Duration\",\"Value\":\"40453\"}`, for each JSON formatted record, as defined below.",
      "I am interested in extracting only the numerical value for duration.",
      "Using jq, a solution for capturing all the duration values as numbers would be:\r\n\r\n    .fields[] \r\n    | select(.Key == \"Duration\")\r\n    | .Value\r\n    | tonumber"
    ],
    "utterance": "Extract the numeric value from every record where the Key is equal to Duration.",
    "expressions": [
      ".fields[] | select(.Key == \"Duration\") | .Value | tonumber"
    ],
    "data": [
      {
        "input": {
          "fields": [
            {
              "Key": "StartDateTime",
              "Value": "06/11/2019 17:58:36"
            },
            {
              "Key": "EndDateTime",
              "Value": "06/11/2019 17:59:17"
            },
            {
              "Key": "Duration",
              "Value": "40453"
            },
            {
              "Key": "Extension",
              "Value": "1544027"
            }
          ]
        },
        "output": 40453
      }
    ],
    "identifier": 58993445
  },
  {
    "context": [
      "I have below output and json query but am unable to retrieve the value next to mode.",
      "kubectl get configmap -n kube-system kube-proxy -o json | jq .data",
      "kubectl get configmap -n kube-system kube-proxy -o json | jq .data.\\\"config.conf\\\".mode",
      "jq: error (at <stdin>:19): Cannot index string with string \"mode\"",
      "Here's a jq-only solution:\n```\n.data\n| .[\"config.conf\"]\n| splits(\"\\n\")\n| select( test(\"^mode\") )\n| [splits(\": *\")]\n| .[1]\n```",
      "Result using the -r command-line option:\n```\niptables\n```"
    ],
    "utterance": "Extract the value corresponding to 'mode' from the embedded key-value configuration text under 'config.conf', where 'mode' is set to 'iptables'.",
    "expressions": [
      ".data[\"config.conf\"] | splits(\"\\n\") | select(test(\"^mode\")) | [splits(\": *\")] | .[1]"
    ],
    "data": [
      {
        "input": {
          "data": {
            "config.conf": "apiVersion: kubeproxy.config.k8s.io/v1alpha1\nbindAddress: 0.0.0.0\nclientConnection:\n  acceptContentTypes: \"\"\n  burst: 10\n  contentType: application/vnd.kubernetes.protobuf\n  kubeconfig: /var/lib/kube-proxy/kubeconfig.conf\n  qps: 5\nclusterCIDR: 10.233.64.0/18\nconfigSyncPeriod: 15m0s\nconntrack:\n  max: null\n  maxPerCore: 32768\n  min: 131072\n  tcpCloseWaitTimeout: 1h0m0s\n  tcpEstablishedTimeout: 24h0m0s\nenableProfiling: false\nhealthzBindAddress: 0.0.0.0:10256\nhostnameOverride: hosta\niptables:\n  masqueradeAll: false\n  masqueradeBit: 14\n  minSyncPeriod: 0s\n  syncPeriod: 30s\nipvs:\n  excludeCIDRs: null\n  minSyncPeriod: 0s\n  scheduler: rr\n  syncPeriod: 30s\nkind: KubeProxyConfiguration\nmetricsBindAddress: 127.0.0.1:10249\nmode: iptables\nnodePortAddresses: []\noomScoreAdj: -999\nportRange: \"\"\nresourceContainer: /kube-proxy\nudpIdleTimeout: 250ms"
          }
        },
        "output": "iptables"
      }
    ],
    "identifier": 58701790
  },
  {
    "context": [
      "But it can be inferred by comparing the `_BOOT_ID` value of the current object with the one on the previous line. If they are different, the message belongs to another boot session and I need to insert that \"-- Reboot --\" line.",
      "How can I compare that value in jq?",
      "A solution can be obtained using `foreach` along the following lines:\n```\njq -nr '\n  foreach inputs as $entry (null;\n    $entry \n    + if (. != null) and (._BOOT_ID != $entry._BOOT_ID)\n      then {emit: true} else null end;\n   if .emit then \"-- Reboot --\" else empty end,\n   .foo)\n'   \n```\n\t\t\t\t\t\t     \nYou would replace `.foo` with the filter defining the projection of interest."
    ],
    "utterance": "Insert a \"-- Reboot --\" line whenever the value of _BOOT_ID changes between consecutive entries.",
    "expressions": [
      "foreach inputs as $entry (null; $entry; if . != null and ._BOOT_ID != $entry._BOOT_ID then \"-- Reboot --\" else empty end, $entry | <your projection here>)"
    ],
    "identifier": 59096426
  },
  {
    "context": [
      "I have been trying to extract a csv from the below json file using jq but not able to get so far.",
      "Expected o/p is:\r\n\r\n    xxx-xxxx-xxx-8b16-xxxxxx,somebname.UNIVERSE.test.com,100.xx.5.xx,UFO-UFO,GALAXY-D123,X-RAY123,Powered On",
      "$ jq -r '.values[] | [ .resourceId, (.\"property-contents\".\"property-content\"[] | .values[]) ] | join(\",\")' your.json",
      "xxxx-xxxx-xxx-8b16-xxxxxx,somebname.UNIVERSE.test.com,100.xx.5.xx,UFO-UFO,GALAXY-D123,X-RAY123,Powered On"
    ],
    "utterance": "Extract each resourceId followed by all its associated property-content values as a single CSV line in the given order.",
    "expressions": [
      ".values[] | [ .resourceId, (.\"property-contents\".\"property-content\"[] | .values[]) ] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "values": [
            {
              "resourceId": "xxxx-xxxx-xxx-8b16-xxxxxx",
              "property-contents": {
                "property-content": [
                  {
                    "statKey": "config|name",
                    "timestamps": [
                      1517591034069
                    ],
                    "values": [
                      "somebname.UNIVERSE.test.com"
                    ]
                  },
                  {
                    "statKey": "summary|guest|ipAddress",
                    "timestamps": [
                      1517591034069
                    ],
                    "values": [
                      "100.xx.5.xx"
                    ]
                  },
                  {
                    "statKey": "summary|parentCluster",
                    "timestamps": [
                      1551120506024
                    ],
                    "values": [
                      "UFO-UFO"
                    ]
                  },
                  {
                    "statKey": "summary|parentDatacenter",
                    "timestamps": [
                      1551120806021
                    ],
                    "values": [
                      "GALAXY-D123"
                    ]
                  },
                  {
                    "statKey": "summary|parentVcenter",
                    "timestamps": [
                      1517591334271
                    ],
                    "values": [
                      "X-RAY123"
                    ]
                  },
                  {
                    "statKey": "summary|runtime|powerState",
                    "timestamps": [
                      1517591034069
                    ],
                    "values": [
                      "Powered On"
                    ]
                  }
                ]
              }
            }
          ]
        },
        "output": "xxxx-xxxx-xxx-8b16-xxxxxx,somebname.UNIVERSE.test.com,100.xx.5.xx,UFO-UFO,GALAXY-D123,X-RAY123,Powered On"
      }
    ],
    "identifier": 58774540
  },
  {
    "context": [
      "I want for each entry to have a dynamic name like COMMAND_1, COMMAND_2... %MEM_1, %MEM_2 etc",
      "A solution can to numerate line with `nl` ...",
      "range( 1 ; ( $header | length ) ) |  {\"key\": ($header[.]+\"_\"+($x[0]|tostring)) , \"value\": $x[.]} ] | from_entries ]'"
    ],
    "utterance": "Rename keys in each entry to include a unique index, resulting in names like COMMAND_1, %MEM_1, COMMAND_2, %MEM_2, etc.",
    "expressions": [
      "[sub(\"\\n$\";\"\") | splits(\"\\n\") | sub(\"^ +\";\"\") | [splits(\" +\")]] | .[0] as $header | .[1:] | [.[] | [. as $x | range(1; ($header | length)) | {\"key\": ($header[.]+\"_\"+($x[0]|tostring)), \"value\": $x[.]} ] | from_entries ]"
    ],
    "identifier": 58750941
  },
  {
    "context": [
      "How do I simply concatenate a new JSON key/value pair to some existing JSON.",
      "say I have:\r\n\r\n    {\"key1\": \"value1\"} \r\n\r\nin variable A in a bash script.  I now want to add:\r\n\r\n    {\"key2\": \"value2\"} \r\n\r\nto A using jq so that that the resulting contents of A are:\r\n\r\n    {\"key1\": \"value1\",\r\n     \"key2\": \"value2\"}",
      "A=$(jq -n --argjson A \"$A\" '$A + {\"key2\": \"value2\"}')"
    ],
    "utterance": "Add the key 'key2' with value 'value2' to an object that already has 'key1': 'value1'.",
    "expressions": [
      "$A + {\"key2\": \"value2\"}"
    ],
    "data": [
      {
        "input": {
          "key1": "value1"
        },
        "output": {
          "key1": "value1",
          "key2": "value2"
        }
      }
    ],
    "identifier": 58783420
  },
  {
    "context": [
      "\"jq --seq format expects each value to be preceded with ASCII RS character (dec 30 / hex 1E)\"",
      "\"If you add these chars to the file, it works.\"",
      "\"jq --seq \".title, .id\" test.json\"",
      "\"But looks like you don't need this option at all? Taking your file (without the RS characters) and feeding it to `jq \".title, .id\" test.json` yields the same results.\""
    ],
    "utterance": "Extract the title and id fields from each object in a file formatted with ASCII RS record separators.",
    "expressions": [
      ".title, .id"
    ],
    "data": [
      {
        "input": "\u001e{\"title\": 1, \"id\":2}\n\u001e{\"title\": 3, \"id\":4}\n\u001e{\"title\": 5, \"id\":6}\n",
        "output": "1\n2\n3\n4\n5\n6\n"
      }
    ],
    "identifier": 58962616
  },
  {
    "context": [
      "We need to generate the name `car0X_hyb.com`  - under `mazda`  string ( while X is the ID number )",
      "Example -  `ID=1`",
      "Then json will be as ...",
      "`ID=4` , Then json will be as ...",
      "`ID=6` , Then json will be as ...",
      "`ID=10` , Then json will be as ...",
      "You can generate a stream of subsequent numbers using `range`, use them to fill the template string, and make an array out of the results, like:",
      "$ jq -n --argjson ID 5 '.mazda = [ range($ID) | \"car\\(\"0\\(.+1)\"[-2:])_hyb.com\" ]'",
      "Adjust leading `0`s and `-2` according to the maximum length of `ID` in characters."
    ],
    "utterance": "Update the value of the 'mazda' key to an array of strings formatted as 'carXX_hyb.com', with XX being 2-digit numbers from 01 to the given ID number.",
    "expressions": [
      ".mazda = [ range($ID) | \"car\\(\"0\\(.+1)\"[-2:])_hyb.com\" ]"
    ],
    "data": [
      {
        "input": {
          "toyota": [
            "car1.com"
          ],
          "mazda": [],
          "ford": [
            "car01_eng.com"
          ]
        },
        "output": {
          "toyota": [
            "car1.com"
          ],
          "mazda": [
            "car01_hyb.com",
            "car02_hyb.com",
            "car03_hyb.com",
            "car04_hyb.com"
          ],
          "ford": [
            "car01_eng.com"
          ]
        }
      }
    ],
    "identifier": 59077074
  },
  {
    "context": [
      "I am writing a jq function to get total quantity.",
      "data=$( echo $response | jq '.objects[] | .qty ' )",
      "How do I sum these to get value:",
      "jq '[.objects[] | .qty] | add'",
      "jq '.objects | map(.qty) | add'",
      "def sigma(s): reduce s as $x (0; .+$x);",
      "sigma(.objects[] | .qty)"
    ],
    "utterance": "Sum all the qty values in the objects array to get the total quantity, for example, 40",
    "expressions": [
      "[.objects[] | .qty] | add",
      ".objects | map(.qty) | add",
      "def sigma(s): reduce s as $x (0; .+$x); sigma(.objects[] | .qty)"
    ],
    "data": [
      {
        "input": {
          "product": "BIG MAC",
          "objects": [
            {
              "qty": 10,
              "size": 32
            },
            {
              "qty": 20,
              "size": 53
            },
            {
              "qty": 10,
              "size": 54
            }
          ]
        },
        "output": 40
      }
    ],
    "identifier": 58917592
  },
  {
    "identifier": 59053729
  },
  {
    "context": [
      "\"but it's unable to pull the last array value as it doesn't have a tableName so I want to use \\(.details.graph.details.name) - \\(.status) ) in addition to what I have.\"",
      "\"You can use .details.tableName // .details.graph.details.name where you previously used .details.tableName :\"",
      "\"(.value.details[] | \\(.details.tableName // .details.graph.details.name) - \\(.status) )\""
    ],
    "utterance": "Extract each service's status and either its tableName or, if tableName is missing, its graph.details.name, along with the corresponding status.",
    "expressions": [
      ".details | to_entries[] | (.value.details[] | \"\\(.details.tableName // .details.graph.details.name) - \\(.status)\")"
    ],
    "data": [
      {
        "input": {
          "status": "UP",
          "details": {
            "Service1": {
              "status": "UP",
              "details": {
                "Hbase": {
                  "status": "UP",
                  "details": {
                    "tableName": "test1"
                  }
                }
              }
            },
            "Service2": {
              "status": "UP",
              "details": {
                "commTableHbase": {
                  "status": "UP",
                  "details": {
                    "tableName": "test2"
                  }
                }
              }
            },
            "Service3": {
              "status": "UP",
              "details": {
                "GraphDSE": {
                  "status": "UP",
                  "details": {
                    "graph": {
                      "status": "UP",
                      "details": {
                        "name": "svoc"
                      }
                    }
                  }
                }
              }
            }
          }
        },
        "output": [
          "test1 - UP",
          "test2 - UP",
          "svoc - UP"
        ]
      }
    ],
    "identifier": 59054257
  },
  {
    "context": [
      "In jq, how can I take this input...\n\n{\n  \"foo\": \"bar\"\n}\n{\n  \"foo\": \"baz\"\n}\n\n...and get this output?\nbar,baz",
      "jq -nr '[inputs|.foo]|join(\",\")'",
      "jq -sr 'map(.foo)|join(\",\")'",
      "The idea is to get bar and baz into an array and then join the elements of the array with \",\".",
      "-r gives you output without quotes."
    ],
    "utterance": "Output the values of the field 'foo' from two objects as a single line, comma-separated.",
    "expressions": [
      "[inputs|.foo]|join(\",\")",
      "map(.foo)|join(\",\")"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "bar"
          },
          {
            "foo": "baz"
          }
        ],
        "output": "bar,baz"
      }
    ],
    "identifier": 58774857
  },
  {
    "context": [
      "Everything is fine unless I forgot to pass variable `$target`:",
      "jq: error: $target is not defined at <top-level>, line 1:",
      "How can I catch this and use default value?",
      "But it seems to be parsing-time error, which obviously can't be caught at runtime.",
      "Check it beforehand",
      "target=${target:-\"/tmp\"}",
      "jq -nr --arg target \"$target\" \\",
      "  '([\"echo\",\"Hello, world\"]|@sh)+\">\\($target)/sample.txt\"' \\"
    ],
    "utterance": "Produce a shell command that writes 'Hello, world' to a file in a specified directory, defaulting to '/tmp' if the directory variable is missing.",
    "expressions": [
      "jq -nr --arg target \"$target\" '([\"echo\",\"Hello, world\"]|@sh)+\">\\($target)/sample.txt\"'"
    ],
    "data": [
      {
        "input": {},
        "output": "echo 'Hello, world' > /tmp/sample.txt"
      }
    ],
    "identifier": 59076541
  },
  {
    "context": [
      "However, some people put forced new lines into their tweets or bios. This is causing the csv file to have multiple lines for entries, often breaking up in the middle of a tweet.",
      "Partial example tweet (json format):\r\n\r\n      {\r\n    \"created_at\": \"Mon Aug 13 10:40:34 +0000 2018\",\r\n    \"id\": 1028954459110555600,\r\n    \"id_str\": \"1028954459110555649\",\r\n    \"full_text\": \"Oh well, they deal with it quite well. Like they add numbers and facts and such crazy stuff.\\nhttps://REPLACED/DuBGmHCnG8\\n#climatechange https://REPLACED/d5IBchM3Uk\",",
      "and running (it's https://github.com/johnkerl/miller)\r\n\r\nmlr --j2c unsparsify input.json >input.csv",
      "Then, using properly the import process you need to use, the `\\n` is not a problem."
    ],
    "utterance": "Convert a JSON object with embedded newlines in string values to CSV, ensuring embedded newlines are preserved and do not break CSV rows.",
    "expressions": [
      "mlr --j2c unsparsify input.json > input.csv"
    ],
    "data": [
      {
        "input": {
          "created_at": "Mon Aug 13 10:40:34 +0000 2018",
          "id": 1028954459110555600,
          "id_str": "1028954459110555649",
          "full_text": "Oh well, they deal with it quite well. Like they add numbers and facts and such crazy stuff.\nhttps://REPLACED/DuBGmHCnG8\n#climatechange https://REPLACED/d5IBchM3Uk",
          "truncated": false,
          "display_text_range": [
            0,
            131
          ],
          "entities": {
            "hashtags": [
              {
                "text": "climatechange",
                "indices": [
                  117,
                  131
                ]
              }
            ],
            "symbols": [],
            "user_mentions": [],
            "urls": [
              {
                "url": "https://REPLACED/DuBGmHCnG8",
                "expanded_url": "https://tamino.wordpress.com/2018/08/08/usa-temperature-can-i-sucker-you/",
                "display_url": "tamino.wordpress.com/2018/08/08/usa\u2026",
                "indices": [
                  93,
                  116
                ]
              },
              {
                "url": "https://REPLACED/d5IBchM3Uk",
                "expanded_url": "https://twitter.com/Tony__Heller/status/1028672939753758720",
                "display_url": "twitter.com/Tony__Heller/s\u2026",
                "indices": [
                  132,
                  155
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 58910133
  },
  {
    "context": [
      "How can I round, floor, ceil, and truncate a number in jq jq-1.5-1-a5b5cbe?",
      "For example, with {\"mass\": 188.72}, I want {\"mass\": 188} with floor, {\"mass\": 189} with ceil and round.",
      "Rounding examples:\n\n5.52 --> 6\n5.50 --> 5 or 6\n-5.52 --> -6",
      "Truncate examples:\n\n5.52 --> 5\n5.50 --> 5\n-5.52 --> -5",
      "In jq 1.6 you have access to round/ceil/floor functions",
      "$ echo '{\"mass\": 188.72}' | jq ' .mass | round '\n189",
      "$ echo '{\"mass\": 188.72}' | jq ' .mass | ceil '\n189",
      "$ echo '{\"mass\": 188.72}' | jq ' .mass | floor '\n188",
      "Note that both jq 1.5 and 1.6 have builtins named `round`, `ceil`, `floor` and `trunc`: they are all 0-arity filters.",
      "[5.52, 5.50, -5.52 ] | map(trunc)\n#=> [5,5,-5]",
      "Some builds may lack those functions, but as far as I'm concerned `floor` is widely available; so, you can implement them using it.",
      "def round: . + 0.5 | floor;",
      "def ceil: if . | floor == . then . else . + 1.0 | floor end;",
      "def trunc: if . < 0 then ceil else floor end;"
    ],
    "utterance": "Obtain the floor, ceiling, round, and truncation values for a given numeric value such as 188.72 or 5.52, including support for negative numbers, using available or custom functions in jq 1.5.",
    "expressions": [
      ".mass | round",
      "// jq 1.6+; also for jq 1.5 if available",
      ".mass | ceil",
      ".mass | floor",
      ".mass | trunc",
      ".mass + 0.5 | tostring | split(\".\") | .[0]",
      "// round (jq 1.5 workaround)",
      ".mass + 0.99999999 | tostring | split(\".\") | .[0]",
      "// ceil (jq 1.5 workaround)",
      ".mass | tostring | split(\".\") | .[0]",
      "// floor (jq 1.5 workaround)",
      "def round: . + 0.5 | floor; .mass | round",
      "// custom round",
      "def ceil: if . | floor == . then . else . + 1.0 | floor end; .mass | ceil",
      "// custom ceil",
      "def trunc: if . < 0 then ceil else floor end; .mass | trunc",
      "// custom trunc"
    ],
    "data": [
      {
        "input": {
          "mass": 188.72
        },
        "output": {
          "floor": 188,
          "ceil": 189,
          "round": 189
        }
      },
      {
        "input": 5.52,
        "output": {
          "round": 6,
          "trunc": 5
        }
      },
      {
        "input": -5.52,
        "output": {
          "round": -6,
          "trunc": -5
        }
      }
    ],
    "identifier": 59063536
  },
  {
    "context": [
      "In the end I want to get something like this working:\n\n    > cat movies.json |\n      jq 'map_values(try (.release_date |= if . == null or . == \"\"\n                                           then .\n                                           else (. | strptime(\"%Y-%m-%d\") | mktime) end)\n                     catch (.))'",
      "$ jq 'map(.release_date = (.release_date | . as $date\n            | try (strptime(\"%Y-%m-%d\") | mktime) catch $date))' release_date.json",
      "$ jq 'def parsedate($date):\n        try ($date | strptime(\"%Y-%m-%d\") | mktime)\n        catch $date;\n\n      map(.release_date = parsedate(.release_date))' release_date.json",
      "The simple workaround in the present case is to avoid '|=' e.g. by:\n\n(.release_date\n    | try (if . == null or . == \"\"\n           then . \n           else strptime(\"%Y-%m-%d\") | mktime end)\n     catch .) as $r\n  | .release_date = $r'"
    ],
    "utterance": "Convert all 'release_date' fields in a list of objects to epoch timestamps if parseable as '%Y-%m-%d', otherwise keep their original value (including null or non-standard strings).",
    "expressions": [
      "map(.release_date = (.release_date | . as $date | try (strptime(\"%Y-%m-%d\") | mktime) catch $date))",
      "def parsedate($date): try ($date | strptime(\"%Y-%m-%d\") | mktime) catch $date; map(.release_date = parsedate(.release_date))",
      "(.release_date | try (if . == null or . == \"\" then . else strptime(\"%Y-%m-%d\") | mktime end) catch .) as $r | .release_date = $r"
    ],
    "data": [
      {
        "input": [
          {
            "id": "42",
            "release_date": "2019-12-31"
          },
          {
            "id": "42",
            "release_date": null
          },
          {
            "id": "42",
            "release_date": "SOON!"
          }
        ],
        "output": [
          {
            "id": "42",
            "release_date": 1577750400
          },
          {
            "id": "42",
            "release_date": null
          },
          {
            "id": "42",
            "release_date": "SOON!"
          }
        ]
      }
    ],
    "identifier": 58879588
  },
  {
    "context": [
      "I want to re-format a JSON file so that certain objects (dictionaries) with some specific keys are on one-line.",
      "For example, any object with key `name` should appear in one line:"
    ],
    "utterance": "Reformat so that any object with key 'name' is printed on one line, while the rest of the structure remains pretty-printed.",
    "expressions": [
      ".",
      "# NOTE: jq does not natively support per-object pretty/compact formatting with mixing indented and one-line objects. There's no direct jq solution to render only objects with 'name' compactly within a pretty-printed document."
    ],
    "data": [
      {
        "input": {
          "this": "that",
          "parameters": [
            {
              "name": "param1",
              "type": "string"
            },
            {
              "name": "param2"
            },
            {
              "name": "param3",
              "default": "@someValue"
            }
          ]
        }
      }
    ],
    "identifier": 58736826
  },
  {
    "context": [
      "I want to populate json template with value \"Hello Jack\", but the \"Hello\" part shall remain inside of template, is there are any way of doing that",
      "jq -n --arg person \"Jack\" '{my_key: \"Hello \"$person}'",
      "Use [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%28foo%29) syntax like so:",
      "jq -n --arg person Jack '{my_key: \"Hello \\($person)\"}'",
      "$ jq -n --arg person Jack -f template.json",
      "{ \"my_key\": \"Hello Jack\" }"
    ],
    "utterance": "Replace a variable placeholder in a template so that 'my_key' has the value 'Hello Jack', with 'Hello' part fixed and 'Jack' sourced from a variable.",
    "expressions": [
      "jq -n --arg person Jack '{my_key: \"Hello \\($person)\"}'",
      "jq -n --arg person Jack -f template.json"
    ],
    "data": [
      {
        "input": {
          "my_key": "Hello \\($person)"
        },
        "output": {
          "my_key": "Hello Jack"
        }
      }
    ],
    "identifier": 58976258
  },
  {
    "context": [
      "Second i want that before adding array i change the value of **price** and then add in **original.json**",
      "jq \".store.book += [input.price=2] \"  original.json  element.json",
      "[ input|.price |= $newprice ]"
    ],
    "utterance": "Add an array element from one file into the 'store.book' array of another file, but set the element's 'price' to 2 before adding.",
    "expressions": [
      ".store.book += [ input|.price = 2 ]"
    ],
    "data": [
      {
        "input": {
          "original.json": {
            "store": {
              "book": [
                {
                  "category": "reference",
                  "author": "Nigel Rees",
                  "title": "Sayings of the Century",
                  "price": 8.95
                }
              ],
              "bicycle": {
                "color": "red",
                "price": 19.95
              }
            },
            "expensive": 10
          },
          "element.json": {
            "category": "fiction",
            "author": "Evelyn Waugh",
            "title": "Sword of Honour",
            "price": 12.99
          }
        },
        "output": {
          "store": {
            "book": [
              {
                "category": "reference",
                "author": "Nigel Rees",
                "title": "Sayings of the Century",
                "price": 8.95
              },
              {
                "category": "fiction",
                "author": "Evelyn Waugh",
                "title": "Sword of Honour",
                "price": 2
              }
            ],
            "bicycle": {
              "color": "red",
              "price": 19.95
            }
          },
          "expensive": 10
        }
      }
    ],
    "identifier": 58974290
  },
  {
    "context": [
      "How can I do this filtering and sorting in place, so that the original structure of the JSON is preserved?",
      "So in your case, the solution has the form:",
      ".[\"HOME_ROSTER\"] |= (...)",
      "That is, the solution would be:",
      ".[\"HOME_ROSTER\"] |=\n  (map(select(.STATS[0].MINUTES != \"N/A\"))\n   | sort_by(.STATS[0].MINUTES) | .[-5:] )"
    ],
    "utterance": "Update HOME_ROSTER so it contains only the 5 players with the highest average minutes played, excluding those whose first entry of MINUTES is N/A, while preserving the overall object structure.",
    "expressions": [
      ".[\"HOME_ROSTER\"] |= (map(select(.STATS[0].MINUTES != \"N/A\")) | sort_by(.STATS[0].MINUTES) | .[-5:] )"
    ],
    "data": [
      {
        "input": {
          "GAME_ID": "0021900121",
          "HOME_TEAM_ID": 1610612740,
          "AWAY_TEAM_ID": 1610612761,
          "GAMECODE": "20191108/TORNOP",
          "SEASON": "2019",
          "HOME_ROSTER": [
            {
              "PLAYER_ID": 1629638,
              "NAME": "Nickeil Alexander-Walker",
              "STATS": [
                {
                  "DATE": "2019-20",
                  "MINUTES": 12.5
                }
              ]
            },
            {
              "PLAYER_ID": 1629627,
              "NAME": "Zion Williamson",
              "STATS": [
                {
                  "DATE": "2019-20",
                  "MINUTES": "N/A"
                }
              ]
            },
            {
              "PLAYER_ID": 1628366,
              "NAME": "Lonzo Ball",
              "STATS": [
                {
                  "DATE": "2019-20",
                  "MINUTES": 30
                }
              ]
            }
          ]
        },
        "output": {
          "GAME_ID": "0021900121",
          "HOME_TEAM_ID": 1610612740,
          "AWAY_TEAM_ID": 1610612761,
          "GAMECODE": "20191108/TORNOP",
          "SEASON": "2019",
          "HOME_ROSTER": [
            {
              "PLAYER_ID": 1629638,
              "NAME": "Nickeil Alexander-Walker",
              "STATS": [
                {
                  "DATE": "2019-20",
                  "MINUTES": 12.5
                }
              ]
            },
            {
              "PLAYER_ID": 1628366,
              "NAME": "Lonzo Ball",
              "STATS": [
                {
                  "DATE": "2019-20",
                  "MINUTES": 30
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 58775875
  },
  {
    "context": [
      "I want to change the 3rd element (or other from bash variable).",
      "jq --argjson index \"$index\" '.[$index] |= <new value>'",
      "|= is the update operator, it lets you change the value of what is addressed on its left hand operand without changing the path, so that you can return the whole array rather than just the updated value.",
      "Note that indices are 0-based, so to change the 3rd element you want to set the bash variable $index to 2.",
      "Using --argjson instead of the usual --arg is needed to avoid handling the variable as a string but rather as a number which we can use as an index."
    ],
    "utterance": "Update the array element at the index specified by a variable to a new value.",
    "expressions": [
      ".[$index] |= <new value>",
      "jq --argjson index \"$index\" '.[$index] |= <new value>'"
    ],
    "data": [
      {
        "input": [
          111,
          222,
          333,
          444
        ],
        "output": [
          111,
          222,
          "some new value",
          444
        ]
      }
    ],
    "identifier": 58857998
  },
  {
    "context": [
      "I want to get all of the .com addresses. So I'm trying to write an if/then to check for mail being null. and if so get userPrincipleName instead.",
      "cat $JSON | jq -r 'map(if (.mail == null or .mail == \"null\")  then .userPrincipalName else .mail end)'",
      "'.[]|if (.mail == null or .mail == \"null\") then .userPrincipalName else .mail end' $JSON"
    ],
    "utterance": "For each entry, return the mail value if it is not null or \"null\"; otherwise, return userPrincipalName.",
    "expressions": [
      "map(if (.mail == null or .mail == \"null\") then .userPrincipalName else .mail end)",
      ".[] | if (.mail == null or .mail == \"null\") then .userPrincipalName else .mail end"
    ],
    "data": [
      {
        "input": [
          {
            "mail": "user1@example.com",
            "userPrincipalName": "user1@example.com"
          },
          {
            "mail": "user2@example.com",
            "userPrincipalName": "user2@example.org"
          },
          {
            "mail": "null",
            "userPrincipalName": "user3@example.com"
          }
        ],
        "output": [
          "user1@example.com",
          "user2@example.com",
          "user3@example.com"
        ]
      }
    ],
    "identifier": 59083114
  },
  {
    "context": [
      "I need to replace the B64 encrypted data with the decoded text.",
      "`jq` 1.6 can decode base64 data internally with the `@base64d` string formatter:",
      "[.[] | . + { Data: .Data | @base64d }]",
      "map( .Data |= @base64d )"
    ],
    "utterance": "Replace each object's 'Data' value with its base64-decoded string, preserving the array structure.",
    "expressions": [
      "[.[] | . + { Data: .Data | @base64d }]",
      "map(.Data |= @base64d)"
    ],
    "data": [
      {
        "input": [
          {
            "Index": 1,
            "Data": "aGVsbG8gaXRlbSAx"
          },
          {
            "Index": 2,
            "Data": "dGhpcyBpcyBpdGVtIDI="
          }
        ],
        "output": [
          {
            "Index": 1,
            "Data": "hello item 1"
          },
          {
            "Index": 2,
            "Data": "this is item 2"
          }
        ]
      }
    ],
    "identifier": 58986761
  },
  {
    "context": [
      "Is there a way within `jq` to do this all in one shot to produce output like this:\r\n\r\n    {\r\n        \"compliant\" : 123000,\r\n        \"noncompliant\" : 2000,\r\n        \"configManager\" : 116\r\n    }",
      "reduce stream as $word ({}; .[($word|tostring)] += 1);",
      "With this, you could use the filter:\r\n\r\n    bow(inputs | .complianceState)",
      "jq -s 'freq(.complianceState)\r\n  | map({key, value: .count})\r\n  | from_entries\r\n' all.json"
    ],
    "utterance": "Produce an object mapping each complianceState value to its frequency count from the input, in a single step.",
    "expressions": [
      "reduce .[] as $x ({}; .[$x.complianceState] += 1)",
      "bow(inputs | .complianceState)",
      "freq(.complianceState)\n  | map({key, value: .count})\n  | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "complianceState": "a",
            "other": 0.5
          },
          {
            "complianceState": "b",
            "other": 1.2
          },
          {
            "complianceState": "a",
            "other": 1.7
          },
          {
            "complianceState": "c",
            "other": 5.3
          },
          {
            "complianceState": "b",
            "other": 1.5
          },
          {
            "complianceState": "e",
            "other": 0.6
          },
          {
            "complianceState": "c",
            "other": 3.4
          },
          {
            "complianceState": "c",
            "other": 5.9
          }
        ],
        "output": {
          "a": 2,
          "b": 2,
          "c": 3,
          "e": 1
        }
      }
    ],
    "identifier": 58881716
  },
  {
    "context": [
      "select( .to.name == \\&quot;$to_status\\&quot;` returns false, where .to.name is &quot;ready for qa&quot; and to_status is &quot;ready for qa&quot;",
      "jq -r --arg to_status &quot;$TO_STATUS&quot; &#39;\n        .transitions[] \n        | select(.to.&quot;name&quot;==$to_status) \n        | .id&#39;)",
      "Don't interpolate; pass `to_status` as an argument.",
      "jq -r --arg t \"$to_status\"  '.transitions[] | select( .to.name == $t ) | .id'"
    ],
    "utterance": "Extract the id of the transition whose .to.name is exactly 'ready for qa'.",
    "expressions": [
      ".transitions[] | select(.to.name == $to_status) | .id",
      ".transitions[] | select(.to.name == $t) | .id"
    ],
    "data": [
      {
        "input": {
          "expand": "transitions",
          "transitions": [
            {
              "id": "11",
              "name": "Backlog",
              "to": {
                "name": "Backlog",
                "id": "10510"
              }
            },
            {
              "id": "51",
              "name": "Ready to QA",
              "to": {
                "name": "Ready for QA",
                "id": "10209"
              }
            }
          ]
        },
        "output": null
      }
    ],
    "identifier": 59051971
  },
  {
    "context": [
      "Now, I have to list all images which do not start with a particular string, say \"random.domain.com\"",
      "here how you can do that with `jq`",
      "kubectl get pods -o json | \\ \n jq '[.items[].spec.containers[].image | select(. | startswith(\"random.domain.com\") | not )] | unique'"
    ],
    "utterance": "List all container image names from pods that do not start with 'random.domain.com'.",
    "expressions": [
      ".items[].spec.containers[].image | select(. | startswith(\"random.domain.com\") | not)"
    ],
    "identifier": 58856694
  },
  {
    "context": [
      "I would like to extract id-name mappings using jq. I want my output to look as follows:",
      "{\"Age vs BMI\":\"8204af40-09e4-11ea-a775-a7174a3c3e58\", \" Age vs LDL\":\"96bb9ce0-09e5-11ea-a775-a7174a3c3e58\"}",
      "Here\u2019s a reduce-free solution:",
      "    INDEX(.[]; .attributes.title) | map_values(.id)",
      "In case your jq is very old, here\u2019s another reduce-free solution:",
      "    map( {(.attributes.title): .id} ) | add"
    ],
    "utterance": "Extract an object mapping each title from the attributes field to the corresponding id.",
    "expressions": [
      "INDEX(.[]; .attributes.title) | map_values(.id)",
      "map({(.attributes.title): .id}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "type": "vis",
            "id": "8204af40-09e4-11ea-a775-a7174a3c3e58",
            "attributes": {
              "title": "Age vs BMI"
            },
            "updated_at": "2019-11-19T08:28:29.499Z",
            "version": "WzIzLDFd"
          },
          {
            "type": "vis",
            "id": "96bb9ce0-09e5-11ea-a775-a7174a3c3e58",
            "attributes": {
              "title": " Age vs LDL"
            },
            "updated_at": "2019-11-19T08:28:29.499Z",
            "version": "WzI0LDFd"
          }
        ],
        "output": {
          "Age vs BMI": "8204af40-09e4-11ea-a775-a7174a3c3e58",
          " Age vs LDL": "96bb9ce0-09e5-11ea-a775-a7174a3c3e58"
        }
      }
    ],
    "identifier": 58968391
  },
  {
    "context": [
      "Using jq, how can I extract the host, name, and date_happened fields from the json output below?",
      "The jq filter: \n```\n.events[]\n| [.host, \n   (.tags[] | select( test(\"^name:\") ) | sub(\"name:\",\"\") ),\n   .date_happened]\n```\nproduces\n\n     [\"i-0e4b192579a9b423b\",\"app2_backend-prod\",1573502725]"
    ],
    "utterance": "Extract host, the value of the tag starting with 'name:', and date_happened fields from each event.",
    "expressions": [
      ".events[] | [.host, (.tags[] | select(test(\"^name:\")) | sub(\"name:\",\"\")), .date_happened]"
    ],
    "data": [
      {
        "input": {
          "events": [
            {
              "alert_type": "success",
              "children": [
                {
                  "alert_type": "error",
                  "date_happened": 1573502725,
                  "id": "5188183926379101887"
                },
                {
                  "alert_type": "success",
                  "date_happened": 1573503145,
                  "id": "5188190972457497744"
                }
              ],
              "comments": [],
              "date_happened": 1573502725,
              "device_name": null,
              "host": "i-0e4b192579a9b423b",
              "id": 5188183933173874377,
              "is_aggregate": true,
              "priority": "normal",
              "resource": "/api/v1/events/5188183933173874377",
              "source": "Monitor Alert",
              "tags": [
                "autoscaling_group:app2_backend-asg-prod",
                "availability-zone:us-east-1b",
                "datadog-agent:true",
                "environment:prod",
                "host:i-0e6b192579a9b423b",
                "iam_profile:app2_backend_instance_profile",
                "image:ami-2769055d",
                "instance-type:m4.large",
                "monitor",
                "name:app2_backend-prod",
                "region:us-east-1",
                "role:app2_backend"
              ]
            }
          ]
        },
        "output": [
          "i-0e4b192579a9b423b",
          "app2_backend-prod",
          1573502725
        ]
      }
    ],
    "identifier": 58823796
  },
  {
    "context": [
      "I want a list of all the houses that have furniture.",
      "I am applying the following jq statement: `.[] | select(.rooms[].furniture | length > 0) | .id`",
      "I am expecting:\n\"jones house\"\n\"smith house\"",
      "The first `rooms` has two objects complying `length > 0`, thus it's selected and printed twice. Use `any` to get your desired output:",
      ".[] | select(any(.rooms[].furniture; length > 0)) | .id"
    ],
    "utterance": "Return the id of each house if at least one of its rooms has any furniture (i.e., the 'furniture' object is non-empty).",
    "expressions": [
      ".[] | select(any(.rooms[].furniture; length > 0)) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "jones house",
            "rooms": [
              {
                "name": "living room",
                "furniture": {
                  "chair": "red"
                }
              },
              {
                "name": "bedroom",
                "furniture": {
                  "chair": "blue"
                }
              },
              {
                "name": "bathroom",
                "furniture": {}
              }
            ]
          },
          {
            "id": "smith house",
            "rooms": [
              {
                "name": "basement",
                "furniture": {
                  "chair": "green"
                }
              }
            ]
          },
          {
            "id": "johnson house",
            "rooms": [
              {
                "name": "study",
                "furniture": {}
              }
            ]
          }
        ],
        "output": [
          "jones house",
          "smith house"
        ]
      }
    ],
    "identifier": 58735473
  },
  {
    "context": [
      "In this case I'd like to exclude any element that contains \"valueFrom\" using jq",
      "After excluding the element mentioned above I am trying to return a result set that looks like this. \nvar1: var1value\nvar2: var2value\nvar3: var3value\nvar4: var4value",
      "$ jq -r '.[] | select(has(\"valueFrom\") | not) | \"\\(.name): \\(.value)\"' input.json"
    ],
    "utterance": "Exclude items that contain the key \"valueFrom\" and print each remaining item's name and value separated by a colon.",
    "expressions": [
      ".[] | select(has(\"valueFrom\") | not) | \"\\(.name): \\(.value)\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "var1",
            "value": "var1value"
          },
          {
            "name": "var2",
            "value": "var2value"
          },
          {
            "name": "var3",
            "value": "var3value"
          },
          {
            "name": "var4",
            "value": "var4value"
          },
          {
            "name": "var5",
            "valueFrom": {
              "secretKeyRef": {
                "key": "var5",
                "name": "var5value"
              }
            }
          }
        ],
        "output": "var1: var1value\nvar2: var2value\nvar3: var3value\nvar4: var4value"
      }
    ],
    "identifier": 58808062
  },
  {
    "context": [
      "\"I'd like to filter json based on whether a value is *not* in a list.\"",
      "\"[.n, .vals.n2] not in  ([\\\"A\\\", \\\"B\\\"], [\\\"B\\\", \\\"C\\\"])\"",
      "\"The expression:\r\n\r\n    ([.n, .vals.n2]) not in ([\\\"A\\\", \\\"B\\\"], [\\\"B\\\", \\\"C\\\"])\"",
      "\"You'll need to do something more like this:\r\n\r\n    select([.n, .vals.n2] as $v | $v != [\\\"A\\\", \\\"B\\\"] and $v != [\\\"B\\\", \\\"C\\\"])\"",
      "\"or\r\n\r\n    select([.n, .vals.n2] as $v | all([\\\"A\\\", \\\"B\\\"], [\\\"B\\\", \\\"C\\\"]; $v != .))\"",
      "\"Also if you wanted to stick with your first approach, you would have to put the values in an array and not just separated by a comma.\"",
      "\"select([.n, .vals.n2] as $i | [[\\\"A\\\", \\\"B\\\"], [\\\"B\\\", \\\"C\\\"]] | index($i) | not)\"",
      "\"[[\\\"A\\\", \\\"B\\\"], [\\\"B\\\", \\\"C\\\"]] as $blacklist\n| map( [.n, .vals.n2] as $i\n       | select( $blacklist | index([$i]) | not) )\""
    ],
    "utterance": "Select all objects whose [n, vals.n2] pair does not match any pair in the blacklist [[\"A\", \"B\"], [\"B\", \"C\"]].",
    "expressions": [
      "[.[] | select([.n, .vals.n2] as $v | $v != [\"A\", \"B\"] and $v != [\"B\", \"C\"])]",
      "[.[] | select([.n, .vals.n2] as $v | all([[\"A\", \"B\"], [\"B\", \"C\"]][]; $v != .))]",
      "[.[] | select([.n, .vals.n2] as $i | [[\"A\", \"B\"], [\"B\", \"C\"]] | index($i) | not)]",
      "[[\"A\", \"B\"], [\"B\", \"C\"]] as $blacklist | map( [.n, .vals.n2] as $i | select($blacklist | index($i) | not) )",
      "[[\"A\", \"B\"], [\"B\", \"C\"]] as $blacklist | map( [.n, .vals.n2] as $i | select($blacklist | index([$i]) | not) )"
    ],
    "data": [
      {
        "input": [
          {
            "n": "A",
            "a": 659533330984,
            "vals": {
              "n2": "B",
              "b": 5193941030
            }
          },
          {
            "n": "A",
            "a": 659533330984,
            "vals": {
              "n2": "C",
              "b": 4872891707
            }
          },
          {
            "n": "B",
            "a": 659533330984,
            "vals": {
              "n2": "C",
              "b": 4872891707
            }
          }
        ],
        "output": [
          {
            "n": "A",
            "a": 659533330984,
            "vals": {
              "n2": "C",
              "b": 4872891707
            }
          }
        ]
      }
    ],
    "identifier": 58876096
  },
  {
    "context": [
      "I want to sort it so it would look like:\r\n```\r\n{\r\n  \"dir10/somepath5\": 30.1,\r\n  \"dir5/somepath4\": 10.1,\r\n  \"dir2/somepath2\": 3.5,\r\n  \"dir1/somepath1\": 1.2,\r\n  \"dir2/somepath3\": 1.0  \r\n}\r\n```",
      "I managed to answer my own question  \r\n`jq 'to_entries | sort_by(.value) | reverse | from_entries'`"
    ],
    "utterance": "Sort the object's entries in descending order by each entry's value.",
    "expressions": [
      "to_entries | sort_by(.value) | reverse | from_entries"
    ],
    "data": [
      {
        "input": {
          "dir1/somepath1": 1.2,
          "dir2/somepath2": 3.5,
          "dir2/somepath3": 1.0,
          "dir5/somepath4": 10.1,
          "dir10/somepath5": 30.1
        },
        "output": {
          "dir10/somepath5": 30.1,
          "dir5/somepath4": 10.1,
          "dir2/somepath2": 3.5,
          "dir1/somepath1": 1.2,
          "dir2/somepath3": 1.0
        }
      }
    ],
    "identifier": 58786871
  },
  {
    "context": [
      "In the value , there is parameter \"shortName\" . I am trying to use jq to create a new json if the '**shortName**' matches a particular value. For example, if i pass **shortName** as **'ghi'** the new json should only contain the below sample. I'm trying to use jq here.",
      "You can use `to_entries()` to create a key/value pair from the JSON objects and match the `.shortName` field against the string needed and use `from_entries` to convert the key value pair back to actual JSON",
      "jq 'to_entries | map( select( .value.shortName == \"ghi\" ) ) | from_entries'",
      "or with providing argument string from command-line using the `--arg` field. With that `sn` becomes the variable that contains the string `ghi`, which can be used inside the filter.",
      "jq --arg sn ghi 'to_entries | map( select( .value.shortName == $sn ) ) | from_entries' json",
      "Here's a solution in the case of \"ghi\":",
      "jq --arg sn ghi '\n    with_entries(select(.value.shortName == $sn))' input.json"
    ],
    "utterance": "Return a new object containing only the entries where shortName equals 'ghi'.",
    "expressions": [
      "to_entries | map(select(.value.shortName == \"ghi\")) | from_entries",
      "to_entries | map(select(.value.shortName == $sn)) | from_entries",
      "with_entries(select(.value.shortName == $sn))"
    ],
    "data": [
      {
        "input": {
          "com-abc": {
            "componentName": "com-abc",
            "shortName": "abc",
            "tag": "1234",
            "commitId": "bb59d7c",
            "repository": "com-abc"
          },
          "com-def": {
            "componentName": "com-def",
            "shortName": "def",
            "tag": "5678",
            "commitId": "bb59d7cwfer",
            "repository": "com-def"
          },
          "com-ghi": {
            "componentName": "com-ghi",
            "shortName": "ghi",
            "tag": "91011",
            "commitId": "b55cwfer",
            "repository": "com-ghi"
          },
          "com-jkl": {
            "componentName": "com-jkl",
            "shortName": "jkl",
            "tag": "9107766",
            "commitId": "b55cwfer10f",
            "repository": "com-jkl"
          }
        },
        "output": {
          "com-ghi": {
            "componentName": "com-ghi",
            "shortName": "ghi",
            "tag": "91011",
            "commitId": "b55cwfer",
            "repository": "com-ghi"
          }
        }
      }
    ],
    "identifier": 58851256
  },
  {
    "context": [
      "I would like to produce a file with the following structure:\r\n\r\n    [\r\n        {\"f1\": \"v1\"},\r\n        {\"f1\": \"v2\"},\r\n        {\"f1\": \"v3\"},\r\n        {\"f1\": \"v4\"}\r\n    ]",
      "You can use the following :\r\n\r\n    jq --slurp 'map(.products[])' /path/to/dir/*.json",
      "The `--slurp` flag tells `jq` to read all its inputs in an array rather than working on them separately. We then map  each object of this array (the original contents of the files) into the sequence of their products."
    ],
    "utterance": "Combine the arrays under 'products' from multiple files into a single flat array containing all product objects.",
    "expressions": [
      "map(.products[])"
    ],
    "data": [
      {
        "input": [
          {
            "products": [
              {
                "f1": "v1"
              },
              {
                "f1": "v2"
              }
            ]
          },
          {
            "products": [
              {
                "f1": "v3"
              },
              {
                "f1": "v4"
              }
            ]
          }
        ],
        "output": [
          {
            "f1": "v1"
          },
          {
            "f1": "v2"
          },
          {
            "f1": "v3"
          },
          {
            "f1": "v4"
          }
        ]
      }
    ],
    "identifier": 59091000
  },
  {
    "context": [
      "I just want to get key name of those fields which are nested arrays. for below json, I want to get in output key-name equals to \"cd\" because that is the only one which is nested.",
      "jq 'to_entries[]|select(.value|type == \"array\")|.key' <<< '\n    {\n      \"ab\": null,\n      \"cd\": [ \"ST\",\"CO\" ],\n      \"EF\": 0,\n      \"GH\": 0,\n      \"IJ\": null,\n      \"IK\": true\n    }'"
    ],
    "utterance": "Return the key names for all top-level fields whose values are arrays.",
    "expressions": [
      "to_entries[] | select(.value|type == \"array\") | .key"
    ],
    "data": [
      {
        "input": {
          "ab": null,
          "cd": [
            "ST",
            "CO"
          ],
          "EF": 0,
          "GH": 0,
          "IJ": null,
          "IK": true
        },
        "output": "cd"
      }
    ],
    "identifier": 58869631
  },
  {
    "context": [
      "Here it is directly from jqplay:  \r\n\r\n    jq '.objects[ ] | \"\\(.id) \\(.batch_fields.SJNB)\"'",
      "If you're running this in the windows command prompt, you have to use double quotes to quote your filter, there's no getting around it. Then from there, you just need to escape characters in your filter appropriately.",
      "> jq \".objects[] | \\\"\\(.id) \\(.batch_fields.SJNB)\\\"\" file.json"
    ],
    "utterance": "Print each object's id and batch_fields.SJNB, separated by a space, with appropriate quoting for Windows command prompt.",
    "expressions": [
      ".objects[] | \"\\\"\\(.id) \\(.batch_fields.SJNB)\\\"\""
    ],
    "identifier": 59044503
  },
  {
    "context": [
      "My goal is to conditionally add \"imporant_key\" : \"\" where it is missing but ***not*** replace any *existing* `important_key` values.",
      ".Index[] |= if has(\"important_key\") then . else .important_key = $myImportantKey end",
      ".Index[] |= { \"important_key\":  \"data\" } + .",
      "Will set the default `important_key` to `\"data\"` if the key does not exist. It will keep any values set as any other values, including `null`."
    ],
    "utterance": "Add the key 'important_key' with value 'data' to each user if and only if the key is missing, leaving existing values unchanged.",
    "expressions": [
      ".Index[] |= if has(\"important_key\") then . else .important_key = \"data\" end",
      ".Index[] |= { \"important_key\": \"data\" } + ."
    ],
    "data": [
      {
        "input": {
          "Index": {
            "example_user": {
              "important_key": "leave_me_alone",
              "blah": {
                "more_stuff": {
                  "ignore_this": "and_this_too"
                }
              }
            },
            "another_user": {
              "blah": {
                "more_stuff": {
                  "ignore_this": "and_this_too"
                }
              }
            },
            "extra_person": {
              "blah": {
                "more_stuff": {
                  "ignore_this": "and_this_too"
                }
              }
            }
          }
        },
        "output": {
          "Index": {
            "example_user": {
              "important_key": "leave_me_alone",
              "blah": {
                "more_stuff": {
                  "ignore_this": "and_this_too"
                }
              }
            },
            "another_user": {
              "blah": {
                "more_stuff": {
                  "ignore_this": "and_this_too"
                }
              },
              "important_key": "data"
            },
            "extra_person": {
              "blah": {
                "more_stuff": {
                  "ignore_this": "and_this_too"
                }
              },
              "important_key": "data"
            }
          }
        }
      }
    ],
    "identifier": 58878849
  },
  {
    "context": [
      "Following is the sample output data in json format when i create a JIRA from command line using `curl` command.",
      "{ \"id\":\"123456\",\"key\":\"ABCD-123\",\"self\":\"http://abcd.com/rest/api/2/issue/123456\" }",
      "How can i read `ABCD-1234` into a variable. i have tried json data parser `jq` but it didn&#39;t help.",
      "With `jq`:",
      "key=$(jq -r '.key' file)"
    ],
    "utterance": "Extract the value of the field named 'key' where its value is 'ABCD-123'.",
    "expressions": [
      ".key",
      "jq -r '.key' file"
    ],
    "data": [
      {
        "input": {
          "id": "123456",
          "key": "ABCD-123",
          "self": "http://abcd.com/rest/api/2/issue/123456"
        },
        "output": "ABCD-123"
      }
    ],
    "identifier": 58968087
  },
  {
    "context": [
      "When the user runs the script :\n./search_job.sh \"Python\" \"New York\"\nthe required output is :\n{\n\"company\": \"The Public Theater\",\n\"title\": \"Web Developer\"\n}\n{\n\"company\": \"Aon Cyber Solutions\",\n\"title\": \"Cybersecurity Firm Seeks Senior Developer\"\n}\n{\n\"company\": \"Sesame\",\n\"title\": \"Software engineer (back end)\"\n}\n{\n\"company\": \"New York University\",\n\"title\": \"Technology Solutions Developer\"\n}",
      "curl -G --data-urlencode \"description=$1\" \\\n        --data-urlencode \"location=$2\"    \\\nhttps://jobs.github.com/positions.json | jq '.[] | { company, title }'"
    ],
    "utterance": "Extract company and title fields for each job in the search result matching given description and location.",
    "expressions": [
      ".[] | { company, title }"
    ],
    "identifier": 59071668
  },
  {
    "context": [
      "I have a json string that I need to convert into an array for passing a password in.",
      "Current json looks like this ... {\r\n        \"password\": \"Password1\",\r\n        \"loginId\": \"USER1\"\r\n   }",
      "I need to change it to this\r\n{\r\n      \"password\":[ \r\n         \"P\",\r\n         \"a\",\r\n         \"s\",\r\n         \"s\",\r\n         \"w\",\r\n         \"o\",\r\n         \"r\",\r\n         \"d\",\r\n         \"1\"\r\n      ],\r\n      \"loginId\":\"USER1\"\r\n   }",
      "In jq, splitting a string by empty string results in a character array just as you need.",
      "jq '[].password |= split(\"\")' file"
    ],
    "utterance": "Convert the value of the password field for each object into an array of its individual characters.",
    "expressions": [
      ".[].password |= split(\"\")"
    ],
    "data": [
      {
        "input": [
          {
            "password": "Password1",
            "loginId": "USER1"
          }
        ],
        "output": [
          {
            "password": [
              "P",
              "a",
              "s",
              "s",
              "w",
              "o",
              "r",
              "d",
              "1"
            ],
            "loginId": "USER1"
          }
        ]
      }
    ],
    "identifier": 58999450
  },
  {
    "context": [
      "In file 2 the versions were changed and i need to echo the new changes.",
      "I need to output text:\r\n\r\n    The new versions are:\r\n    bpm 1.1.6\r\n    haproxy 9.8.1",
      "Edit following your updated request in the comments : the following `jq` command will output the versions changed between the first file and the second. It nicely handles downgrades and somewhat handles products that have appeared or disappeared  in the second file (although it always shows the version as `version --&gt; null` whether it is a product that appeared or disappeared).\r\n\r\n    jq --slurp -r 'map(.releases) | add\n       | group_by(.name) \n       | map(select(.[0].version != .[1].version)) \n       | map (\"\\(.[0].name) : \\(.[0].version) --> \\(.[1].version)\")\n       | join(\"\\n\")' file_one.json file_two.json"
    ],
    "utterance": "List releases whose version changed from the first file to the second, showing their names and version transitions.",
    "expressions": [
      "jq --slurp -r 'map(.releases) | add | group_by(.name) | map(select(.[0].version != .[1].version)) | map (\"\\(.[0].name) : \\(.[0].version) --> \\(.[1].version)\") | join(\"\\n\")' file_one.json file_two.json"
    ],
    "data": [
      {
        "input": [
          {
            "releases": [
              {
                "name": "bpm",
                "version": "1.1.5"
              },
              {
                "name": "haproxy",
                "version": "9.8.0"
              },
              {
                "name": "test",
                "version": "10"
              }
            ]
          },
          {
            "releases": [
              {
                "name": "bpm",
                "version": "1.1.6"
              },
              {
                "name": "haproxy",
                "version": "9.8.1"
              },
              {
                "name": "test",
                "version": "10"
              }
            ]
          }
        ],
        "output": "bpm : 1.1.5 --> 1.1.6\nhaproxy : 9.8.0 --> 9.8.1"
      }
    ],
    "identifier": 59085432
  },
  {
    "context": [
      "I want to extract only the mac fields from this result with jq JSON processor:",
      "Best will be if I get only the mac addresses, without json formatting - if possible - as an result.",
      "The following uses `..` and so may not be exactly what you want, but it has the merit of simplicity:",
      "jq -r '.. | objects | .mac // empty' input.json"
    ],
    "utterance": "Extract all mac field values as plain text from the nested data structure.",
    "expressions": [
      ".. | objects | .mac // empty"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "jsonrpc": "2.0",
            "result": [
              0,
              {
                "results": [
                  {
                    "mac": "11:22:33:44:55:66",
                    "noise": 0,
                    "mesh llid": 0,
                    "connected_time": 165947,
                    "rx": {
                      "rate": 6000
                    },
                    "mesh local PS": "",
                    "tx": {
                      "rate": 6000
                    },
                    "signal": -63
                  }
                ]
              }
            ]
          },
          {
            "id": 2,
            "jsonrpc": "2.0",
            "result": [
              0,
              {
                "results": [
                  {
                    "mac": "11:22:33:44:55:66",
                    "noise": -105,
                    "mesh llid": 0,
                    "connected_time": 106975,
                    "rx": {
                      "rate": 650000
                    },
                    "mesh local PS": "",
                    "tx": {
                      "rate": 360000
                    },
                    "inactive": 40
                  },
                  {
                    "mac": "11:22:33:44:55:66",
                    "noise": -105,
                    "mesh llid": 0,
                    "connected_time": 20813,
                    "rx": {
                      "rate": 24000
                    },
                    "mesh local PS": "",
                    "tx": {
                      "rate": 6000
                    },
                    "inactive": 230
                  },
                  {
                    "mac": "11:22:33:44:55:66",
                    "noise": -105,
                    "mesh llid": 0,
                    "connected_time": 2106,
                    "rx": {
                      "rate": 24000
                    },
                    "mesh local PS": "",
                    "tx": {
                      "rate": 6000
                    },
                    "inactive": 240
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          "11:22:33:44:55:66",
          "11:22:33:44:55:66",
          "11:22:33:44:55:66",
          "11:22:33:44:55:66"
        ]
      }
    ],
    "identifier": 58985255
  },
  {
    "context": [
      "So I would like to know if I can use the [cli tool jq](https://stedolan.github.io/jq/) to filter the objects based on a specific tag Value? And if it is possible to list out all Value of a specific Tag Key?",
      "Filter objects based on a specific tag value:\r\n\r\n    aws resourcegroupstaggingapi get-resources --region REGIONCODE \\\r\n        | jq '.ResourceTagMappingList[] | select(.Tags[0].Value == \"VALUETYPE\")'",
      "`aws resourcegroupstaggingapi get-resources --region \"$AWS_REGION\" --tag-filters Key=TAG_NAME | jq '.ResourceTagMappingList[] | select(any(.Tags[] ; .Key == \"TAG_NAME\" and .Value == \"TAG_VALUE\"))'`",
      "`aws resourcegroupstaggingapi get-resources --region \"$AWS_REGION\" --tag-filters Key=TAG_NAME | jq '.ResourceTagMappingList[] | select(any(.Tags[] ; .Key == \"TAG_NAME\" and (.Value | contains(\"SUBSTRING\"))))'`"
    ],
    "utterance": "Filter resources to those where any tag has Key equal to TAG_NAME and Value equal to TAG_VALUE.",
    "expressions": [
      ".ResourceTagMappingList[] | select(any(.Tags[] ; .Key == \"TAG_NAME\" and .Value == \"TAG_VALUE\"))",
      ".ResourceTagMappingList[] | select(any(.Tags[] ; .Key == \"TAG_NAME\" and (.Value | contains(\"SUBSTRING\"))))"
    ],
    "data": [
      {
        "input": {
          "ResourceTagMappingList": [
            {
              "ResourceARN": "arn:aws:acm:eu-west-1:123456789000:certificate/XXXXX-YYYY-8888-9999-CCCCCCCCCCCCC",
              "Tags": [
                {
                  "Key": "Environment",
                  "Value": "BAR"
                }
              ]
            },
            {
              "ResourceARN": "arn:aws:acm:eu-west-1:123456789000:certificate/XXXXX-YYYY-8888-9999-CCCCCCCCCCCCC",
              "Tags": [
                {
                  "Key": "Environment",
                  "Value": "FOO"
                }
              ]
            },
            {
              "ResourceARN": "arn:aws:ec2:eu-west-1:123456789000:elastic-ip/eipalloc-112345440809463",
              "Tags": [
                {
                  "Key": "Component",
                  "Value": "somethingCool"
                },
                {
                  "Key": "DeployID",
                  "Value": "di-01"
                },
                {
                  "Key": "Name",
                  "Value": "eip-nat-somethingCool-di-01"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "ResourceARN": "arn:aws:acm:eu-west-1:123456789000:certificate/XXXXX-YYYY-8888-9999-CCCCCCCCCCCCC",
            "Tags": [
              {
                "Key": "Environment",
                "Value": "BAR"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 58903160
  },
  {
    "context": [
      "I don't want just a list of package names, I want to convert the hash of package-name/version-range data into a string with their names and ranges, like this:\n\nbabel@^7.3.12 react@^16.0.0 react-dom@^16.0.0 webpack@^4.0.0",
      "What must be produced:\n\nansi-styles@^4.1.0 supports-color@^7.1.0",
      "jq \".dependencies | to_entries | map_values( .key + \\\"@\\\" + .value ) | join(\\\" \\\" )\" package.json",
      ".dependencies | [ keys[] as $k | \"\\($k)@\\(.[$k])\" ] | join(\" \")"
    ],
    "utterance": "Produce a space-separated string listing each dependency and its version range in the format name@range from the dependencies object.",
    "expressions": [
      ".dependencies | to_entries | map_values(.key + \"@\" + .value) | join(\" \")",
      ".dependencies | [ keys[] as $k | \"\\($k)@\\(.[$k])\" ] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "name": "chalk",
          "version": "3.0.0",
          "description": "Terminal string styling done right",
          "license": "MIT",
          "repository": "chalk/chalk",
          "main": "source",
          "engines": {
            "node": ">=8"
          },
          "scripts": {
            "test": "xo && nyc ava && tsd",
            "bench": "matcha benchmark.js"
          },
          "dependencies": {
            "ansi-styles": "^4.1.0",
            "supports-color": "^7.1.0"
          },
          "devDependencies": {
            "ava": "^2.4.0",
            "coveralls": "^3.0.7",
            "execa": "^3.2.0",
            "import-fresh": "^3.1.0",
            "matcha": "^0.7.0",
            "nyc": "^14.1.1",
            "resolve-from": "^5.0.0",
            "tsd": "^0.7.4",
            "xo": "^0.25.3"
          }
        },
        "output": "ansi-styles@^4.1.0 supports-color@^7.1.0"
      }
    ],
    "identifier": 59023885
  },
  {
    "context": [
      "my data looks like: \n\n    {\"key\": \"site=\\\"abc\\\"\"}",
      "I want to filter using contains (or some other method) for where site=abc but not site=abc123",
      "current code that gets abc and abc123:",
      "jq -c '.textPayload | select(contains(\"abc\"))' test.json",
      "Consider:\n\n```\n$ echo '{\"key\": \"site=\\\"abc\\\"\"}' | jq 'select(.key | contains(\"\\\"abc\\\"\"))'\n{\n  \"key\": \"site=\\\"abc\\\"\"\n}\n",
      "$ echo '{\"key\": \"site=\\\"abc\\\"\"}' | jq 'select(.key | index(\"\\\"abc\\\"\"))'\n{\n  \"key\": \"site=\\\"abc\\\"\"\n}\n",
      "$ echo '{\"key\": \"site=\\\"abc\\\"\"}' | jq 'select(.key | test(\"\\\"abc\\\"\"))'\n{\n  \"key\": \"site=\\\"abc\\\"\"\n}\n"
    ],
    "utterance": "Select objects whose key field contains the exact substring 'site=\"abc\"', excluding substrings like 'site=\"abc123\"'.",
    "expressions": [
      "select(.key | contains(\"\\\"abc\\\"\"))",
      "select(.key | index(\"\\\"abc\\\"\"))",
      "select(.key | test(\"\\\"abc\\\"\"))"
    ],
    "data": [
      {
        "input": {
          "key": "site=\"abc\""
        },
        "output": {
          "key": "site=\"abc\""
        }
      },
      {
        "input": {
          "key": "site=\"abc123\""
        }
      }
    ],
    "identifier": 58894567
  },
  {
    "context": [
      "I have two files containing objects. The fields of each object are arrays of objects. I would like to merge the object arrays by each key.",
      "file1.json\n{\n    \"foo\": [\n        {\n            \"nested\": \"object\"\n        }\n    ],\n    \"bar\": [\n        {\n            \"nested\": \"object.bar\"\n        }\n    ]\n}\n",
      "file2.json\n{\n    \"foo\": [\n        {\n            \"nested\": \"object.foo2\"\n        }\n    ],\n    \"baz\": [\n        {\n            \"nested\": \"object.baz\"\n        }\n    ]\n}\n",
      "merged.json\n{\n    \"foo\": [\n        {\n            \"nested\": \"object\"\n        },\n        {\n            \"nested\": \"object.foo2\"\n        },\n    ]\n    \"bar\": [\n        {\n            \"nested\": \"object.bar\"\n        }\n    ]\n    \"baz\": [\n        {\n            \"nested\": \"object.baz\"\n        }\n    ]\n}\n",
      "Using nested `reduce`s:\n```\nreduce inputs as $in (.;\n  reduce ($in | keys_unsorted[]) as $k (.;\n    .[$k] += $in[$k]\n  )\n)\n```",
      "You can use the following :\n\n    map(to_entries) | add | group_by(.key) | map({ key: (.[0].key), value:([.[].value | add]) }) | from_entries\n"
    ],
    "utterance": "Merge multiple objects that each have fields containing arrays of objects, so that for each key the arrays are concatenated across all input objects.",
    "expressions": [
      "reduce inputs as $in (.; reduce ($in | keys_unsorted[]) as $k (.; .[$k] += $in[$k]))",
      "map(to_entries) | add | group_by(.key) | map({ key: (.[0].key), value: ([.[].value | add]) }) | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "foo": [
              {
                "nested": "object"
              }
            ],
            "bar": [
              {
                "nested": "object.bar"
              }
            ]
          },
          {
            "foo": [
              {
                "nested": "object.foo2"
              }
            ],
            "baz": [
              {
                "nested": "object.baz"
              }
            ]
          }
        ],
        "output": {
          "foo": [
            {
              "nested": "object"
            },
            {
              "nested": "object.foo2"
            }
          ],
          "bar": [
            {
              "nested": "object.bar"
            }
          ],
          "baz": [
            {
              "nested": "object.baz"
            }
          ]
        }
      }
    ],
    "identifier": 58770155
  },
  {
    "context": [
      "Now I can do something like this quite well with `jq`\n\n    $ jq -r '[\"foo1.bar1@email.com\"]' permissions.json",
      "Now the email needs to come from a variable",
      "Ive tried sending the var as an `--arg`.",
      "So how can I use the email as a variable and extract the permissions out of it using `jq` ?",
      "USER=foo1.bar1@email.com\njq --arg USER \"$USER\" -r '.[$USER][]' permissions.json",
      "for role in $(jq --arg u \"$user\" -r '.[$u][]' permissions.json)",
      "% jq -r 'keys[] as $user | .[$user][] | \"User \\($user) has role \\(.)\"' permissions.json"
    ],
    "utterance": "Extract the list of roles assigned to a given user email address provided as a variable.",
    "expressions": [
      "jq --arg USER \"$USER\" -r '.[$USER][]' permissions.json",
      "jq --arg u \"$USER\" -r '.[$u][]' permissions.json"
    ],
    "data": [
      {
        "input": {
          "foo1.bar1@email.com": [
            "projects/development/roles/superadmin",
            "compute.networkAdmin"
          ],
          "foo2.bar2@email.co": [
            "compute.networkAdmin"
          ]
        },
        "output": [
          "projects/development/roles/superadmin",
          "compute.networkAdmin"
        ]
      }
    ],
    "identifier": 59127004
  },
  {
    "context": [
      "I want to emit only the parent key for an object based on the contents of .name: where .name == \"Tree\", return \"63\".",
      "You can format the JSON in a key/value format using `to_entries()` and get the key corresponding to a certain value",
      "jq --raw-output 'to_entries[] | select(.value.name == \"Tree\").key'"
    ],
    "utterance": "Return the key whose nested object's name is equal to \"Tree\".",
    "expressions": [
      "to_entries[] | select(.value.name == \"Tree\").key"
    ],
    "data": [
      {
        "input": {
          "63": {
            "state": {
              "on": false,
              "alert": "select",
              "mode": "automation",
              "reachable": true
            },
            "swupdate": {
              "state": "notupdatable",
              "lastinstall": "2019-09-15T11:19:15"
            },
            "type": "plug",
            "name": "Tree",
            "modelid": "XXX",
            "manufacturername": "XXX",
            "productname": "plug",
            "capabilities": {
              "certified": false,
              "control": {},
              "streaming": {
                "renderer": false,
                "proxy": false
              }
            },
            "config": {
              "archetype": "plug",
              "function": "functional",
              "direction": "omnidirectional"
            },
            "uniqueid": "00:0d:6f:ff:fe:da:c9:dc-01",
            "swversion": "2.0.022"
          }
        },
        "output": "63"
      }
    ],
    "identifier": 58748582
  },
  {
    "context": [
      "How do I sort by `StartTime` and return latest `\"SnapshotId\": \"snap-xxxxxxxxxxxxxxxx\"`?",
      "So if you don\\'t care about ties, a simple solution to the problem is:\n\n    sort_by(.StartTime) | .[-1] | .SnapshotId",
      "this can be abbreviated to just:\n\n    sort_by(.StartTime)[-1].SnapshotId",
      "If you prefer to use `jq`, you can get the same results as follows (as @peak indicated):\n\n    aws ec2 describe-snapshots \\\n        --owner-ids xxxxxxxxxxxx \\\n        | jq -r '.Snapshots | sort_by(.StartTime)[-1].SnapshotId'\n"
    ],
    "utterance": "Get the SnapshotId of the latest snapshot by StartTime from the Snapshots array.",
    "expressions": [
      ".Snapshots | sort_by(.StartTime)[-1].SnapshotId",
      "sort_by(.StartTime)[-1].SnapshotId"
    ],
    "identifier": 58753143
  },
  {
    "context": [
      "My original json:\r\n\r\n``` lang-js\r\n{\r\n   columns:[\"colA\",\"colB\",\"colC\"]\r\n   values: [\r\n       [\"3\",\"abc\",200],\r\n       [\"4\",\"def\",300],\r\n       [\"5\",\"ghi\",400],\r\n       [\"6\",\"jkl\",500]\r\n   ]\r\n\r\n}\r\n```",
      "I want to produce:\r\n``` lang-js\r\n[\r\n    {colA: 3, colB: \"abc\", colC: 200},\r\n    {colA: 4, colB: \"def\", colC: 300},\r\n    {colA: 5, colB: \"ghi\", colC: 400},\r\n    {colA: 6, colB: \"jkl\", colC: 500}\r\n]\r\n```",
      "With this def, the \"main\" jq filter is simply:\r\n\n```\n.columns as $headers\n| .values\n| map(objectify($headers))\n```"
    ],
    "utterance": "Transform data with column names and row values into an array of objects, assigning each column's value in order, and converting numeric strings to numbers.",
    "expressions": [
      "def objectify(headers):\n  def tonumberq: tonumber? // .;\n  def trimq: if type == \"string\" then sub(\"^ +\";\"\") | sub(\" +$\";\"\") else . end;\n  def tonullq: if . == \"\" then null else . end;\n  . as $in\n  | reduce range(0; headers|length) as $i\n      ({}; .[headers[$i]] = ($in[$i] | trimq | tonumberq | tonullq) );\n.columns as $headers | .values | map(objectify($headers))"
    ],
    "data": [
      {
        "input": {
          "columns": [
            "colA",
            "colB",
            "colC"
          ],
          "values": [
            [
              "3",
              "abc",
              200
            ],
            [
              "4",
              "def",
              300
            ],
            [
              "5",
              "ghi",
              400
            ],
            [
              "6",
              "jkl",
              500
            ]
          ]
        },
        "output": [
          {
            "colA": 3,
            "colB": "abc",
            "colC": 200
          },
          {
            "colA": 4,
            "colB": "def",
            "colC": 300
          },
          {
            "colA": 5,
            "colB": "ghi",
            "colC": 400
          },
          {
            "colA": 6,
            "colB": "jkl",
            "colC": 500
          }
        ]
      }
    ],
    "identifier": 58996780
  },
  {
    "context": [
      "I am trying to print as below  \n```\nService1  up  \ncredittable  up  \nService2 UP  \ndebittable up  \nService3 up  \nloantable up  \n```",
      "With the -r option, the following filter:\n```\n.details\n| to_entries[]\n| \"\\(.key) \\(.value.status)\",\n  (.value.details[]\n   | \"\\(.details.Tablename) \\(.status)\" )\n```   \n\nproduces the desired output."
    ],
    "utterance": "Print each service name and its status, followed by each nested Tablename and its status in order.",
    "expressions": [
      ".details | to_entries[] | \"\\(.key) \\(.value.status)\", (.value.details[] | \"\\(.details.Tablename) \\(.status)\")"
    ],
    "data": [
      {
        "input": {
          "status": "UP",
          "details": {
            "Service1": {
              "status": "UP",
              "details": {
                "Credit": {
                  "status": "UP",
                  "details": {
                    "Tablename": "credittable"
                  }
                }
              }
            },
            "Service2": {
              "status": "UP",
              "details": {
                "Debit": {
                  "status": "UP",
                  "details": {
                    "Tablename": "debittable"
                  }
                }
              }
            },
            "Service3": {
              "status": "UP",
              "details": {
                "Loan": {
                  "status": "UP",
                  "details": {
                    "Tablename": "loantable"
                  }
                }
              }
            }
          }
        },
        "output": [
          "Service1 UP",
          "credittable UP",
          "Service2 UP",
          "debittable UP",
          "Service3 UP",
          "loantable UP"
        ]
      }
    ],
    "identifier": 59002388
  },
  {
    "context": [
      "But i would like to replace the empty quotes \"\" next to \"body\" with the value from the output of xyz.txt which means the value of ${file} and is hence a multi string with separate lines.",
      "Given -R/--raw-input and -s/--slurp flags together, jq makes input file's content accessible through `.` filter. This can be used for your purpose like this:",
      "jq -Rs '{body:.}' xyz.txt > myfile.json"
    ],
    "utterance": "Replace the value of the 'body' key with the entire, potentially multi-line, contents of another file.",
    "expressions": [
      "jq -Rs '{body:.}' xyz.txt"
    ],
    "data": [
      {
        "input": {
          "xyz.txt": "line 1\nline 2\nline 3"
        },
        "output": {
          "body": "line 1\nline 2\nline 3"
        }
      }
    ],
    "identifier": 58740310
  },
  {
    "context": [
      "I want to split like below",
      "Parent.json\n    {\n        \"store\": {\n            \"book\": [\n                \"$ref\": \"book1.json\",\n                \"$ref\": \"book2.json\"\n            ],\n            \"bicycle\": {\n                \"color\": \"red\",\n                \"price\": 19.95\n            }\n        },\n        \"expensive\": 10\n    }",
      "book1.json\n    {\n        \"category\": \"reference\",\n        \"author\": \"Nigel Rees\",\n        \"title\": \"Sayings of the Century\",\n        \"price\": 8.95\n    }",
      "Producing those multiple lines,\n\n   $ jq -c '.store.book as $books | .store.book = [\n         { \"$ref\": \"book\\(range(1; $books | length + 1)).json\" } ], $books[]' Main.json",
      "genparent() {\n  jq '.store.book = [ { \"$ref\": \"book\\(range(1; .store.book | length + 1)).json\" } ]' > Parent.json\n}",
      "genbooks() {\n  jq -c '.store.book[]'\n}"
    ],
    "utterance": "Generate a parent configuration file listing book objects as $ref entries to external files, and create a separate file for each book object.",
    "expressions": [
      ".store.book as $books | .store.book = [ { \"$ref\": \"book\\(range(1; $books | length + 1)).json\" } ], $books[]",
      ".store.book = [ { \"$ref\": \"book\\(range(1; .store.book | length + 1)).json\" } ]",
      ".store.book[]"
    ],
    "data": [
      {
        "input": {
          "store": {
            "book": [
              {
                "category": "reference",
                "author": "Nigel Rees",
                "title": "Sayings of the Century",
                "price": 8.95
              },
              {
                "category": "fiction",
                "author": "Evelyn Waugh",
                "title": "Sword of Honour",
                "price": 12.99
              }
            ],
            "bicycle": {
              "color": "red",
              "price": 19.95
            }
          },
          "expensive": 10
        },
        "output": {
          "parent": {
            "store": {
              "book": [
                {
                  "$ref": "book1.json"
                },
                {
                  "$ref": "book2.json"
                }
              ],
              "bicycle": {
                "color": "red",
                "price": 19.95
              }
            },
            "expensive": 10
          },
          "book1": {
            "category": "reference",
            "author": "Nigel Rees",
            "title": "Sayings of the Century",
            "price": 8.95
          },
          "book2": {
            "category": "fiction",
            "author": "Evelyn Waugh",
            "title": "Sword of Honour",
            "price": 12.99
          }
        }
      }
    ],
    "identifier": 58818799
  },
  {
    "context": [
      "I am trying to extract the name and version so i get the following:",
      "bpm 1.1.5",
      "haproxy 9.8.0",
      "How is it possible to add a space?",
      ".name + \" \" + .version",
      "\"\\(.name) \\(.version)\""
    ],
    "utterance": "Extract name and version values, outputting each pair in a single line separated by a space.",
    "expressions": [
      ".releases[] | .name + \" \" + .version",
      ".releases[] | \"\u001b[.name] \u001b[.version]\""
    ],
    "data": [
      {
        "input": {
          "releases": [
            {
              "name": "bpm",
              "version": "1.1.5"
            },
            {
              "name": "haproxy",
              "version": "9.8.0"
            }
          ]
        },
        "output": [
          "bpm 1.1.5",
          "haproxy 9.8.0"
        ]
      }
    ],
    "identifier": 58995103
  },
  {
    "context": [
      "What i need is:\r\n\r\n```\r\n[\r\n  {\r\n    id: \"20191022203822\",\r\n    title: \"How tech companies measure \u201clegal\u201d\",\r\n```\r\n\r\nCan anybody help?",
      "every JSON compliant utility would output a whole JSON following JSON syntax, whereas you wanted a non-JSON output. I guess your best bet is to run it through `sed` where you drop the quotes from the label (but that approach is prone to false-positives): \r\n```\r\njq ... | sed -E 's/(^ *)\"([^\"]*)\":/\\1\\2:/'\r\n```",
      "In the present case, one could start with a recursive definition:\r\n\r\n```\r\ndef printObject(offset):\r\n  (offset * \" \" // \"\") as $offset\r\n  | reduce to_entries[] as $kv (\"\";\r\n      ($kv.value\r\n       | if type == \"string\" then \"\\\"\\(.)\\\"\"\r\n         elif type == \"object\" then printObject(offset+2)\r\n         else . end) as $v\r\n      | . + $offset  +  \"  \\($kv.key): \\($v)\\n\")\r\n  | \"{\\n\" + . + $offset + \"}\";\r\n\r\n```\r\n\r\nWith this definition,\r\n```\r\n{a:1, b:\"etc\", c: {d: [1,2,3]} } | printObject(0)\r\n```\r\nproduces:\r\n\r\n```\r\n{\r\n  a: 1,\r\n  b: \"etc\",\r\n  c: {\r\n    d: [1,2,3]\r\n  }\r\n}\r\n```"
    ],
    "utterance": "Output objects with unquoted keys instead of quoted keys, preserving all values.",
    "expressions": [
      "jq ... | sed -E 's/(^ *)\"([^\"]*)\":/\\1\\2:/'",
      "def printObject(offset):\n  (offset * \" \" // \"\") as $offset\n  | reduce to_entries[] as $kv (\"\";\n      ($kv.value\n       | if type == \"string\" then \"\\\"\\(.)\\\"\"\n         elif type == \"object\" then printObject(offset+2)\n         else . end) as $v\n      | . + $offset  +  \"  \\($kv.key): \\($v)\\n\")\n  | \"{\\n\" + . + $offset + \"}\";\n\n[.articles[] | ...] | printObject(0)"
    ],
    "identifier": 58956653
  },
  {
    "context": [
      "cat host.json | jq --arg HGP \"$HGPATH\" '.hostgroup.ref=$HGP'",
      "jq --arg HGP \"$HGPATH\" '.hostgroup.ref=$HGP' host.json"
    ],
    "utterance": "Set the value at .hostgroup.ref to the value of the shell variable containing a string with forward slashes (e.g., '/rest/config/hostgroup/5').",
    "expressions": [
      ".hostgroup.ref = $HGP"
    ],
    "data": [
      {
        "input": {
          "hostgroup": {
            "ref": null
          }
        },
        "output": {
          "hostgroup": {
            "ref": "/rest/config/hostgroup/5"
          }
        }
      }
    ],
    "identifier": 58753438
  },
  {
    "context": [
      "I want to parse the output such that I have a single CSV output of each individual item with its parent order ID.",
      "So if a single order contains multiple items, I need the orderID repeated for each item in its order.",
      "Expected output (without column headers of course):",
      "orderId,orderItemId,sku,name",
      "217356098,327010821,\"JC-C10S\",\"TestDescription\"",
      "217356098,327010822,\"JC-C106\",\"AnotherTestDescription\"",
      "With the -r command-line option, the following jq filter:",
      ".orders[]",
      "| .orderId as $oid",
      "| .items[]",
      "| [$oid, .orderItemId, .sku, .name]",
      "| @csv"
    ],
    "utterance": "Extract each item from all orders as CSV lines containing orderId, orderItemId, sku, and name, repeating orderId for every item.",
    "expressions": [
      ".orders[] | .orderId as $oid | .items[] | [$oid, .orderItemId, .sku, .name] | @csv"
    ],
    "data": [
      {
        "input": {
          "orders": [
            {
              "orderId": 217356098,
              "items": [
                {
                  "orderItemId": 327010821,
                  "lineItemKey": "1",
                  "sku": "AJC-C10S",
                  "name": "TestDescription",
                  "imageUrl": null,
                  "weight": null,
                  "quantity": 2,
                  "unitPrice": 106.85,
                  "taxAmount": null,
                  "shippingAmount": null,
                  "warehouseLocation": null,
                  "options": [],
                  "productId": null,
                  "fulfillmentSku": null,
                  "adjustment": false,
                  "upc": null,
                  "createDate": "2016-11-09T02:11:28.307",
                  "modifyDate": "2016-11-09T02:11:28.307"
                },
                {
                  "orderItemId": 327010822,
                  "lineItemKey": "1",
                  "sku": "AJC-C106",
                  "name": "AnotherTestDescription",
                  "imageUrl": null,
                  "weight": null,
                  "quantity": 2,
                  "unitPrice": 106.85,
                  "taxAmount": null,
                  "shippingAmount": null,
                  "warehouseLocation": null,
                  "options": [],
                  "productId": null,
                  "fulfillmentSku": null,
                  "adjustment": false,
                  "upc": null,
                  "createDate": "2016-11-09T02:11:28.307",
                  "modifyDate": "2016-11-09T02:11:28.307"
                }
              ]
            }
          ],
          "total": 359934,
          "page": 1,
          "pages": 179968
        },
        "output": [
          "217356098,327010821,\"AJC-C10S\",\"TestDescription\"",
          "217356098,327010822,\"AJC-C106\",\"AnotherTestDescription\""
        ]
      }
    ],
    "identifier": 58783071
  },
  {
    "context": [
      "I want to filter it so that I get back:\r\n\r\n    {\r\n      \"x\": [\r\n        { \"b\": 1 },\r\n        { \"b\": 2 }\r\n      ]\r\n    }",
      "\".x[] | select(.b)\"\r\n\r\nBut, that gives me back just a list of the objects with b as so:\r\n\r\n    { \"b\": 1 }\r\n    { \"b\": 2 }\r\n\r\nI want the original surrounding object as well.",
      ".x |= map(select(has(\"b\")))"
    ],
    "utterance": "Filter the top-level object's 'x' array to include only objects that have the key 'b', keeping the full wrapping structure.",
    "expressions": [
      ".x |= map(select(has(\"b\")))"
    ],
    "data": [
      {
        "input": {
          "x": [
            {
              "a": 1
            },
            {
              "a": 2
            },
            {
              "b": 1
            },
            {
              "b": 2
            }
          ]
        },
        "output": {
          "x": [
            {
              "b": 1
            },
            {
              "b": 2
            }
          ]
        }
      }
    ],
    "identifier": 58675837
  },
  {
    "context": [
      "I want to merge these files together, using the filename as the jq selector and the contents of the file as the value. The output of this would be:\n\n{\n  \"property1\": \"newValue\",\n  \"sub\": {\n     \"property2\": \"newProperty2\"\n   },\n   \"other\": {\n      \"complex\": {\n        \"cprop\": \"cpropvalue\"\n      }\n   }\n}\n",
      "Here\u0019s a solution to the closely-related problem which assumes that all the files contain valid JSON: \n\n```\njq '\n  def props: \n    split(\".\") | map(select(length>0));\n\n  reduce inputs as $json (.;\n    setpath(input_filename | props; $json) )\n' main.json .other .property1 .sub.property2 \n```"
    ],
    "utterance": "Merge multiple files where each filename specifies the field path and each file's content provides the value, updating fields accordingly including nested properties.",
    "expressions": [
      "jq '\n  def props: \n    split(\".\") | map(select(length>0));\n\n  reduce inputs as $json (.;\n    setpath(input_filename | props; $json) )\n' main.json .other .property1 .sub.property2 "
    ],
    "data": [
      {
        "input": {
          "main.json": {
            "property1": "someValue",
            "sub": {
              "property2": "property2"
            }
          },
          ".property1": "newValue\n",
          ".sub.property2": "newProperty2\n",
          ".other": "{\n  \"complex\": {\n    \"cprop\": \"cpropvalue\"\n  }\n}\n"
        },
        "output": {
          "property1": "newValue",
          "sub": {
            "property2": "newProperty2"
          },
          "other": {
            "complex": {
              "cprop": "cpropvalue"
            }
          }
        }
      }
    ],
    "identifier": 58757384
  },
  {
    "context": [
      "I run jq from bash and all my new lines are escaped",
      "release_message='```a\\na\\n```'",
      "jq --arg message \"$release_message\" '{text:$message}'",
      "Have bash produce the literal string, pass with --arg or specify --raw-input/-R to have the input encoded in JSON, plus --slurp so that the multiple lines are considered as a single string."
    ],
    "utterance": "Build an object with a key whose value preserves actual newlines in the value assigned from a bash variable containing literal newlines.",
    "expressions": [
      "jq --arg message \"$release_message\" '{text:$message}'",
      "echo \"$release_message\" | jq -R --slurp '{text:.}'"
    ],
    "identifier": 59075249
  },
  {
    "context": [
      "I need to find an object inside of an array of objects and then modify a nested object inside of that object.",
      "for this example I'm trying to modify the \"pos_color\" value for the track where the label is AX11S1.bw.",
      ".tracks |= map(if .label==\"AX11S1.bw\" \n               then .style.pos_color = \"NEW VALUE\" \n               else . end)"
    ],
    "utterance": "Update the pos_color field inside the style object for the track whose label is AX11S1.bw to a new value.",
    "expressions": [
      ".tracks |= map(if .label==\"AX11S1.bw\" then .style.pos_color = \"NEW VALUE\" else . end)"
    ],
    "data": [
      {
        "input": {
          "tracks": [
            {
              "style": {
                "clip_marker_color": "red",
                "neg_color": "#005EFF",
                "pos_color": "blue",
                "height": 100
              },
              "variance_band": true,
              "max_score": 100,
              "label": "AX11S1.bw",
              "min_score": 0
            },
            {
              "style": {
                "clip_marker_color": "red",
                "neg_color": "#005EFF",
                "pos_color": "blue",
                "height": 100
              },
              "variance_band": true,
              "max_score": 100,
              "label": "AX11S2.bw",
              "min_score": 0
            },
            {
              "style": {
                "clip_marker_color": "red",
                "neg_color": "#005EFF",
                "pos_color": "blue",
                "height": 100
              },
              "variance_band": true,
              "max_score": 100,
              "label": "AX11S3.bw",
              "min_score": 0
            }
          ]
        },
        "output": {
          "tracks": [
            {
              "style": {
                "clip_marker_color": "red",
                "neg_color": "#005EFF",
                "pos_color": "NEW VALUE",
                "height": 100
              },
              "variance_band": true,
              "max_score": 100,
              "label": "AX11S1.bw",
              "min_score": 0
            },
            {
              "style": {
                "clip_marker_color": "red",
                "neg_color": "#005EFF",
                "pos_color": "blue",
                "height": 100
              },
              "variance_band": true,
              "max_score": 100,
              "label": "AX11S2.bw",
              "min_score": 0
            },
            {
              "style": {
                "clip_marker_color": "red",
                "neg_color": "#005EFF",
                "pos_color": "blue",
                "height": 100
              },
              "variance_band": true,
              "max_score": 100,
              "label": "AX11S3.bw",
              "min_score": 0
            }
          ]
        }
      }
    ],
    "identifier": 58783807
  },
  {
    "context": [
      "I have \"unit_number\" and \"key\" values and I want to find backing_uuid based on the unit_number and key values.",
      "I have json file like this:",
      "the jq query would be:",
      "",
      "    .guest_disk_facts[]",
      "    | select(.unit_number==2 and .key == 2002).backing_uuid",
      "",
      "and output: 9000da43-8471-57a6-8b18-4425a356b3cb"
    ],
    "utterance": "Find the backing_uuid where unit_number is 2 and key is 2002.",
    "expressions": [
      ".guest_disk_facts[] | select(.unit_number==2 and .key == 2002).backing_uuid"
    ],
    "data": [
      {
        "input": {
          "changed": false,
          "failed": false,
          "guest_disk_facts": {
            "0": {
              "backing_uuid": "9000da43-8471-57a6-8b18-92381ab3c3f6",
              "key": 2000,
              "unit_number": 0
            },
            "1": {
              "backing_uuid": "9000da43-8471-57a6-8b18-2788c2398ba7",
              "key": 2001,
              "unit_number": 1
            },
            "2": {
              "backing_uuid": "9000da43-8471-57a6-8b18-4425a356b3cb",
              "key": 2002,
              "unit_number": 2
            }
          }
        },
        "output": "9000da43-8471-57a6-8b18-4425a356b3cb"
      }
    ],
    "identifier": 58904801
  },
  {
    "identifier": 58883722
  },
  {
    "context": [
      "jq -j 'to_entries[] | (.key, \"\\u0000\", .value, \"\\u0000\")' <<<\"$input\"",
      "Note the use of `jq -j`, which suppresses quoting (like `-r`), but *also* suppresses the implicit newline between items, letting us manually insert a NUL instead."
    ],
    "utterance": "Produce key-value pairs, delimited by NUL characters, for each top-level pair.",
    "expressions": [
      "jq -j 'to_entries[] | (.key, \"\\u0000\", .value, \"\\u0000\")'"
    ],
    "data": [
      {
        "input": {
          "a": "z",
          "b": "y",
          "c": "x"
        },
        "output": "a\\0z\\0b\\0y\\0c\\0x\\0"
      }
    ],
    "identifier": 58999047
  }
]