[
  {
    "identifier": 62127039
  },
  {
    "context": [
      "I have a set of data, containing pronunciation of words in Cantonese:\r\n\r\n    {\r\n        \u76e3: [gaam1],\r\n        \u53c3: [caam1],\r\n        \u4e09: [saam1],\r\n        ...\r\n    }\r\n\r\nAnd I want to search and modify them to the following:\r\n\r\n    {\r\n        \u76e3: [g\u0101am],\r\n        \u53c3: [c\u0101am],\r\n        \u4e09: [s\u0101am],\r\n        ...\r\n    }",
      "the following filter would do the job:\r\n\r\n    map_values( map(sub( \"aam1$\"; \"\u0101am\") ))",
      "Consider for example:\r\n\r\n    sub( \"aa(?<x>[a-z])1\"; \"\u0101a\\(.x)\")"
    ],
    "utterance": "Replace all string values ending in 'aam1' within arrays that are values of the object, substituting them with '\u0101am'.",
    "expressions": [
      "map_values(map(sub(\"aam1$\"; \"\u0101am\")))"
    ],
    "data": [
      {
        "input": {
          "\u76e3": [
            "gaam1"
          ],
          "\u53c3": [
            "caam1"
          ],
          "\u4e09": [
            "saam1"
          ]
        },
        "output": {
          "\u76e3": [
            "g\u0101am"
          ],
          "\u53c3": [
            "c\u0101am"
          ],
          "\u4e09": [
            "s\u0101am"
          ]
        }
      }
    ],
    "identifier": 61825385
  },
  {
    "context": [
      "I want to add an element to the array value of the \"parameter\" keys:",
      "walk(if type==\"object\" and has(\"parameters\")\n     then .parameters += [{\"extra\": \"value\"}]\n     else . end)"
    ],
    "utterance": "Add an object with key 'extra' and value 'value' to every array that is the value of a 'parameters' key within nested objects.",
    "expressions": [
      "walk(if type==\"object\" and has(\"parameters\") then .parameters += [{\"extra\": \"value\"}] else . end)"
    ],
    "data": [
      {
        "input": {
          "paths": {
            "/great/endpoint1": {
              "get": {
                "parameters": []
              }
            },
            "/great/endpoint2": {
              "post": {
                "parameters": []
              }
            }
          },
          "x-id": "abc"
        },
        "output": {
          "paths": {
            "/great/endpoint1": {
              "get": {
                "parameters": [
                  {
                    "extra": "value"
                  }
                ]
              }
            },
            "/great/endpoint2": {
              "post": {
                "parameters": [
                  {
                    "extra": "value"
                  }
                ]
              }
            }
          },
          "x-id": "abc"
        }
      }
    ],
    "identifier": 61526217
  },
  {
    "context": [
      "Say I would like to search for \"wetransfer@extensions.thunderbird.net\", and would like an output which shows me where it was found with something like this:\n\n    { \"addons\": [ {\"id\": \"wetransfer@extensions.thunderbird.net\"} ] }\n\nIs there a way to get that with `jq` or with some other json tool?",
      "< input.json jq -c --arg s wetransfer@extensions.thunderbird.net '\n  paths as $p | select(getpath($p) == $s) | null | setpath($p;$s)'",
      "produces:\n\n    {\"addons\":[{\"id\":\"wetransfer@extensions.thunderbird.net\"}]}\n"
    ],
    "utterance": "Find objects where 'id' is 'wetransfer@extensions.thunderbird.net' and output minimal structure showing their location and value.",
    "expressions": [
      "jq -c --arg s wetransfer@extensions.thunderbird.net 'paths as $p | select(getpath($p) == $s) | null | setpath($p;$s)'"
    ],
    "data": [
      {
        "input": {
          "schemaVersion": 31,
          "addons": [
            {
              "id": "wetransfer@extensions.thunderbird.net",
              "syncGUID": "{e6369308-1efc-40fd-aa5f-38da7b20df9b}",
              "version": "2.0.0"
            },
            {
              "id": "other@extensions.thunderbird.net",
              "syncGUID": "{xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx}",
              "version": "1.0.0"
            }
          ]
        },
        "output": {
          "addons": [
            {
              "id": "wetransfer@extensions.thunderbird.net"
            }
          ]
        }
      }
    ],
    "identifier": 62052536
  },
  {
    "context": [
      "is there a way to loop through all of the pipelines using the `get-pipeline-state` and identify the stage name and action name without manually going through output of each of the pipelines.",
      "aws codepipeline get-pipeline-state \\",
      "--query 'stageStates[?latestExecution.status==`InProgress`].{stageName:stageName,actionName:actionStates[0].actionName,token:actionStates[0].latestExecution.token}'"
    ],
    "utterance": "List stage names, first action names, and approval tokens for all stages in all pipelines where the latest execution is InProgress.",
    "expressions": [
      "aws codepipeline get-pipeline-state --name <pipeline-name> --query 'stageStates[?latestExecution.status==`InProgress`].{stageName:stageName,actionName:actionStates[0].actionName,token:actionStates[0].latestExecution.token}'"
    ],
    "identifier": 62122382
  },
  {
    "context": [
      "Now I want to know where I can find shoes:",
      "I\u2019d like to know the box they\u2019re in as well.",
      "Even better yet: I\u2019d like to find all items and provide the information, like this:\n\"shoes\": [ {\"lorry1\", \"box1\"}, {\"lorry2\", \"box1\" } ],\n\"snacks\": [ {\"lorry1\", \"box1\"}, {\"lorry2\", \"box1\"} ],\n\"beer\": [ {\"lorry1\", \"box2\"}, {\"lorry2\", \"box2\"} ],\n\"potatoes\": [ {\"lorry1\", \"box2\"} ]",
      "[path(.[][][].item) as $p | [$p, getpath($p)]] |\ngroup_by( .[1] ) |\nmap({(.[0][1]): (. | map([.[0][0,1]]))})|\nadd",
      "path(.. | select(.item? == \"shoes\"))",
      "jq -c '. as $in\n  | [paths as $p | select($p[-1] == \"item\") | $p]\n  | group_by(. as $p | $in|getpath($p))\n  | .[]\n  | (.[0] as $p | $in | getpath($p)) as $v\n  | {($v|tostring):  ( map(.[:-1] | if .[-1] | type == \"number\" then .[:-1] else . end)) }\n'\n\nWith your input:\n{\"beer\":[[\"lorry1\",\"box2\"],[\"lorry2\",\"box2\"]]}\n{\"potatoes\":[[\"lorry1\",\"box2\"]]}\n{\"shoes\":[[\"lorry1\",\"box1\"],[\"lorry2\",\"box1\"]]}\n{\"snacks\":[[\"lorry1\",\"box1\"],[\"lorry2\",\"box1\"]]}"
    ],
    "utterance": "List for each item the lorry and box it is located in, producing an object where each item maps to an array of [lorry, box] pairs.",
    "expressions": [
      "[path(.[][][].item) as $p | [$p, getpath($p)]] |\ngroup_by( .[1] ) |\nmap({(.[0][1]): (. | map([.[0][0,1]]))})|\nadd",
      ". as $in\n  | [paths as $p | select($p[-1] == \"item\") | $p]\n  | group_by(. as $p | $in|getpath($p))\n  | .[]\n  | (.[0] as $p | $in | getpath($p)) as $v\n  | {($v|tostring):  ( map(.[:-1] | if .[-1] | type == \"number\" then .[:-1] else . end)) }\n",
      "([path(.[][][].item) as $p | [$p, getpath($p)]] | group_by(.[1]) | map({ (.[0][1]) : (map([.[0][0,1]])) }) | add)"
    ],
    "data": [
      {
        "input": {
          "lorry1": {
            "box1": [
              {
                "item": "shoes",
                "state": "new"
              },
              {
                "item": "snacks",
                "state": "new"
              }
            ],
            "box2": [
              {
                "item": "beer",
                "state": "cold"
              },
              {
                "item": "potatoes"
              }
            ]
          },
          "lorry2": {
            "box1": [
              {
                "item": "shoes",
                "state": "new"
              },
              {
                "item": "snacks",
                "state": "new"
              }
            ],
            "box2": [
              {
                "item": "beer",
                "state": "lukewarm"
              }
            ]
          }
        },
        "output": {
          "beer": [
            [
              "lorry1",
              "box2"
            ],
            [
              "lorry2",
              "box2"
            ]
          ],
          "potatoes": [
            [
              "lorry1",
              "box2"
            ]
          ],
          "shoes": [
            [
              "lorry1",
              "box1"
            ],
            [
              "lorry2",
              "box1"
            ]
          ],
          "snacks": [
            [
              "lorry1",
              "box1"
            ],
            [
              "lorry2",
              "box1"
            ]
          ]
        }
      }
    ],
    "identifier": 62066592
  },
  {
    "context": [
      "for row in $(jq -r '.g[] | @base64' <<< $raw); do\n    echo -e \"${prefix}    $(_jq $row '.id')${hk}  $(_jq $row '.name')\"\ndone",
      "That approach is way more complex than is really needed. Does this do what you wanted?",
      "< json.json jq --arg prefix \"${prefix}\" --arg hk \"${hk}\" -r \\\n  '.g[] | \"\\($prefix)    \\(.id) \\($hk)  \\(.name)\"'",
      "This replaces the `for` loop entirely with a single `jq` call, using jq to do the string formatting instead of `echo`, eliminating the base64 encoding and decoding, and eliminating four subprocess calls per row."
    ],
    "utterance": "Display each object's id and name in the 'g' array, formatted with a prefix and a separator.",
    "expressions": [
      ".g[] | \"\u001b[36m    \\(.id)\u001b[34m)  \\(.name)\""
    ],
    "data": [
      {
        "input": {
          "g": [
            {
              "id": "1",
              "name": "Group - 1"
            },
            {
              "id": "2",
              "name": "Group - 2"
            },
            {
              "id": "10",
              "name": "Group - 10"
            }
          ]
        },
        "output": [
          "    1)  Group - 1",
          "    2)  Group - 2",
          "    10)  Group - 10"
        ]
      }
    ],
    "identifier": 61597675
  },
  {
    "context": [
      "I am trying to convert an array to string and would like to be:",
      "declare -r LOCAL_VERSIONS=(\n        \"1.3.17\"\n        \"1.3.18\"\n        \"1.3.19\"\n        \"1.3.20\"\n        \"1.4.0-beta.1\"\n        \"1.4.0-beta.1\"\n        \"1.4.0-beta.2\"\n        \"1.4.0\"\n        \"1.4.1\"\n        \"1.4.2\"\n        \"1.4.3\"\n        \"1.4.4\"\n        \"1.5.0-beta.1\"\n        \"1.5.0\"\n        \"1.5.1\"\n        \"1.5.2\"\n    )",
      "The `-r` in `jq -r` removed quotes, this is what's needed :",
      "declare VERSIONS=($(curl -s https://api.github.com/repos/humhub/humhub/releases | jq '[].name'))"
    ],
    "utterance": "Produce a space-separated list, each value wrapped in double quotes, from the .name fields of all objects in an array.",
    "expressions": [
      ".[].name",
      "\"declare -r LOCAL_VERSIONS=($(curl -s https://api.github.com/repos/humhub/humhub/releases | jq '.[].name'))\""
    ],
    "identifier": 62104704
  },
  {
    "context": [
      "I need to get a key by value. Specifically, I need to get the key 2 search by value AWS2.",
      "{\n      \"1\": [\"AWS1\"],\n      \"2\": [\"AWS2\"],\n      \"3\": [\"AWS3\"]\n    }",
      "\"VersionIdsToStages\": {\n        \"1\": [\n            \"AWS1\"\n        ],\n        \"2\": [\n            \"AWS2\"\n        ],\n        \"3\": [\n            \"AWS3\"\n        ]\n    }",
      "I am trying\n\n    .VersionIdsToStages|map_values(select(contains([\"AWS2\"]))) | keys[0]\n\nwithout sucess.",
      "You could use the following :\n\n    map_values(select(contains([\"AWS2\"]))) | keys",
      "If you can assume that only a single value will ever match, you can add a `[0]` to the end to retrieve the key only rather than an array containing it."
    ],
    "utterance": "Retrieve the key from the VersionIdsToStages object whose value array contains AWS2.",
    "expressions": [
      ".VersionIdsToStages | map_values(select(contains([\"AWS2\"]))) | keys",
      ".VersionIdsToStages | map_values(select(contains([\"AWS2\"]))) | keys[0]"
    ],
    "data": [
      {
        "input": {
          "ARN": "xxxxx",
          "Name": "xxxx",
          "Description": "xxxx",
          "KmsKeyId": "xxxx",
          "RotationEnabled": true,
          "RotationLambdaARN": "arggg",
          "RotationRules": {
            "AutomaticallyAfterDays": 30
          },
          "LastRotatedDate": "2020-05-27T12:05:56.061000-03:00",
          "LastChangedDate": "2020-05-27T13:05:34.807000-03:00",
          "LastAccessedDate": "2020-05-26T21:00:00-03:00",
          "Tags": [
            {
              "Key": "aws:cloudformation:stack-name",
              "Value": "medusa-monitoring-alerts-role"
            },
            {
              "Key": "aws:cloudformation:logical-id",
              "Value": "xxx"
            },
            {
              "Key": "Team",
              "Value": "xxx xxx"
            },
            {
              "Key": "aws:cloudformation:stack-id",
              "Value": "xxx"
            }
          ],
          "VersionIdsToStages": {
            "1": [
              "AWS1"
            ],
            "2": [
              "AWS2"
            ],
            "3": [
              "AWS3"
            ]
          }
        },
        "output": [
          "2"
        ]
      }
    ],
    "identifier": 62047373
  },
  {
    "context": [
      "First, I'm attempting to add a condition which will remove objects where the key \"reprint\" has the value true.",
      "So an efficient way to select the objects for which .reprint is `false` is to use the filter:\n\n    map(select(.reprint == false))",
      "If you just want the JSON objects as a stream, you could write:\n\n    .[] | select(.reprint == false)"
    ],
    "utterance": "Filter out all objects where the key 'reprint' is true.",
    "expressions": [
      "map(select(.reprint == false))",
      ".[] | select(.reprint == false)",
      ".[] | select(.reprint == true | not)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Static Orb",
            "reprint": true
          },
          {
            "name": "Solemn Simulacrum",
            "reprint": false
          }
        ],
        "output": [
          {
            "name": "Solemn Simulacrum",
            "reprint": false
          }
        ]
      }
    ],
    "identifier": 62103800
  },
  {
    "context": [
      "I want to merge the 2 json files using the Dates (which are not specified as keys) and reassign keys and values to the output, such that the output is something like:",
      "reduce inputs[] as [$date, $value] ({};\n  if has($date) then\n    .[$date] += {value2: $value}\n  else\n    .[$date] = {$date, value1: $value}\n  end\n) | map(.)",
      "If the arrays in file1.json and file2.json are in lockstep as in your example, you could simply write:\n\n.[0] |= map({date: .[0], value1: .[1]})\n| .[1] |= map({date: .[0], value2: .[1]})\n| transpose\n| map(add)"
    ],
    "utterance": "Produce an array of objects where each object corresponds to a date, with properties 'date', 'value1' from the first file, and 'value2' from the second file, matching entries by their date.",
    "expressions": [
      "reduce inputs[] as [$date, $value] ({};\n  if has($date) then\n    .[$date] += {value2: $value}\n  else\n    .[$date] = {$date, value1: $value}\n  end\n) | map(.)",
      ".[0] |= map({date: .[0], value1: .[1]})\n| .[1] |= map({date: .[0], value2: .[1]})\n| transpose\n| map(add)"
    ],
    "data": [
      {
        "input": [
          [
            [
              "04-05-2020",
              12
            ],
            [
              "03-05-2020",
              16
            ]
          ],
          [
            [
              "04-05-2020",
              50
            ],
            [
              "03-05-2020",
              70
            ]
          ]
        ],
        "output": [
          {
            "date": "04-05-2020",
            "value1": 12,
            "value2": 50
          },
          {
            "date": "03-05-2020",
            "value1": 16,
            "value2": 70
          }
        ]
      }
    ],
    "identifier": 61591963
  },
  {
    "context": [
      "Is it possible to combine these two commands in one and make it shorter (or unique: without `.Results`, `.Persons`, `.PersonalInfo` sections accessing)?",
      "I tried the next, for example, to combine:\n\n    jq -r '. | .Results | .[] | .Persons | .[] | .PersonalInfo | (.Name2 or .LASTNAME)' question*.json\n\nIt outputs:\n\n    true\n    true\n    true",
      "But I want:\n\n    Pete\n    Bob\n    Bond",
      "Number of variable keys could be bigger than two: `LASTNAME`, `lname`, `ThirdName`, `Name2`",
      "If you need to shorten the syntax you can use:\n\n```jq\n.. | (.LASTNAME? // .Name2?) | select(.)\n```",
      "cat question*.json | jq '.Results[].Persons[] | (.Address|.City) + \"; \" + (.id|tostring) + \"; \" + (.PersonalInfo| .LASTNAME // .Name2)'\n\"Portland; 20; Pete\"\n\"New York; 21; Bob\"\n\"Las Vegas; 2000; Bond\""
    ],
    "utterance": "Extract and print all available values using any of the keys LASTNAME, Name2, or similar, regardless of their presence or nesting, from multiple files with different structures.",
    "expressions": [
      ".. | (.LASTNAME? // .Name2?) | select(.)",
      ".Results[].Persons[] | .PersonalInfo | .LASTNAME // .Name2"
    ],
    "data": [
      {
        "input": {
          "Results": [
            {
              "Persons": [
                {
                  "id": 20,
                  "Position": "office employee",
                  "Profession": "Office workers",
                  "Address": {
                    "City": "Portland",
                    "State": "Washington",
                    "Country": "USA"
                  },
                  "PersonalInfo": {
                    "LASTNAME": "Pete",
                    "FIRSTNAME": "Columb",
                    "MIDNAME": "George"
                  }
                },
                {
                  "id": 21,
                  "Position": "Manager",
                  "Profession": "Medicine",
                  "Address": {
                    "City": "New York",
                    "State": "",
                    "Country": "USA"
                  },
                  "PersonalInfo": {
                    "LASTNAME": "Bob",
                    "FIRSTNAME": "Smith",
                    "MIDNAME": ""
                  }
                }
              ],
              "ItemsNumber": 2,
              "AdditionalItems": {}
            }
          ]
        },
        "output": [
          "Pete",
          "Bob"
        ]
      },
      {
        "input": {
          "Results": [
            {
              "Persons": [
                {
                  "id": 2000,
                  "Position": "Director",
                  "Profession": "Marketing",
                  "Address": {
                    "City": "Las Vegas",
                    "State": "Nevada",
                    "Country": "USA"
                  },
                  "PersonalInfo": {
                    "Name1": "Steven",
                    "Name2": "Bond",
                    "Name3": ""
                  }
                }
              ],
              "ItemsNumber": 1,
              "AdditionalItems": {}
            }
          ]
        },
        "output": [
          "Bond"
        ]
      }
    ],
    "identifier": 62102387
  },
  {
    "context": [
      "I am merging two json files using \"jq -s . file1 file2\", but I want them to get merged without comma separation. Also it shouldn't start with []",
      "**Required output:**\n```\n{\n  \"node1\": {\n    \"Environment\": \"PRD\",\n    \"OS\": \"linux\"\n  },\n  \"node2\": {\n    \"Environment\": \"NPR\",\n    \"OS\": \"linux\"\n  },\n    \"node3\": {\n    \"Environment\": \"PRD\",\n    \"OS\": \"linux\"\n  },\n  \"node4\": {\n    \"Environment\": \"NPR\",\n    \"OS\": \"linux\"\n  }\n} \n```",
      "One option slong the lines of your attempt:\n\n    jq -s add file1 file2",
      "Another:\n\n       jq -n 'input+input' file1 file2"
    ],
    "utterance": "Merge two files containing objects so that the resulting output is a single object containing all key-value pairs from both files.",
    "expressions": [
      "jq -s add file1 file2",
      "jq -n 'input+input' file1 file2"
    ],
    "data": [
      {
        "input": [
          {
            "node1": {
              "Environment": "PRD",
              "OS": "linux"
            },
            "node2": {
              "Environment": "NPR",
              "OS": "linux"
            }
          },
          {
            "node3": {
              "Environment": "PRD",
              "OS": "linux"
            },
            "node4": {
              "Environment": "NPR",
              "OS": "linux"
            }
          }
        ],
        "output": {
          "node1": {
            "Environment": "PRD",
            "OS": "linux"
          },
          "node2": {
            "Environment": "NPR",
            "OS": "linux"
          },
          "node3": {
            "Environment": "PRD",
            "OS": "linux"
          },
          "node4": {
            "Environment": "NPR",
            "OS": "linux"
          }
        }
      }
    ],
    "identifier": 61769820
  },
  {
    "context": [
      "But I need it like this (1 \"contacts\" array containing all the filtered input lines)...",
      "To get the \"expected\" output as shown, you could use the following jq filter in conjunction with the -s option:",
      "{ contacts: [.[] | [.contacts]] | add }",
      "a complete solution using an alternative approach is shown below.",
      "[ [inputs.contacts \n   | .fields[].id |= tonumber\n   | .orgid |= tonumber] ]\n| {contacts: add}"
    ],
    "utterance": "Combine all 'contacts' objects from multiple input objects into a single array under a top-level 'contacts' key.",
    "expressions": [
      "{ contacts: [.[] | [.contacts]] | add }",
      "[ [inputs.contacts | .fields[].id |= tonumber | .orgid |= tonumber] ] | {contacts: add}"
    ],
    "data": [
      {
        "input": [
          {
            "contacts": {
              "orgid": "1",
              "email": "janedoe@aol.com",
              "first_name": "Jane",
              "last_name": "Doe",
              "phone": "4045551212",
              "tags": [
                "tag1",
                "tag2"
              ],
              "fields": [
                {
                  "id": "2",
                  "value": "IB4220"
                },
                {
                  "id": "3",
                  "value": "1994-05-18"
                },
                {
                  "id": "12",
                  "value": "CONSULTANT"
                },
                {
                  "id": "13",
                  "value": "janedoe@aol.com"
                },
                {
                  "id": "6",
                  "value": "111 Main Blvd"
                },
                {
                  "id": "7",
                  "value": "Babylon"
                },
                {
                  "id": "8",
                  "value": "NY"
                },
                {
                  "id": "9",
                  "value": "11702-1522"
                },
                {
                  "id": "10",
                  "value": "US"
                },
                {
                  "id": "11",
                  "value": ""
                },
                {
                  "id": "5",
                  "value": "http://www.something.com/janedoe"
                }
              ]
            }
          },
          {
            "contacts": {
              "orgid": "1",
              "email": "janedoe@aol.com",
              "first_name": "Jane",
              "last_name": "Doe",
              "phone": "4045551212",
              "tags": [
                "tag1",
                "tag2"
              ],
              "fields": [
                {
                  "id": "2",
                  "value": "IB4220"
                },
                {
                  "id": "3",
                  "value": "1994-05-18"
                },
                {
                  "id": "12",
                  "value": "CONSULTANT"
                },
                {
                  "id": "13",
                  "value": "janedoe@aol.com"
                },
                {
                  "id": "6",
                  "value": "111 Main Blvd"
                },
                {
                  "id": "7",
                  "value": "Babylon"
                },
                {
                  "id": "8",
                  "value": "NY"
                },
                {
                  "id": "9",
                  "value": "11702-1522"
                },
                {
                  "id": "10",
                  "value": "US"
                },
                {
                  "id": "11",
                  "value": ""
                },
                {
                  "id": "5",
                  "value": "http://www.something.com/janedoe"
                }
              ]
            }
          }
        ],
        "output": {
          "contacts": [
            {
              "orgid": "1",
              "email": "janedoe@aol.com",
              "first_name": "Jane",
              "last_name": "Doe",
              "phone": "4045551212",
              "tags": [
                "tag1",
                "tag2"
              ],
              "fields": [
                {
                  "id": "2",
                  "value": "IB4220"
                },
                {
                  "id": "3",
                  "value": "1994-05-18"
                },
                {
                  "id": "12",
                  "value": "CONSULTANT"
                },
                {
                  "id": "13",
                  "value": "janedoe@aol.com"
                },
                {
                  "id": "6",
                  "value": "111 Main Blvd"
                },
                {
                  "id": "7",
                  "value": "Babylon"
                },
                {
                  "id": "8",
                  "value": "NY"
                },
                {
                  "id": "9",
                  "value": "11702-1522"
                },
                {
                  "id": "10",
                  "value": "US"
                },
                {
                  "id": "11",
                  "value": ""
                },
                {
                  "id": "5",
                  "value": "http://www.something.com/janedoe"
                }
              ]
            },
            {
              "orgid": "1",
              "email": "janedoe@aol.com",
              "first_name": "Jane",
              "last_name": "Doe",
              "phone": "4045551212",
              "tags": [
                "tag1",
                "tag2"
              ],
              "fields": [
                {
                  "id": "2",
                  "value": "IB4220"
                },
                {
                  "id": "3",
                  "value": "1994-05-18"
                },
                {
                  "id": "12",
                  "value": "CONSULTANT"
                },
                {
                  "id": "13",
                  "value": "janedoe@aol.com"
                },
                {
                  "id": "6",
                  "value": "111 Main Blvd"
                },
                {
                  "id": "7",
                  "value": "Babylon"
                },
                {
                  "id": "8",
                  "value": "NY"
                },
                {
                  "id": "9",
                  "value": "11702-1522"
                },
                {
                  "id": "10",
                  "value": "US"
                },
                {
                  "id": "11",
                  "value": ""
                },
                {
                  "id": "5",
                  "value": "http://www.something.com/janedoe"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 62095357
  },
  {
    "context": [
      "I would like o extract the email id of the user.",
      "You\u2019ll get the exact same result simply running:",
      "jq -r '.permissions[].emailid' JsonFileToTest"
    ],
    "utterance": "Extract all emailid values from the permissions array.",
    "expressions": [
      ".permissions[].emailid",
      "jq -r '.permissions[].emailid' JsonFileToTest"
    ],
    "data": [
      {
        "input": {
          "permissions": [
            {
              "emailid": "test1@test.com",
              "rights": "read"
            },
            {
              "emailid": "test2@test.com",
              "rights": "read"
            }
          ]
        },
        "output": [
          "test1@test.com",
          "test2@test.com"
        ]
      }
    ],
    "identifier": 62089274
  },
  {
    "context": [
      "But how can i get the values from the above?",
      "You don't need to use `--yaml-output` flag, which tries to parse the output of the filter defined as a YAML entity. For getting the raw strings, use a filter in the JSON context itself",
      "yq -r '.images.tags[]'",
      "Found the answer, Inian kind of posted an answer but there was a small change",
      "yq -r '.images.tags | to_entries[].value | split(\":\")[0]' values.yaml"
    ],
    "utterance": "Retrieve all values from the nested 'tags' object under 'images'.",
    "expressions": [
      ".images.tags[]",
      ".images.tags | to_entries[].value"
    ],
    "data": [
      {
        "input": {
          "images": {
            "tags": {
              "one": "abc:v0.3-16-07",
              "two": "xyz:ng-0.23.0",
              "pq": "qaa:0df1e21e752b3d3.2020-04-27_1"
            }
          }
        },
        "output": [
          "abc:v0.3-16-07",
          "xyz:ng-0.23.0",
          "qaa:0df1e21e752b3d3.2020-04-27_1"
        ]
      }
    ],
    "identifier": 61779277
  },
  {
    "context": [
      "I want to convert it into a single object { a:\"value\", b:\"value\", c:\"value\" }",
      "I can use the following filter .[0] + .[1] + .[2], but i want to do it for the whole array without specifying all the indexes.",
      "You can use `reduce`:",
      "reduce .[] as $o ({}; . + $o)",
      "The simplest way is just to call [`add` filter](https://stedolan.github.io/jq/manual/#add).",
      "$ jq 'add' test.json",
      "In case you want to merge all objects in array recursively (didn't find any similar answer here):",
      "jq 'reduce .[] as $x ({}; . * $x)'"
    ],
    "utterance": "Combine all objects in an array into a single object by merging their keys and values.",
    "expressions": [
      "add",
      "reduce .[] as $o ({}; . + $o)",
      "reduce .[] as $x ({}; . * $x)"
    ],
    "data": [
      {
        "input": [
          {
            "a": "value"
          },
          {
            "b": "value"
          },
          {
            "c": "value"
          }
        ],
        "output": {
          "a": "value",
          "b": "value",
          "c": "value"
        }
      }
    ],
    "identifier": 62081114
  },
  {
    "context": [
      "But when I try to parse the next file using the same command:",
      "{ \"items\": [{ \"id\": 110, \"date1\": 1590590723, \"date2\": null, \"name\": \"somename\" }]}",
      "jq: error (at test2.json:1): strftime/1 requires parsed datetime inputs",
      "maybe there is a better way to skip (ignore) those values, leaving nulls in output:",
      "You could tweak your jq program so that it reads:",
      "def tod: if type==\"number\" then strftime(\"%B %d %Y %I:%M%p\") else tostring end;",
      ".[] | .[] | .name + \"; \" + (.date1|tod) + \"; \" + (.date2|tod)",
      "An alternative would be:",
      "def tod: (tonumber? | strftime(\"%B %d %Y %I:%M%p\")) // null;",
      ".[] | .[] | \"\\(.name); \\(.date1|tod); \\(.date2|tod)\""
    ],
    "utterance": "For each item, output name, formatted date1, and formatted date2, but if date2 is null, output null instead of formatting.",
    "expressions": [
      "def tod: if type==\"number\" then strftime(\"%B %d %Y %I:%M%p\") else tostring end; .[] | .[] | .name + \"; \" + (.date1|tod) + \"; \" + (.date2|tod)",
      "def tod: (tonumber? | strftime(\"%B %d %Y %I:%M%p\")) // null; .[] | .[] | \"\\(.name); \\(.date1|tod); \\(.date2|tod)\""
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "id": 110,
              "date1": 1590590723,
              "date2": null,
              "name": "somename"
            }
          ]
        },
        "output": [
          "somename; May 27 2020 02:45PM; null"
        ]
      }
    ],
    "identifier": 62074440
  },
  {
    "context": [
      "i want to use jq to split a very large json (>80GB) file into smaller parts (<1GB or a fixed number of lines).",
      "jq \". | length\" z:\\DOWNLOAD\\rows.json",
      "jq \".[0:1]\" z:\\DOWNLOAD\\rows.json",
      "jq: error (at z:\\DOWNLOAD\\rows.json:589): Cannot index object with object"
    ],
    "utterance": "Select the first item from an array using an expression that works in a Windows shell.",
    "expressions": [
      "jq \".[0]\" z:\\DOWNLOAD\\rows.json"
    ],
    "data": [
      {
        "input": [
          {
            "node": "http://www.wikidata.org/entity/Q952111",
            "Unterklasse_von": "http://www.wikidata.org/entity/Q2095"
          },
          {
            "node": "http://www.wikidata.org/entity/Q12345",
            "Unterklasse_von": "http://www.wikidata.org/entity/Q6789"
          }
        ],
        "output": {
          "node": "http://www.wikidata.org/entity/Q952111",
          "Unterklasse_von": "http://www.wikidata.org/entity/Q2095"
        }
      }
    ],
    "identifier": 62031931
  },
  {
    "context": [
      "I am trying to get the values of the `Name` tag of AWS EC2 instances using jq.",
      "How can I get the value of the `Name` tag from EC2 instances?",
      "jq -r '.Reservations[].Instances[] \\ | ((.Tags // empty) | from_entries) as $tags | [($tags.Name), ($tags.environment), .ImageId, .InstanceId, .AmiLaunchIndex] | @csv'",
      "The `.Tags // empty` will ignore those with tags that do not exist if you are wondering."
    ],
    "utterance": "List the value of the Name tag for every EC2 instance.",
    "expressions": [
      ".Reservations[].Instances[] | (.Tags // empty | from_entries).Name"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "AmiLaunchIndex": 0,
                  "ImageId": "ami-00c3c949f325a4149",
                  "InstanceId": "i-0c17052ee1c7113e5",
                  "Architecture": "x86_64",
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "bastion001"
                    },
                    {
                      "Key": "environment",
                      "Value": "stg-us-east"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": "bastion001"
      }
    ],
    "identifier": 61732744
  },
  {
    "context": [
      "What I'm aiming for is to have the `speakerTag`for each segment included in my jq output.",
      ".response.annotationResults[].speechTranscriptions[].alternatives[].words[]\n | select(.speakerTag)\n | {time: .startTime, speaker: .speakerTag}",
      ".response.annotationResults[].speechTranscriptions[].alternatives[]\n| (INDEX(.words[] | select(.speakerTag); .startTime) | map_values(.speakerTag)) as $dict\n| {startTime: .words[0].startTime, segment: .transcript}\n| . + {speaker: $dict[.startTime]}"
    ],
    "utterance": "For each transcript segment, include the corresponding speaker as indicated by speakerTag for the segment's startTime.",
    "expressions": [
      ".response.annotationResults[].speechTranscriptions[].alternatives[].words[] | select(.speakerTag) | {time: .startTime, speaker: .speakerTag}",
      ".response.annotationResults[].speechTranscriptions[].alternatives[] | (INDEX(.words[] | select(.speakerTag); .startTime) | map_values(.speakerTag)) as $dict | {startTime: .words[0].startTime, segment: .transcript} | . + {speaker: $dict[.startTime]}"
    ],
    "data": [
      {
        "input": {
          "response": {
            "annotationResults": [
              {
                "speechTranscriptions": [
                  {
                    "alternatives": [
                      {
                        "transcript": "Example transcript segment",
                        "words": [
                          {
                            "word": "Example",
                            "startTime": "0s"
                          },
                          {
                            "word": "transcript",
                            "startTime": "1s"
                          },
                          {
                            "word": "segment",
                            "startTime": "2s"
                          }
                        ]
                      },
                      {
                        "transcript": "Another transcript segment",
                        "words": [
                          {
                            "word": "Another",
                            "startTime": "3s"
                          },
                          {
                            "word": "transcript",
                            "startTime": "4s"
                          },
                          {
                            "word": "segment",
                            "startTime": "5s"
                          }
                        ]
                      },
                      {
                        "words": [
                          {
                            "word": "Example",
                            "startTime": "0s",
                            "speakerTag": 1
                          },
                          {
                            "word": "transcript",
                            "startTime": "1s",
                            "speakerTag": 1
                          },
                          {
                            "word": "segment",
                            "startTime": "2s",
                            "speakerTag": 1
                          },
                          {
                            "word": "Another",
                            "startTime": "3s",
                            "speakerTag": 2
                          },
                          {
                            "word": "transcript",
                            "startTime": "4s",
                            "speakerTag": 2
                          },
                          {
                            "word": "segment",
                            "startTime": "5s",
                            "speakerTag": 2
                          }
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": [
          {
            "startTime": "0s",
            "segment": "Example transcript segment",
            "speaker": 1
          },
          {
            "startTime": "3s",
            "segment": "Another transcript segment",
            "speaker": 2
          }
        ]
      }
    ],
    "identifier": 61712885
  },
  {
    "context": [
      "My json file is similar of this: {\r\n\"A1\": \"1.2\"\r\n\"A2\": \"3.5\"\r\n\"A3\": \"2.6\"\r\n}",
      "I need transform it to csv file and it looks like this:\r\nA1,1.2\r\nA2,3.5\r\nA3,2.6",
      "$ jq -r 'to_entries[] | [.key, (.value | tonumber)] | @csv' input.json",
      "\"A1\",1.2\r\n\"A2\",3.5\r\n\"A3\",2.6"
    ],
    "utterance": "Convert all key-value pairs in the object into CSV rows with the key and the value as columns, converting values to numbers.",
    "expressions": [
      "to_entries[] | [.key, (.value | tonumber)] | @csv"
    ],
    "data": [
      {
        "input": {
          "A1": "1.2",
          "A2": "3.5",
          "A3": "2.6"
        },
        "output": [
          "\"A1\",1.2",
          "\"A2\",3.5",
          "\"A3\",2.6"
        ]
      }
    ],
    "identifier": 61749964
  },
  {
    "context": [
      "I am trying to convert a file containing key = value pairs into JSON.\r\nThis file might contain Windows EOL (```\\r\\n```) and empty lines.",
      "Given the following input (mind the empty lines):\r\n```\r\nfoo = aa\r\nbar = bb\r\n\r\nqux = cc\r\nwhite space = white space\r\n* = special-char\r\n\r\n\r\n```\r\nThis is the expected result:\r\n```\r\n{\r\n  &quot;foo&quot;: &quot;aa&quot;,\r\n  &quot;bar&quot;: &quot;bb&quot;,\r\n  &quot;qux&quot;: &quot;cc&quot;,\r\n  &quot;white space&quot;: &quot;white space&quot;,\r\n  &quot;*&quot;: &quot;special-char&quot;\r\n}\r\n```\r\n",
      "You were really close. Drop `\\r`s at the end, split by ` = `, transform resulting arrays into objects, put them into an array and pass it to `add`.",
      "[ inputs\r\n  | gsub(&quot;\\r$&quot;; &quot;&quot;)\r\n  | split(&quot; = &quot;; &quot;&quot;)\r\n  | select(length == 2)\r\n  | {(.[0]): .[1]}\r\n] | add",
      "If one of the &quot;values&quot; contains an &quot;=&quot; then using `split(&quot;=&quot;)` naively will produce incorrect results. If your jq supports `capture`, then here is a solution that avoids that issue:\r\n```\r\njq -nR '\r\n  def trim: sub(&quot;^ +&quot;;&quot;&quot;) | sub(&quot; +$&quot;;&quot;&quot;);\r\n  [inputs\r\n   | select(index(&quot;=&quot;))\r\n   | sub(&quot;\\r$&quot;; &quot;&quot;)\r\n   | capture( &quot;(?&lt;key&gt;[^=]*)=(?&lt;value&gt;.*)&quot; )\r\n   | ( (.key |= trim) | (.value |= trim)) ]\r\n  | from_entries'",
      "You need `--raw-input`/`-R` and `--null-input`/`-n` options specified on the command line in order for this to work."
    ],
    "utterance": "Convert lines containing key = value pairs, ignoring empty lines and handling Windows EOL, into a single object mapping each key to its value",
    "expressions": [
      "[inputs | gsub(\"\\r$\"; \"\") | split(\" = \"; \"\") | select(length == 2) | {(.[0]): .[1]}] | add",
      "def trim: sub(\"^ +\";\"\") | sub(\" +$\";\"\"); [inputs | select(index(\"=\")) | sub(\"\\r$\"; \"\") | capture(\"(?<key>[^=]*)=(?<value>.*)\") | ((.key |= trim) | (.value |= trim)) ] | from_entries"
    ],
    "data": [
      {
        "input": "foo = aa\r\nbar = bb\r\n\r\nqux = cc\r\nwhite space = white space\r\n* = special-char\r\n\r\n\r\n",
        "output": {
          "foo": "aa",
          "bar": "bb",
          "qux": "cc",
          "white space": "white space",
          "*": "special-char"
        }
      }
    ],
    "identifier": 61794706
  },
  {
    "context": [
      "I want to add the symbol that is outside the array:",
      "desired response:\n\"26,26.25,25.75,26.0625,1038600,957762000000,ABC\"",
      "In your case, you could go with:\n.symbol as $symbol\n| .candles[]\n| [.open, .high, .low, .close, .volume, .datetime, $symbol]\n| @csv",
      "or equivalently but without the $-variable:\n(.candles[] | [.open, .high, .low, .close, .volume, .datetime]) + [.symbol]\n| @csv"
    ],
    "utterance": "For each item in 'candles', output the fields open, high, low, close, volume, datetime, and the top-level symbol in CSV format.",
    "expressions": [
      ".symbol as $symbol | .candles[] | [.open, .high, .low, .close, .volume, .datetime, $symbol] | @csv",
      "(.candles[] | [.open, .high, .low, .close, .volume, .datetime]) + [.symbol] | @csv"
    ],
    "data": [
      {
        "input": {
          "candles": [
            {
              "open": 26,
              "high": 26.25,
              "low": 25.75,
              "close": 26.0625,
              "volume": 1038600,
              "datetime": 957762000000
            },
            {
              "open": 25.8125,
              "high": 26.25,
              "low": 25.75,
              "close": 26,
              "volume": 765900,
              "datetime": 957848400000
            }
          ],
          "symbol": "ABC",
          "empty": false
        },
        "output": [
          "\"26,26.25,25.75,26.0625,1038600,957762000000,ABC\"",
          "\"25.8125,26.25,25.75,26,765900,957848400000,ABC\""
        ]
      }
    ],
    "identifier": 61705239
  },
  {
    "context": [
      "I want to construct the target address in the format `ip:port`",
      "The desired output as follows:\n[\n\"192.168.0.1:8080\",\n\"192.168.0.2:8080\",\n\"192.168.0.3:8080\"\n]",
      "Then you can use this :\n\n    jq '[ .ips[] + \":\" + .port ]' input\n    \n---\n\n    [\n      \"192.168.0.1:8080\",\n      \"192.168.0.2:8080\",\n      \"192.168.0.3:8080\"\n    ]"
    ],
    "utterance": "For each address in the 'ips' array, append the value of 'port' with a colon separator, returning an array of these strings.",
    "expressions": [
      "[ .ips[] + \":\" + .port ]"
    ],
    "data": [
      {
        "input": {
          "ips": [
            "192.168.0.1",
            "192.168.0.2",
            "192.168.0.3"
          ],
          "port": "8080"
        },
        "output": [
          "192.168.0.1:8080",
          "192.168.0.2:8080",
          "192.168.0.3:8080"
        ]
      }
    ],
    "identifier": 62012671
  },
  {
    "context": [
      "I would like to remove the B objects where A is greater than 5, transforming",
      "You can still use a *del(select..) thing*.",
      ".myArray[] |= del(select(.A > 5) .B)"
    ],
    "utterance": "Remove the B field from elements in myArray where A is greater than 5, keeping the A fields unchanged.",
    "expressions": [
      ".myArray[] |= del(select(.A > 5) .B)"
    ],
    "data": [
      {
        "input": {
          "title": "myTitle",
          "myArray": [
            {
              "A": 1,
              "B": "foo"
            },
            {
              "A": 4,
              "B": "bar"
            },
            {
              "A": 7,
              "B": "barfoo"
            },
            {
              "A": 9,
              "B": "foobar"
            }
          ]
        },
        "output": {
          "title": "myTitle",
          "myArray": [
            {
              "A": 1,
              "B": "foo"
            },
            {
              "A": 4,
              "B": "bar"
            },
            {
              "A": 7
            },
            {
              "A": 9
            }
          ]
        }
      }
    ],
    "identifier": 61571148
  },
  {
    "context": [
      "I need to get the max value of \"date\" field in the JSON file in the \"results\" array",
      "jq '.results | max_by(.date) | .date' \"$jsonfilePath\"",
      "Given --stream option on the command line, JQ won't load the whole input into the memory, instead it'll read the input token by token...",
      "For example:\n```\njq -n --stream 'reduce (inputs|select(.[0][-1]==\"date\" and length==2)[1]) as $d (null; [.,$d]|max)' file\n```",
      "With this in our toolkit, we can simply write:\n```\nmax_by(.results[].date; .)\n```"
    ],
    "utterance": "Find the maximum value of the \"date\" field in the \"results\" array in a large file.",
    "expressions": [
      ".results | max_by(.date) | .date",
      "jq -n --stream 'reduce (inputs|select(.[0][-1]==\"date\" and length==2)[1]) as $d (null; [.,$d]|max)' file"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "Id": "123",
              "date": 1588910400000,
              "col": "test"
            },
            {
              "Id": "1234",
              "date": 1588910412345,
              "col": "test2"
            }
          ],
          "col2": 123
        },
        "output": 1588910412345
      }
    ],
    "identifier": 61691807
  },
  {
    "context": [
      "I'd like to add 2 values - `EnvType` and `KMSID` - (doesn't matter where in the config file) so that the end result would look like\n[\n  \"EnvType=dev\",\n  \"KMSID=xxxxx-yyyyyy-ffffff\",\n  \"ECSClusterName=cluster\",\n  \"VPCID=vpc-xxxx\",\n  \"ALBName=ALB\"\n]",
      "Put new `key=value` pairs into an array, and add that array to the original one.\n$ jq '. + [\"EnvType=dev\", \"KMSID=xxxxx-yyyyyy-ffffff\"]' config.json"
    ],
    "utterance": "Add the key-value pairs EnvType=dev and KMSID=xxxxx-yyyyyy-ffffff to the existing array of strings in the config file.",
    "expressions": [
      ". + [\"EnvType=dev\", \"KMSID=xxxxx-yyyyyy-ffffff\"]"
    ],
    "data": [
      {
        "input": [
          "ECSClusterName=cluster",
          "VPCID=vpc-xxxx",
          "ALBName=ALB"
        ],
        "output": [
          "ECSClusterName=cluster",
          "VPCID=vpc-xxxx",
          "ALBName=ALB",
          "EnvType=dev",
          "KMSID=xxxxx-yyyyyy-ffffff"
        ]
      }
    ],
    "identifier": 62017112
  },
  {
    "context": [
      "how do I transform the first json format data to the \"from\" format, adding an extra path.",
      "**From:**",
      "{\n  \"v1\": \"9.0.19\",\n  \"v2\": \"9.0.52\",\n  \"t2\": \"9.3.2\",\n  \"t3\": \"9.3.2\",\n  \"x\": \"9.0.46\"\n}",
      "**To**",
      "{\n\t  \"new_v1\": {\n\t\t  \"v1\": \"9.0.19\",\n\t\t  \"v2\": \"9.0.52\",\n\t\t  \"t2\": \"9.3.2\",\n\t\t  \"t3\": \"9.3.2\",\n\t\t  \"x\": \"9.0.46\"\n\t  }\n}",
      "jq '{\"new_v1\": .}' from.json",
      "or even just:",
      "jq '{new_v1: .}' from.json"
    ],
    "utterance": "Wrap the entire object inside a new top-level object under the key new_v1.",
    "expressions": [
      "{new_v1: .}",
      "{\"new_v1\": .}"
    ],
    "data": [
      {
        "input": {
          "v1": "9.0.19",
          "v2": "9.0.52",
          "t2": "9.3.2",
          "t3": "9.3.2",
          "x": "9.0.46"
        },
        "output": {
          "new_v1": {
            "v1": "9.0.19",
            "v2": "9.0.52",
            "t2": "9.3.2",
            "t3": "9.3.2",
            "x": "9.0.46"
          }
        }
      }
    ],
    "identifier": 61690375
  },
  {
    "context": [
      "I have a requirement to tag records uniquely with UUIDs (for a correlation id). I cant see a direct way to do this via the options, is such a thing possible? If not, is there some kind of workaround that might be able to do this?",
      "jq currently has no support for UUID generation, so your best bet would be to feed UUIDs in to jq, e.g. along these lines:",
      "Assuming the availability of a uuid generator such as uuidgen, you could use `input` or `inputs` along the following lines:",
      "It is possible to generate pseudo-random numbers in `jq` if you provide _one_ initial random number (`--argjson initialRandomNumber`).",
      "def nextRandomUUID($state): ...",
      "`output 3`: generate random UUID",
      "{ \"newState\":1188119770, \"randomUUID\":\"cdcda95b-af57-1303-da72-d21c6e7b1861\" }",
      "If using Linux (MacOS?), you can use the content of `/proc/sys/kernel/random/uuid`:",
      "jq -n --arg uuid \"$(cat /proc/sys/kernel/random/uuid)\"  '{\"id\": $uuid}'",
      "You could combine jq's compact format (`-c` option) and read each item in shell, generate a uuid externally, then feed that to jq again to insert it.",
      "Here\u2019s an example (using `uuidgen`) if you have a big array file:",
      "jq --stream -cn 'fromstream(1 | truncate_stream(inputs))' big-array.json | while read -r item; do jq '.id |= $uuid' --arg uuid \"$(uuidgen)\" <<<\"$item\"; done"
    ],
    "utterance": "Attach a unique UUID as a field to each record in an array.",
    "expressions": [
      "jq --stream -cn 'fromstream(1 | truncate_stream(inputs))' big-array.json | while read -r item; do jq '.id |= $uuid' --arg uuid \"$(uuidgen)\" <<<\"$item\"; done",
      "jq -n --arg uuid \"$(cat /proc/sys/kernel/random/uuid)\"  '{\"id\": $uuid}'"
    ],
    "identifier": 61842926
  },
  {
    "context": [
      "i need to update all the key values using one jq command.",
      ". + {environmentType:\"xz\", fqdn:\"abc\", tpg:\"mnop\" }",
      ".products[].attributes.artifactDetails.url = \"abc\", .products[].cookbookName = \"cookbook\"",
      "I need only one JQ command to update all the values in Json file and output should be redirect  to final.json file.",
      "In a nutshell, use '|' instead of ','.",
      ".products[].attributes.artifactDetails.url = \"abc\"\n| .products[].cookbookName = \"cookbook\""
    ],
    "utterance": "Update multiple specified keys and nested values at once: set environmentType to \"xz\", fqdn to \"abc\", tpg to \"mnop\", all products[].attributes.artifactDetails.url to \"abc\", and all products[].cookbookName to \"cookbook\" in one command.",
    "expressions": [
      ".environmentType = \"xz\"\n| .fqdn = \"abc\"\n| .tpg = \"mnop\"\n| .products[].attributes.artifactDetails.url = \"abc\"\n| .products[].cookbookName = \"cookbook\""
    ],
    "data": [
      {
        "input": {
          "changeDetails": {
            "chgNumber": "$ASKNOW_CRQ"
          },
          "environmentType": "$ENV_TYPE",
          "fqdn": "$FQDN.visa.com",
          "products": [
            {
              "action": "deploy",
              "attributes": {
                "artifactDetails": {
                  "url": "$ARTIFACT_URL"
                },
                "containers": "$CONTAINER_NAME"
              },
              "productName": "$PACKAGE_ID",
              "cookbookName": "visa_springboot"
            }
          ],
          "tpg": "O&I"
        },
        "output": {
          "changeDetails": {
            "chgNumber": "$ASKNOW_CRQ"
          },
          "environmentType": "xz",
          "fqdn": "abc",
          "products": [
            {
              "action": "deploy",
              "attributes": {
                "artifactDetails": {
                  "url": "abc"
                },
                "containers": "$CONTAINER_NAME"
              },
              "productName": "$PACKAGE_ID",
              "cookbookName": "cookbook"
            }
          ],
          "tpg": "mnop"
        }
      }
    ],
    "identifier": 61830348
  },
  {
    "context": [
      "Now I want to add an item `availabiltyZone: $PREFERRED_ZONE` to each of the array elements of `managedNodeGroups`.",
      "For example, I want the output to be:",
      "{",
      "  \"kind\": \"ClusterConfig\",",
      "  \"managedNodeGroups\": [",
      "    {",
      "      \"name\": \"default-nodegroup\",",
      "      \"instanceType\": \"t3.medium\",",
      "      \"availabilityZone\": \"us-east-1a\"",
      "    },",
      "    {",
      "      \"name\": \"elk-master-nodegroup\",",
      "      \"instanceType\": \"t3.medium\",",
      "      \"availabilityZone\": \"us-east-1a\"",
      "    },",
      "    {",
      "      \"name\": \"elk-data-nodegroup\",",
      "      \"instanceType\": \"t3.medium\",",
      "      \"availabilityZone\": \"us-east-1a\"",
      "    }",
      "  ]",
      "}",
      "The jq filter shown in the Q has incorrect positioning of the quotation marks.",
      "With your input data in input.json, the following invocation succeeds:",
      "jq --arg CONTR_CLUSTER_NAME \"My-${StackName}\" --arg CONTR_CLUSTER_REGION \"${Region}\"  --arg ZONES \"${Zones}\" --arg PREFERRED_ZONE \"${Region}-a\" '",
      "  .metadata.name = $CONTR_CLUSTER_NAME",
      "  | .metadata.region = $CONTR_CLUSTER_REGION",
      "  | .availabilityZones = ($ZONES|split(\",\"))",
      "  | (.managedNodeGroups[] | .preferredZone ) = $PREFERRED_ZONE",
      "' input.json"
    ],
    "utterance": "Add the field availabilityZone with value us-east-1a to each element in managedNodeGroups.",
    "expressions": [
      ".managedNodeGroups[] |= . + {availabilityZone: $PREFERRED_ZONE}"
    ],
    "data": [
      {
        "input": {
          "kind": "ClusterConfig",
          "managedNodeGroups": [
            {
              "name": "default-nodegroup",
              "instanceType": "t3.medium"
            },
            {
              "name": "elk-master-nodegroup",
              "instanceType": "t3.medium"
            },
            {
              "name": "elk-data-nodegroup",
              "instanceType": "t3.medium"
            }
          ]
        },
        "output": {
          "kind": "ClusterConfig",
          "managedNodeGroups": [
            {
              "name": "default-nodegroup",
              "instanceType": "t3.medium",
              "availabilityZone": "us-east-1a"
            },
            {
              "name": "elk-master-nodegroup",
              "instanceType": "t3.medium",
              "availabilityZone": "us-east-1a"
            },
            {
              "name": "elk-data-nodegroup",
              "instanceType": "t3.medium",
              "availabilityZone": "us-east-1a"
            }
          ]
        }
      }
    ],
    "identifier": 61847629
  },
  {
    "context": [
      "I'm trying to get a boolean that show me if any value are not empty with jq.",
      "is possible that `jq 'if .a and .b =!'` return true or false ? any exit code maybe ?",
      "empty:\n\n    | jq '.a , .b' \n    []\n    []",
      "jq -n '{a:[1],b:[1]} | any(.a, .b; . == [])'",
      "false"
    ],
    "utterance": "Determine if any of the keys 'a' or 'b' are empty arrays and return a boolean.",
    "expressions": [
      "any(.a, .b; . == [])"
    ],
    "data": [
      {
        "input": {
          "a": [
            1
          ],
          "b": [
            1
          ]
        },
        "output": false
      }
    ],
    "identifier": 61685700
  },
  {
    "context": [
      "Then I would like to have this output (only keep the items that have the property `fruit` equal to `pear`):",
      "You can use this instead:\n```\ndel(.first_level.second_level[] | select(.fruit != \"pear\"))\n```",
      "Or if you insist on a solution involving `|=`:\n```\n.first_level.second_level |= map(select(.fruit == \"pear\"))\n```"
    ],
    "utterance": "Keep only elements where the property fruit is equal to pear in the second_level array nested under first_level.",
    "expressions": [
      "del(.first_level.second_level[] | select(.fruit != \"pear\"))",
      ".first_level.second_level |= map(select(.fruit == \"pear\"))"
    ],
    "data": [
      {
        "input": {
          "first_level": {
            "second_level": [
              {
                "fruit": "apple"
              },
              {
                "fruit": "pear"
              },
              {
                "fruit": "banana"
              },
              {
                "fruit": "donuts"
              }
            ]
          }
        },
        "output": {
          "first_level": {
            "second_level": [
              {
                "fruit": "pear"
              }
            ]
          }
        }
      }
    ],
    "identifier": 62007725
  },
  {
    "context": [
      "I have a .env file with this content:\r\n\r\n    APP_ENV=local\r\n    APP_DEBUG=true\r\n    APP_URL=http://example.com.br\r\n\r\nAnd I need to transform in something like this:\r\n\r\n    \"environment\": [\r\n        {\r\n            \"name\": \"APP_ENV\",\r\n            \"value\": \"local\"\r\n        },\r\n        {\r\n            \"name\": \"APP_DEBUG\",\r\n            \"value\": \"true\"\r\n        },\r\n        {\r\n            \"name\": \"APP_URL\",\r\n            \"value\": \"http://example.com.br\"\r\n        }\r\n    ]",
      "jq -sR '{\"Environment\": [ split(\"\\n\")[:-1][] | rtrimstr(\"\\r\") | split(\"=\") | {name:.[0],value:.[1]}]}' env"
    ],
    "utterance": "Convert a text file containing lines in key=value format to an object with a key 'Environment' mapping to a list of objects with 'name' and 'value' fields extracted from each line.",
    "expressions": [
      "jq -sR '{\"Environment\": [ split(\"\\n\")[:-1][] | rtrimstr(\"\\r\") | split(\"=\") | {name:.[0],value:.[1]}]}' env"
    ],
    "data": [
      {
        "input": "APP_ENV=local\nAPP_DEBUG=true\nAPP_URL=http://example.com.br\n",
        "output": {
          "Environment": [
            {
              "name": "APP_ENV",
              "value": "local"
            },
            {
              "name": "APP_DEBUG",
              "value": "true"
            },
            {
              "name": "APP_URL",
              "value": "http://example.com.br"
            }
          ]
        }
      }
    ],
    "identifier": 62025896
  },
  {
    "context": [
      "But then I would like to add a {\"multiple_tweets\": true} to all the objects that have more than one tweet_ids.",
      "jq -s '. | group_by(.user) | .[] | {user_id: .[0].user.id, user_name: .[0].user.screen_name, user_followers: .[0].user.followers_count, tweet_ids: [.[].id]} | (select(.tweet_ids | length > 1) .multiple_tweets = true)'",
      "But if (for whatever reason, in this example is not really needed, in fact I was doing it just to understand the update-assignment) I want to use the |= operator,",
      "jq -s '. | group_by(.user) | .[] | {user_id: .[0].user.id, user_name: .[0].user.screen_name, user_followers: .[0].user.followers_count, tweet_ids: [.[].id]} |= (select(.tweet_ids | length > 1) .multiple_tweets = true)'",
      "If instead of using the operator |= directly, I pipe through the identity operator first, it works fine.",
      "jq -s '. | group_by(.user) | .[] | {user_id: .[0].user.id, user_name: .[0].user.screen_name, user_followers: .[0].user.followers_count, tweet_ids: [.[].id]} | . |= (select(.tweet_ids | length > 1) .multiple_tweets = true)'"
    ],
    "utterance": "Add a field multiple_tweets: true to all grouped user objects where tweet_ids has more than one element.",
    "expressions": [
      ". | group_by(.user) | .[] | {user_id: .[0].user.id, user_name: .[0].user.screen_name, user_followers: .[0].user.followers_count, tweet_ids: [.[].id]} | (select(.tweet_ids | length > 1) .multiple_tweets = true)",
      ". | group_by(.user) | .[] | {user_id: .[0].user.id, user_name: .[0].user.screen_name, user_followers: .[0].user.followers_count, tweet_ids: [.[].id]} | . |= (select(.tweet_ids | length > 1) .multiple_tweets = true)"
    ],
    "identifier": 61983958
  },
  {
    "context": [
      "Using arbitrary [tag:json] with [tag:jq] how can I print a version with the \"values\" cleared to \"empty\".",
      "You can get paths to non-iterable values at any level in the input using `paths(scalars)`, and update them with *empty* values using `reduce` and `setpath`-`getpath` built-ins.",
      "{null: null, boolean: false, number: 0, string: \"\"} as $e\n| reduce paths(scalars) as $p (.; setpath($p; $e[getpath($p)|type])"
    ],
    "utterance": "Replace all non-iterable values with their empty equivalents, leaving objects and arrays intact.",
    "expressions": [
      "{null: null, boolean: false, number: 0, string: \"\"} as $e | reduce paths(scalars) as $p (.; setpath($p; $e[getpath($p)|type]))"
    ],
    "data": [
      {
        "input": {
          "colors": [
            {
              "color": "black",
              "category": "hue",
              "type": "primary",
              "code": {
                "rgba": [
                  255,
                  255,
                  255,
                  1
                ],
                "hex": "#000"
              }
            }
          ]
        },
        "output": {
          "colors": [
            {
              "color": "",
              "category": "",
              "type": "",
              "code": {
                "rgba": [],
                "hex": ""
              }
            }
          ]
        }
      },
      {
        "input": {
          "kind": "youtube#searchListResponse",
          "etag": "\"m2yskBQFythfE4irbTIeOgYYfBU/PaiEDiVxOyCWelLPuuwa9LKz3Gk\"",
          "nextPageToken": "CAUQAA",
          "regionCode": "KE",
          "pageInfo": {
            "totalResults": 4249,
            "resultsPerPage": 5
          },
          "items": [
            {
              "kind": "youtube#searchResult",
              "etag": "\"m2yskBQFythfE4irbTIeOgYYfBU/2dIR9BTfr7QphpBuY3hPU-h5u-4\"",
              "id": {
                "kind": "youtube#video",
                "videoId": "IirngItQuVs"
              }
            }
          ]
        },
        "output": {
          "kind": "",
          "etag": "",
          "nextPageToken": "",
          "regionCode": "",
          "pageInfo": {
            "totalResults": 0,
            "resultsPerPage": 0
          },
          "items": [
            {
              "kind": "",
              "etag": "",
              "id": {
                "kind": "",
                "videoId": ""
              }
            }
          ]
        }
      }
    ],
    "identifier": 61683452
  },
  {
    "context": [
      "I need to get id value and IPv4_address value where IPv4_address exists (this shouldn't be null).",
      "for the ipv4_address:1.1.1.1 & ipv4_address:1.1.1.2, i need to get the id output which is \"4e-0365-4e29-95ca-329165eecf8a\" and \"c9061b6674a8546cea\" along with IP address.",
      "I was trying to use jq but with this I'm not able to get the both values",
      "$ cat input.js | jq -r '.USER[] | select(.ipv4_address) | \"\\(.ipv4_address) \\(.id)\"' > result.js",
      "In the above command when you do select(.ipv4_address) It basically drops all the records for which ipv4_address value is null or it is not present."
    ],
    "utterance": "Select all objects with a non-null ipv4_address and output both the ipv4_address and id values on each line.",
    "expressions": [
      ".USER[] | select(.ipv4_address) | \"\\(.ipv4_address) \\(.id)\""
    ],
    "data": [
      {
        "input": {
          "errorcode": 0,
          "message": "Done",
          "operation": "get",
          "resourceType": "USER",
          "username": "root",
          "tenant_name": "Owner",
          "tenant_id": "05db6674ad458546cd2",
          "resourceName": "",
          "USER": [
            {
              "is_default": "false",
              "session_timeout": "0",
              "permission": "root",
              "name": "ee",
              "session_timeout_unit": "",
              "tenant_id": "55bcb6674ad45854",
              "id": "4e-0365-4e29-95ca-329165eecf8a",
              "ipv4_address": "1.1.1.1",
              "state": "Up",
              "tenant_name": "Owner",
              "encrypted": "false",
              "groups": [
                "owner"
              ],
              "root_user": ""
            },
            {
              "is_default": "false",
              "session_timeout": "0",
              "permission": "read",
              "name": "test",
              "session_timeout_unit": "",
              "tenant_id": "bc906674ad458546cd2",
              "id": "12cd0-fb7f-4abf-b060-48e98b794b06",
              "tenant_name": "Owner",
              "encrypted": "false",
              "groups": [
                "read"
              ],
              "root_user": ""
            },
            {
              "is_default": "true",
              "session_timeout": "0",
              "permission": "root",
              "name": "root",
              "session_timeout_unit": "",
              "tenant_id": "c905db6d458546cd2",
              "id": "c9061b6674a8546cea",
              "ipv4_address": "1.1.1.2",
              "state": "Not Reachable",
              "tenant_name": "Owner",
              "encrypted": "false",
              "groups": [
                "owner"
              ],
              "root_user": ""
            },
            {
              "is_default": "false",
              "session_timeout": "0",
              "permission": "readonly",
              "name": "a",
              "session_timeout_unit": "",
              "tenant_id": "c905674ad458546cd2",
              "id": "bc8a-4fd6-bc09-8c39c131b54e",
              "tenant_name": "Owner",
              "encrypted": "false",
              "groups": [
                "read"
              ],
              "root_user": ""
            }
          ]
        },
        "output": [
          "1.1.1.1 4e-0365-4e29-95ca-329165eecf8a",
          "1.1.1.2 c9061b6674a8546cea"
        ]
      }
    ],
    "identifier": 61597122
  },
  {
    "context": [
      "I want the string \"foo\", because that is the key whose child value \"primary' is true.",
      "jq -r '.[] | select(.primary == true)'",
      "But that returns the value of \"foo\", not the string \"foo\" itself.",
      "Then you can filter with .value.primary and map the result with .key:",
      "to_entries | map(select(.value.primary)  | .key)",
      "Or to get just the first item of the array:",
      "to_entries | map(select(.value.primary)  | .key)[0]"
    ],
    "utterance": "Return the key of the top-level object whose child attribute 'primary' is true.",
    "expressions": [
      "to_entries | map(select(.value.primary) | .key)",
      "to_entries | map(select(.value.primary) | .key)[0]"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "primary": true,
            "blah": "beep"
          },
          "bar": {
            "primary": false,
            "blah": "narf"
          },
          "baz": {
            "primary": false,
            "blah": "poink"
          }
        },
        "output": [
          "foo"
        ]
      }
    ],
    "identifier": 62031471
  },
  {
    "context": [
      "I have the following ouput\n[\n \"notimportant\",\n     [\n       \"val1\",\n       \"val2\",\n       ...,\n       \"valn\"\n     ]\n]",
      "I'm trying to store every value into a bash string, using jq I tried this ...which feels clunky and also has a slow performance. I'm trying to dump the values at once without looping on all the elements",
      "outTABS=$(curl -s \"$url\" | jq -r '.[1]|.|@tsv')",
      "outLINE=$(curl -s \"$url\" | jq -r '.[1]|.[]|[.]|@tsv')",
      "> echo \"$outTABS\"\nval1\tval2\tvaln",
      "> echo \"$outLINE\"\nval1\nval2\nvaln"
    ],
    "utterance": "Extract all the string values from the second element of a two-element array response, outputting them either tab-separated or each on a new line.",
    "expressions": [
      ".[1] | .[]",
      ".[1]|.|@tsv",
      ".[1]|.[]|[.]|@tsv"
    ],
    "data": [
      {
        "input": [
          "notimportant",
          [
            "val1",
            "val2",
            "valn"
          ]
        ],
        "output": [
          "val1",
          "val2",
          "valn"
        ]
      }
    ],
    "identifier": 61528218
  },
  {
    "context": [
      "How can I take this input and create a new json looking like\n\n{\"Devices\":[\"TV\",\"radio\",\"pc\"]}",
      "Put them into an array and pair that with `Devices` key in an object.",
      "$ jq '{Devices:[.Results[].Attributes.rhasspyName]}' file\n{\n  \"Devices\": [\n    \"TV\",\n    \"radio\",\n    \"pc\"\n  ]\n}"
    ],
    "utterance": "Create an object with a Devices key whose value is an array of all rhasspyName values from the Attributes of each item in Results.",
    "expressions": [
      "{Devices: [.Results[].Attributes.rhasspyName]}"
    ],
    "data": [
      {
        "input": {
          "Arg": "room=Rhasspy rhasspyName",
          "Results": [
            {
              "Name": "TV",
              "Internals": {},
              "Readings": {},
              "Attributes": {
                "rhasspyName": "TV"
              }
            },
            {
              "Name": "dyTest01",
              "Internals": {},
              "Readings": {},
              "Attributes": {
                "rhasspyName": "radio"
              }
            },
            {
              "Name": "enoAcPC01",
              "Internals": {},
              "Readings": {},
              "Attributes": {
                "rhasspyName": "pc"
              }
            }
          ],
          "totalResultsReturned": 3
        },
        "output": {
          "Devices": [
            "TV",
            "radio",
            "pc"
          ]
        }
      }
    ],
    "identifier": 62006972
  },
  {
    "context": [
      "I want to save CPU by calling jq just once and extract all single or array values.",
      "Expected output for above echo command:\n\n    4\n    9\n    9\n    0\n    4\n    2",
      "Expected output for above echo command:\n\n    1\n    3\n    1\n    3\n    1\n    3\n    1\n    3\n    1\n    3\n    1\n    3",
      "The jq script packs all `xyz` objects in a single array and filters it with the `m` function for each field represented as a path expression. The function returns a string formatted as `field=(val1 val2... valN)`, where the field name is the last component of the path expression, i.e. `x` for `.x` and `a` for `.inner_arr[].a` (extracted on the first item of the array)."
    ],
    "utterance": "Extract the values for z, x, y, id, inner_arr.a, and inner_arr.b from all xyz entries at all time steps, and output each as a separate array ordered to match the traversal.",
    "expressions": [
      "def m(exp): first(.[0] | path(exp)[-1]) + \"=(\" + (map(exp) | @sh) + \")\"; [ .coordinates[].xyz[] ] | m(.x), m(.y), m(.z), m(.id), m(.inner_arr[].a), m(.inner_arr[].b)"
    ],
    "data": [
      {
        "input": {
          "unique": 1924,
          "coordinates": [
            {
              "time": "2015-01-25T00:00:01.683",
              "xyz": [
                {
                  "z": 4,
                  "y": 2,
                  "x": 1,
                  "id": 99,
                  "inner_arr": [
                    {
                      "a": 1,
                      "b": 2
                    },
                    {
                      "a": 3,
                      "b": 4
                    }
                  ]
                },
                {
                  "z": 9,
                  "y": 9,
                  "x": 8,
                  "id": 100,
                  "inner_arr": [
                    {
                      "a": 1,
                      "b": 2
                    },
                    {
                      "a": 3,
                      "b": 4
                    }
                  ]
                },
                {
                  "z": 9,
                  "y": 6,
                  "x": 10,
                  "id": 101,
                  "inner_arr": [
                    {
                      "a": 1,
                      "b": 2
                    },
                    {
                      "a": 3,
                      "b": 4
                    }
                  ]
                }
              ]
            },
            {
              "time": "2015-01-25T00:00:02.790",
              "xyz": [
                {
                  "z": 0,
                  "y": 3,
                  "x": 7,
                  "id": 99,
                  "inner_arr": [
                    {
                      "a": 1,
                      "b": 2
                    },
                    {
                      "a": 3,
                      "b": 4
                    }
                  ]
                },
                {
                  "z": 4,
                  "y": 6,
                  "x": 2,
                  "id": 100,
                  "inner_arr": [
                    {
                      "a": 1,
                      "b": 2
                    },
                    {
                      "a": 3,
                      "b": 4
                    }
                  ]
                },
                {
                  "z": 2,
                  "y": 9,
                  "x": 51,
                  "id": 101,
                  "inner_arr": [
                    {
                      "a": 1,
                      "b": 2
                    },
                    {
                      "a": 3,
                      "b": 4
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "x=(1 8 10 7 2 51)",
          "y=(2 9 6 3 6 9)",
          "z=(4 9 9 0 4 2)",
          "id=(99 100 101 99 100 101)",
          "a=(1 3 1 3 1 3 1 3 1 3 1 3)",
          "b=(2 4 2 4 2 4 2 4 2 4 2 4)"
        ]
      }
    ],
    "identifier": 61657791
  },
  {
    "context": [
      "Need to get value of `id` that corresponds **`name='robot$deployer'`**. How can `$` be escaped so `jq` only select corrct ID (1321) instead of both (1321 and 1326)?",
      "ROBOT_LOGIN=\"robot\\$deployer\"",
      "export ROBOT_ID=$(echo $PROJECT_INFO | jq --arg rl \"${ROBOT_LOGIN}\" '.[] | select(.name == $rl) | .id')",
      "The thing you were trying to do is handled by the jq `select` function:",
      "ROBOT_ID=$(jq '.[] | select(.name == \"robot$deployer\") | .id')"
    ],
    "utterance": "Retrieve the id of the object whose name exactly matches 'robot$deployer'.",
    "expressions": [
      ".[] | select(.name == \"robot$deployer\") | .id",
      ".[] | select(.name == $rl) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1321,
            "name": "robot$deployer",
            "token": "",
            "description": "deployer",
            "project_id": 55,
            "expires_at": 1590799816,
            "disabled": false,
            "creation_time": "2020-04-29T10:50:16.029882-07:00",
            "update_time": "2020-04-29T10:50:16.029882-07:00"
          },
          {
            "id": 1326,
            "name": "robot$test",
            "token": "",
            "description": "test",
            "project_id": 55,
            "expires_at": 1590862956,
            "disabled": false,
            "creation_time": "2020-04-30T04:22:36.940445-07:00",
            "update_time": "2020-04-30T04:22:36.940445-07:00"
          }
        ],
        "output": 1321
      }
    ],
    "identifier": 61599834
  },
  {
    "context": [
      "$ jq -n 'range(0; 4)'",
      "0\n1\n2\n3",
      "$ jq -n 'range(0, 4)'",
      "0\n1\n2\n3",
      "jq defines range/1 as:\n\ndef range($x): range(0;$x);",
      "So range(0,$n) evaluates to\n\n    range(0), range($n)\n\nwhich yields the stream `empty, range($n)`, which is equivalent to the stream \n\n    range(0;$n)"
    ],
    "utterance": "Produce the values from 0 up to, but not including, 4 using range with either a comma or semicolon argument separator.",
    "expressions": [
      "range(0; 4)",
      "range(0, 4)"
    ],
    "data": [
      {
        "input": null,
        "output": [
          0,
          1,
          2,
          3
        ]
      }
    ],
    "identifier": 61657757
  },
  {
    "context": [
      "What I need to do is merge in child documents at `.resources[].properties.template`, such that the first file is at `.resources[0].properties.template`, the second file is at `.resources[1].properties.template` etc.",
      "I'm looking for a single `jq` command that can merge in the child files.",
      "Assuming the number of objects in `resources` equals the number of child documents, this should do the trick:",
      "jq '.resources[].properties.template |= . + input' parent children..."
    ],
    "utterance": "Merge each child file into the corresponding element's properties.template field in the resources array of the parent, in order.",
    "expressions": [
      ".resources[].properties.template |= . + input"
    ],
    "data": [
      {
        "input": {
          "parent": {
            "resources": [
              {
                "name": "child0",
                "properties": {
                  "template": {}
                }
              },
              {
                "name": "child1",
                "properties": {
                  "template": {}
                }
              },
              {
                "name": "child2",
                "properties": {
                  "template": {}
                }
              }
            ]
          },
          "child0": {
            "foo": 1
          },
          "child1": {
            "bar": 2
          },
          "child2": {
            "baz": 3
          }
        },
        "output": {
          "resources": [
            {
              "name": "child0",
              "properties": {
                "template": {
                  "foo": 1
                }
              }
            },
            {
              "name": "child1",
              "properties": {
                "template": {
                  "bar": 2
                }
              }
            },
            {
              "name": "child2",
              "properties": {
                "template": {
                  "baz": 3
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 61655397
  },
  {
    "context": [
      "I am trying to retrieve the secrets in the following format:\r\n\r\n    KEY_1=\"XXXX\"\r\n    KEY_2=0",
      "This command is working fine but with a small problem. This command is adding an extra double quotation mark (`\"\"`) in the `value` field. It is giving the following output:\r\n\r\n     KEY_1=\"\"XXXX\"\"\r\n     KEY_2=\"0\"",
      "But I do not want these extra double quotation marks to be added. I want the output should be in the same format as described above while retrieving above i.e, without extra quotation marks."
    ],
    "utterance": "Format each key/value pair as KEY=value, quoting string values with exactly one pair of double quotes and leaving numeric values unquoted.",
    "expressions": [
      "to_entries[] | \"\\(.key)=\\(if (type == \"object\" and .value | type == \"string\") or (.value | type == \"string\") then \"\\\"\\(.value)\\\"\" else (.value|tostring) end)\""
    ],
    "identifier": 61586847
  },
  {
    "context": [
      "The values are \"dummy group 1\", \"dummy group 2\"",
      "Here is the actual json output that I'm trying to filter:",
      "[ { \"groupid\": \"92\", \"name\": \"dummy group 1\" }, { \"groupid\": \"93\", \"name\": \"dummy group 2\" } ]",
      "If I type the value then it works",
      "echo $groupid_json | jq  -r '.result[] | select(.name == \"dummy group 1\") | .groupid'",
      "jq -r --arg name \"$i\" '.[] | select(.name == $name) .groupid' <<< $groupid_json"
    ],
    "utterance": "Select the groupid of an object where name equals a given value that contains spaces, such as 'dummy group 1' or 'dummy group 2'.",
    "expressions": [
      ".[] | select(.name == $name) .groupid",
      ".result[] | select(.name == $name) | .groupid"
    ],
    "data": [
      {
        "input": [
          {
            "groupid": "92",
            "name": "dummy group 1"
          },
          {
            "groupid": "93",
            "name": "dummy group 2"
          }
        ],
        "output": "92"
      }
    ],
    "identifier": 61587875
  },
  {
    "context": [
      "Easiest way to convert a bash array to a JSON array using JQ is to use the `--args` flag.",
      "$ jq -n '$ARGS.positional' --args \"${group_list[@]}\"",
      "[ \"dummy group 1\", \"dummy group 2\" ]"
    ],
    "utterance": "Convert a bash array with space-containing elements into an array of separate string values.",
    "expressions": [
      "jq -n '$ARGS.positional' --args \"${group_list[@]}\""
    ],
    "data": [
      {
        "input": [
          "dummy group 1",
          "dummy group 2"
        ],
        "output": [
          "dummy group 1",
          "dummy group 2"
        ]
      }
    ],
    "identifier": 61588841
  },
  {
    "context": [
      "I would like to just keep the elements that are of interest for me but I want to keep the general structure.",
      "Did I miss something that either allows easier specifying deep objects keys like:",
      ".[] | {name: .name, colors.head.eyes = .colors.head.eyes}",
      "or some even more convenient: some sub key filter mechanism like",
      ".[] | filteKeys([\"name\", \"colors.head.eyes\"])",
      "*some sub key filter mechanism* can be implemented as follows.",
      "def pick(paths):\n  . as $in\n  | reduce path(paths) as $path (null;\n    setpath($path; $in | getpath($path))\n  );",
      "And you can use it like:\n.[] | pick(.name, .colors.head.eyes)"
    ],
    "utterance": "Extract objects with only the name field and the colors.head.eyes field, maintaining the nested structure.",
    "expressions": [
      "def pick(paths):\n  . as $in\n  | reduce path(paths) as $path (null;\n    setpath($path; $in | getpath($path))\n  );\n.[] | pick(.name, .colors.head.eyes)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "age": 12,
            "weight": 23,
            "colors": {
              "head": {
                "hair": "blue",
                "eyes": "green"
              }
            }
          },
          {
            "name": "bar",
            "age": 42,
            "weight": 54,
            "colors": {
              "head": {
                "hair": "blue",
                "eyes": "blue"
              }
            }
          },
          {
            "name": "baz",
            "age": 65,
            "weight": 439,
            "colors": {
              "head": {
                "hair": "green",
                "eyes": "red"
              }
            }
          }
        ],
        "output": [
          {
            "name": "foo",
            "colors": {
              "head": {
                "eyes": "green"
              }
            }
          },
          {
            "name": "bar",
            "colors": {
              "head": {
                "eyes": "blue"
              }
            }
          },
          {
            "name": "baz",
            "colors": {
              "head": {
                "eyes": "red"
              }
            }
          }
        ]
      }
    ],
    "identifier": 61655382
  },
  {
    "context": [
      "if I had just the numbers 0500000US33009, 0500000US38041, and 0500000US38043 in column 1 and 51289.0, 46793.0, and 39857.0 in column 2. How might I do this, and make sure that the resulting JSON has quotes around the \"0500000US33009\"?",
      "jq -Rn 'reduce inputs as $in ({};   . + ($in|split(\",\")|{(.[0]): .[1] |  tonumber}))'",
      "{\n  \"0500000US33009\": 51289.0,\n  \"0500000US38041\": 46793.0,\n  \"0500000US38043\": 39857.0\n}"
    ],
    "utterance": "Convert two columns of values, where the first column is used as string keys and the second column as numeric values with decimals, into a single object with quoted keys and numeric values with decimal points.",
    "expressions": [
      "jq -Rn 'reduce inputs as $in ({}; . + ($in|split(\",\")|{(.[0]): .[1] | tonumber}))'"
    ],
    "data": [
      {
        "input": "0500000US33009,51289.0\n0500000US38041,46793.0\n0500000US38043,39857.0",
        "output": {
          "0500000US33009": 51289.0,
          "0500000US38041": 46793.0,
          "0500000US38043": 39857.0
        }
      }
    ],
    "identifier": 62037680
  },
  {
    "context": [
      "So, I basically have a file `test.json`\n```\n[\n  \"Name=TestName\",\n  \"Tag=TestTag\"\n]\n```\n\nWhich I'd like to transform into \n```\n[\n  {\n    \"ParameterKey\": \"Name\",\n    \"ParameterValue\": \"TestName\",\n  },\n  {\n    \"ParameterKey\": \"Tag\",\n    \"ParameterValue\": \"TestTag\",\n  }\n]\n```",
      "[.[] |  {ParameterKey: split(\"=\")[0], ParameterValue: split(\"=\")[1]}]",
      "jq -n '[ inputs[] | split(\"=\") | {ParameterKey: .[0], ParameterValue: .[1]} ]'"
    ],
    "utterance": "Convert an array of strings in the format 'Key=Value' into an array of objects with fields ParameterKey and ParameterValue holding the key and value.",
    "expressions": [
      "[.[] | {ParameterKey: split(\"=\")[0], ParameterValue: split(\"=\")[1]}]",
      "[ inputs[] | split(\"=\") | {ParameterKey: .[0], ParameterValue: .[1]} ]"
    ],
    "data": [
      {
        "input": [
          "Name=TestName",
          "Tag=TestTag"
        ],
        "output": [
          {
            "ParameterKey": "Name",
            "ParameterValue": "TestName"
          },
          {
            "ParameterKey": "Tag",
            "ParameterValue": "TestTag"
          }
        ]
      }
    ],
    "identifier": 61751375
  },
  {
    "context": [
      "the time frame for the queries have to be divided. So I am left with a JSON as follows:",
      "[inputs | .results[] | map( { (.field) : .value} ) | add]\n| group_by(.AccountId)\n| map([.[0].AccountId, (map(.number_of_requests|tonumber) | add)])\n| sort_by(.[1]) | reverse\n| \"\\(.[]) \" ' $ResultsDir",
      "The jq command that you have written in the above script is able to get the AccountId and aggregated value of number_of_requests.",
      "[inputs | .results[] | map( { (.field) : .value} ) | add] | group_by(.AccountId)| map([.[0].AccountId, (map(.number_of_requests|tonumber) | add)])| sort_by(.[1]) | reverse| \"\\(.[]) \""
    ],
    "utterance": "Aggregate number_of_requests for each AccountId across multiple input objects, outputting AccountId and total number_of_requests for each.",
    "expressions": [
      "[inputs | .results[] | map({ (.field): .value}) | add] | group_by(.AccountId) | map([.[0].AccountId, (map(.number_of_requests|tonumber) | add)]) | sort_by(.[1]) | reverse"
    ],
    "data": [
      {
        "input": [
          {
            "results": [
              [
                {
                  "field": "AccountId",
                  "value": "11352"
                },
                {
                  "field": "number_of_requests",
                  "value": "241398"
                }
              ],
              [
                {
                  "field": "AccountId",
                  "value": "74923"
                },
                {
                  "field": "number_of_requests",
                  "value": "238566"
                }
              ]
            ],
            "statistics": {
              "recordsMatched": 502870.0,
              "recordsScanned": 165908292.0,
              "bytesScanned": 744173091162.0
            },
            "status": "Complete"
          },
          {
            "results": [
              [
                {
                  "field": "AccountId",
                  "value": "11352"
                },
                {
                  "field": "number_of_requests",
                  "value": "185096"
                }
              ]
            ],
            "statistics": {
              "recordsMatched": 502870.0,
              "recordsScanned": 165908292.0,
              "bytesScanned": 744173091162.0
            },
            "status": "Complete"
          }
        ],
        "output": [
          [
            "11352",
            426494
          ],
          [
            "74923",
            238566
          ]
        ]
      }
    ],
    "identifier": 61652099
  },
  {
    "context": [
      "I am looking for an approach to prepare the json file with mutiple empID before triggering the CURL.",
      "But am not sure how to traverse through each individual empID field and replace its value with dynamic CURRENT values.",
      "You can use the `range()` function in `jq` to create the number range from 1 to million and create multiple objects using the `reduce()` function",
      "jq -n 'reduce range(1; 1000000) as $data (.; . + [{\"field\": { \"empID\": $data, \"location\": \"India\"}}])'",
      "You\u2019re looking for the `range` built-in.",
      ".[] | [.field.empID = range(1;1000000)]"
    ],
    "utterance": "Generate an array of objects where each object's empID field is set to every integer from 1 to 999999, and the location field is 'India'.",
    "expressions": [
      "jq -n 'reduce range(1; 1000000) as $data (.; . + [{\"field\": { \"empID\": $data, \"location\": \"India\"}}])'",
      ".[] | [.field.empID = range(1;1000000)]"
    ],
    "identifier": 61653907
  },
  {
    "context": [
      "timestamp is ISO8601 format.",
      "I want to convert the **timestamp** from UTC to Madrid time.",
      "report_dump=$(TZ=Erope/Madrid jq1.6 -j --raw-output ... | .[\"@timestamp\"] | sub(\".[0-9]+Z$\"; \"Z\") | fromdateiso8601 | strflocaltime(\"%Y-%m-%dT%H:%M:%S %Z\"), ...",
      "Here's an illustration using the TZ environment variable, e.g.",
      "TZ=Europe/Madrid jq -n -f program.jq",
      "{ \"@timestamp\": \"2020-05-04T18:02:13Z\" } | .[\"@timestamp\"] | fromdateiso8601   # converts to seconds | gmtime | strftime(\"%Y-%m-%dT%H:%M:%S%Z\")",
      "Output: \"2020-05-04T19:02:13CET\"",
      "Note: %Z becomes CET."
    ],
    "utterance": "Convert a UTC-formatted ISO8601 timestamp to Madrid local time using the time zone Europe/Madrid.",
    "expressions": [
      ".[\"@timestamp\"] | fromdateiso8601 | strflocaltime(\"%Y-%m-%dT%H:%M:%S %Z\")",
      ".[\"@timestamp\"] | fromdateiso8601 | gmtime | strftime(\"%Y-%m-%dT%H:%M:%S%Z\")"
    ],
    "data": [
      {
        "input": {
          "@timestamp": "2020-05-04T18:02:13Z"
        },
        "output": "2020-05-04T20:02:13 CEST"
      }
    ],
    "identifier": 61587494
  },
  {
    "context": [
      "I basically need the jq expression to get \"vendor2\" when I am given LSGS-2002-RC.",
      "jq -r '.vendors | to_entries[] | select(.value.vendor_version==\"LSGS-2002-RC\").key'",
      "jq -r --arg vendor \"LSGS-2002-RC\" '.vendors | to_entries[] | select(.value.vendor_version == $vendor).key'",
      ".vendors | keys[] as $k | if .[$k].vendor_version == \"LSGS-2002-RC\" then $k else empty end"
    ],
    "utterance": "Get the parent key whose child object has vendor_version equal to LSGS-2002-RC.",
    "expressions": [
      ".vendors | to_entries[] | select(.value.vendor_version==\"LSGS-2002-RC\").key",
      ".vendors | to_entries[] | select(.value.vendor_version == $vendor).key",
      ".vendors | keys[] as $k | if .[$k].vendor_version == \"LSGS-2002-RC\" then $k else empty end"
    ],
    "data": [
      {
        "input": {
          "vendors": {
            "vendor1": {
              "vendor_version": "LS TT1706-POL",
              "vendor_name": "toyota"
            },
            "vendor2": {
              "vendor_version": "LSGS-2002-RC",
              "vendor_name": "honda"
            },
            "vendor3": {
              "vendor_version": "LS1903",
              "vendor_name": "suzuki"
            }
          }
        },
        "output": "vendor2"
      }
    ],
    "identifier": 62007673
  },
  {
    "context": [
      "For example, if the list of the filenames on `stdin` is `/etc/alpha.txt` and `/tmp/beta.txt`",
      "And `/etc/alpha.txt` contains `wibble`",
      "And `/tmp/beta.txt` contains `fu\\nbar`",
      "Then what I'd like to generate is\n\n```{\"/etc/alpha.txt\":\"wibble\",\"/tmp/beta.txt\":\"fu\\nbar\"}```",
      "I can install utilities like `jq`.",
      "xargs -L 1 -I {} jq -sR --arg key {} '{ ($key): .}' {} | jq -s 'add'",
      "xargs -I {} jq -sR '{(input_filename):.}' {} | jq -s add"
    ],
    "utterance": "Produce an object with file paths as keys and their file contents as values, for a list of file paths read from standard input.",
    "expressions": [
      "xargs -L 1 -I {} jq -sR --arg key {} '{ ($key): .}' {} | jq -s 'add'",
      "xargs -I {} jq -sR '{(input_filename):.}' {} | jq -s add"
    ],
    "data": [
      {
        "input": [
          "/etc/alpha.txt",
          "/tmp/beta.txt"
        ],
        "output": {
          "/etc/alpha.txt": "wibble",
          "/tmp/beta.txt": "fu\\nbar"
        }
      }
    ],
    "identifier": 61807377
  },
  {
    "context": [
      "I want to transform it to :\n[\n  {\n    \"a\": 1,\n    \"b\": 2,\n    \"c\": 3,\n    \"e\": {\n      \"f\": 4,\n      \"g\": 8\n    }\n  },\n  {\n    \"a\": 5,\n    \"b\": 6,\n    \"c\": 7\n  },\n  {\n    \"a\": 9,\n    \"b\": 10,\n    \"c\": 11,\n    \"e\": {\n      \"f\": 12,\n      \"g\": 13\n    }\n  }\n]",
      "So each element that is of form :\n\"c\": {\n    \"d\": 3\n}\nI want to transform to:\n\"c\": 3",
      "walk(if type == \"object\" and keys_unsorted == [\"d\"] then .d else . end)"
    ],
    "utterance": "Replace each object whose value is an object with sole key 'd' with that 'd' value throughout all levels of the data.",
    "expressions": [
      "walk(if type == \"object\" and keys_unsorted == [\"d\"] then .d else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 2,
            "c": {
              "d": 3
            },
            "e": {
              "f": 4,
              "g": {
                "d": 8
              }
            }
          },
          {
            "a": 5,
            "b": 6,
            "c": {
              "d": 7
            }
          },
          {
            "a": 9,
            "b": 10,
            "c": {
              "d": 11
            },
            "e": {
              "f": 12,
              "g": {
                "d": 13
              }
            }
          }
        ],
        "output": [
          {
            "a": 1,
            "b": 2,
            "c": 3,
            "e": {
              "f": 4,
              "g": 8
            }
          },
          {
            "a": 5,
            "b": 6,
            "c": 7
          },
          {
            "a": 9,
            "b": 10,
            "c": 11,
            "e": {
              "f": 12,
              "g": 13
            }
          }
        ]
      }
    ],
    "identifier": 61855442
  },
  {
    "context": [
      "These values for `props` must be read from the text file. In it they are in the following format:\r\nFILE_HASH=+XW4QKN5Y4ynTx43m4NYbMuk1x3P91f1biAVZBpj4fI=\r\nFILE_SIZE=980374602\r\nMETADATA_HASH=O7CLdR2j7qoD0RI2k1AGc8b+xoWYn20Ic24eZ1ZWUWE=\r\nMETADATA_SIZE=91669",
      "My task is to read the file and somehow create the final JSON (append formatted text to `props` block).",
      "Invocation: jq -n -R -f program.jq props.txt",
      "program.jq:\r\n[inputs | capture(\"^(?<key>[^=]*)=(?<value>.*)\")]\r\n| from_entries"
    ],
    "utterance": "Convert key=value formatted lines from a text file into a JSON object mapping keys to values.",
    "expressions": [
      "[inputs | capture(\"^(?<key>[^=]*)=(?<value>.*)\")] | from_entries"
    ],
    "data": [
      {
        "input": "FILE_HASH=+XW4QKN5Y4ynTx43m4NYbMuk1x3P91f1biAVZBpj4fI=\nFILE_SIZE=980374602\nMETADATA_HASH=O7CLdR2j7qoD0RI2k1AGc8b+xoWYn20Ic24eZ1ZWUWE=\nMETADATA_SIZE=91669",
        "output": {
          "FILE_HASH": "+XW4QKN5Y4ynTx43m4NYbMuk1x3P91f1biAVZBpj4fI=",
          "FILE_SIZE": "980374602",
          "METADATA_HASH": "O7CLdR2j7qoD0RI2k1AGc8b+xoWYn20Ic24eZ1ZWUWE=",
          "METADATA_SIZE": "91669"
        }
      }
    ],
    "identifier": 61607509
  },
  {
    "context": [
      "I would like to be able to grab any occurrence of \"cn\" and their corresponding \"SANs\" to iterate it across and create their individual columns, respectively:",
      "This can be done using the filter:",
      "[ [.enrollments[0].csr |  {cn, sans: .sans[]} | [.cn, .sans] ],",
      "  [.enrollments[1].csr |  {cn, sans: .sans[]} | [.cn, .sans] ] ]",
      "| transpose",
      "| map(add)",
      "| .[]",
      "| @csv",
      "The first program above can be generalized to allow the \"enrollments\" array to be arbitrarily long as follows:",
      "[ .enrollments[]",
      "  | [ .csr |  {cn, sans: .sans[]} | [.cn, .sans] ]]",
      "| transpose",
      "| map(add)",
      "| .[]",
      "| @tsv"
    ],
    "utterance": "Produce a table where each 'Common Name' and its SANs are shown in grouped columns across, with each SAN in its own row, matching columns for each enrollment.",
    "expressions": [
      "[ [.enrollments[0].csr |  {cn, sans: .sans[]} | [.cn, .sans] ],\n  [.enrollments[1].csr |  {cn, sans: .sans[]} | [.cn, .sans] ] ]\n| transpose\n| map(add)\n| .[]\n| @csv",
      "[ .enrollments[]\n  | [ .csr |  {cn, sans: .sans[]} | [.cn, .sans] ]]\n| transpose\n| map(add)\n| .[]\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "enrollments": [
            {
              "adminContact": {
                "email": "admin@domain.com",
                "firstName": "john",
                "lastName": "doe",
                "phone": "555-555-5555"
              },
              "certificateType": "third-party",
              "changeManagement": true,
              "csr": {
                "c": "US",
                "cn": "www.column.com",
                "l": "Houston",
                "o": "A Company International Ltd.",
                "ou": "Technology and Operations Services",
                "sans": [
                  "example1.com",
                  "example2.com",
                  "example3.com",
                  "example4.com"
                ],
                "st": "Bermingham"
              }
            },
            {
              "adminContact": {
                "email": "admin@domain.com",
                "firstName": "john",
                "lastName": "doe",
                "phone": "555-555-5555"
              },
              "certificateType": "third-party",
              "changeManagement": true,
              "csr": {
                "c": "US",
                "cn": "www.column2.com",
                "l": "Houston",
                "o": "A Company International Ltd.",
                "ou": "Technology and Operations Services",
                "sans": [
                  "www.example1.com",
                  "www.example2.com",
                  "www.example3.com",
                  "www.example4.com"
                ],
                "st": "Bermingham"
              }
            }
          ]
        },
        "output": "www.column.com\texample1.com\twww.column2.com\twww.example1.com\nwww.column.com\texample2.com\twww.column2.com\twww.example2.com\nwww.column.com\texample3.com\twww.column2.com\twww.example3.com\nwww.column.com\texample4.com\twww.column2.com\twww.example4.com"
      }
    ],
    "identifier": 61860347
  },
  {
    "context": [
      "for val in r.json():\n    if val['name'] == \"val_name\":\n        return val['id']\nreturn \"null\"",
      "the response I get from that api call is\n\n    [\n        {\n            \"id\": \"1123\",\n            ...\n            \"name\": \"daName\",\n            ...\n        },\n        {\n            \"id\": \"123123123\",\n            ...\n            \"name\": \"daName2\",\n            ...\n        },"
    ],
    "utterance": "Return the id value for the object where name equals val_name.",
    "expressions": [
      ".[] | select(.name == \"val_name\") | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1123",
            "last_message_id": "1123",
            "last_pin_timestamp": "2020-03-02T20:12:59.378000+00:00",
            "type": 0,
            "name": "daName",
            "position": 4,
            "parent_id": "544433",
            "topic": "theTopic",
            "guild_id": "123322",
            "permission_overwrites": [
              {
                "id": "1231232",
                "type": "role",
                "allow": 0,
                "deny": 213123
              }
            ],
            "nsfw": false,
            "rate_limit_per_user": 0
          },
          {
            "id": "123123123",
            "type": 2,
            "name": "daName2",
            "position": 0,
            "parent_id": "123123123",
            "bitrate": 64000,
            "user_limit": 0,
            "guild_id": "234141232",
            "permission_overwrites": [
              {
                "id": "2345242342",
                "type": "role",
                "allow": 0,
                "deny": 0
              },
              {
                "id": "`12123123",
                "type": "role",
                "allow": 0,
                "deny": 402663472
              }
            ],
            "nsfw": false
          }
        ],
        "output": "1123"
      }
    ],
    "identifier": 61823091
  },
  {
    "context": [
      "I like to extract those MAC addresses using jq. it seems to be tricky on this one.",
      ".[]\n| .metadata.annotations[]\n| (fromjson? // empty)\n| .[]\n| select(has(\"mac\"))\n| {mac}",
      "cat abc.json | jq -r  '.metadata.annotations.\"k8s.v1.cni.cncf.io/networks-status\" | fromjson | .[].mac ' ",
      "kubectl get po -o json -A | jq -r '.items[] | {name: .metadata.name, mac: (.metadata.annotations[\"k8s.v1.cni.cncf.io/network-status\"] // \"[]\" | fromjson | .[0].mac)}'"
    ],
    "utterance": "Extract all MAC addresses from the k8s.v1.cni.cncf.io/networks-status or network-status annotation of each pod.",
    "expressions": [
      ".[] | .metadata.annotations[] | (fromjson? // empty) | .[] | select(has(\"mac\")) | {mac}",
      ".metadata.annotations[\"k8s.v1.cni.cncf.io/networks-status\"] | fromjson | .[].mac",
      ".metadata.annotations[\"k8s.v1.cni.cncf.io/network-status\"] | fromjson | .[].mac",
      ".items[] | {name: .metadata.name, mac: (.metadata.annotations[\"k8s.v1.cni.cncf.io/network-status\"] // \"[]\" | fromjson | .[0].mac)}"
    ],
    "data": [
      {
        "input": [
          {
            "apiVersion": "v1",
            "kind": "Pod",
            "metadata": {
              "annotations": {
                "k8s.v1.cni.cncf.io/network-status": "[{\"name\": \"eps-cni\",\"ips\": [\"172.31.83.216\"],\"default\": true,\"dns\": {}},{\"name\": \"ipvlan1-busybox1\",\"interface\": \"net1\",\"ips\": [\"172.31.230.70\"],\"mac\": \"0a:2d:40:c6:f8:ea\",\"dns\": {}},{\"name\": \"ipvlan2-busybox1\",\"interface\": \"net2\",\"ips\": [\"172.31.232.70\"],\"mac\": \"0a:52:8a:62:5d:f4\",\"dns\": {}}]",
                "k8s.v1.cni.cncf.io/networks": "ipvlan1-busybox1, ipvlan2-busybox1",
                "k8s.v1.cni.cncf.io/networks-status": "[{\"name\": \"eps-cni\",\"ips\": [\"172.31.83.216\"],\"default\": true,\"dns\": {}},{\"name\": \"ipvlan1-busybox1\",\"interface\": \"net1\",\"ips\": [\"172.31.230.70\"],\"mac\": \"0a:2d:40:c6:f8:ea\",\"dns\": {}},{\"name\": \"ipvlan2-busybox1\",\"interface\": \"net2\",\"ips\": [\"172.31.232.70\"],\"mac\": \"0a:52:8a:62:5d:f4\",\"dns\": {}}]"
              }
            }
          }
        ],
        "output": [
          "0a:2d:40:c6:f8:ea",
          "0a:52:8a:62:5d:f4"
        ]
      }
    ],
    "identifier": 61989556
  },
  {
    "context": [
      "My Bash script has lots of variable assignments which are put in a JSON file:",
      "When validating the file `output.json` jq says:",
      "How can I make a valid JSON file out of it? Any `\\` and `\"` should be preserved.",
      "The correct JSON string would be",
      "Pass `$var` as a raw string argument and JQ will automatically convert it to a valid JSON string.",
      "$ jq -n --arg var \"$var\" '{$var}'"
    ],
    "utterance": "Create an object where a variable's value, including all backslashes and double quotes, is preserved as a valid string.",
    "expressions": [
      "jq -n --arg var \"$var\" '{var: $var}'"
    ],
    "data": [
      {
        "input": {
          "var": "Hello\n    \"world\". \n    This is \\anything \\or \\nothing\n"
        },
        "output": {
          "var": "Hello\n    \\\"world\\\". \n    This is \\\\anything \\\\or \\\\nothing\n"
        }
      }
    ],
    "identifier": 61564361
  },
  {
    "context": [
      "I am reading an array from a file",
      "why does jq read content print or echo content as space separated array for the below codeblock at the whitespace rather than the comma ',' as explicitly stated?",
      "This happens because IFS affects word splitting and not program output. Since there is no word splitting in the scope of your variable, it doesn't affect anything.",
      "If you instead define it in the scope that does word splitting, i.e. the scope in which the $(..) expansion happens:",
      "IFS=','",
      "var=( $(echo \"foo,bar\") )"
    ],
    "utterance": "Extract the content array as individual elements such that each array item, even with spaces, is preserved as a separate value.",
    "expressions": [
      ".content[]"
    ],
    "data": [
      {
        "input": {
          "content": [
            "string with spaces",
            "another string with spaces",
            "yet another string with spaces"
          ]
        },
        "output": [
          "string with spaces",
          "another string with spaces",
          "yet another string with spaces"
        ]
      }
    ],
    "identifier": 61787932
  },
  {
    "context": [
      "But when I tried to pass the shell variable to jq -n reduce range it throws error like below.",
      "START and END are not visible to JQ as they're shell variables. You need to pass them to JQ as arguments or environment variables.",
      "jq -n --argjson START 1 --argjson END 100 'reduce range($START; $END) as $data (.; . + [{\"field\": { \"empID\": $data, \"location\": \"India\"}}])' > test.json"
    ],
    "utterance": "Generate an array of objects with 'empID' ranging from START to END and 'location' set to 'India', using START and END values provided as shell variables.",
    "expressions": [
      "jq -n --argjson START 1 --argjson END 100 'reduce range($START; $END) as $data (.; . + [{\"field\": { \"empID\": $data, \"location\": \"India\"}}])'"
    ],
    "identifier": 61866465
  },
  {
    "context": [
      "I'd like to add an object for each line in `service-accounts-list.txt`, like so:",
      "jq -nR --argfile result result.json '\n  $result \n  | .access += [{role: \"WRITER\", userByEmail: inputs}] \n' service-accounts-list.txt",
      "jq -Rn \\\n   --slurpfile res result.json \\\n   '[ inputs | split(\"\\n\") | add ] as $data \n    | $res[] \n    | reduce $data[] as $d (.; .access += [{ role: \"WRITER\", userByEmail: $d  }] )' \\\nservice-accounts-list.txt"
    ],
    "utterance": "Append an object with role 'WRITER' and userByEmail set to each line from a service account list file to the access array of an existing data file.",
    "expressions": [
      "jq -nR --argfile result result.json '\n  $result \n  | .access += [{role: \"WRITER\", userByEmail: inputs}] \n' service-accounts-list.txt",
      "jq -Rn \\\n   --slurpfile res result.json \\\n   '[ inputs | split(\"\\n\") | add ] as $data \n    | $res[] \n    | reduce $data[] as $d (.; .access += [{ role: \"WRITER\", userByEmail: $d  }] )' \\\nservice-accounts-list.txt"
    ],
    "data": [
      {
        "input": {
          "service-accounts-list.txt": "serviceAccount:p12345-001@gcp-sa-logging.iam.gserviceaccount.com\nserviceAccount:p12345-002@gcp-sa-logging.iam.gserviceaccount.com\nserviceAccount:p12345-003@gcp-sa-logging.iam.gserviceaccount.com\nserviceAccount:p12345-004@gcp-sa-logging.iam.gserviceaccount.com\nserviceAccount:p12345-005@gcp-sa-logging.iam.gserviceaccount.com\n",
          "result.json": {
            "access": [
              {
                "role": "WRITER",
                "specialGroup": "projectWriters"
              },
              {
                "role": "OWNER",
                "specialGroup": "projectOwners"
              },
              {
                "role": "READER",
                "specialGroup": "projectReaders"
              }
            ]
          }
        },
        "output": {
          "access": [
            {
              "role": "WRITER",
              "specialGroup": "projectWriters"
            },
            {
              "role": "OWNER",
              "specialGroup": "projectOwners"
            },
            {
              "role": "READER",
              "specialGroup": "projectReaders"
            },
            {
              "role": "WRITER",
              "userByEmail": "serviceAccount:p12345-001@gcp-sa-logging.iam.gserviceaccount.com"
            },
            {
              "role": "WRITER",
              "userByEmail": "serviceAccount:p12345-002@gcp-sa-logging.iam.gserviceaccount.com"
            },
            {
              "role": "WRITER",
              "userByEmail": "serviceAccount:p12345-003@gcp-sa-logging.iam.gserviceaccount.com"
            },
            {
              "role": "WRITER",
              "userByEmail": "serviceAccount:p12345-004@gcp-sa-logging.iam.gserviceaccount.com"
            },
            {
              "role": "WRITER",
              "userByEmail": "serviceAccount:p12345-005@gcp-sa-logging.iam.gserviceaccount.com"
            }
          ]
        }
      }
    ],
    "identifier": 61737304
  },
  {
    "context": [
      "Attempt to parse with jq:\r\n\r\n./mumble.py.exp | jq \".\"\r\n\r\nparse error: Invalid numeric literal at line 1, column 8",
      "I\u2019d like to look at the last field in the Python and not have to try to work it through jq but I don\u2019t know how to do it."
    ],
    "utterance": "Extract the value of the 'last' field from each item in an array of objects.",
    "expressions": [
      ".[].last"
    ],
    "data": [
      {
        "input": [
          {
            "last": 313.14,
            "bidPrice": null,
            "quoteTimestamp": "2020-05-19T20:00:00+00:00",
            "mid": null,
            "open": 315.03,
            "timestamp": "2020-05-19T20:00:00+00:00",
            "tngoLast": 313.14,
            "lastSize": null,
            "askSize": null,
            "ticker": "AAPL",
            "askPrice": null,
            "low": 313.01,
            "volume": 25189979,
            "prevClose": 314.96,
            "bidSize": null,
            "lastSaleTimestamp": "2020-05-19T20:00:00+00:00",
            "high": 318.52
          }
        ],
        "output": [
          313.14
        ]
      }
    ],
    "identifier": 61903763
  },
  {
    "context": [
      "But how can I achieve the same result if I don't know the position of \"Category4\" (which could be at root level or nested deep inside other objects)?",
      "Use [`walk` builtin](https://stedolan.github.io/jq/manual/v1.6/?#walk(f)) for applying filters to values at arbitrary depths without changing the overall structure.",
      "walk(select(.Id? == 4) .Children += $a)"
    ],
    "utterance": "Add an object as a child of every object with Id equal to 4, regardless of its position in the nested structure.",
    "expressions": [
      "walk(select(.Id? == 4) .Children += $a)"
    ],
    "data": [
      {
        "input": {
          "categories": [
            {
              "Id": 1,
              "Name": "Category1",
              "Children": []
            },
            {
              "Id": 2,
              "Name": "Category2",
              "Children": [
                {
                  "Id": 4,
                  "Name": "Category4",
                  "Children": []
                }
              ]
            },
            {
              "Id": 3,
              "Name": "Category3",
              "Children": []
            }
          ]
        },
        "output": {
          "categories": [
            {
              "Id": 1,
              "Name": "Category1",
              "Children": []
            },
            {
              "Id": 2,
              "Name": "Category2",
              "Children": [
                {
                  "Id": 4,
                  "Name": "Category4",
                  "Children": [
                    {
                      "Id": 5,
                      "Name": "Category5",
                      "Children": []
                    }
                  ]
                }
              ]
            },
            {
              "Id": 3,
              "Name": "Category3",
              "Children": []
            }
          ]
        }
      }
    ],
    "identifier": 61996457
  },
  {
    "context": [
      "What I need is to remove all lines apart from \"id:\" and \"name:\" and preserve the JSON structure.",
      "With `jq`:\n\n    $ jq 'map({id: .id, name: .name})' input.json \n    [\n      {\n        \"id\": \"34234243224224\",\n        \"name\": \"asdasdaasd\"\n      }\n    ]"
    ],
    "utterance": "Remove all fields except id and name, keeping the array and object structure.",
    "expressions": [
      "map({id: .id, name: .name})"
    ],
    "data": [
      {
        "input": [
          {
            "api_key": "123123112313121321",
            "collaborators_count": 1,
            "created_at": "",
            "custom_event_fields_used": 0,
            "discarded_app_versions": [],
            "discarded_errors": [],
            "errors_url": "https://api.bugsnag.com/projects/1231231231312/errors",
            "events_url": "https://api.bugsnag.com/projects/1231231231213/events",
            "global_grouping": [],
            "html_url": "https://app.bugsnag.com/lol/kek/",
            "id": "34234243224224",
            "ignore_old_browsers": true,
            "ignored_browser_versions": {},
            "is_full_view": true,
            "language": "javascript",
            "location_grouping": [],
            "name": "asdasdaasd",
            "open_error_count": 3,
            "release_stages": [
              "production"
            ],
            "resolve_on_deploy": false,
            "slug": "wqeqweqwwqweq",
            "type": "js",
            "updated_at": "2020-04-06T15:22:10.480Z",
            "url": "https://api.bugsnag.com/projects/12312312213123",
            "url_whitelist": null
          }
        ],
        "output": [
          {
            "id": "34234243224224",
            "name": "asdasdaasd"
          }
        ]
      }
    ],
    "identifier": 61746910
  },
  {
    "context": [
      "I\u2019d like to remove any fields that match a regular expression, while preserving all other fields and the structure of the JSON.",
      "jq 'del(.. | .foo?, .foobar?, .foosball?)'",
      "but I would like to do this with a regular expression, something like",
      "jq 'del(.. | .(\"^foo\")?)'  # This does not work",
      "Here\u2019s a simple solution using `walk`:",
      "walk(if type==\"object\"\n     then with_entries(select(.key | test(\"^foo\") | not))\n     else . end)"
    ],
    "utterance": "Remove all fields where the key matches the regular expression '^foo', preserving all other fields and the structure including empty objects.",
    "expressions": [
      "walk(if type==\"object\" then with_entries(select(.key | test(\"^foo\") | not)) else . end)"
    ],
    "data": [
      {
        "input": {
          "this": {
            "foobar": {
              "that": "too"
            },
            "baz": 3,
            "foo": 1,
            "morefoo": {
              "foosball": "hi"
            }
          }
        },
        "output": {
          "this": {
            "baz": 3,
            "morefoo": {}
          }
        }
      }
    ],
    "identifier": 61859923
  },
  {
    "context": [
      "I am trying to get the json into newline delimited format so that I can upload the json file to Big Query.",
      "I have tried the following JQ code however it does not convert it into a format accepted by BiG Query.",
      "$ cat a.json | jq -c '.[]'",
      "I personally tried:",
      "cat <filename>.json | jq -c '.'",
      "and it works. Meaning, the end result is a valid newline delimited json."
    ],
    "utterance": "Produce a newline-delimited format where each line is the entire object from the original data, suitable for uploading.",
    "expressions": [
      ".",
      "-c '.'"
    ],
    "data": [
      {
        "input": {
          "annotation_results": [
            {
              "input_uri": "foo",
              "segment": {},
              "shot_annotations": []
            }
          ]
        },
        "output": "{\"annotation_results\":[{\"input_uri\":\"foo\",\"segment\":{},\"shot_annotations\":[]}]}"
      }
    ],
    "identifier": 61532208
  },
  {
    "context": [
      "I need to the output using jq to filter the name(.metadata.name) for those items in the list that have the state(.status[].state) as sleeping in below format\r\nName ID\r\nraj",
      "However I am unable to combine the name and generate the output.",
      "sleeping.jq is:\r\n```\r\n.a[]\r\n| .metadata.name as $raj\r\n| select( any(.status[].state; has(\"sleeping\")) )\r\n| \"Name ID \\($raj)\"\r\n```",
      "the result is:\r\n```\r\nName ID raj\r\nName ID tom\r\n```"
    ],
    "utterance": "List the name for each entry where any status state is sleeping.",
    "expressions": [
      ".a[] | .metadata.name as $raj | select(any(.status[].state; has(\"sleeping\"))) | \"Name ID \\($raj)\""
    ],
    "data": [
      {
        "input": {
          "a": [
            {
              "metadata": {
                "name": "raj"
              },
              "status": [
                {
                  "state": {
                    "sleeping": {
                      "started": "2020-05-11T14:49:04Z",
                      "ID": "1002"
                    }
                  }
                },
                {
                  "state": {
                    "sleeping": {
                      "started": "2020-05-11T14:49:04Z",
                      "ID": "1002"
                    }
                  }
                }
              ],
              "phase": "sleeping"
            },
            {
              "metadata": {
                "name": "tom"
              },
              "status": [
                {
                  "state": {
                    "sleeping": {
                      "started": "2020-05-11T14:49:04Z",
                      "ID": "1002"
                    }
                  }
                },
                {
                  "state": {
                    "sleeping": {
                      "started": "2020-05-11T14:49:04Z",
                      "ID": "1002"
                    }
                  }
                }
              ],
              "phase": "sleeping"
            }
          ]
        },
        "output": "Name ID raj\nName ID tom"
      }
    ],
    "identifier": 61746783
  },
  {
    "context": [
      "I want to use `jq` to return the `RuleArn` value if the following condition matches i.e. `.[].Conditions[].Values[]` has an element that matches `app.fantastic.com`",
      ".[] | select(.Conditions[].Values? | index(\"app.fantastic.com\")) | .RuleArn",
      ".[] | select(.Conditions[].Values[]? == \"app.fantastic.com\") | .RuleArn"
    ],
    "utterance": "Return the RuleArn values where any Conditions[].Values contains the string \"app.fantastic.com\".",
    "expressions": [
      ".[] | select(.Conditions[].Values? | index(\"app.fantastic.com\")) | .RuleArn",
      ".[] | select(.Conditions[].Values[]? == \"app.fantastic.com\") | .RuleArn"
    ],
    "data": [
      {
        "input": [
          {
            "Conditions": [
              {
                "Field": "http-header",
                "HttpHeaderConfig": {
                  "Values": [
                    "dark"
                  ],
                  "HttpHeaderName": "Environment"
                }
              },
              {
                "Values": [
                  "app.fantastic.com"
                ],
                "Field": "host-header",
                "HostHeaderConfig": {
                  "Values": [
                    "app.fantastic.com"
                  ]
                }
              }
            ],
            "IsDefault": false,
            "Priority": "3",
            "RuleArn": "iwantthisvalue"
          }
        ],
        "output": "iwantthisvalue"
      }
    ],
    "identifier": 61534283
  },
  {
    "context": [
      "My eventual goal is to save the artifact_id to a var using bash"
    ],
    "utterance": "Extract the value of artifact_id from the builds array when creating a base ami with packer",
    "expressions": [
      ".builds[0].artifact_id"
    ],
    "data": [
      {
        "input": {
          "builds": [
            {
              "name": "amazon-ebs",
              "builder_type": "amazon-ebs",
              "build_time": 1589466697,
              "files": null,
              "artifact_id": "eu-west-1:ami-04d3331ac647e751b",
              "packer_run_uuid": "add4c072-7ac2-f5e9-b941-6b80003c03ec",
              "custom_data": {
                "my_custom_data": "example"
              }
            }
          ],
          "last_run_uuid": "add4c072-7ac2-f5e9-b941-6b80003c03ec"
        },
        "output": "eu-west-1:ami-04d3331ac647e751b"
      }
    ],
    "identifier": 61910590
  },
  {
    "context": [
      "What I want in my new json file",
      "{\r\n\"node\":{\r\n\t\t\"Environment\": \"PRD\",\r\n\t\t\"Os\": \"linux\"\r\n\t},\r\n\"node2\":{\r\n\t\t\"Environment\": \"PRD\",\r\n\t\t\"Os\": \"linux\"\r\n\t},\r\n\"node3\":{\r\n\t\t\"Environment\": \"PRD\",\r\n\t\t\"Os\": \"linux\"\r\n\t},\r\n\"node4\":{\r\n\t\t\"Environment\": \"NPR\",\r\n\t\t\"Os\": \"linux\"\r\n\t},\t\r\n\"node5\":{\r\n\t\t\"Environment\": \"NPR\",\r\n\t\t\"Os\": \"linux\"\r\n\t}\r\n}\t\r\n\t\r\n",
      "A way of doing it:\r\n```\r\n.rows | map({(.automatic.fqdn): {Environment: .normal.environment, OS: .automatic.os}}) | add\r\n```\r\n<sup>[Online demo](https://jqplay.org/s/SVYH5-jLGN)</sup>"
    ],
    "utterance": "Create an object mapping each node's fqdn to an object with its environment and OS, as extracted from the data.",
    "expressions": [
      ".rows | map({(.automatic.fqdn): {Environment: .normal.environment, OS: .automatic.os}}) | add"
    ],
    "data": [
      {
        "input": {
          "rows": [
            {
              "automatic": {
                "fqdn": "node1",
                "os": "linux"
              },
              "normal": {
                "environment": "PRD"
              }
            },
            {
              "automatic": {
                "fqdn": "node2",
                "os": "linux"
              },
              "normal": {
                "environment": "PRD"
              }
            },
            {
              "automatic": {
                "fqdn": "node3",
                "os": "linux"
              },
              "normal": {
                "environment": "PRD"
              }
            },
            {
              "automatic": {
                "fqdn": "node4",
                "os": "linux"
              },
              "normal": {
                "environment": "NPR"
              }
            },
            {
              "automatic": {
                "fqdn": "node5",
                "os": "linux"
              },
              "normal": {
                "environment": "NPR"
              }
            }
          ]
        },
        "output": {
          "node1": {
            "Environment": "PRD",
            "OS": "linux"
          },
          "node2": {
            "Environment": "PRD",
            "OS": "linux"
          },
          "node3": {
            "Environment": "PRD",
            "OS": "linux"
          },
          "node4": {
            "Environment": "NPR",
            "OS": "linux"
          },
          "node5": {
            "Environment": "NPR",
            "OS": "linux"
          }
        }
      }
    ],
    "identifier": 61766505
  },
  {
    "context": [
      "I like to create a JSON dictionary like {\"stack-vpc-cidr\": \"172.31.0.0/16\"}.",
      "How can I turn them into lines of JSON dictionary using jq?",
      "but you can just do below by spelling out the explicit k/v names\n\n    { (.ExportName) : (.OutputValue) }",
      "Or you could modify your jq invocation to use a similar snippet along the lines of:\n\n    [ .Stacks[] .... \n     | { (.ExportName) : (.OutputValue) } ]\n    | add"
    ],
    "utterance": "Produce a single dictionary where each ExportName becomes a key and OutputValue becomes its value, filtering only outputs where ExportName is not null and StackName matches a specific value.",
    "expressions": [
      "[.Stacks[] | select(.StackName==\"mlai-metadata-development-backend\") | .Outputs[] | select(.ExportName != null) | { (.ExportName) : (.OutputValue) }] | add",
      "[.Stacks[] | select(.StackName==$stack) | .Outputs[] | select(.ExportName != null) | { (.ExportName): (.OutputValue) }] | add",
      "reduce inputs as $i (null; . + ($i|{ (.ExportName) : (.OutputValue) }))"
    ],
    "data": [
      {
        "input": [
          {
            "OutputKey": "outputvpcid",
            "OutputValue": "vpc-d4520cb1",
            "Description": "VPC ID of the Stack mlai-metadata-development-backend",
            "ExportName": "stack-vpc-id"
          },
          {
            "OutputKey": "outputvpccidr",
            "OutputValue": "172.31.0.0/16",
            "Description": "VPC CIDR of the Stack mlai-metadata-development-backend",
            "ExportName": "stack-vpc-cidr"
          }
        ],
        "output": {
          "stack-vpc-id": "vpc-d4520cb1",
          "stack-vpc-cidr": "172.31.0.0/16"
        }
      }
    ],
    "identifier": 61632324
  },
  {
    "context": [
      "I would like to reformat this json to *only* include 'blocks' that contain specific hex values.",
      "Can someone tell me how to remove all items not having those 2 hex identifiers but still keep the same json structure?",
      ".aircraft |= map(select(.hex | IN(\"44b5b4\", \"00901a\")))",
      "jq '.aircraft |= map(select(.hex == \"44b5b4\" or .hex == \"00901a\"))' json"
    ],
    "utterance": "Keep only aircraft entries where the hex value is exactly '44b5b4' or '00901a', preserving the original structure.",
    "expressions": [
      ".aircraft |= map(select(.hex | IN(\"44b5b4\", \"00901a\")))",
      ".aircraft |= map(select(.hex == \"44b5b4\" or .hex == \"00901a\"))"
    ],
    "data": [
      {
        "input": {
          "now": 1589987097.9,
          "aircraft": [
            {
              "mlat": [],
              "rssi": -26.2,
              "track": 319,
              "speed": 354,
              "messages": 16,
              "seen": 0.7,
              "altitude": 38000,
              "vert_rate": 0,
              "hex": "44b5b4",
              "tisb": []
            },
            {
              "squawk": "6220",
              "altitude": 675,
              "seen": 1.1,
              "messages": 7220,
              "tisb": [],
              "hex": "484a95",
              "mlat": [],
              "rssi": -22
            },
            {
              "hex": "484846",
              "tisb": [],
              "messages": 20,
              "speed": 89,
              "seen": 0.4,
              "squawk": "7000",
              "altitude": 500,
              "rssi": -23.7,
              "track": 185,
              "mlat": []
            },
            {
              "category": "B1",
              "mlat": [],
              "rssi": -24.3,
              "flight": "ZSGBX   ",
              "altitude": 3050,
              "squawk": "7000",
              "seen": 16.8,
              "messages": 37,
              "tisb": [],
              "hex": "00901a"
            }
          ],
          "messages": 35857757
        },
        "output": {
          "now": 1589987097.9,
          "aircraft": [
            {
              "mlat": [],
              "rssi": -26.2,
              "track": 319,
              "speed": 354,
              "messages": 16,
              "seen": 0.7,
              "altitude": 38000,
              "vert_rate": 0,
              "hex": "44b5b4",
              "tisb": []
            },
            {
              "category": "B1",
              "mlat": [],
              "rssi": -24.3,
              "flight": "ZSGBX   ",
              "altitude": 3050,
              "squawk": "7000",
              "seen": 16.8,
              "messages": 37,
              "tisb": [],
              "hex": "00901a"
            }
          ],
          "messages": 35857757
        }
      }
    ],
    "identifier": 61918080
  },
  {
    "context": [
      "How to use sed with jq to replace _ in key name with symbol a",
      "{ \"product_name\":\"kl\" }",
      "should become",
      "{ \"productaname\":\"kl\" }",
      "No need for `sed`; it's easy to do in just `jq`:",
      "$ jq '{ productaname: .product_name }' <<<'{ \"product_name\":\"kl\" }'",
      "{ \"productaname\":\"kl\" }",
      "If you want to replace underscores with a's in all keys of an object:",
      "$ jq 'with_entries(.key |= gsub(\"_\"); \"a\"))' <<<'{ \"product_name\":\"kl\", \"foo_bar\":12 }'",
      "{ \"productaname\":\"kl\",\"fooabar\":12}"
    ],
    "utterance": "Rename all object keys by replacing underscores with the letter a.",
    "expressions": [
      "with_entries(.key |= gsub(\"_\"; \"a\"))"
    ],
    "data": [
      {
        "input": {
          "product_name": "kl",
          "foo_bar": 12
        },
        "output": {
          "productaname": "kl",
          "fooabar": 12
        }
      }
    ],
    "identifier": 61974393
  },
  {
    "context": [
      "I would like to pull in these 4 sources, and output a file that has the following data linkeed by the property_expressions.json:",
      "- The \"name\" & \"property_type\" of the regex_property.json (renamed to regex_name or something similiar)",
      "- The \"name\" from log_sources.json and log_source_types.json (renamed to ls_name & lst_name, respectively)",
      "Such as below",
      "merged_example.json",
      "[ { \"identifier\": \"0311c65b-d5b5-483e-943f-b539543a8e95\", ... \"property_type\": \"numeric\", \"regex_name\": \"indexTotalSize\", \"lst_name\": \"SIM Audit\", \"ls_name\": \"SIM Audit-2 :: eng-qradar-aio-01\" } ]",
      "jq -n \\",
      " --argfile lst log_source_types.json \\",
      " --argfile ls  log_sources.json \\",
      " --argfile pe  property_expressions.json \\",
      " --argfile rp  regex_properties.json '",
      "  [ range(0, $pe|length) as $i",
      "    | {identifier: $pe[$i].identifier,",
      "       log_source_type_id: $lst[$i].id,",
      "       log_source_id: $pe[$i].log_source_id,",
      "       regex_property_identifier: $pe[$i].regex_property_identifier,",
      "       property_type: $rp[$i].property_type,",
      "       regex_name: $rp[$i].name,",
      "       lst_name: $lst[$i].name,",
      "       ls_name: $ls[$i].name",
      "     }",
      "  ]",
      "'"
    ],
    "utterance": "For each entry in property_expressions.json, produce an object containing its identifiers along with the property_type and name from regex_properties.json (as regex_name), the name from log_sources.json (as ls_name), and the name from log_source_types.json (as lst_name), linked by the respective IDs.",
    "expressions": [
      "jq -n \\\n --argfile lst log_source_types.json \\\n --argfile ls  log_sources.json \\\n --argfile pe  property_expressions.json \\\n --argfile rp  regex_properties.json '\n  [ range(0, $pe|length) as $i\n    | {identifier: $pe[$i].identifier,\n       log_source_type_id: $lst[$i].id,\n       log_source_id: $pe[$i].log_source_id,\n       regex_property_identifier: $pe[$i].regex_property_identifier,\n       property_type: $rp[$i].property_type,\n       regex_name: $rp[$i].name,\n       lst_name: $lst[$i].name,\n       ls_name: $ls[$i].name\n     }\n  ]\n'"
    ],
    "data": [
      {
        "input": {
          "regex_properties.json": [
            {
              "identifier": "59723052-d96c-4cef-ba7b-69d426602e04",
              "property_type": "numeric",
              "name": "indexTotalSize"
            }
          ],
          "log_sources.json": [
            {
              "id": 64,
              "name": "SIM Audit-2 :: eng-qradar-aio-01",
              "type_id": 105,
              "last_event_time": 1588628234930
            }
          ],
          "log_source_types.json": [
            {
              "name": "SIM Audit",
              "id": 105
            }
          ],
          "property_expressions.json": [
            {
              "identifier": "0311c65b-d5b5-483e-943f-b539543a8e95",
              "log_source_type_id": 105,
              "log_source_id": 65,
              "regex_property_identifier": "59723052-d96c-4cef-ba7b-69d426602e04"
            }
          ]
        },
        "output": [
          {
            "identifier": "0311c65b-d5b5-483e-943f-b539543a8e95",
            "log_source_type_id": 105,
            "log_source_id": 65,
            "regex_property_identifier": "59723052-d96c-4cef-ba7b-69d426602e04",
            "property_type": "numeric",
            "regex_name": "indexTotalSize",
            "lst_name": "SIM Audit",
            "ls_name": "SIM Audit-2 :: eng-qradar-aio-01"
          }
        ]
      }
    ],
    "identifier": 61614422
  },
  {
    "context": [
      "I need to change the contents of the \"display\" field to use underscores instead of spaces, so the result is like this (note underscores in Billing_Date and Billing_Accounting_Date):",
      ".mappings.properties[].meta.display |= gsub(\" \"; \"_\")",
      "walk(if type == \"object\" and has(\"display\") then .display |= gsub(\" \"; \"_\") else . end)"
    ],
    "utterance": "Replace all spaces with underscores in every 'display' field nested under any object in the input data.",
    "expressions": [
      ".mappings.properties[].meta.display |= gsub(\" \"; \"_\")",
      "walk(if type == \"object\" and has(\"display\") then .display |= gsub(\" \"; \"_\") else . end)"
    ],
    "data": [
      {
        "input": {
          "mappings": {
            "properties": {
              "billing_date": {
                "type": "date",
                "meta": {
                  "display": "Billing Date",
                  "format": ":%x"
                }
              },
              "billing_accounting_date": {
                "type": "date",
                "meta": {
                  "display": "Billing Accounting Date",
                  "format": ":%x"
                }
              }
            }
          }
        },
        "output": {
          "mappings": {
            "properties": {
              "billing_date": {
                "type": "date",
                "meta": {
                  "display": "Billing_Date",
                  "format": ":%x"
                }
              },
              "billing_accounting_date": {
                "type": "date",
                "meta": {
                  "display": "Billing_Accounting_Date",
                  "format": ":%x"
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 61526906
  },
  {
    "context": [
      "I have a JSON of nested array that I would like to filter and then sum the `size` field values for all partitions of a particular topic/prefix. So, for topicA, I want to add the 70, 45 and 100 for topicA-0, topicA-1, topicA-2 sizes to get 215.",
      "Select partitions whose name start with `topicA-`, populate an array with their sizes and feed it to `add`.",
      "[.brokers[].logDirs[].partitions[] | select(.partition|startswith(\"topicA-\")) .size] | add"
    ],
    "utterance": "Sum the size field for all partitions whose partition name starts with topicA-.",
    "expressions": [
      "[.brokers[].logDirs[].partitions[] | select(.partition|startswith(\"topicA-\")) .size] | add"
    ],
    "data": [
      {
        "input": {
          "version": 1,
          "brokers": [
            {
              "broker": 1,
              "logDirs": [
                {
                  "logDir": "/var/lib/kafka/data",
                  "error": null,
                  "partitions": [
                    {
                      "partition": "topicA-0",
                      "size": 70,
                      "offsetLag": 0,
                      "isFuture": false
                    },
                    {
                      "partition": "topicB-0",
                      "size": 40,
                      "offsetLag": 0,
                      "isFuture": false
                    },
                    {
                      "partition": "topicC-0",
                      "size": 20,
                      "offsetLag": 0,
                      "isFuture": false
                    },
                    {
                      "partition": "topicD-0",
                      "size": 30,
                      "offsetLag": 0,
                      "isFuture": false
                    }
                  ]
                }
              ]
            },
            {
              "broker": 2,
              "logDirs": [
                {
                  "logDir": "/var/lib/kafka/data",
                  "error": null,
                  "partitions": [
                    {
                      "partition": "topicA-1",
                      "size": 45,
                      "offsetLag": 0,
                      "isFuture": false
                    },
                    {
                      "partition": "topicB-1",
                      "size": 50,
                      "offsetLag": 0,
                      "isFuture": false
                    },
                    {
                      "partition": "topicC-1",
                      "size": 10,
                      "offsetLag": 0,
                      "isFuture": false
                    },
                    {
                      "partition": "topicD-1",
                      "size": 20,
                      "offsetLag": 0,
                      "isFuture": false
                    }
                  ]
                }
              ]
            },
            {
              "broker": 3,
              "logDirs": [
                {
                  "logDir": "/var/lib/kafka/data",
                  "error": null,
                  "partitions": [
                    {
                      "partition": "topicA-2",
                      "size": 100,
                      "offsetLag": 0,
                      "isFuture": false
                    },
                    {
                      "partition": "topicB-2",
                      "size": 60,
                      "offsetLag": 0,
                      "isFuture": false
                    },
                    {
                      "partition": "topicC-2",
                      "size": 80,
                      "offsetLag": 0,
                      "isFuture": false
                    },
                    {
                      "partition": "topicD-2",
                      "size": 5,
                      "offsetLag": 0,
                      "isFuture": false
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": 215
      }
    ],
    "identifier": 61803107
  },
  {
    "context": [
      "data | jq '[0].eq == .[1].eq'",
      "data | jq -e '[0].eq == .[1].eq' > /dev/null",
      "true",
      "false"
    ],
    "utterance": "Compare whether the 'eq' fields of the first and second objects in an array are equal, even if they include dollar signs and special characters.",
    "expressions": [
      ".[0].eq == .[1].eq"
    ],
    "data": [
      {
        "input": [
          {
            "eq": "$a=b^2"
          },
          {
            "eq": "$a=b**2"
          }
        ],
        "output": false
      }
    ],
    "identifier": 61935595
  },
  {
    "context": [
      "I have a JSON File with - from what I understand - , objects listed:",
      "{\r\n  \"pc\": {\r\n    \"1.15.2\": {\r\n      \"protocol\": \"pc/1.15.2\",\r\n      \"version\": \"pc/1.15.2\",\r\n      \"language\": \"pc/1.15.2\"\r\n    }\r\n  }\r\n}",
      "I want it to look like this:",
      "{\r\n  \"pc\": {\r\n    \"1.15.2\": {\r\n      \"protocol\": \"pc/1.15.2\",\r\n      \"version\": \"pc/1.15.2\",\r\n      \"language\": \"pc/1.15.2\",\r\n      \"biomes\": \"pc/1.15.2\",\r\n      \"blocks\": \"pc/1.15.2\",\r\n      \"entities\": \"pc/1.15.2\",\r\n      \"items\": \"pc/1.15.2\",\r\n      \"recipes\": \"pc/1.15.2\"\r\n    }\r\n  }\r\n}",
      "However, on the above command I get:\r\n\r\n    jq: error (at <stdin>:501): Cannot index array with string \"pc\"",
      "Your idea is right, but you don't need the `--slurp` mode/`-s`, which puts the whole JSON within an array. Dropping it should work as expected",
      "jq --argjson data \\\r\n   '{\"biomes\": \"pc/1.15.2\",\"blocks\": \"pc/1.15.2\",\"entities\": \"pc/1.15.2\",\"items\": \"pc/1.15.2\",\"recipes\": \"pc/1.15.2\"}' \\\r\n      '.pc |= with_entries(select(.key==\"1.15.2\").value += $data)' json"
    ],
    "utterance": "Add the keys biomes, blocks, entities, items, and recipes with value \"pc/1.15.2\" under the object at pc[\"1.15.2\"].",
    "expressions": [
      "jq --argjson data '{\"biomes\": \"pc/1.15.2\",\"blocks\": \"pc/1.15.2\",\"entities\": \"pc/1.15.2\",\"items\": \"pc/1.15.2\",\"recipes\": \"pc/1.15.2\"}' '.pc |= with_entries(select(.key==\"1.15.2\").value += $data)'"
    ],
    "data": [
      {
        "input": {
          "pc": {
            "1.15.2": {
              "protocol": "pc/1.15.2",
              "version": "pc/1.15.2",
              "language": "pc/1.15.2"
            }
          }
        },
        "output": {
          "pc": {
            "1.15.2": {
              "protocol": "pc/1.15.2",
              "version": "pc/1.15.2",
              "language": "pc/1.15.2",
              "biomes": "pc/1.15.2",
              "blocks": "pc/1.15.2",
              "entities": "pc/1.15.2",
              "items": "pc/1.15.2",
              "recipes": "pc/1.15.2"
            }
          }
        }
      }
    ],
    "identifier": 61650539
  },
  {
    "context": [
      "I need to print a json file in bash in a way that each element of the file fits in one line.",
      "There are a couple of elements with many caracters and when I print it they take several lines.",
      "I would like find a way that bash prints the begining + $. Dollar sign means there is aditional text not being displayed.",
      "jq . your.json | ./trim.sh 25",
      "The argument value of 25 is desired length."
    ],
    "utterance": "Print each element so that if its length exceeds a given number of characters, it is truncated and appended with a dollar sign.",
    "expressions": [
      "jq . your.json | while read -r LINE; do [[ ${#LINE} -ge 25 ]] && echo \"${LINE:0:25}$\" || echo \"$LINE\"; done"
    ],
    "identifier": 61638971
  },
  {
    "context": [
      "I am trying to convert the \"id\" field to a number using jq's \"tonumber\" function.",
      "Here is my jq filter I am working with to no avail...",
      "It converts the field to a number; but yields the following undesired result (the repetition of the record many times.)",
      "Desired result:",
      "This yields your expected output:",
      ".[].fields[].id |= tonumber",
      "`|=` takes the paths `.[].fields[].id` expands to and applies `tonumber` to their values."
    ],
    "utterance": "Convert all values of the 'id' field in each object of the 'fields' array to a number, leaving the rest of the object unchanged.",
    "expressions": [
      ".[].fields[].id |= tonumber"
    ],
    "data": [
      {
        "input": [
          {
            "orgid": "1",
            "email": "janedoe@aol.com",
            "first_name": "Jane",
            "last_name": "Doe",
            "phone": "4045551212",
            "tags": [
              "tag1",
              "tag2"
            ],
            "fields": [
              {
                "id": "2",
                "value": "IB4220"
              },
              {
                "id": "3",
                "value": "1994-05-18"
              },
              {
                "id": "12",
                "value": "CONSULTANT"
              },
              {
                "id": "13",
                "value": "janedoe@aol.com"
              },
              {
                "id": "6",
                "value": "111 Main Blvd"
              },
              {
                "id": "7",
                "value": "Babylon"
              },
              {
                "id": "8",
                "value": "NY"
              },
              {
                "id": "9",
                "value": "11702-1522"
              },
              {
                "id": "10",
                "value": "US"
              },
              {
                "id": "11",
                "value": ""
              },
              {
                "id": "5",
                "value": "http://www.something.com/janedoe"
              }
            ]
          }
        ],
        "output": [
          {
            "orgid": "1",
            "email": "janedoe@aol.com",
            "first_name": "Jane",
            "last_name": "Doe",
            "phone": "4045551212",
            "tags": [
              "tag1",
              "tag2"
            ],
            "fields": [
              {
                "id": 2,
                "value": "IB4220"
              },
              {
                "id": 3,
                "value": "1994-05-18"
              },
              {
                "id": 12,
                "value": "CONSULTANT"
              },
              {
                "id": 13,
                "value": "janedoe@aol.com"
              },
              {
                "id": 6,
                "value": "111 Main Blvd"
              },
              {
                "id": 7,
                "value": "Babylon"
              },
              {
                "id": 8,
                "value": "NY"
              },
              {
                "id": 9,
                "value": "11702-1522"
              },
              {
                "id": 10,
                "value": "US"
              },
              {
                "id": 11,
                "value": ""
              },
              {
                "id": 5,
                "value": "http://www.something.com/janedoe"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 61904789
  },
  {
    "context": [
      "Each item contains field ```a``` and ```b```. I&#39;d love to get a list of values of field ```a``` such that field ```a```&#39;s value starts with field ```b```&#39;s value.",
      "For your given input data, put in an array, you could use `startswith()` function as below.",
      "jq '.[] | .b as $data | select(.a | startswith($data) ).a'"
    ],
    "utterance": "Return all values of field a where the value of a starts with the value of field b in each item.",
    "expressions": [
      ".[] | .b as $data | select(.a | startswith($data)).a"
    ],
    "data": [
      {
        "input": [
          {
            "a": "1234",
            "b": "123"
          },
          {
            "a": "1234",
            "b": "12"
          },
          {
            "a": "foo",
            "b": "bar"
          }
        ],
        "output": [
          "1234",
          "1234"
        ]
      }
    ],
    "identifier": 61906141
  },
  {
    "context": [
      "I can successfully extract the ranges I care about with this, `[.prefixes[] | select(.region == \"us-west-2\") | .ip_prefix] | sort | unique`, and it gives me this:",
      "I can't figure out how to convert this to an arbitrarily-keyed object with jq. In order to properly use the array object, I need to convert it to a dictionary, something like `{ \"arbitrary-key\": \"100.20.0.0/14\" }`.",
      "The following script uses the .ip_prefix as the key, thus perhaps avoiding the need for the `sort|unique`.  It yields:\n{\n  \"35.180.0.0/16\": \"35.180.0.0/16\",\n  \"52.94.76.0/22\": \"52.94.76.0/22\"\n}",
      "data | jq '\n  .prefixes \n  | map(select(.region | test(\"west\"))\n        | {(.ip_prefix): .ip_prefix} )\n  | add '"
    ],
    "utterance": "Convert all id_prefix values for regions containing 'west' into an object where each key is the id_prefix and the value is the same id_prefix.",
    "expressions": [
      ".prefixes | map(select(.region | test(\"west\")) | {(.ip_prefix): .ip_prefix}) | add"
    ],
    "data": [
      {
        "input": {
          "syncToken": "1589917992",
          "createDate": "2020-05-19-19-53-12",
          "prefixes": [
            {
              "ip_prefix": "35.180.0.0/16",
              "region": "eu-west-3",
              "service": "AMAZON",
              "network_border_group": "eu-west-3"
            },
            {
              "ip_prefix": "52.94.76.0/22",
              "region": "us-west-2",
              "service": "AMAZON",
              "network_border_group": "us-west-2"
            }
          ]
        },
        "output": {
          "35.180.0.0/16": "35.180.0.0/16",
          "52.94.76.0/22": "52.94.76.0/22"
        }
      }
    ],
    "identifier": 61940049
  },
  {
    "context": [
      "i have a json file representing a table with two columns.",
      "the Column values are in an array",
      "`{ 'columnA':[1,2,3], 'columnB':[6,7,8] }`",
      "i need to convert it to an array of rows:",
      "`[ {'columnA':1, 'columnB':6}, {'columnA':2, 'columnB':7}, {'columnA':3, 'columnB':8}, ]`",
      "Here is one solution:",
      "[range(0; .columnA|length) as $i | {columnA: .columnA[$i], columnB: .columnB[$i]}]",
      "Use `transpose` builtin:",
      "[ [{columnA: .columnA[]}], [{columnB: .columnB[]}] ] | transpose | map(add)",
      "[.columnA,.columnB] | transpose | map({\"columnA\":.[0], \"columnB\": .[1]})"
    ],
    "utterance": "Transform an object with column-named arrays into an array where each element is a row object pairing corresponding values from each column.",
    "expressions": [
      "[range(0; .columnA|length) as $i | {columnA: .columnA[$i], columnB: .columnB[$i]}]",
      "[[{columnA: .columnA[]}], [{columnB: .columnB[]}]] | transpose | map(add)",
      "[.columnA, .columnB] | transpose | map({\"columnA\": .[0], \"columnB\": .[1]})"
    ],
    "data": [
      {
        "input": {
          "columnA": [
            1,
            2,
            3
          ],
          "columnB": [
            6,
            7,
            8
          ]
        },
        "output": [
          {
            "columnA": 1,
            "columnB": 6
          },
          {
            "columnA": 2,
            "columnB": 7
          },
          {
            "columnA": 3,
            "columnB": 8
          }
        ]
      }
    ],
    "identifier": 61791902
  },
  {
    "context": [
      "I want to list the keys of a nested object of my document.",
      "For example, I want the keys in the `a` object: `a1`, `a2`",
      "The sample document:",
      "{\n    \"a\": {\n        \"a1\": \"hello\",\n        \"a2\": \"world\"\n    },\n\n    \"b\": {\n        \"b1\": \"bonjour\",\n        \"b2\": \"monde\"\n    }\n}",
      "I know I can use `keys`, but it seems to work only for the first level object: `cat my.json | jq keys` will output `a, b`.",
      "So far I chain two calls with `jq` but I wonder if we can do it in one call ?",
      "`cat my.json | jq .a | jq keys` --> `a1, a2`",
      "Ok I&#39;ve just find out in a single call :",
      "cat my.json | jq '.a|keys' \n    a1, a2",
      "Or even as @Inian suggested without the `cat`",
      "jq '.a|keys' my.json \n    a1, a2"
    ],
    "utterance": "List all the keys of the object at property 'a' in the document.",
    "expressions": [
      ".a | keys"
    ],
    "data": [
      {
        "input": {
          "a": {
            "a1": "hello",
            "a2": "world"
          },
          "b": {
            "b1": "bonjour",
            "b2": "monde"
          }
        },
        "output": [
          "a1",
          "a2"
        ]
      }
    ],
    "identifier": 61934978
  },
  {
    "context": [
      "I want to change the ancestorId field for the packageDirectory objects where default is true. In that case oldValue in the example should become newValue.",
      "You'd use an if-then-else expression for it, not select.",
      ".packageDirectories |= map(\n  if .default == true\n  then .ancestorId = \"newValue\"\n  else . end\n)",
      "FYPI, there is a way to achieve the goal using `select`:",
      ".packageDirectories[] |=\n  ((select(.default == true) | .ancestorId = \"newValue\") // . )"
    ],
    "utterance": "Change the ancestorId field to \"newValue\" for objects in packageDirectories where default is true.",
    "expressions": [
      ".packageDirectories |= map(if .default == true then .ancestorId = \"newValue\" else . end)",
      ".packageDirectories[] |= ((select(.default == true) | .ancestorId = \"newValue\") // . )"
    ],
    "data": [
      {
        "input": {
          "packageDirectories": [
            {
              "path": "sfdx-source/unpackaged"
            },
            {
              "path": "sfdx-source/untracked"
            },
            {
              "path": "sfdx-source/zipsc",
              "package": "ZipSC",
              "versionName": "Version 0.1",
              "versionNumber": "0.1.0.NEXT",
              "ancestorId": "oldValue",
              "default": true
            },
            {
              "path": "sfdx-source/unpackaged/open-cti",
              "package": "OpenCTI",
              "versionName": "Ver 0.3",
              "versionNumber": "0.3.0.NEXT",
              "ancestorId": "04t1P000000cB425QAE",
              "default": false
            }
          ],
          "sfdcLoginUrl": "https://login.salesforce.com",
          "sourceApiVersion": "47.0",
          "namespace": "ZAR",
          "packageAliases": {
            "ZAR": "0Ho1P000000XZA4SAO",
            "OpenCTI": "0Ho1P000000X3AvSAO"
          }
        },
        "output": {
          "packageDirectories": [
            {
              "path": "sfdx-source/unpackaged"
            },
            {
              "path": "sfdx-source/untracked"
            },
            {
              "path": "sfdx-source/zipsc",
              "package": "ZipSC",
              "versionName": "Version 0.1",
              "versionNumber": "0.1.0.NEXT",
              "ancestorId": "newValue",
              "default": true
            },
            {
              "path": "sfdx-source/unpackaged/open-cti",
              "package": "OpenCTI",
              "versionName": "Ver 0.3",
              "versionNumber": "0.3.0.NEXT",
              "ancestorId": "04t1P000000cB425QAE",
              "default": false
            }
          ],
          "sfdcLoginUrl": "https://login.salesforce.com",
          "sourceApiVersion": "47.0",
          "namespace": "ZAR",
          "packageAliases": {
            "ZAR": "0Ho1P000000XZA4SAO",
            "OpenCTI": "0Ho1P000000X3AvSAO"
          }
        }
      }
    ],
    "identifier": 61561413
  },
  {
    "context": [
      "I am trying to convert below output into a valid json output.",
      "**output**\n```\nsvc pts/0        localhost. Tue Apr 28 21:40   still logged in   \nsvc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)    \nsvc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)\n...etc\n```",
      "**valid json output**\n```\n{\n\t\"Result\": [{\n\t\t\"models\": [\"svc pts 0 localhost.Tue Apr 28 21: 40 still logged in\",\n\t\t\t\"svc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)\"\n\t\t]\n\t}]\n}\n```",
      "You can use [tag:jq] like:\n```\nprogram | jq -Rn '{Result:[{models:[inputs]}]}'\n```"
    ],
    "utterance": "Wrap each input line as a string in an array called models inside a Result array within an object.",
    "expressions": [
      "{Result:[{models:[inputs]}]}"
    ],
    "data": [
      {
        "input": "svc pts/0        localhost. Tue Apr 28 21:40   still logged in   \nsvc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)\nsvc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)",
        "output": {
          "Result": [
            {
              "models": [
                "svc pts/0        localhost. Tue Apr 28 21:40   still logged in   ",
                "svc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)",
                "svc pts/0        localhost. Tue Apr 28 21:40 - 21:40  (00:00)"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 61629999
  },
  {
    "context": [
      "I get back a JSON array as follows:  \r\n```[{\"name\":\"id\",\"type\":\"int\",\"doc\":\"Documentation for the id field.\"},{\"name\":\"test_string\",\"type\":\"string\",\"doc\":\"Documentation for the test_string field\"}]```",
      "My goal is to do a call with jq applied to return the following (given the example above):  \r\n```{\"id\":1234567890,\"test_string\":\"xxxxxxxxxx\"}```",
      "doc fields are ignored",
      "the values for \"name\" ... are concatenated with either:\r\n   * :1234567890   ...when the \"type\" for that object is \"int\"\r\n   * \":xxxxxxxxxx\"   ...when the \"type\" for that object is \"string\"",
      "jq -c 'map({(.name): (if .type == \"int\" then 1234567890 else \"xxxxxxxxxx\" end)})|add'"
    ],
    "utterance": "Create an object with each field's name as key, assigning 1234567890 if the type is int or \"xxxxxxxxxx\" if the type is string, ignoring the doc field.",
    "expressions": [
      "map({(.name): (if .type == \"int\" then 1234567890 else \"xxxxxxxxxx\" end)}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "id",
            "type": "int",
            "doc": "Documentation for the id field."
          },
          {
            "name": "test_string",
            "type": "string",
            "doc": "Documentation for the test_string field"
          }
        ],
        "output": {
          "id": 1234567890,
          "test_string": "xxxxxxxxxx"
        }
      }
    ],
    "identifier": 61964573
  },
  {
    "context": [
      "I have the following list of files:\n\n```\n/tmp/jboss/ejb-jar_3_2.xsd\n/tmp/jboss/example.crt\n/tmp/jboss/example.key\n/tmp/jboss/incomingrunasidentityloginmodule.zip\n/tmp/jboss/jboss-eap-7.0.0.zip\n/tmp/jboss/jboss-eap-7.0.8-patch.zip\n/tmp/jboss/keystore.jks\n/tmp/jboss/logger-api.sh\n/tmp/jboss/mgmt-api-example.txt\n/tmp/jboss/wildfly-dist-10.1.0.Final.zip\n/tmp/jboss/wildfly-dist-7.1.0.GA-redhat-8.jar\n```\n\nthat I would like to convert to the following JSON structure, where the dirname is the final path in the directory structure.\n```\n[ \n  { dirname: \"jboss\", filename: \"/tmp/jboss/ejb-jar_3_2.xsd\" },\n  { dirname: \"jboss\", filename: \"/tmp/jboss/example.crt\" },\n...\n...\n]\n```",
      "cat /tmp/files.txt | jq --raw-input '. |  { dirname: .match(regex).capture[0], filename: .}'",
      "jq -nR '\n      [inputs | capture(\".*/(?<dirname>[^/]*)/[^/]+$\") + { filname: .}]'"
    ],
    "utterance": "Convert a list of file paths to an array of objects, each containing the last directory in the path as dirname and the full file path as filename.",
    "expressions": [
      "jq -nR '[inputs | capture(\".*/(?<dirname>[^/]*)/[^/]+$\") + { filename: .}]'"
    ],
    "data": [
      {
        "input": [
          "/tmp/jboss/ejb-jar_3_2.xsd",
          "/tmp/jboss/example.crt",
          "/tmp/jboss/example.key",
          "/tmp/jboss/incomingrunasidentityloginmodule.zip",
          "/tmp/jboss/jboss-eap-7.0.0.zip",
          "/tmp/jboss/jboss-eap-7.0.8-patch.zip",
          "/tmp/jboss/keystore.jks",
          "/tmp/jboss/logger-api.sh",
          "/tmp/jboss/mgmt-api-example.txt",
          "/tmp/jboss/wildfly-dist-10.1.0.Final.zip",
          "/tmp/jboss/wildfly-dist-7.1.0.GA-redhat-8.jar"
        ],
        "output": [
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/ejb-jar_3_2.xsd"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/example.crt"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/example.key"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/incomingrunasidentityloginmodule.zip"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/jboss-eap-7.0.0.zip"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/jboss-eap-7.0.8-patch.zip"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/keystore.jks"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/logger-api.sh"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/mgmt-api-example.txt"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/wildfly-dist-10.1.0.Final.zip"
          },
          {
            "dirname": "jboss",
            "filename": "/tmp/jboss/wildfly-dist-7.1.0.GA-redhat-8.jar"
          }
        ]
      }
    ],
    "identifier": 61964866
  },
  {
    "context": [
      "I need to add pupils grouped by Level and Genre.",
      "And I need to convert to csv like:\r\n\r\n    One, Boys, 9\r\n    One, Girls, 13\r\n    Two, Boys, 3\r\n    Two, Girls, 0",
      "You just need to group by `Genre` after `Level`.",
      "  group_by(.Level)[]\r\n| group_by(.Genre)[]\r\n| [.[0].Level, .[0].Genre, (map(.pupils) | add)]\r\n| @csv"
    ],
    "utterance": "Group entries by Level and Genre, summing the pupils for each group, and output the results as CSV rows with Level, Genre, and the summed pupils.",
    "expressions": [
      "group_by(.Level)[] | group_by(.Genre)[] | [.[0].Level, .[0].Genre, (map(.pupils) | add)] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Maths",
            "Level": "One",
            "Genre": "Boys",
            "pupils": 5
          },
          {
            "name": "English",
            "Level": "Two",
            "Genre": "Boys",
            "pupils": 3
          },
          {
            "name": "Maths",
            "Level": "One",
            "Genre": "Girls",
            "pupils": 7
          },
          {
            "name": "English",
            "Level": "One",
            "Genre": "Girls",
            "pupils": 6
          },
          {
            "name": "Social",
            "Level": "One",
            "Genre": "Boys",
            "pupils": 4
          },
          {
            "name": "Social",
            "Level": "Two",
            "Genre": "Girls",
            "pupils": 0
          }
        ],
        "output": [
          "\"One\",\"Boys\",9",
          "\"One\",\"Girls\",13",
          "\"Two\",\"Boys\",3",
          "\"Two\",\"Girls\",0"
        ]
      }
    ],
    "identifier": 61969556
  },
  {
    "context": [
      "I want to turn \n{\n  \"filename\": \"./readme.md\",\n  \"line\": 5,\n  \"rule\": \"MD009\",\n  \"aliases\": [\n    \"no-trailing-spaces\"\n  ],\n  \"description\": \"Trailing spaces\"\n}\n{\n  \"filename\": \"./readme.md\",\n  \"line\": 6,\n  \"rule\": \"MD009\",\n  \"aliases\": [\n    \"no-trailing-spaces\"\n  ],\n  \"description\": \"Trailing spaces\"\n}\ninto \n{\"filename\": \"./readme.md\",\"line\": 5,\"rule\": \"MD009\",\"aliases\": [\"no-trailing-spaces\"],\"description\":\"Trailing spaces\"}\n{\"filename\": \"./readme.md\",\"line\": 6,\"rule\": \"MD009\",\"aliases\": [\"no-trailing-spaces\"],\"description\":\"Trailing spaces\"}\nBasically each { } is on its own line",
      "As always when it comes to working with JSON in scripts and from the command line, `jq` to the rescue:\n\n    $ jq -c . input.json"
    ],
    "utterance": "Print each object in compact form on its own line, preserving one object per line.",
    "expressions": [
      "jq -c ."
    ],
    "data": [
      {
        "input": "{\n  \"filename\": \"./readme.md\",\n  \"line\": 5,\n  \"rule\": \"MD009\",\n  \"aliases\": [\n    \"no-trailing-spaces\"\n  ],\n  \"description\": \"Trailing spaces\"\n}\n{\n  \"filename\": \"./readme.md\",\n  \"line\": 6,\n  \"rule\": \"MD009\",\n  \"aliases\": [\n    \"no-trailing-spaces\"\n  ],\n  \"description\": \"Trailing spaces\"\n}",
        "output": "{ \"filename\": \"./readme.md\", \"line\": 5, \"rule\": \"MD009\", \"aliases\": [\"no-trailing-spaces\"], \"description\": \"Trailing spaces\" }\n{ \"filename\": \"./readme.md\", \"line\": 6, \"rule\": \"MD009\", \"aliases\": [\"no-trailing-spaces\"], \"description\": \"Trailing spaces\" }"
      }
    ],
    "identifier": 62055014
  },
  {
    "context": [
      "Example input:\r\n```\r\n{\r\n  \"firstName\": \"Jam\",\r\n  \"Product\": [\r\n    {\r\n      \"productId\": \"5e09ad38986b7c30f339c5c0\"\r\n    },\r\n    {\r\n      \"productId\": \"5e09407b986b7c30f339c18e\"\r\n    },\r\n    {\r\n      \"productId\": \"5e094c2a986b7c30f339c1d2\"\r\n    }\r\n  ]\r\n}\r\n```",
      "Expected output:\r\n```\r\nJam,5e09ad38986b7c30f339c5c0\r\nJam,5e09407b986b7c30f339c18e\r\nJam,5e094c2a986b7c30f339c1d2\r\n```",
      "To generate a report in CSV format you need to put column values into an array and pass it to `@csv` filter.",
      "`jq -r '[.firstName] + (.Product[] | [.productId]) | @csv' file`"
    ],
    "utterance": "Produce a report where each line combines the top-level firstName field with every productId from each element in the Product array as CSV.",
    "expressions": [
      "[.firstName] + (.Product[] | [.productId]) | @csv"
    ],
    "data": [
      {
        "input": {
          "firstName": "Jam",
          "Product": [
            {
              "productId": "5e09ad38986b7c30f339c5c0"
            },
            {
              "productId": "5e09407b986b7c30f339c18e"
            },
            {
              "productId": "5e094c2a986b7c30f339c1d2"
            }
          ]
        },
        "output": [
          "\"Jam\",\"5e09ad38986b7c30f339c5c0\"",
          "\"Jam\",\"5e09407b986b7c30f339c18e\"",
          "\"Jam\",\"5e094c2a986b7c30f339c1d2\""
        ]
      }
    ],
    "identifier": 61972797
  },
  {
    "context": [
      "I need group by name and sum the cash and send the result a .csv like:\r\n\r\n    John,13\r\n    Anna,7",
      "JQ has `group_by` as a builtin, use that and do `map(.cash) | add` to sum `cash` values for each group.",
      "group_by(.name)[] | [.[0].name, (map(.cash) | add)] | @csv"
    ],
    "utterance": "Group objects by the 'name' field and sum the 'cash' values for each name, producing a CSV report where each row contains a name and its total cash.",
    "expressions": [
      "group_by(.name)[] | [.[0].name, (map(.cash) | add)] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "John",
            "cash": 5
          },
          {
            "name": "Anna",
            "cash": 4
          },
          {
            "name": "Anna",
            "cash": 3
          },
          {
            "name": "John",
            "cash": 8
          }
        ],
        "output": [
          "\"Anna\",7",
          "\"John\",13"
        ]
      }
    ],
    "identifier": 61953604
  },
  {
    "context": [
      "So I need get a 3rd json file out of these, which has \"type\", \"arcs\", \"id\", and \"PRICE\" (the addition).",
      "jq 'add as $prices | input\n| .objects.us_counties_20m.geometries[] |= . + {PRICE: $prices[.id]}' file2 file1",
      "`add` can be substituted with `.[0]` if the array in `file2` contains only one object."
    ],
    "utterance": "Add a PRICE field to each county geometry by matching its id to a value in a lookup file containing county ids and their corresponding prices.",
    "expressions": [
      "add as $prices | input | .objects.us_counties_20m.geometries[] |= . + {PRICE: $prices[.id]}"
    ],
    "data": [
      {
        "input": [
          {
            "type": "Topology",
            "transform": {
              "scale": [
                0.035896170617061705,
                0.005347309530953095
              ],
              "translate": [
                -179.14734,
                17.884813
              ]
            },
            "objects": {
              "us_counties_20m": {
                "type": "GeometryCollection",
                "geometries": [
                  {
                    "type": "Polygon",
                    "arcs": [],
                    "id": "0500000US01001"
                  },
                  {
                    "type": "Polygon",
                    "arcs": [],
                    "id": "0500000US01009"
                  },
                  {
                    "type": "Polygon",
                    "arcs": [],
                    "id": "0500000US01017"
                  },
                  {
                    "type": "Polygon",
                    "arcs": [],
                    "id": "0500000US01021"
                  }
                ]
              }
            }
          },
          [
            {
              "0500000US01001": 51289.0,
              "0500000US01009": 46793.0,
              "0500000US01017": 39857.0,
              "0500000US01021": 48859.0
            }
          ]
        ],
        "output": {
          "type": "Topology",
          "transform": {
            "scale": [
              0.035896170617061705,
              0.005347309530953095
            ],
            "translate": [
              -179.14734,
              17.884813
            ]
          },
          "objects": {
            "us_counties_20m": {
              "type": "GeometryCollection",
              "geometries": [
                {
                  "type": "Polygon",
                  "arcs": [],
                  "id": "0500000US01001",
                  "PRICE": 51289.0
                },
                {
                  "type": "Polygon",
                  "arcs": [],
                  "id": "0500000US01009",
                  "PRICE": 46793.0
                },
                {
                  "type": "Polygon",
                  "arcs": [],
                  "id": "0500000US01017",
                  "PRICE": 39857.0
                },
                {
                  "type": "Polygon",
                  "arcs": [],
                  "id": "0500000US01021",
                  "PRICE": 48859.0
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 62035887
  },
  {
    "context": [
      "Using JQ, I want to add the corresponding elements of the both array and result a new array. In case of date string the value from one of the array will be fine. The Expected output is",
      "[\n        \"2020-05-07T16:30:00.000+0530\",\n        1,\n        45,\n        1689,\n        3,\n        20,\n        8115,\n        17519\n      ]",
      "Pair corresponding elements using `transpose`, and create a new array with sums of them.",
      "transpose | [.[0][0]] + map(add)[1:]"
    ],
    "utterance": "Sum the corresponding numeric elements of two arrays of equal length, keeping the date string from the first array as the first element in the result.",
    "expressions": [
      "transpose | [.[0][0]] + map(add)[1:]"
    ],
    "data": [
      {
        "input": [
          [
            "2020-05-07T16:30:00.000+0530",
            1,
            29,
            693,
            0,
            7,
            3663,
            7413
          ],
          [
            "2020-05-07T15:30:00.000+0530",
            0,
            16,
            996,
            3,
            13,
            4452,
            10106
          ]
        ],
        "output": [
          "2020-05-07T16:30:00.000+0530",
          1,
          45,
          1689,
          3,
          20,
          8115,
          17519
        ]
      }
    ],
    "identifier": 61674867
  },
  {
    "context": [
      "I wish to perform this exact transformation in jq stream mode with the goal of avoiding memory pressure.",
      "I cannot find a way to store the \"key1\" value to be referenced as entries in \"values\" are processed.",
      "To reiterate, I desire the exact output from the non-stream version.",
      "Here\u0019s a solution using --stream and `foreach` that can be used for a stream of JSON objects of the type described.",
      "then .emit = {key: .key, member: $in[0][1], score: $in[1]}"
    ],
    "utterance": "Transform line-delimited objects so that for each key/member/score tuple in the nested value field, output a flat object containing the parent key, member name, and score, using stream processing to minimize memory usage.",
    "expressions": [
      "foreach inputs as $in (null;\n   if $in|length == 2\n   then if $in[0][0] == \"key\" then .key=$in[1]\n        elif $in[0][0] == \"value\" \n        then .emit = {key: .key, member: $in[0][1], score: ($in[1]|tostring)}\n        else .emit=null end\n   else .emit=null end;\n   select(.emit) | .emit)"
    ],
    "data": [
      {
        "input": [
          {
            "key": "key1",
            "value": {
              "one": 1,
              "two": 2
            }
          },
          {
            "key": "key2",
            "value": {
              "three": 3,
              "four": 4
            }
          }
        ],
        "output": [
          {
            "key": "key1",
            "member": "one",
            "score": "1"
          },
          {
            "key": "key1",
            "member": "two",
            "score": "2"
          },
          {
            "key": "key2",
            "member": "three",
            "score": "3"
          },
          {
            "key": "key2",
            "member": "four",
            "score": "4"
          }
        ]
      }
    ],
    "identifier": 61687180
  },
  {
    "context": [
      "The piece I need to change is the block containing `\"query\": \"label_values(env)\",` and I just need to change the value of `\"regex\": \"\",`",
      "jq '.templating.list[] | select(.name == \"env\") |= . + {regex:\"*\"}' \"dashboard.json\" > test.json",
      "The problem is then it only prints the \".list[]\" elements instead of the whole file.",
      ".templating.list[] |= ( select(.query == \"label_values(env)\").regex = \"\" )",
      ".templating.list[] |= (select(.name == \"env\") .regex = \"*\" )"
    ],
    "utterance": "Update the value of the 'regex' property to '*' in the object under 'templating.list[]' where the 'name' property equals 'env'.",
    "expressions": [
      ".templating.list[] |= (select(.name == \"env\") .regex = \"*\")"
    ],
    "data": [
      {
        "input": {
          "templating": {
            "list": [
              {
                "allValue": ".*",
                "current": {},
                "datasource": "$Source",
                "hide": 0,
                "includeAll": false,
                "label": null,
                "multi": true,
                "name": "node",
                "options": [],
                "query": "label_values(node_boot_time{env=~\"$env\"}, instance)",
                "refresh": 1,
                "regex": "",
                "sort": 0,
                "tagValuesQuery": "",
                "tags": [],
                "tagsQuery": "",
                "type": "query",
                "useTags": false
              },
              {
                "allValue": null,
                "current": {
                  "tags": [],
                  "text": "",
                  "value": ""
                },
                "datasource": "$Source",
                "definition": "label_values(env)",
                "hide": 0,
                "includeAll": true,
                "label": "env",
                "multi": false,
                "name": "env",
                "options": [],
                "query": "label_values(env)",
                "refresh": 1,
                "regex": "",
                "skipUrlSync": false,
                "sort": 1,
                "tagValuesQuery": "",
                "tags": [],
                "tagsQuery": "",
                "type": "query",
                "useTags": false
              },
              {
                "current": {
                  "tags": [],
                  "text": "",
                  "value": ""
                },
                "hide": 0,
                "includeAll": false,
                "label": null,
                "multi": false,
                "name": "Source",
                "options": [],
                "query": "prometheus",
                "refresh": 1,
                "regex": "",
                "skipUrlSync": false,
                "type": "datasource"
              }
            ]
          }
        },
        "output": {
          "templating": {
            "list": [
              {
                "allValue": ".*",
                "current": {},
                "datasource": "$Source",
                "hide": 0,
                "includeAll": false,
                "label": null,
                "multi": true,
                "name": "node",
                "options": [],
                "query": "label_values(node_boot_time{env=~\"$env\"}, instance)",
                "refresh": 1,
                "regex": "",
                "sort": 0,
                "tagValuesQuery": "",
                "tags": [],
                "tagsQuery": "",
                "type": "query",
                "useTags": false
              },
              {
                "allValue": null,
                "current": {
                  "tags": [],
                  "text": "",
                  "value": ""
                },
                "datasource": "$Source",
                "definition": "label_values(env)",
                "hide": 0,
                "includeAll": true,
                "label": "env",
                "multi": false,
                "name": "env",
                "options": [],
                "query": "label_values(env)",
                "refresh": 1,
                "regex": "*",
                "skipUrlSync": false,
                "sort": 1,
                "tagValuesQuery": "",
                "tags": [],
                "tagsQuery": "",
                "type": "query",
                "useTags": false
              },
              {
                "current": {
                  "tags": [],
                  "text": "",
                  "value": ""
                },
                "hide": 0,
                "includeAll": false,
                "label": null,
                "multi": false,
                "name": "Source",
                "options": [],
                "query": "prometheus",
                "refresh": 1,
                "regex": "",
                "skipUrlSync": false,
                "type": "datasource"
              }
            ]
          }
        }
      }
    ],
    "identifier": 61870396
  }
]