[
  {
    "context": [
      "I run jq with multiple identically-structured json files as input, to output a single CSV stream, with a jq script ending like:",
      "where that third line is to avoid repeating the CSV header for each JSON file. It's an ugly hack because it hardcodes the first input filename. I'd like to instead use `input_filenames[0]` but there is no such global property \u2014 or am I missing it? Or is there some other neater way to avoid repeating the header row in the output CSV?",
      "One way is to use `input` to handle the very first JSON entity, and then use `inputs` to handle the rest, all with jq's -n command-line option.",
      "input\n| . as $in\n| (map(keys_unsorted) | add | unique) as $cols\n| $cols,\n  (($in, inputs) | map(. as $row | $cols | map($row[.])))"
    ],
    "utterance": "Output the CSV header only once when processing multiple input files with identical structure.",
    "expressions": [
      "input\n| . as $in\n| (map(keys_unsorted) | add | unique) as $cols\n| $cols,\n  (($in, inputs) | map(. as $row | $cols | map($row[.])))"
    ],
    "identifier": 66226257
  },
  {
    "context": [
      "So I just want the value of *name*  when *type* is  KUDU_TSERVER",
      "cat test |jq '.items[]' |jq  'select(.type == \"KUDU_TSERVER\" )' |jq -r '.name'",
      "You definitely can do single jq query.",
      "cat test | jq -r '.items[] | select(.type == \"KUDU_TSERVER\" ) | .name'"
    ],
    "utterance": "Retrieve the values of 'name' where 'type' equals 'KUDU_TSERVER' within the 'items' array.",
    "expressions": [
      ".items[] | select(.type == \"KUDU_TSERVER\") | .name"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "name": "kudu-KUDU_TSERVER-2d63fec551a74320fdcc0c65007c76e4",
              "type": "KUDU_TSERVER",
              "serviceRef": {
                "clusterName": "cluster",
                "serviceName": "kudu"
              },
              "entityStatus": "GOOD_HEALTH"
            },
            {
              "name": "kudu-KUDU_MASTER-95ebd4d9a5158d59306372ed306993fe",
              "type": "KUDU_MASTER",
              "serviceRef": {
                "clusterName": "cluster",
                "serviceName": "kudu"
              },
              "entityStatus": "GOOD_HEALTH"
            }
          ]
        },
        "output": [
          "kudu-KUDU_TSERVER-2d63fec551a74320fdcc0c65007c76e4"
        ]
      }
    ],
    "identifier": 66256053
  },
  {
    "context": [
      "print the pattern between (and excluding) two pattern as many as occasion it appears",
      "\"devices\": [\n    \"Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01\",\n    ...\n]",
      "Parse the json object string to a value, and extract the values from the object and the values from each of the values' `devices` property.",
      "fromjson[].devices[]"
    ],
    "utterance": "List all items from every 'devices' array in the data, regardless of how many times it appears.",
    "expressions": [
      "fromjson[].devices[]"
    ],
    "data": [
      {
        "input": {
          "3": {
            "cpumask": "0x000000003C000000",
            "devices": [
              "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01",
              "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01",
              "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01"
            ]
          },
          "2": {
            "cpumask": "0x0000000000060000",
            "devices": [
              "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01",
              "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01"
            ]
          }
        },
        "output": [
          "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01",
          "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01",
          "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01",
          "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01",
          "Samsung SSD 970 PRO 1TB               XXXXXXXXXXXXXXX     01"
        ]
      }
    ],
    "identifier": 66224693
  },
  {
    "context": [
      "The coordinates have too much decimal numbers, so I would like to simplify them to 6 decimals.",
      "There isn't a straight forward `sprintf` like function in the math library supported by `jq` that allows you to format floating point number with a specified precision e.g. say `'2.5f'`. But you can use the string functions to convert the number to float and extract the digits and convert it back ",
      "jq '.features[].geometry.coordinates |= \n       map( tostring | capture(\"(?<n>-?[0-9]+\\.[0-9]{6})\").n | tonumber )'"
    ],
    "utterance": "Truncate all geometry coordinate values in the features array to six decimal places.",
    "expressions": [
      ".features[].geometry.coordinates |= map( tostring | capture(\"(?<n>-?[0-9]+\\.[0-9]{6})\").n | tonumber )"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {},
              "geometry": {
                "type": "Point",
                "coordinates": [
                  -69.23583984375,
                  45.460130637921004
                ]
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {},
              "geometry": {
                "type": "Point",
                "coordinates": [
                  -69.23584,
                  45.460131
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 66243482
  },
  {
    "context": [
      "What I need is simply to extract **id**, **sales** from **sorted_employees** AND **full name** for that employee from **employees**.. like this:",
      "{ \"Full name\": \"John Doe\", \"ID\": \"employee1\", \"Sales\": \"26\" }",
      "You could combine the two arrays and just group by the common ID field and form the desired output object",
      "jq '.employees + .sorted_employees | group_by(.id) | \n  map({\"Full name\": .[0].\"full name\", ID: .[0].id, \"Sales\": .[1].sales})'"
    ],
    "utterance": "For each employee, combine the full name from employees and the id and sales from sorted_employees into a single object.",
    "expressions": [
      ".employees + .sorted_employees | group_by(.id) | map({\"Full name\": .[0].\"full name\", ID: .[0].id, \"Sales\": .[1].sales})"
    ],
    "data": [
      {
        "input": {
          "employees": [
            {
              "started_at": "2018-05-01 12.00",
              "id": "employee1",
              "facebook": "https://fb/john_doe",
              "full name": "John Doe"
            },
            {
              "started_at": "2017-05-01 12.00",
              "id": "employee2",
              "facebook": "https://fb/sam_jones",
              "full name": "Sam Jones"
            },
            {
              "started_at": "2016-05-01 12.00",
              "id": "employee3",
              "facebook": "https://fb/jane_roe",
              "full name": "Jane Roe"
            }
          ],
          "sorted_employees": [
            {
              "id": "employee1",
              "sales": 26
            },
            {
              "id": "employee2",
              "sales": 119
            },
            {
              "id": "employee3",
              "sales": 84
            }
          ]
        },
        "output": [
          {
            "Full name": "John Doe",
            "ID": "employee1",
            "Sales": 26
          },
          {
            "Full name": "Sam Jones",
            "ID": "employee2",
            "Sales": 119
          },
          {
            "Full name": "Jane Roe",
            "ID": "employee3",
            "Sales": 84
          }
        ]
      }
    ],
    "identifier": 66224534
  },
  {
    "context": [
      "The json structure is always the same. How can I get 'the-dynamic-value-i-need-to-get'? Also I may need to retrieve 'env-name-DYNAMIC'",
      "Use the `keys[]` attribute",
      ".RuntimeSources | keys[]",
      ".RuntimeSources | keys[] as $k | .[$k] | keys[]",
      "you can just select the paths that contains 3 levels",
      "paths | select( length == 3 ) | .[1]",
      "paths | select( length == 3 ) | .[2]",
      "I managed to get it with:",
      "jq '.RuntimeSources | .[] | keys'"
    ],
    "utterance": "Extract the dynamic key name under .RuntimeSources, and extract the key name nested beneath that key.",
    "expressions": [
      ".RuntimeSources | keys[]",
      ".RuntimeSources | keys[] as $k | .[$k] | keys[]",
      ".RuntimeSources | .[] | keys",
      "paths | select( length == 3 ) | .[1]",
      "paths | select( length == 3 ) | .[2]"
    ],
    "data": [
      {
        "input": {
          "RuntimeSources": {
            "env-name-DYNAMIC": {
              "the-dynamic-value-i-need-to-get": {
                "url": ""
              }
            }
          },
          "DeploymentId": 147,
          "Serial": 158
        },
        "output": {
          "first_level_key": "env-name-DYNAMIC",
          "second_level_key": "the-dynamic-value-i-need-to-get"
        }
      }
    ],
    "identifier": 66227214
  },
  {
    "context": [
      "Then i use the following commands to store the `host`,`dbname`,`user`, and `password`.",
      "db_main_host=$(echo $db_main_info | jq -r '.host')",
      "db_main_name=$(echo $db_main_info | jq -r '.dbname')",
      "db_main_user=$(echo $db_main_info | jq -r '.user')",
      "db_main_password=$(echo $db_main_info | jq -r '.password')"
    ],
    "utterance": "Extract the values of host, dbname, user, and password as separate variables from the retrieved data.",
    "expressions": [
      ".host",
      ".dbname",
      ".user",
      ".password"
    ],
    "data": [
      {
        "input": {
          "host": "env-prod-blah-db.blah.us-east-1.rds.amazonaws.com",
          "dbname": "blah",
          "user": "root",
          "password": "blah"
        },
        "output": {
          "host": "env-prod-blah-db.blah.us-east-1.rds.amazonaws.com",
          "dbname": "blah",
          "user": "root",
          "password": "blah"
        }
      }
    ],
    "identifier": 66294605
  },
  {
    "context": [
      "I would like to extract the content of the `props` variable and have it as extra object properties, looking like this:\n[\n    { \n      \"name\": \"object1\",\n      \"prop\": \"prop1\",\n      \"prop1\": \"value1\",\n      \"prop2\": \"value2\",\n      \"prop3\": \"value3\"\n    },\n    { \n      \"name\": \"object2\",\n      \"prop\": \"prop2\",\n      \"prop1\": \"value4\",\n      \"prop2\": \"value5\",\n      \"prop3\": \"value6\"\n    },\n]",
      "Use `add` to merge the propN objects into one, `del` to remove the original `props`:\n\n    jq '[.[] | . + (.props | add) | del(.props)]' file.json",
      "You can indeed use `map` to shorten it a bit:\n\n    jq 'map(. + (.props | add) | del(.props))' file.json"
    ],
    "utterance": "Flatten each object's 'props' array into properties at the top level and remove 'props'.",
    "expressions": [
      "[.[] | . + (.props | add) | del(.props)]",
      "map(. + (.props | add) | del(.props))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "object1",
            "prop": "prop1",
            "props": [
              {
                "prop1": "value1"
              },
              {
                "prop2": "value2"
              },
              {
                "prop3": "value3"
              }
            ]
          },
          {
            "name": "object2",
            "prop": "prop2",
            "props": [
              {
                "prop1": "value4"
              },
              {
                "prop2": "value5"
              },
              {
                "prop3": "value6"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "object1",
            "prop": "prop1",
            "prop1": "value1",
            "prop2": "value2",
            "prop3": "value3"
          },
          {
            "name": "object2",
            "prop": "prop2",
            "prop1": "value4",
            "prop2": "value5",
            "prop3": "value6"
          }
        ]
      }
    ],
    "identifier": 66266130
  },
  {
    "context": [
      "\"I have a clear before and desired \\\"after\\\";\"",
      "**Before:**",
      "[",
      "  \"Access Token Manipulation\",",
      "  \"T1134\",",
      "  [",
      "    {",
      "      \"kill_chain_name\": \"mitre-attack\",",
      "      \"phase_name\": \"defense-evasion\"",
      "    },",
      "    {",
      "      \"kill_chain_name\": \"mitre-attack\",",
      "      \"phase_name\": \"privilege-escalation\"",
      "    }",
      "  ]",
      "]",
      "**After:**",
      "[",
      "  \"Access Token Manipulation\",",
      "  \"T1134\",",
      "  \"defense-evasion\"",
      "]",
      "[",
      "  \"Access Token Manipulation\",",
      "  \"T1134\",",
      "  \"privilege-escalation\"",
      "]",
      "jq '[.[0],.[1]] as $h | .[2][].phase_name | $h + [.]'"
    ],
    "utterance": "For each phase_name in the third element's objects, create a new array containing the first two elements and the phase_name value.",
    "expressions": [
      "[.[0],.[1]] as $h | .[2][].phase_name | $h + [.]"
    ],
    "data": [
      {
        "input": [
          "Access Token Manipulation",
          "T1134",
          [
            {
              "kill_chain_name": "mitre-attack",
              "phase_name": "defense-evasion"
            },
            {
              "kill_chain_name": "mitre-attack",
              "phase_name": "privilege-escalation"
            }
          ]
        ],
        "output": [
          [
            "Access Token Manipulation",
            "T1134",
            "defense-evasion"
          ],
          [
            "Access Token Manipulation",
            "T1134",
            "privilege-escalation"
          ]
        ]
      }
    ],
    "identifier": 66282000
  },
  {
    "context": [
      "Basically I'm trying to turn some of the keys into values, and re-organize some parts of the JSON.",
      "The source JSON is the following :",
      "{\n  \"ABCC\": {\n    \"pairs\": {\n      \"CND\": {\n        \"tsyms\": {\n          \"BTC\": {\n            \"useless_variable1\": \"useless_value1\",\n            \"useless_variable2\": \"useless_value2\"\n          },\n          \"ETH\": {\n            \"useless_variable1\": \"useless_value1\",\n            \"useless_variable2\": \"useless_value2\"\n          }\n        }\n      },\n      \"ELF\": {\n        \"tsyms\": {\n          \"ETH\": {\n            \"useless_variable1\": \"useless_value1\",\n            \"useless_variable2\": \"useless_value2\"\n          },\n          \"BTC\": {\n            \"useless_variable1\": \"useless_value1\",\n            \"useless_variable2\": \"useless_value2\"\n          }\n        }\n      }\n    }\n  },\n  \"ACX\": {\n    \"pairs\": {\n      \"PLA\": {\n        \"tsyms\": {\n          \"AUD\": {\n            \"useless_variable1\": \"useless_value1\",\n            \"useless_variable2\": \"useless_value2\"\n          },\n          \"USDT\": {\n            \"useless_variable1\": \"useless_value1\",\n            \"useless_variable2\": \"useless_value2\"\n          }\n        }\n      },\n      \"BTC\": {\n        \"tsyms\": {\n          \"USDT\": {\n            \"useless_variable1\": \"useless_value1\",\n            \"useless_variable2\": \"useless_value2\"\n          },\n          \"AUD\": {\n            \"useless_variable1\": \"useless_value1\",\n            \"useless_variable2\": \"useless_value2\"\n          }\n        }\n      }\n    }\n  }\n}",
      "And the expected JSON output would be something like that :",
      "{\n  \"ABCC\": {\n    \"pairs\": [\n      \"CND/BTC\",\n      \"CND/ETH\",\n      \"ELF/ETH\",\n      \"ELF/BTC\"\n    ]\n  },\n  \"ACX\": {\n    \"pairs\": [\n      \"PLA/AUD\",\n      \"PLA/USDT\",\n      \"BTC/USDT\",\n      \"BTC/AUD\"\n    ]\n  }\n}",
      "The key to a straightforward solution is to write a helper function for extracting the key/key strings:",
      "def pairs:\n  keys_unsorted[] as $k1\n  | .[$k1][]\n  | keys_unsorted[] as $k3\n  | \"\\($k1)/\\($k3)\";",
      "Now, thanks to jq's |= operator, the solution can be written simply as:",
      "map_values(.pairs |= [pairs])"
    ],
    "utterance": "For each top-level key, extract all currency pairs in the form 'X/Y' from the nested pairs and their tsyms, and replace the value of 'pairs' with an array of these pair strings.",
    "expressions": [
      "def pairs:\n  keys_unsorted[] as $k1\n  | .[$k1].tsyms\n  | keys_unsorted[] as $k3\n  | \"\\($k1)/\\($k3)\";\nmap_values(.pairs |= [pairs])"
    ],
    "data": [
      {
        "input": {
          "ABCC": {
            "pairs": {
              "CND": {
                "tsyms": {
                  "BTC": {
                    "useless_variable1": "useless_value1",
                    "useless_variable2": "useless_value2"
                  },
                  "ETH": {
                    "useless_variable1": "useless_value1",
                    "useless_variable2": "useless_value2"
                  }
                }
              },
              "ELF": {
                "tsyms": {
                  "ETH": {
                    "useless_variable1": "useless_value1",
                    "useless_variable2": "useless_value2"
                  },
                  "BTC": {
                    "useless_variable1": "useless_value1",
                    "useless_variable2": "useless_value2"
                  }
                }
              }
            }
          },
          "ACX": {
            "pairs": {
              "PLA": {
                "tsyms": {
                  "AUD": {
                    "useless_variable1": "useless_value1",
                    "useless_variable2": "useless_value2"
                  },
                  "USDT": {
                    "useless_variable1": "useless_value1",
                    "useless_variable2": "useless_value2"
                  }
                }
              },
              "BTC": {
                "tsyms": {
                  "USDT": {
                    "useless_variable1": "useless_value1",
                    "useless_variable2": "useless_value2"
                  },
                  "AUD": {
                    "useless_variable1": "useless_value1",
                    "useless_variable2": "useless_value2"
                  }
                }
              }
            }
          }
        },
        "output": {
          "ABCC": {
            "pairs": [
              "CND/BTC",
              "CND/ETH",
              "ELF/ETH",
              "ELF/BTC"
            ]
          },
          "ACX": {
            "pairs": [
              "PLA/AUD",
              "PLA/USDT",
              "BTC/USDT",
              "BTC/AUD"
            ]
          }
        }
      }
    ],
    "identifier": 66218359
  },
  {
    "context": [
      "I have some unformatted JSON files. I want to format them with jq and see the formatted output via less:\r\n\r\n```sh\r\ncat *.json | jq | less\r\n```",
      "But it doesn&#39;t work. Just shows the jq&#39;s help.",
      "O.K., jq needs a filter, minimum a `.`, but...\r\n\r\n```sh\r\ncat *.json | jq\r\n```\r\n\r\nworks for me.",
      "For one thing, it colour-codes its output (unless you explicitly turn that option off). But more relevantly to this question, for version 1.5, if it detects that its output stream is a terminal and its input stream is not a terminal and there are no non-option command-line arguments at all, it assumes that you meant to use the filter `.`.",
      "So that&#39;s what happens when you type `cat *.json | jq`. In that case, jq&#39;s input stream is a pipe (from the `cat` command) but its output stream is the terminal. So it assumes a default filter of `.`.",
      "But when you pipe the output of `jq` through `less`, `jq`&#39;s output stream is no longer a terminal. Now it&#39;s a pipe (connected to a `less` process). So the automatic filter `.` is not inserted, and `jq` complains that no filter was provided.",
      "By the way, if you wanted to see coloured output with `less` (and you&#39;re using Gnu `less`), then you could use the command:\r\n\r\n    cat *.json | jq . -C | less -R   # The . is not necessary with v1.6"
    ],
    "utterance": "Format and pretty-print the contents of multiple unformatted input files when displaying them through a pager program.",
    "expressions": [
      "jq ."
    ],
    "identifier": 66296840
  },
  {
    "context": [
      "I would need to merge the elements of the second file into an object array in the first file based on searching the `reference` field.",
      "I would like to get: [...] \"details\" : [ ... matched objects from file 2 ... ]",
      "This would be way easier if you used `reduce` instead.",
      "jq 'reduce inputs[] as $rec (INDEX(.reference);\n  .[$rec.reference | tostring].details += [$rec]\n) | map(.)' es_file1.json es_file2.json",
      "Here's a straightforward, reduce-free solution:",
      "jq '\n  group_by(.reference)\n  | INDEX(.[]; .[0]|.reference|tostring) as $dict\n  | input\n  | map_values(. + {details: $dict[.reference|tostring]})\n' 2.json 1.json"
    ],
    "utterance": "For each element in the first input, fill its details array with all elements from the second input whose reference matches.",
    "expressions": [
      "reduce inputs[] as $rec (INDEX(.reference);\n  .[$rec.reference | tostring].details += [$rec]\n) | map(.)",
      "group_by(.reference)\n| INDEX(.[]; .[0]|.reference|tostring) as $dict\n| input\n| map_values(. + {details: $dict[.reference|tostring]})"
    ],
    "data": [
      {
        "input": [
          [
            {
              "reference": 25422,
              "order_number": "10_1",
              "details": []
            },
            {
              "reference": 25423,
              "order_number": "10_2",
              "details": []
            }
          ],
          [
            {
              "record_id": 1,
              "reference": 25422,
              "row_description": "descr_1_0"
            },
            {
              "record_id": 2,
              "reference": 25422,
              "row_description": "descr_1_1"
            },
            {
              "record_id": 3,
              "reference": 25423,
              "row_description": "descr_2_0"
            }
          ]
        ],
        "output": [
          {
            "reference": 25422,
            "order_number": "10_1",
            "details": [
              {
                "record_id": 1,
                "reference": 25422,
                "row_description": "descr_1_0"
              },
              {
                "record_id": 2,
                "reference": 25422,
                "row_description": "descr_1_1"
              }
            ]
          },
          {
            "reference": 25423,
            "order_number": "10_2",
            "details": [
              {
                "record_id": 3,
                "reference": 25423,
                "row_description": "descr_2_0"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 66281220
  },
  {
    "context": [
      "what I would like to do is \n\n```\ncat eval.json | jq \\\n'.\"3193328829c7b3ec6be0ab6bfd8988b97a35006ea578c9ce4ab7fe29cbc5ec94\".result.rows[] | select (.[2]==\"stop\")'\n```\n\nThis works fine, except I need to do this in the general case where I don't know the Image ID ahead of time.",
      "If you want to specify the first key, use `keys_unsorted[0]`, as in:\n\n```\n.[keys_unsorted[0]].result.rows[] | select (.[2]==\"stop\")\n```"
    ],
    "utterance": "Select all rows where the third element equals \"stop\" from the rows array under the result key of the first top-level object, regardless of its key.",
    "expressions": [
      ".[keys_unsorted[0]].result.rows[] | select (.[2]==\"stop\")"
    ],
    "data": [
      {
        "input": {
          "3193328829c7b3ec6be0ab6bfd8988b97a35006ea578c9ce4ab7fe29cbc5ec94": {
            "result": {
              "final_action": "stop",
              "header": [
                "Trigger_Id",
                "Check_Output",
                "Gate_Action",
                "Whitelisted"
              ],
              "row_count": 3,
              "rows": [
                [
                  "41cb7cdf04850e33a11f80c42bf660b3",
                  "Dockerfile directive 'HEALTHCHECK' not found, matching condition 'not_exists' check",
                  "warn",
                  false
                ],
                [
                  "CVE-2018-20839+libudev1",
                  "MEDIUM Vulnerability found in os package type (dpkg) - libudev1 (CVE-2018-20839 - http://people.ubuntu.com/~ubuntu-security/cve/CVE-2018-20839)",
                  "warn",
                  false
                ],
                [
                  "CVE-2021-3156+sudo",
                  "HIGH Vulnerability found in os package type (dpkg) - sudo (fixed in: 1.8.31-1ubuntu1.2)(CVE-2021-3156 - http://people.ubuntu.com/~ubuntu-security/cve/CVE-2021-3156)",
                  "stop",
                  false
                ]
              ]
            }
          },
          "policy_data": [],
          "policy_name": "",
          "whitelist_data": [],
          "whitelist_names": []
        },
        "output": [
          [
            "CVE-2021-3156+sudo",
            "HIGH Vulnerability found in os package type (dpkg) - sudo (fixed in: 1.8.31-1ubuntu1.2)(CVE-2021-3156 - http://people.ubuntu.com/~ubuntu-security/cve/CVE-2021-3156)",
            "stop",
            false
          ]
        ]
      }
    ],
    "identifier": 66294487
  },
  {
    "identifier": 66330138
  },
  {
    "context": [
      "I want to swap the counts of the two objects based on a condition to result in the following, using JQ.",
      "I can't get the correct operator to modify the second. Is something like the following possible, using JQ?",
      "Here is a straightforward solution that only uses builtins and shows how updates can be chained together using '|' (*).",
      "```\n.food.fruit |=\n  (map(.type) as $types\n   | ($types | index(\"apple\")) as $ia\n   | ($types | index(\"banana\")) as $ib\n   | .[$ia].count as $ac\n   | .[$ia].count = .[$ib].count\n   | .[$ib].count = $ac\n  )\n```",
      "```\n.food.fruit |= (\n   ( .[] | select( .type == \"apple\"  ) | .count ) as $count1 |\n   ( .[] | select( .type == \"banana\" ) | .count ) as $count2 |\n\n   ( .[] | select( .type == \"apple\"  ) | .count ) = $count2 |\n   ( .[] | select( .type == \"banana\" ) | .count ) = $count1\n)\n```"
    ],
    "utterance": "Swap the 'count' values of the objects with 'type' equal to 'apple' and 'banana' in the 'food.fruit' array.",
    "expressions": [
      ".food.fruit |= (\n   ( .[] | select( .type == \"apple\"  ) | .count ) as $count1 |\n   ( .[] | select( .type == \"banana\" ) | .count ) as $count2 |\n\n   ( .[] | select( .type == \"apple\"  ) | .count ) = $count2 |\n   ( .[] | select( .type == \"banana\" ) | .count ) = $count1\n)",
      ".food.fruit |= (\n   ( .[] | select( .type == \"apple\"  ) | .count ) as $count1 |\n   ( .[] | select( .type == \"banana\" ) | .count ) as $count2 |\n\n   .[] |= (\n      .count = (\n         if .type == \"apple\" then\n            $count2\n         elif .type == \"banana\" then\n            $count1\n         else\n            .count\n         end\n      )\n   )\n)",
      ".food.fruit |=\n  (map(.type) as $types\n   | ($types | index(\"apple\")) as $ia\n   | ($types | index(\"banana\")) as $ib\n   | .[$ia].count as $ac\n   | .[$ia].count = .[$ib].count\n   | .[$ib].count = $ac\n  )"
    ],
    "data": [
      {
        "input": {
          "food": {
            "fruit": [
              {
                "type": "apple",
                "count": 0
              },
              {
                "type": "banana",
                "count": 1
              },
              {
                "type": "orange",
                "count": 0
              }
            ]
          }
        },
        "output": {
          "food": {
            "fruit": [
              {
                "type": "apple",
                "count": 1
              },
              {
                "type": "banana",
                "count": 0
              },
              {
                "type": "orange",
                "count": 0
              }
            ]
          }
        }
      }
    ],
    "identifier": 66260639
  },
  {
    "context": [
      "i want that a json like this ... end up like this ...",
      "You can use `map_values` on the `.properties` object The function returns the object back, selecting the field value given as part of the expression.",
      "jq '.properties | map_values(.default)'"
    ],
    "utterance": "Extract an object mapping top-level property names to their default values as defined in the schema's properties.",
    "expressions": [
      ".properties | map_values(.default)"
    ],
    "data": [
      {
        "input": {
          "type": "object",
          "properties": {
            "string": {
              "type": "ingeger",
              "default": "the default string"
            },
            "number": {
              "type": "number",
              "default": 1
            },
            "object": {
              "type": "object",
              "properties": {
                "string": {
                  "type": "ingeger",
                  "default": "the default string 2"
                },
                "number": {
                  "type": "number",
                  "default": 2
                }
              }
            }
          }
        },
        "output": {
          "string": "the default string",
          "number": 1,
          "object": null
        }
      }
    ],
    "identifier": 66320608
  },
  {
    "context": [
      "I want my output to be this. I just want to Grab  \"description\": & \"rtmp_url\":",
      "test description test url1",
      "test 2 description test rtmp_url",
      "jq -r '.features[].properties | \"\\(.description) \\(.rtmp_url)\"' input.json",
      "produces",
      "test description test url1",
      "test 2 description test rtmp_url"
    ],
    "utterance": "List the description and rtmp_url fields for each element in the features array, formatted as: <description> <rtmp_url>.",
    "expressions": [
      ".features[].properties | \"\u001b[38;5;13m\\(.description) \\(.rtmp_url)\u001b[0m\"",
      "jq -r '.features[].properties | \"\\(.description) \\(.rtmp_url)\"'"
    ],
    "data": [
      {
        "input": {
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "coordinates": [
                  -55.37174,
                  55.77598
                ],
                "type": "Point"
              },
              "properties": {
                "direction": "EB",
                "mrm": 55,
                "id": "555",
                "jurisdiction": "test",
                "route": "I-64",
                "description": "test description",
                "deviceid": "",
                "rtmp_url": "test url1"
              }
            },
            {
              "type": "Feature",
              "geometry": {
                "coordinates": [
                  -55.36782,
                  55.77382
                ],
                "type": "Point"
              },
              "properties": {
                "direction": "WB",
                "mrm": 44,
                "id": "4444",
                "jurisdiction": "test 2 jurisdiction",
                "route": "I-64",
                "description": "test 2 description",
                "deviceid": "",
                "rtmp_url": "test rtmp_url"
              }
            }
          ]
        },
        "output": "test description test url1\ntest 2 description test rtmp_url"
      }
    ],
    "identifier": 66298636
  },
  {
    "context": [
      "I would like to change a field in my json file as specified by another json file.",
      "I have an external override file that specifies how `name` in certain objects should be overridden, for example:\r\n\r\n```json\r\n{\"id\": 20, \"name\": \"Bar\"}\r\n{\"id\": 10, \"name\": \"foo edited\"}\r\n```",
      "the override may be shorter than input, in which case the `name` should be unchanged.",
      "Given the above input and the override, I would like to obtain the following output:\r\n\r\n```json\r\n{\"id\": 10, \"name\": \"foo edited\", \"some_other_field\": \"value 1\"}\r\n{\"id\": 20, \"name\": \"Bar\", \"some_other_field\": \"value 2\"}\r\n{\"id\": 25, \"name\": \"baz\", \"some_other_field\": \"value 10\"}\r\n```",
      "There are many possibilities, but probably the simplest, efficient solution would use the built-in function: `INDEX/2`, e.g. as follows:\r\n```\r\njq -n --slurpfile dict f2.json '\r\n  (INDEX($dict[]; .id) | map_values(.name)) as $d\r\n  | inputs\r\n  | .name = ($d[.id|tostring] // .name)\r\n' f1.json\r\n```"
    ],
    "utterance": "Replace the value of the 'name' field for objects with ids specified in an override file, leaving other fields and unmatched objects unchanged.",
    "expressions": [
      "(INDEX($dict[]; .id) | map_values(.name)) as $d | inputs | .name = ($d[.id|tostring] // .name)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 10,
            "name": "foo",
            "some_other_field": "value 1"
          },
          {
            "id": 20,
            "name": "bar",
            "some_other_field": "value 2"
          },
          {
            "id": 25,
            "name": "baz",
            "some_other_field": "value 10"
          }
        ],
        "output": [
          {
            "id": 10,
            "name": "foo edited",
            "some_other_field": "value 1"
          },
          {
            "id": 20,
            "name": "Bar",
            "some_other_field": "value 2"
          },
          {
            "id": 25,
            "name": "baz",
            "some_other_field": "value 10"
          }
        ]
      }
    ],
    "identifier": 66320492
  },
  {
    "context": [
      "I want to use the existing value (100005436) of the id field and replace it with a new value (200005436) based on the existing value. Basically, I just want to replace the first character of the string in the existing value.",
      "replace the first character of the string ...",
      "map(.id |= \"2\" + .[1:])",
      ".[].id |= sub(\"^.\"; \"2\")",
      "more generally:\nmap(.id |= (.[0:1]|tonumber+1|tostring) + .[1:])",
      "more generally:\n.[].id |= (. as $id | sub(\"^.\"; $id[0:1] | tonumber+1 | tostring)"
    ],
    "utterance": "Replace the first character of each object's id field with '2' in an array of objects.",
    "expressions": [
      "map(.id |= \"2\" + .[1:])",
      ".[].id |= sub(\"^.\"; \"2\")",
      "[].id |= \"2\" + .[1:]"
    ],
    "data": [
      {
        "input": [
          {
            "id": "100006578",
            "name": "Someone",
            "category": "frontend"
          },
          {
            "id": "100005436",
            "name": "Someone",
            "category": "backend"
          }
        ],
        "output": [
          {
            "id": "200006578",
            "name": "Someone",
            "category": "frontend"
          },
          {
            "id": "200005436",
            "name": "Someone",
            "category": "backend"
          }
        ]
      }
    ],
    "identifier": 66324817
  },
  {
    "context": [
      "I want to replace the value of all ```\"location\"``` tags with ```-``` wherever there is a ```/```.",
      "So after the replacement, the above text becomes:",
      "{...\"location\":\"apmservices-at:21.3.0.2-linux-amd64\"...}",
      "Using [tag:jq]:",
      "```\n.payload[].location |= gsub(\"/\";\"-\")\n```",
      "Or, if you want every \"location\" key checked, irrespective of where the key occurs:",
      "```\nwalk(if type == \"object\" and (.location|type==\"string\") \n     then .location |= gsub(\"/\";\"-\") else . end)\n```"
    ],
    "utterance": "Replace every slash character with a dash in all values for location keys.",
    "expressions": [
      ".payload[].location |= gsub(\"/\";\"-\")",
      "walk(if type == \"object\" and (.location|type==\"string\") then .location |= gsub(\"/\";\"-\") else . end)"
    ],
    "data": [
      {
        "input": {
          "version": "21.0.0.1",
          "artifact": "artifact",
          "payload": [
            {
              "id": "ng-at-ng/at",
              "name": "ng/at",
              "location": "apmservices/at:21.3.0.2-linux-amd64",
              "component": "core",
              "tag": "21.3.0.2-linux-amd64"
            },
            {
              "id": "doi-dspintegrator-doi/dspintegrator",
              "name": "doi/dspintegrator",
              "location": "doi/1.3.3/dspintegrator:2.0.0-RELEASE_183",
              "component": "doi",
              "tag": "2.0.0-RELEASE_183"
            }
          ]
        },
        "output": {
          "version": "21.0.0.1",
          "artifact": "artifact",
          "payload": [
            {
              "id": "ng-at-ng/at",
              "name": "ng/at",
              "location": "apmservices-at:21.3.0.2-linux-amd64",
              "component": "core",
              "tag": "21.3.0.2-linux-amd64"
            },
            {
              "id": "doi-dspintegrator-doi/dspintegrator",
              "name": "doi/dspintegrator",
              "location": "doi-1.3.3-dspintegrator:2.0.0-RELEASE_183",
              "component": "doi",
              "tag": "2.0.0-RELEASE_183"
            }
          ]
        }
      }
    ],
    "identifier": 66324241
  },
  {
    "context": [
      "jq --arg value \"25\" '. += [{\"version\": $value|tonumber, \"file\": \"branding/$value|tonumber\"}]' versions.json >tmp.json && mv tmp.json versions.json",
      "The result is:",
      "[{\"version\": 24, \"file\": \"branding/24\"}, {\"version\": 25, \"file\": \"branding/$value|tonumber\"}]",
      "Expected result:",
      "[{\"version\": 24, \"file\": \"branding/24\"}, {\"version\": 25, \"file\": \"branding/25\"}]",
      "You need to use interpolation to have the filter evaluated.",
      "{\"version\": $value|tonumber, \"file\": \"branding/\\($value|tonumber)\"}"
    ],
    "utterance": "Append an object with version 25 and file branding/25, using a variable for the value 25",
    "expressions": [
      ". += [{\"version\": $value|tonumber, \"file\": \"branding/\\($value|tonumber)\"}]"
    ],
    "data": [
      {
        "input": [
          {
            "version": 24,
            "file": "branding/24"
          }
        ],
        "output": [
          {
            "version": 24,
            "file": "branding/24"
          },
          {
            "version": 25,
            "file": "branding/25"
          }
        ]
      }
    ],
    "identifier": 66334680
  },
  {
    "context": [
      "\".p[]?.product.productId\" the issue is here, when p is null or an empty array [].",
      "All I want is to be able to ignore the P when it is null or [].",
      "Specifically, `.p[]` is like `.p | (try .[] catch empty)`, so there is nothing to stop the `.p` from raising an exception.",
      "You might like to consider using `try` explicitly:",
      "    $ jq -n '[] | try .p[] catch null'"
    ],
    "utterance": "Retrieve values from the property 'p' when it is an array, and ignore or safely handle the case when 'p' is null or an empty array.",
    "expressions": [
      ".p?[]",
      "try .p[] catch null"
    ],
    "data": [
      {
        "input": {
          "p": null
        },
        "output": null
      },
      {
        "input": {
          "p": []
        },
        "output": null
      },
      {
        "input": {
          "p": [
            {}
          ]
        },
        "output": [
          {}
        ]
      }
    ],
    "identifier": 66349432
  },
  {
    "context": [
      "I want to have an output as :\r\n[\r\n  {\r\n    \"Robin\": \"id1\"\r\n  },\r\n  {\r\n    \"John\": \"id2\"\r\n  },\r\n  {\r\n    \"Jane\": \"id3\"\r\n  }\r\n]",
      "Yu need:\r\n    cat data1.jtxt | jq 'to_entries|map({(.value.name):(.value.id)})'",
      "If you want to keep the \"object separation\" just remove the `| add`"
    ],
    "utterance": "Transform an array of objects with 'id' and 'name' fields into an array where each object maps the name to the id.",
    "expressions": [
      "map({(.name): .id})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "id1",
            "name": "Robin"
          },
          {
            "id": "id2",
            "name": "John"
          },
          {
            "id": "id3",
            "name": "Jane"
          }
        ],
        "output": [
          {
            "Robin": "id1"
          },
          {
            "John": "id2"
          },
          {
            "Jane": "id3"
          }
        ]
      }
    ],
    "identifier": 66360203
  },
  {
    "context": [
      "How can I make the output one line per record so that it looks like:",
      "{&quot;Name&quot;:&quot;stedolan&quot;,&quot;RecordTimestamp&quot;:&quot;2021-02-25T05:00:06.740+0000&quot;}",
      "jq has an option for this:  --compact-output",
      "jq --compact-output ... foo.json"
    ],
    "utterance": "Produce output with each entire record on a single line with no newlines between fields.",
    "expressions": [
      "jq --compact-output ... foo.json"
    ],
    "data": [
      {
        "input": {
          "Name": "stedolan",
          "RecordTimestamp": "2021-02-25T05:00:06.740+0000"
        },
        "output": "{\"Name\":\"stedolan\",\"RecordTimestamp\":\"2021-02-25T05:00:06.740+0000\"}"
      }
    ],
    "identifier": 66377978
  },
  {
    "context": [
      "I want to print full paths and values of every file using `jq`. For example, with input from above:\r\n\r\n    folder1/file1 - value1\r\n    folder1/folder2/file2 - value2\r\n    file3 - value3",
      "Here is a solution which takes advantage of jq's TCO (tail-call optimization) by defining the recursive function as a filter with arity 0 (i.e., no arguments):\r\n```\r\n# input: [array, $path]\r\ndef unwrap:\r\n  .[1] as $path\r\n  | .[0][]\r\n  | if .children then [.children, $path + [.name]] | unwrap\r\n    else [$path + [.name], .value]\r\n    end;\r\n\r\n[.] | unwrap | \"\\(.[0]|join(\"/\")) - \\(.[1])\"\r\n```",
      "Yes, it is possible. You can use a recursive function like below for achieving this.\r\n``` none\r\ndef f($path):\r\n  ($path + [.name]) as $path\r\n  | if has(\"value\")\r\n  then \"\\($path | join(\"/\")) - \\(.value)\"\r\n  else .children[] | f($path) end;\r\n.[] | f([])\r\n```"
    ],
    "utterance": "Print the full path and value for every file, with paths constructed from nested name fields separated by '/', in a folder-like structure.",
    "expressions": [
      "def unwrap:\n  .[1] as $path\n  | .[0][]\n  | if .children then [.children, $path + [.name]] | unwrap\n    else [$path + [.name], .value]\n    end;\n[.] | unwrap | \"\\(.[0]|join(\"/\")) - \\(.[1])\"",
      "def f($path):\n  ($path + [.name]) as $path\n  | if has(\"value\")\n  then \"\\($path | join(\"/\")) - \\(.value)\"\n  else .children[] | f($path) end;\n.[] | f([])"
    ],
    "data": [
      {
        "input": [
          {
            "name": "folder1",
            "children": [
              {
                "name": "file1",
                "value": "value1"
              },
              {
                "name": "folder2",
                "children": [
                  {
                    "name": "file2",
                    "value": "value2"
                  }
                ]
              }
            ]
          },
          {
            "name": "file3",
            "value": "value3"
          }
        ],
        "output": [
          "folder1/file1 - value1",
          "folder1/folder2/file2 - value2",
          "file3 - value3"
        ]
      }
    ],
    "identifier": 66337430
  },
  {
    "context": [
      "Now when I add a new \"setting2\" (which has the same keys, but values can be different) to defaults.json, I would like to update current.json with that setting, without overwriting the \"currentvalue\" field. How can I do this using jq?",
      "The following jq program first finds the \"new\" paths in default.json by subtracting the paths in current.json from the paths in default.json, and then updates the \"current\" JSON by adding all the \"new\" paths and their associated values:",
      "jq --argfile default default.json '\n . as $current\n | ([$default|paths] - [$current|paths]) as $new\n | reduce $new[] as $p ($current; \n     setpath($p; $default|getpath($p)))\n' current.json"
    ],
    "utterance": "Merge new settings from defaults.json into current.json, adding any new settings without overwriting the existing 'CurrentValue' fields.",
    "expressions": [
      "jq --argfile default default.json '\n . as $current\n | ([$default|paths] - [$current|paths]) as $new\n | reduce $new[] as $p ($current; \n     setpath($p; $default|getpath($p)))\n' current.json"
    ],
    "data": [
      {
        "input": {
          "// defaults.json": [
            {
              "AttributeName": "setting1",
              "Value": [
                {
                  "ValueName": "Disabled",
                  "ValueDisplayName": "Disabled"
                },
                {
                  "ValueName": "Enabled",
                  "ValueDisplayName": "Enabled"
                }
              ],
              "DefaultValue": "Enabled"
            },
            {
              "AttributeName": "setting2",
              "Value": [
                {
                  "ValueName": "Low",
                  "ValueDisplayName": "Low"
                },
                {
                  "ValueName": "High",
                  "ValueDisplayName": "High"
                }
              ],
              "DefaultValue": "Low"
            }
          ],
          "// current.json": [
            {
              "AttributeName": "setting1",
              "Value": [
                {
                  "ValueName": "Disabled",
                  "ValueDisplayName": "Disabled"
                },
                {
                  "ValueName": "Enabled",
                  "ValueDisplayName": "Enabled"
                }
              ],
              "DefaultValue": "Enabled",
              "CurrentValue": "Enabled"
            }
          ]
        },
        "output": [
          {
            "AttributeName": "setting1",
            "Value": [
              {
                "ValueName": "Disabled",
                "ValueDisplayName": "Disabled"
              },
              {
                "ValueName": "Enabled",
                "ValueDisplayName": "Enabled"
              }
            ],
            "DefaultValue": "Enabled",
            "CurrentValue": "Enabled"
          },
          {
            "AttributeName": "setting2",
            "Value": [
              {
                "ValueName": "Low",
                "ValueDisplayName": "Low"
              },
              {
                "ValueName": "High",
                "ValueDisplayName": "High"
              }
            ],
            "DefaultValue": "Low"
          }
        ]
      }
    ],
    "identifier": 66355350
  },
  {
    "context": [
      "arr=($(echo '{\"crew\":[{\"name\":\"kirk\"},{\"name\":\"bones\"},{\"name\":\"mr spock\"}]}' | jq -r '.crew[].name | @sh'))",
      "declare -a \"ary=($(echo '{\"crew\":[{\"name\":\"kirk\"},{\"name\":\"bones\"},{\"name\":\"mr spock\"}]}' | jq -r '.crew[].name | @sh'))\"",
      "jq_out=$(echo '{\"crew\":[{\"name\":\"kirk\"},{\"name\":\"bones\"},{\"name\":\"mr spock\"}]}' | jq -r '.crew[].name | @sh')",
      "declare -a \"ary=( $jq_out )\"",
      "while read -r name ; do\n    ary+=(\"$name\")\ndone < <(echo '{\"crew\":[{\"name\":\"kirk\"},{\"name\":\"bones\"},{\"name\":\"mr spock\"}]}' |\n   jq -r '.crew[].name')"
    ],
    "utterance": "Extract all objects' name fields from the crew array where names may contain spaces.",
    "expressions": [
      ".crew[].name",
      ".crew[].name | @sh"
    ],
    "data": [
      {
        "input": {
          "crew": [
            {
              "name": "kirk"
            },
            {
              "name": "bones"
            },
            {
              "name": "mr spock"
            }
          ]
        },
        "output": [
          "kirk",
          "bones",
          "mr spock"
        ]
      }
    ],
    "identifier": 66370745
  },
  {
    "context": [
      "My goal is to get a list of operationIds.",
      ".paths.*.*.operationId",
      "So your meta-expression `.paths.*.*.operationId` could be written in jq as:",
      ".paths[]?[]?.operationId",
      ".paths[]?[]?.operationId?",
      "With the sample input, either of these produces:\n\"listPets\"\n\"createPets\"\n\"showPetById\""
    ],
    "utterance": "Extract all operationId values under each HTTP method for every path defined within the 'paths' object.",
    "expressions": [
      ".paths[]?[]?.operationId",
      ".paths[]?[]?.operationId?"
    ],
    "data": [
      {
        "input": {
          "paths": {
            "/pets": {
              "get": {
                "operationId": "listPets"
              },
              "post": {
                "operationId": "createPets"
              }
            },
            "/pets/{petId}": {
              "get": {
                "operationId": "showPetById"
              }
            }
          }
        },
        "output": [
          "listPets",
          "createPets",
          "showPetById"
        ]
      }
    ],
    "identifier": 66382300
  },
  {
    "context": [
      "I have a list of YouTube videos and and want to fetch their `id`, `name` and the preview image.",
      "I'm making use of `youtube-dl` to get a json output, that I parse for the keys `id`, `title` and the nested array `thumbnails`.",
      "Ideally the output would look like this:\n\"4czjS9h4Fpg\",\"Perseverance Rover\u2019s Descent and Touchdown on Mars (Official NASA Video)\",\"168x94\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCKgBEF5IVfKriqkDDggBFQAAiEIYAXABwAEG&rs=AOn4CLBeXaobqWQ3MHAvEzLHQtitoAKKow\",\"196x110\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCMQBEG5IVfKriqkDDggBFQAAiEIYAXABwAEG&rs=AOn4CLB2j8DNX2ZOyXHUS2MwRz4gG8admQ\",\"246x138\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCPYBEIoBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&rs=AOn4CLDUIrTqT-g6F5z62q_Jq2RXy3AydQ\",\"336x188\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCNACELwBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&rs=AOn4CLDtiAfOuC4lgjiMxXeJ3qIh7uV6Zg\",\"1920x1080\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/maxresdefault.jpg\",",
      "You can use map for expanding each object in the third element to resolution and url.",
      ".[:2] + (.[2] | map(.resolution, .url)) | @csv",
      "Alternatively, an exception-driven approach like below would also yield the same result given your sample input.",
      "map((.[] | .resolution, .url)? // .) | @csv"
    ],
    "utterance": "Produce a CSV line that outputs the id, title, and then, for each thumbnail, its resolution and url, from an array of [id, title, thumbnails].",
    "expressions": [
      ".[:2] + (.[2] | map(.resolution, .url)) | @csv",
      "map((.[] | .resolution, .url)? // .) | @csv"
    ],
    "data": [
      {
        "input": [
          "4czjS9h4Fpg",
          "Perseverance Rover\u2019s Descent and Touchdown on Mars (Official NASA Video)",
          [
            {
              "height": 94,
              "url": "https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCKgBEF5IVfKriqkDDggBFQAAiEIYAXABwAEG&rs=AOn4CLBeXaobqWQ3MHAvEzLHQtitoAKKow",
              "width": 168,
              "resolution": "168x94",
              "id": "0"
            },
            {
              "height": 110,
              "url": "https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCMQBEG5IVfKriqkDDggBFQAAiEIYAXABwAEG&rs=AOn4CLB2j8DNX2ZOyXHUS2MwRz4gG8admQ",
              "width": 196,
              "resolution": "196x110",
              "id": "1"
            },
            {
              "height": 138,
              "url": "https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCPYBEIoBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&rs=AOn4CLDUIrTqT-g6F5z62q_Jq2RXy3AydQ",
              "width": 246,
              "resolution": "246x138",
              "id": "2"
            },
            {
              "height": 188,
              "url": "https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCNACELwBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&rs=AOn4CLDtiAfOuC4lgjiMxXeJ3qIh7uV6Zg",
              "width": 336,
              "resolution": "336x188",
              "id": "3"
            },
            {
              "height": 1080,
              "url": "https://i.ytimg.com/vi/4czjS9h4Fpg/maxresdefault.jpg",
              "width": 1920,
              "resolution": "1920x1080",
              "id": "4"
            }
          ]
        ],
        "output": "\"4czjS9h4Fpg\",\"Perseverance Rover\u2019s Descent and Touchdown on Mars (Official NASA Video)\",\"168x94\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCKgBEF5IVfKriqkDDggBFQAAiEIYAXABwAEG&rs=AOn4CLBeXaobqWQ3MHAvEzLHQtitoAKKow\",\"196x110\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEbCMQBEG5IVfKriqkDDggBFQAAiEIYAXABwAEG&rs=AOn4CLB2j8DNX2ZOyXHUS2MwRz4gG8admQ\",\"246x138\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCPYBEIoBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&rs=AOn4CLDUIrTqT-g6F5z62q_Jq2RXy3AydQ\",\"336x188\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/hqdefault.jpg?sqp=-oaymwEcCNACELwBSFXyq4qpAw4IARUAAIhCGAFwAcABBg==&rs=AOn4CLDtiAfOuC4lgjiMxXeJ3qIh7uV6Zg\",\"1920x1080\",\"https://i.ytimg.com/vi/4czjS9h4Fpg/maxresdefault.jpg\""
      }
    ],
    "identifier": 66332143
  },
  {
    "context": [
      "I would like to select the \"highest of first\" values, being 0.99980000 - how do I go about it with jq?",
      "Use `max_by`:",
      "    jq -r 'max_by(.[0] | tonumber) | .[0]' file.json"
    ],
    "utterance": "Find the largest value in the first element position of each inner array.",
    "expressions": [
      "max_by(.[0] | tonumber) | .[0]"
    ],
    "data": [
      {
        "input": [
          [
            "0.99980000",
            "3813863.19000000"
          ],
          [
            "0.99970000",
            "3813412.11000000"
          ],
          [
            "0.99960000",
            "1188619.16000000"
          ],
          [
            "0.99950000",
            "1992659.70000000"
          ],
          [
            "0.99940000",
            "3258570.31000000"
          ]
        ],
        "output": "0.99980000"
      }
    ],
    "identifier": 66394429
  },
  {
    "context": [
      "I defined a function named `grep` in my `~/.jq`:\r\n\r\n```jq\r\ndef grep($q; $f):\r\n  paths as $p |\r\n  select(getpath($p)?|test($q;$f)) |\r\n  $p ;\r\n```",
      "as-is, an error is thrown if the function is called with only a single parameter (`jq: error: grep/1 is not defined at <top-level>`)",
      "All you have to do is add a suitable def for `grep/1` in ~/.jq.  For example, you could add (after `grep/2`):\r\n\r\n    def grep($q): grep($q; \"i\");",
      "if you want \"i\" to be the default.  (You could change the default to be \"\" if you like, but then your query will not return any answers with json.txt.)"
    ],
    "utterance": "Define a function that matches values with a regular expression, allowing the regex flags argument to be optional and defaulting to 'i' if omitted.",
    "expressions": [
      "def grep($q; $f): paths as $p | select(getpath($p)?|test($q;$f)) | $p ;\ndef grep($q): grep($q; \"i\");"
    ],
    "data": [
      {
        "input": {
          "packages_cache": {
            "https://packagecontrol.io/repository.json": [
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {},
              {}
            ]
          }
        },
        "output": [
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "name"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "homepage"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "readme"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "issues"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "releases",
            0,
            "url"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "releases",
            1,
            "url"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "releases",
            2,
            "url"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "releases",
            3,
            "url"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "releases",
            4,
            "url"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "releases",
            5,
            "url"
          ],
          [
            "packages_cache",
            "https://packagecontrol.io/repository.json",
            625,
            "releases",
            6,
            "url"
          ]
        ]
      }
    ],
    "identifier": 66342200
  },
  {
    "context": [
      "The output I need is:\n\"Page 1\",\"11111\",\"Hello World\"\n\"Page 2\",\"22222\",\"Hello World\"\n\"Page 3\",\"33333\",\"Hello World\"",
      "I can get the elements from the array with:\ncat my.json | jq -r '.results[] | [.title, .content.id] | @csv'\nBut how do I add the \"query\" element which is outside of the array to each line in the output?",
      ".query as $q | .results[] | [.title, .content.id, $q] | @csv",
      "(.results[] | [.title, .content.id]) + [.query] | @csv"
    ],
    "utterance": "Output each result's title, content id, and the top-level query value together as CSV rows.",
    "expressions": [
      ".query as $q | .results[] | [.title, .content.id, $q] | @csv",
      "(.results[] | [.title, .content.id]) + [.query] | @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "title": "Page 1",
              "content": {
                "id": "11111"
              }
            },
            {
              "title": "Page 2",
              "content": {
                "id": "22222"
              }
            },
            {
              "title": "Page 3",
              "content": {
                "id": "33333"
              }
            }
          ],
          "start": 0,
          "limit": 25,
          "size": 3,
          "totalSize": 3,
          "query": "Hello World"
        },
        "output": "\"Page 1\",\"11111\",\"Hello World\"\n\"Page 2\",\"22222\",\"Hello World\"\n\"Page 3\",\"33333\",\"Hello World\""
      }
    ],
    "identifier": 66383823
  },
  {
    "context": [
      "So if \"TheField\" doesn't exist or it's null I need to delete SomeField6. Right now instead of delete current field JQ delete all statement and I get nothing on response.",
      "A simple and robust (w.r.t. versions of jq) method for conditionally adding a key, $k, to an object, $o, is to use the template:",
      "$o + (if CONDITION then {($k): $value} else null end)",
      "So in your case, you could write something like:",
      "((try first(.response.somefield4[].TheField[]) catch null) // null) as $value",
      ". + (if $value then {SomeField6: $value} else null end)",
      "If $o is an object which may or may not have a key, say $k, then to delete the key if its value is null, and leave $o as-is otherwise, you could write:",
      "$o | if .[$k] == null then del(.[$k]) else . end"
    ],
    "utterance": "Set SomeField6 to the value of .response.somefield4[].TheField[] only if it exists and is not null; otherwise, remove SomeField6 from the output.",
    "expressions": [
      "((try first(.response.somefield4[].TheField[]) catch null) // null) as $value | . + (if $value then {SomeField6: $value} else null end)"
    ],
    "data": [
      {
        "input": {
          "response": {
            "somefield1": 0,
            "somefield2": 0,
            "somefield3": 0.0,
            "somefield4": [
              {
                "somefield5": "abc",
                "somefield6": "123",
                "TheField": [
                  "\u0000\"{\"id\":\"123,SomeFields\":{\"SomeField\":{some data}}}\"\\u0000"
                ]
              }
            ]
          }
        },
        "output": {
          "SomeField6": "\u0000\"{\"id\":\"123,SomeFields\":{\"SomeField\":{some data}}}\"\\u0000"
        }
      },
      {
        "input": {
          "response": {
            "somefield1": 0,
            "somefield2": 0,
            "somefield3": 0.0,
            "somefield4": [
              {
                "somefield5": "abc",
                "somefield6": "123"
              }
            ]
          }
        },
        "output": {}
      }
    ],
    "identifier": 66385148
  },
  {
    "context": [
      "I have JSON\n\n```\n[\n  {\"id\": \"1\"},\n  {\"id\": \"5\"},\n  {\"id\": \"9\"},\n  {\"id\": \"0\"},\n  {\"id\": \"3\"}\n]\n```\n\nI want to insert an object to produce:\n\n```\n[\n  {\"id\": \"1\"},\n  {\"id\": \"5\"},\n  {\"id\": \"2\"},\n  {\"id\": \"9\"},\n  {\"id\": \"0\"},\n  {\"id\": \"3\"}\n]\n```\n\nHow do I do this jq? Either by index or relative to other objects.",
      "def insert($i; $x): .[:$i] + [$x] + .[$i:];"
    ],
    "utterance": "Insert {\"id\": \"2\"} at index 2 in the array of objects.",
    "expressions": [
      "insert(2; {\"id\": \"2\"})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1"
          },
          {
            "id": "5"
          },
          {
            "id": "9"
          },
          {
            "id": "0"
          },
          {
            "id": "3"
          }
        ],
        "output": [
          {
            "id": "1"
          },
          {
            "id": "5"
          },
          {
            "id": "2"
          },
          {
            "id": "9"
          },
          {
            "id": "0"
          },
          {
            "id": "3"
          }
        ]
      }
    ],
    "identifier": 66428658
  },
  {
    "context": [
      "The problem is that I can't hardcode the JSON so I'm inputting the string as a variable. But I can't get the syntax to work:",
      "cat $jsonFile | jq -r --arg objName $objectName --arg jsonString $objJSON '.data[$objName] += $jsonString'",
      "Use `--argjson` rather than `--arg` when passing JSON rather than strings.",
      "jq --arg     objectName \"$objName\" \\\n   --argjson jsonString \"$objJSON\" \\\n  '.data[$objectName] += $jsonString'"
    ],
    "utterance": "Dynamically add a new object as a field to the 'data' key, using variables for both the field name and the object value.",
    "expressions": [
      ".data[$objectName] += $jsonString"
    ],
    "data": [
      {
        "input": {
          "data": {}
        },
        "output": {
          "data": {
            "objName": {
              "test": "json"
            }
          }
        }
      }
    ],
    "identifier": 66405239
  },
  {
    "context": [
      "This works:\n\n    - run: call some https endpoint > at.json\n    - run: jq '.authorizationToken' at.json\n",
      "Now I need to set this value as a env-var. [Reading the docs on this, it looks like it can be done][1], but I'm not sure how to call jq and set the key/value into an env-var.",
      "I feel like I need to do something like this:\n\n    - run: echo \"AUTH_TOKEN=run the jq command here\" >> $GITHUB_ENV\n",
      "- I needed to use `>> $GITHUB_ENV` to set the environement variable.\n- I needed to get the correct syntax to run a set of command line programs, inline.\n\n    - run: call some https endpoint > at.json\n    - run: echo \"AUTH_TOKEN= $(jq '.authorizationToken' at.json)\" >> $GITHUB_ENV\n    - run: echo \"${{ env.AUTH_TOKEN }}\"\n",
      "Like you discovered yourself, you can pass it as an environment variable:\nsteps:\n  - run: |\n      token=$( callEndpoint | jq '.authorizationToken' )\n      echo \"AUTH_TOKEN=$token\" >> \"$GITHUB_ENV\""
    ],
    "utterance": "Extract the value of the authorizationToken key from the file at.json and assign it to an environment variable AUTH_TOKEN for use in later steps.",
    "expressions": [
      "jq '.authorizationToken' at.json",
      "callEndpoint | jq '.authorizationToken'"
    ],
    "data": [
      {
        "input": {
          "authorizationToken": "<snip>",
          "expiration": "2021-02-26T18:18:38+00:00"
        },
        "output": "<snip>"
      }
    ],
    "identifier": 66381595
  },
  {
    "context": [
      "How do I create a new json file from a list of key value pairs, with sub sections and using `jq` (or something else in a shell script)?",
      "data | jq -nR '\n\ndef parse: capture(\"(?<x>[^:]*):(?<y>[^=]*)=(?<value>.*)\");\n\nreduce inputs as $line ({};\n   ($line | parse) as $p\n   | .[$p.x][$p.y] = ($p.value) )\n'",
      "That will convert into:\n\n    {\n      \"AppSettings\": {\n        \"Environment\": \"Dev\",\n      },\n      \"Security\": {\n        \"ClientId\": \"123456\",\n        \"ClientSecret\": \"abcdefg\"\n      }\n    }"
    ],
    "utterance": "Convert lines in the format Section:Key=Value into a nested object with keys for each section and corresponding key-value pairs under each section.",
    "expressions": [
      "jq -nR '\n\ndef parse: capture(\"(?<x>[^:]*):(?<y>[^=]*)=(?<value>.*)\");\n\nreduce inputs as $line ({};\n   ($line | parse) as $p\n   | .[$p.x][$p.y] = ($p.value) )\n'"
    ],
    "data": [
      {
        "input": "Security:ClientId=123456\nSecurity:clientSecret=abcdefg\nAppSettings:Environment=Dev",
        "output": {
          "AppSettings": {
            "Environment": "Dev"
          },
          "Security": {
            "ClientId": "123456",
            "clientSecret": "abcdefg"
          }
        }
      }
    ],
    "identifier": 66432229
  },
  {
    "context": [
      "I have several json files I want to combine. Some are arrays of objects and some are single objects. I want to effectively concatenate all of this into a single array.",
      "For example:",
      "[ { \"name\": \"file1\" } ]",
      "{ \"name\": \"file2\" }",
      "{ \"name\": \"file3\" }",
      "And I want to end up with:",
      "[ { \"name\": \"file1\" } { \"name\": \"file2\" }, { \"name\": \"file3\" }, ]",
      "This did it:\n> jq -n '[inputs] | add' $(find . -name '*.json') > combined.json",
      "jq -n 'reduce inputs as $in (null;\n   . + if $in|type == \"array\" then $in else [$in] end)\n' $(find . -name '*.json') > combined.json"
    ],
    "utterance": "Combine multiple files, some containing an array of objects and some containing single objects, into a single array with all objects.",
    "expressions": [
      "[inputs] | add",
      "reduce inputs as $in (null; . + if $in|type == \"array\" then $in else [$in] end)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "file1"
            }
          ],
          {
            "name": "file2"
          },
          {
            "name": "file3"
          }
        ],
        "output": [
          {
            "name": "file1"
          },
          {
            "name": "file2"
          },
          {
            "name": "file3"
          }
        ]
      }
    ],
    "identifier": 66443228
  },
  {
    "context": [
      "How to make this return 1 or some non-zero value?",
      "You should use `input` with `-n`/`--null-input` on the command line. This way JQ will fail if its input is empty.",
      "$ echo | jq -n 'input.key'",
      "$ echo $?",
      "5",
      "If you want to specify the return code when the input is empty, you could use `halt_error/1`, like so:",
      "$ echo \"\" | jq -n 'try input.key catch halt_error(9)' 2> /dev/null",
      "$ echo $?",
      "9"
    ],
    "utterance": "Return a non-zero exit code when the input is empty.",
    "expressions": [
      "jq -n 'input.key'",
      "jq -n 'try input.key catch halt_error(9)'"
    ],
    "data": [
      {
        "input": "",
        "output": ""
      }
    ],
    "identifier": 66468950
  },
  {
    "context": [
      "I want to process data with a bash script but have trouble to get the InfluxDB output to the desired csv output with all tags and fields.",
      "And I would like to transform it to:",
      "\"name\",\"symbol\",\"symbolTo\",\"time\",\"priceMean\"",
      "\"tickerPrice\",\"AAVE\",\"EUR\",1614402874120627200,282.398263888889",
      "\"tickerPrice\",\"BTC\",\"EUR\",1614402874120627200,39189.756944444445",
      "Because this is not the only query I want to do it would be nice that it is universal for the content, so the number of fields and tags could be different.",
      "The following produces the required output in a way that allows for multiple values of \"time\" in each `.values` array, but does not refer to the specific headers except for \"name\":",
      "def headers:\n (.tags | keys_unsorted) as $tags\n | ([\"name\"] + $tags + .columns); \n\n.results[0]\n| (.series[0] | headers),\n  (.series[] | ([.name, .tags[]] + .values[]))\n| @csv"
    ],
    "utterance": "Convert query results containing varying tags and fields into CSV format with each row containing the name, tags, and all values, and include a universal header row.",
    "expressions": [
      "def headers:\n (.tags | keys_unsorted) as $tags\n | ([\"name\"] + $tags + .columns);\n\n.results[0]\n| (.series[0] | headers),\n  (.series[] | ([.name, .tags[]] + .values[]))\n| @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "series": [
                {
                  "name": "tickerPrice",
                  "tags": {
                    "symbol": "AAVE",
                    "symbolTo": "EUR"
                  },
                  "columns": [
                    "time",
                    "priceMean"
                  ],
                  "values": [
                    [
                      1614402874120627200,
                      282.398263888889
                    ]
                  ]
                },
                {
                  "name": "tickerPrice",
                  "tags": {
                    "symbol": "BTC",
                    "symbolTo": "EUR"
                  },
                  "columns": [
                    "time",
                    "priceMean"
                  ],
                  "values": [
                    [
                      1614402874120627200,
                      39189.756944444445
                    ]
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "\"name\",\"symbol\",\"symbolTo\",\"time\",\"priceMean\"",
          "\"tickerPrice\",\"AAVE\",\"EUR\",1614402874120627200,282.398263888889",
          "\"tickerPrice\",\"BTC\",\"EUR\",1614402874120627200,39189.756944444445"
        ]
      }
    ],
    "identifier": 66403782
  },
  {
    "context": [
      "Have a value inside a JSON object with a variable that needs to be updated using JQ, below is my son file and jq command I&#39;m using to update **accountid** in json file",
      "jq &#39;map(.$accountid = &quot;123&quot;)&#39; myjson.json",
      "jq: error (at myjson.json:1): Cannot index string with string &quot;$accountid&quot;",
      "Consider therefore this example:",
      "echo '{\"bucketname\":\"test/$accountid/123\",\"objectname\":\"test/$accountid/123\",\"targetlocation\":\"$TARGET_LOCATION\"}' | jq 'map_values( sub(\"[$]accountid\";\"123\") )'",
      "produces:",
      "{\n  \"bucketname\": \"test/123/123\",\n  \"objectname\": \"test/123/123\",\n  \"targetlocation\": \"$TARGET_LOCATION\"\n}"
    ],
    "utterance": "Replace all occurrences of '$accountid' with '123' in every value of the object.",
    "expressions": [
      "map_values(sub(\"[$]accountid\";\"123\"))"
    ],
    "data": [
      {
        "input": {
          "bucketname": "test/$accountid/123",
          "objectname": "test/$accountid/123",
          "targetlocation": "$TARGET_LOCATION"
        },
        "output": {
          "bucketname": "test/123/123",
          "objectname": "test/123/123",
          "targetlocation": "$TARGET_LOCATION"
        }
      }
    ],
    "identifier": 66449754
  },
  {
    "context": [
      "I want the region and aws_account_id to be updated dynamically instead of hardcoding the value directly inside the taskdef.json.Is there a way to update these value?"
    ],
    "utterance": "Replace all instances of 'region' and 'aws_account_id' with specified values throughout the data structure.",
    "expressions": [
      "jq --arg region \"$region\" --arg account_id \"$account_id\" 'walk(if type==\"string\" then gsub(\"region\"; $region) | gsub(\"aws_account_id\"; $account_id) else . end)' taskdef.json"
    ],
    "data": [
      {
        "input": {
          "containerDefinitions": [
            {
              "logConfiguration": [
                {
                  "logDriver": "fluentd",
                  "options": {
                    "tag": "fluentd demo"
                  },
                  "secretOptions": [
                    {
                      "name": "fluentd-address",
                      "valueFrom": "arn:aws:ssm:region:aws_account_id:parameter:parameter_name"
                    },
                    {
                      "name": "fluentd-name",
                      "valueFrom": "arn:aws:ssm:region:aws_account_id:parameter:parameter_name"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "containerDefinitions": [
            {
              "logConfiguration": [
                {
                  "logDriver": "fluentd",
                  "options": {
                    "tag": "fluentd demo"
                  },
                  "secretOptions": [
                    {
                      "name": "fluentd-address",
                      "valueFrom": "arn:aws:ssm:us-east-1:12345:parameter:parameter_name"
                    },
                    {
                      "name": "fluentd-name",
                      "valueFrom": "arn:aws:ssm:us-east-1:12345:parameter:parameter_name"
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 66450137
  },
  {
    "context": [
      "My end goal is to have a Json file like this:\n\n    {\n      \"Security\": {\n        \"ClientId\": \"123456\",\n        \"ClientSecret\": \"abcdefg\"\n      },\n      \"AppSettings\": {\n        \"Environment\": \"Dev\"\n      },\n      \"AnotherCustomSetting\": \"SomethingElse\"      \n    }",
      "In my previous question I did not indicate that I would need properties at the root level (`AnotherCustomSetting` in this case).",
      "So I attempted to put an `if` statement in the `reduce inputs` section.  Unfortunately it is failing with the following error:\n\n> jq: error (at <stdin>:4): Cannot index object with null",
      "Is it possible to do an `if then else` in a `reduce inputs` section like I am attempting?  If so, how is it done?",
      "This should do it:\n\ndef parse: capture(\"(?<x>[^:=]*)(:(?<y>[^:=]*))?=(?<value>.*)\");\n\nreduce inputs as $line ({};\n   ($line | parse) as $p\n   | if $p.y then .[$p.x][$p.y] = $p.value\n     else .[$p.x] = $p.value end )"
    ],
    "utterance": "Parse key-value lines where keys may have an optional group (as in Group:Property=Value), and build output so grouped properties are objects and ungrouped become root-level properties with their values.",
    "expressions": [
      "def parse: capture(\"(?<x>[^:=]*)(:(?<y>[^:=]*))?=(?<value>.*)\");\n\nreduce inputs as $line ({};\n   ($line | parse) as $p\n   | if $p.y then .[$p.x][$p.y] = $p.value\n     else .[$p.x] = $p.value end )"
    ],
    "data": [
      {
        "input": "Security:ClientId=123456\nSecurity:ClientSecret=abcdefg\nAppSettings:Environment=Dev\nAnotherCustomSetting=SomethingElse",
        "output": {
          "Security": {
            "ClientId": "123456",
            "ClientSecret": "abcdefg"
          },
          "AppSettings": {
            "Environment": "Dev"
          },
          "AnotherCustomSetting": "SomethingElse"
        }
      }
    ],
    "identifier": 66449460
  },
  {
    "context": [
      "I have two json files that I would like to merge using jq in order to pass to AWS Lambda as a payload.",
      "I know I can do ```jq -s . File1 File2```, but this puts it into an array - is there a way to do this merge without putting the two files into an array?",
      "This seemed to work ```jq -s &#39;.[0] * .[1]&#39; File1 File2```"
    ],
    "utterance": "Combine two files containing distinct objects into a single object containing all top-level pairs from both files.",
    "expressions": [
      "jq -s '.[0] * .[1]' File1 File2"
    ],
    "data": [
      {
        "input": [
          {
            "Product": {
              "name": "Foo",
              "description": "bar"
            }
          },
          {
            "Store": {
              "id": "123",
              "location": "abc"
            }
          }
        ],
        "output": {
          "Product": {
            "name": "Foo",
            "description": "bar"
          },
          "Store": {
            "id": "123",
            "location": "abc"
          }
        }
      }
    ],
    "identifier": 66509004
  },
  {
    "context": [
      "\"jq .lighthouseResult.categories.performance.score web.json\" is \"2.8  s\" and when I see the same value in CSV, I see a special character due the space in between 2.8 and s.",
      "If `.lighthouseResult.categories.performance.score` does indeed contain a single space, then you could remove it by using this jq program:",
      ".lighthouseResult.categories.performance.score | sub(\" \";\"\")",
      "To remove all spaces, change `sub` to `gsub`.",
      "To remove unwanted characters, you might wish to consider a filter such as: gsub(\"[^A-Za-z0-9.]\";\"\")"
    ],
    "utterance": "Extract the value at .lighthouseResult.categories.performance.score, removing all spaces or non-alphanumeric characters except the period.",
    "expressions": [
      ".lighthouseResult.categories.performance.score | gsub(\" \";\"\")",
      ".lighthouseResult.categories.performance.score | gsub(\"[^A-Za-z0-9.]\";\"\")"
    ],
    "identifier": 66515843
  },
  {
    "context": [
      "I am struggling to prepend and postpend some text to this output.  I need to prepend \r\n\r\n    appConfig = JSON.parse(`\r\n\r\nand postpend \r\n\r\n    `);\r\n",
      "How can I prepend and postpend text to this output?",
      "One all-jq possibility would be as follows:\r\n\r\n```\r\njq -nRrj '\r\n  def parse: capture(\"(?<x>[^:=]*)(:(?<y>[^:=]*))?=(?<value>.*)\");\r\n  reduce inputs as $line ({};\r\n    ($line | parse) as $p\r\n    | if $p.y then .[$p.x][$p.y] = $p.value\r\n      else .[$p.x] = $p.value end )\r\n  | \"appConfig = JSON.parse(`\", ., \"`);\"\r\n'\r\n```",
      "With the sample input, this produces:\r\n```\r\nappConfig = JSON.parse(`{\r\n  \"Security\": {\r\n    \"ClientId\": \"123456\",\r\n    \"ClientSecret\": \"abcdefg\"\r\n  },\r\n  \"AppSettings\": {\r\n    \"Environment\": \"Dev\"\r\n  },\r\n  \"AnotherCustomSetting\": \"SomethingElse\"\r\n}`);"
    ],
    "utterance": "Wrap the parsed configuration in appConfig = JSON.parse(`...`); so the output is a JavaScript assignment with the configuration as a string template.",
    "expressions": [
      "jq -nRrj '\n  def parse: capture(\"(?<x>[^:=]*)(:(?<y>[^:=]*))?=(?<value>.*)\");\n  reduce inputs as $line ({};\n    ($line | parse) as $p\n    | if $p.y then .[$p.x][$p.y] = $p.value\n      else .[$p.x] = $p.value end )\n  | \"appConfig = JSON.parse(`\", ., \"`);\"\n'"
    ],
    "data": [
      {
        "input": "Security:ClientId=123456\nSecurity:ClientSecret=abcdefg\nAppSettings:Environment=Dev\nAnotherCustomSetting=SomethingElse\n",
        "output": "appConfig = JSON.parse(`{\n  \"Security\": {\n    \"ClientId\": \"123456\",\n    \"ClientSecret\": \"abcdefg\"\n  },\n  \"AppSettings\": {\n    \"Environment\": \"Dev\"\n  },\n  \"AnotherCustomSetting\": \"SomethingElse\"\n}`);"
      }
    ],
    "identifier": 66471564
  },
  {
    "context": [
      "I want to use `jq` to convert this file to a plain text configuration file of a following format:\r\n\r\n    KEY1=value1\r\n    KEY2=value2\r\n    ...\r\n    KEYn=valuen\r\n\r\n(the keys should be uppercased in the result file).",
      "jq -r 'to_entries[] | (.key | ascii_upcase) + \"=\" + .value' < example.json"
    ],
    "utterance": "Convert a flat key-value mapping to lines of KEY=VALUE where the keys are uppercased.",
    "expressions": [
      "to_entries[] | (.key | ascii_upcase) + \"=\" + .value"
    ],
    "data": [
      {
        "input": {
          "key1": "value1",
          "key2": "value2",
          "keyn": "valuen"
        },
        "output": "KEY1=value1\nKEY2=value2\nKEYN=valuen"
      }
    ],
    "identifier": 66564551
  },
  {
    "context": [
      "Need some help with jq and reading in a json file that must have \\n values because I need to import it into something else later. How can I have jq interpret it as a literal \\n instead of the line breaks below....?  Notice my json has a \\n and I want it like that.",
      "It should look like this, but it looks like the one above. How can I make it look like this.\r\n\r\n    Alex A really\\nnice kid\r\n    ----------------------------------------done---------------------\r\n    James One mature\\nBoy who\\ndoes his homework\r\n    ----------------------------------------done---------------------\r\n",
      "You can actually do this directly in `jq`, by replacing actual newlines (which are represented by `\\n` in JSON strings) with literal `\\` and `n` characters:\r\n\r\n    $ jq -r -M '.person[] | .name + \" \" + (.description | gsub(\"\\n\"; \"\\\\n\"))' file.json",
      "Alex A really\\nnice kid",
      "James One mature\\nBoy who\\ndoes his homework"
    ],
    "utterance": "Output each person\u2019s name followed by their description, converting newline characters in the description to the literal string \\n.",
    "expressions": [
      ".person[] | .name + \" \" + (.description | gsub(\"\\n\"; \"\\\\n\"))"
    ],
    "data": [
      {
        "input": {
          "person": [
            {
              "name": "Alex",
              "age": "10",
              "description": "A really\nnice kid"
            },
            {
              "name": "James",
              "age": "17",
              "description": "One mature\nBoy who\ndoes his homework"
            }
          ]
        },
        "output": [
          "Alex A really\\nnice kid",
          "James One mature\\nBoy who\\ndoes his homework"
        ]
      }
    ],
    "identifier": 66540184
  },
  {
    "context": [
      "But I want to concatenate each structure in to an array, like:",
      "[",
      "\t{",
      "\t  \"name\": \"name1\",",
      "\t  \"subject\": \"subj1\",",
      "\t  \"version\": \"1\"",
      "\t},",
      "\t{",
      "\t  \"name\": \"name2\",",
      "\t  \"subject\": \"subj2\",",
      "\t  \"version\": \"1\"",
      "\t}",
      "]"
    ],
    "utterance": "Combine multiple structured objects into a single array, each object having fields 'name', 'subject', and 'version', with potentially different values.",
    "expressions": [
      "jq -s '.' file1.json file2.json",
      "jq -s '.' <<< \"$(cat file1.json)\" <<< \"$(cat file2.json)\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "name1",
            "subject": "subj1",
            "version": "1"
          },
          {
            "name": "name2",
            "subject": "subj2",
            "version": "1"
          }
        ],
        "output": [
          {
            "name": "name1",
            "subject": "subj1",
            "version": "1"
          },
          {
            "name": "name2",
            "subject": "subj2",
            "version": "1"
          }
        ]
      }
    ],
    "identifier": 66570695
  },
  {
    "context": [
      "And I want to get the results as such:  \r\n\r\n    {\"count\": 23, \"users\": [2, 5]} \r\n\r\nwhere all the ids are grouped into an array.",
      "I have just figured out how to make it work, which is: \r\n\r\n```bash\r\necho \"$json\" | jq -c '{\"count\": .payload.count, \"users\": [.payload.results[].id]}'\r\n```"
    ],
    "utterance": "Extract the count and collect all ids from the results array into a users array.",
    "expressions": [
      "{\"count\": .payload.count, \"users\": [.payload.results[].id]}"
    ],
    "data": [
      {
        "input": {
          "payload": {
            "count": 23,
            "results": [
              {
                "id": 2,
                "name": "bob"
              },
              {
                "id": 5,
                "name": "John"
              }
            ]
          }
        },
        "output": {
          "count": 23,
          "users": [
            2,
            5
          ]
        }
      }
    ],
    "identifier": 66571645
  },
  {
    "context": [
      "What I would like to is create a new JSON object that combines keys from JSON object #1 (specifically the Template_SR key) and JSON object #2 (the Template_Name and Template_ID keys), but only when a VM-Template cannot be found on Pool_ID that matches on both object #1 and object #2",
      "For the two given JSON objects:\r\ndest_sr.json:\r\n{\r\n  \"Type\": \"pool\",\r\n  \"Pool_ID\": \"adb58e84\",\r\n  \"Template_SR\": \"fc820294\"\r\n}\r\n{\r\n  \"Type\": \"pool\",\r\n  \"Pool_ID\": \"d2dea684\",\r\n  \"Template_SR\": \"313f2a07\"\r\n}\r\n\r\nsrc_templates.json:\r\n{\r\n  \"Type\": \"VM-template\",\r\n  \"Template_Name\": \"CentOS 7 CloudInit V1\",\r\n  \"Template_ID\": \"9b1833a3\",\r\n  \"Pool_ID\": \"adb58e84\"\r\n}\r\n",
      "Is there any way I can write my merge so that the object would look like this? \r\n{\r\n  \"Type\":\"VM-template\",\r\n  \"Pool_ID\":\"d2dea684\",\r\n  \"Template_SR\":\"fc820294\",\r\n  \"Template_Name\":\"CentOS 7 CloudInit V1\",\r\n  \"Template_ID\":\"9b1833a3\"\r\n}\r\n",
      "I think given your particular inputs and your desired result, I don&#39;t think the hashing is necessary. It seems like all you need to do is select the inputs from `dest_sr.json` where it doesn&#39;t match the id in `src_templates.json`, then combine it with the desired values from the template.",
      "$ jq --argfile template src_templates.json '\r\nselect(.Pool_ID != $template.Pool_ID) + ($template|{Template_Name,Template_ID})\r\n' dest_sr.json"
    ],
    "utterance": "For each entry, if Pool_ID does not match between the two files, output an object containing Template_SR from the first and Template_Name, Template_ID from the second, merged together.",
    "expressions": [
      "jq --argfile template src_templates.json 'select(.Pool_ID != $template.Pool_ID) + ($template|{Template_Name,Template_ID})' dest_sr.json"
    ],
    "data": [
      {
        "input": [
          {
            "Type": "pool",
            "Pool_ID": "adb58e84",
            "Template_SR": "fc820294"
          },
          {
            "Type": "pool",
            "Pool_ID": "d2dea684",
            "Template_SR": "313f2a07"
          }
        ],
        "output": {
          "Type": "pool",
          "Pool_ID": "d2dea684",
          "Template_SR": "313f2a07",
          "Template_Name": "CentOS 7 CloudInit V1",
          "Template_ID": "9b1833a3"
        }
      },
      {
        "input": {
          "Type": "VM-template",
          "Template_Name": "CentOS 7 CloudInit V1",
          "Template_ID": "9b1833a3",
          "Pool_ID": "adb58e84"
        }
      }
    ],
    "identifier": 66538285
  },
  {
    "context": [
      "Can anyone help me to understand how I can print countryCode followed by connectionName and load with a percentage symbol all on one line nicely formatted - all using jq - not using sed, column or any other unix external command.",
      "map(select(.countryCode == \\\"US\\\" and .load <= \\\"99\\\")) | sort_by(.load) | limit(20;.[]) | [.countryCode, .connectionName, .load] | (.[1])",
      "jq -r -c 'map(select(.countryCode == \"US\" and .load <= 99)) |\n              sort_by(.load) |\n              limit(20;.[]) |\n              \"\\(.countryCode) \\(.connectionName) \\(.load)%\"'"
    ],
    "utterance": "Print the countryCode, connectionName, and load (appending a percent sign) for up to 20 US servers with load 99 or less, each on one formatted line.",
    "expressions": [
      "map(select(.countryCode == \"US\" and .load <= 99)) | sort_by(.load) | limit(20;.[]) | \"\\(.countryCode) \\(.connectionName) \\(.load)%\""
    ],
    "identifier": 66581331
  },
  {
    "context": [
      "I\u2019m trying to figure out how to examine a schema and get back all $refs (specifically, their values) in to an array that I can examine in bash.",
      "I\u2019m trying to get a list of `$ref`s that are external to the file. Let\u2019s say I have a schema like this, how can I get an array of \"Apple.schema.json\" and \"Banaan.schema.json\" (or the entire property would be fine)?",
      "So to get the list of $ref's\n\n    jq -r '.properties[] | select(.\">$ref\" != null) | .\"$ref\"' filename",
      "One way to be succinct while being sure to retrieve just the values at the `\"$ref\"` key:\n```\njq -r '.properties[] | .\"$ref\" // empty'\n```"
    ],
    "utterance": "Extract all $ref field values from the properties object as an array.",
    "expressions": [
      ".properties[] | select(.\"$ref\" != null) | .\"$ref\"",
      ".properties[] | .\"$ref\" // empty"
    ],
    "data": [
      {
        "input": {
          "$schema": "http://json-schema.org/draft-07/schema",
          "$id": "MySchema.schema.json",
          "version": "1.2.3",
          "type": "object",
          "properties": {
            "DEFINED_TYPE": {
              "type": "string"
            },
            "Apple": {
              "$ref": "Apple.schema.json"
            },
            "Banana": {
              "$ref": "Banana.schema.json"
            },
            "Chicken": {
              "$ref": "#/definitions/Chicken"
            },
            "TIME": {
              "type": "string",
              "format": "date-time"
            }
          }
        },
        "output": [
          "Apple.schema.json",
          "Banana.schema.json",
          "#/definitions/Chicken"
        ]
      }
    ],
    "identifier": 66532654
  },
  {
    "context": [
      "Essentially \"mitre_test\" should get compared to \"sys_id\". When compared, the \"mitreid\" from in2.json becomes technique_ID in the output (and is generally the unifying field of each output object).",
      "some of the mitre_test values have pairs and are not in a real array. I can split on those and break them out, but find myself losing the other information from in1.json.",
      "Notice in the \"metadata\" for the output that is contains the \"number\" values from in1.json, and stored in a weird way (but the way that the receiving tool requires).",
      "Break out the mitre_test values that were previously just a comma separated set of values with map and try.",
      "jq . in1.json in2.json | \\\njq '.[] |{number: .number, test: .test, mitreid: .mitreid, mitre_test: .mitre_test}'  |\\\njq -s '[. |map(try(.mitre_test |= split(\",\")) // .)|\\\n.[] | [.number,.test,.mitreid] as $h | .mitre_test[] |$h + [.] | \\\n{DET_ID: .[0], tactic: .[1], techniqueID: .[2], mitre_test: .[3]}]'",
      "jq '[group_by(.mitre_test)[]|{mitre_test: .[0].mitre_test, techniqueID: [.[].techniqueID],tactic: [.[].tactic], DET_ID: [.[].DET_ID]}]|\\\ndel(.[].techniqueID[] | nulls) | del(.[].tactic[] | nulls) | del(.[].DET_ID[] | nulls)'",
      "jq '.[]| [{techniqueID: .techniqueID[0],tactic: .tactic[0], metadata: [{name: \"DET_ID\",value: .DET_ID[]}]}] | .[] | \\\nselect((.metadata|length)>0)'"
    ],
    "utterance": "Merge two files by splitting mitre_test on commas, matching values between the files, and assembling output objects with techniqueID, tactic, and metadata containing all matching number values under DET_ID, preserving static fields.",
    "expressions": [
      "jq . in1.json in2.json | jq '.[] |{number: .number, test: .test, mitreid: .mitreid, mitre_test: .mitre_test}' | jq -s '[. |map(try(.mitre_test |= split(\",\")) // .)| .[] | [.number,.test,.mitreid] as $h | .mitre_test[] |$h + [.] | {DET_ID: .[0], tactic: .[1], techniqueID: .[2], mitre_test: .[3]}]'",
      "jq '[group_by(.mitre_test)[]|{mitre_test: .[0].mitre_test, techniqueID: [.[].techniqueID],tactic: [.[].tactic], DET_ID: [.[].DET_ID]}]| del(.[].techniqueID[] | nulls) | del(.[].tactic[] | nulls) | del(.[].DET_ID[] | nulls)'",
      "jq '.[]| [{techniqueID: .techniqueID[0],tactic: .tactic[0], metadata: [{name: \"DET_ID\",value: .DET_ID[]}]}] | .[] | select((.metadata|length)>0)'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "test": "Execution",
              "mitreid": "T1204.001",
              "mitre_test": "90b"
            },
            {
              "test": "Defense Evasion",
              "mitreid": "T1070.001",
              "mitre_test": "afa"
            },
            {
              "test": "Credential Access",
              "mitreid": "T1556.004",
              "mitre_test": "14b"
            },
            {
              "test": "Initial Access",
              "mitreid": "T1200",
              "mitre_test": "f22"
            },
            {
              "test": "Impact",
              "mitreid": "T1489",
              "mitre_test": "fa2"
            }
          ],
          [
            {
              "number": "REL0001346",
              "desc": "apple",
              "mitre_test": "afa"
            },
            {
              "number": "REL0001343",
              "desc": "pear",
              "mitre_test": "90b"
            },
            {
              "number": "REL0001366",
              "desc": "orange",
              "mitre_test": "14b,f22"
            },
            {
              "number": "REL0001378",
              "desc": "pineapple",
              "mitre_test": "90b"
            }
          ]
        ],
        "output": [
          {
            "techniqueID": "T1070.001",
            "tactic": "defense-evasion",
            "score": 1,
            "color": "",
            "comment": "",
            "enabled": true,
            "metadata": [
              {
                "name": "DET_ID",
                "value": "REL0001346"
              }
            ],
            "showSubtechniques": true
          },
          {
            "techniqueID": "T1204.001",
            "tactic": "execution",
            "score": 1,
            "color": "",
            "comment": "",
            "enabled": true,
            "metadata": [
              {
                "name": "DET_ID",
                "value": "REL0001343"
              },
              {
                "name": "DET_ID",
                "value": "REL0001378"
              }
            ],
            "showSubtechniques": true
          },
          {
            "techniqueID": "T1556.004",
            "tactic": "credential-access",
            "score": 1,
            "color": "",
            "comment": "",
            "enabled": true,
            "metadata": [
              {
                "name": "DET_ID",
                "value": "REL0001366"
              }
            ],
            "showSubtechniques": true
          },
          {
            "techniqueID": "T1200",
            "tactic": "initial-access",
            "score": 1,
            "color": "",
            "comment": "",
            "enabled": true,
            "metadata": [
              {
                "name": "DET_ID",
                "value": "REL0001366"
              }
            ],
            "showSubtechniques": true
          }
        ]
      }
    ],
    "identifier": 66375616
  },
  {
    "context": [
      "from the list above, I would like to only export title, login, uid, shared folder, and folder fields to csv file.",
      "my goal is to eliminate capturing following fields\n\n - password\n - login_url\n - notes\n - option1\n - option2",
      "Here&#39;s one way:\n```\n.records[]\n| [.title, .login, .uid] + ((.folders[]? // null) | [.shared_folder, .folder])\n| @tsv\n```",
      "jq --raw-output '.records[] | [.title, .login, .uid, .folders[0].shared_folder,.folders[0].folder] |@tsv'"
    ],
    "utterance": "Extract the fields title, login, uid, shared_folder, and folder from each record and output them in CSV format, omitting password, login_url, notes, option1, and option2.",
    "expressions": [
      ".records[] | [.title, .login, .uid] + ((.folders[]? // null) | [.shared_folder, .folder]) | @tsv",
      ".records[] | [.title, .login, .uid, .folders[0].shared_folder,.folders[0].folder] |@tsv"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "title": "root logon",
              "login": "61819009",
              "uid": "ajsd879asdjksasda123asd1asd1",
              "password": "OizfD19jC$ySaV$MKpSF",
              "login_url": "http://192.168.0.1/",
              "notes": ""
            },
            {
              "title": "important admin account",
              "login": "admin",
              "uid": "asdjhkasdh89eoajdiuas98ue9aoi",
              "password": "0z5gDUC#Rb354TlLq$KJ",
              "login_url": "",
              "notes": "",
              "folders": [
                {
                  "shared_folder": "Department",
                  "folder": "Important",
                  "option1": false,
                  "option2": false
                }
              ]
            },
            {
              "title": "another important admin",
              "login": "admin@domain.com",
              "uid": "asjhe98asiajsijeouiaueiaiu",
              "password": "3pUs@uXEqsxCv7PRkDlJ",
              "login_url": "http://192.168.0.2/",
              "notes": ""
            },
            {
              "title": "switch admin",
              "login": "admin",
              "uid": "asjhe89ausiodjakljskea90ik",
              "password": "hMB!eMsAE8q4aDQuM4LY",
              "login_url": "",
              "notes": "",
              "folders": [
                {
                  "shared_folder": "Department2",
                  "folder": "network\\switches",
                  "option1": false,
                  "option2": false
                }
              ]
            }
          ]
        },
        "output": [
          "root logon\t61819009\tajsd879asdjksasda123asd1asd1\t\t",
          "important admin account\tadmin\tasdjhkasdh89eoajdiuas98ue9aoi\tDepartment\tImportant",
          "another important admin\tadmin@domain.com\tasjhe98asiajsijeouiaueiaiu\t\t",
          "switch admin\tadmin\tasjhe89ausiodjakljskea90ik\tDepartment2\tnetwork\\switches"
        ]
      }
    ],
    "identifier": 66574180
  },
  {
    "context": [
      "I want them to join to one json object like:",
      "Use [tag:jq]&#39;s [`add`][1], this will concatenate all the input objects;",
      "jq -s add <<<< \"$j1 $j2 $j3\"",
      "jq -s add file1 file2 file3",
      "command | jq -s add",
      "You can add multiple columns by hand like so;",
      "jq -s '[0] * .[1] * .[2]' file1 file2 file3",
      "Both options result in: {\r\n  \"Woonkamer\": {\r\n    \"currentTemperature\": 21.8,\r\n    \"battery\": 75,\r\n    \"isFailed\": false\r\n  },\r\n  \"Hal\": {\r\n    \"currentTemperature\": 19.5,\r\n    \"battery\": 48,\r\n    \"isFailed\": false\r\n  },\r\n  \"Bijkeuken\": {\r\n    \"currentTemperature\": 18.4,\r\n    \"battery\": 56,\r\n    \"isFailed\": false\r\n  }\r\n}"
    ],
    "utterance": "Combine several separate objects, each keyed by a room name, into a single object with all keys at the same level.",
    "expressions": [
      "jq -s add",
      "jq -s '.[0] * .[1] * .[2]'"
    ],
    "data": [
      {
        "input": [
          {
            "Woonkamer": {
              "currentTemperature": 21.8,
              "battery": 75,
              "isFailed": false
            }
          },
          {
            "Hal": {
              "currentTemperature": 19.5,
              "battery": 48,
              "isFailed": false
            }
          },
          {
            "Bijkeuken": {
              "currentTemperature": 18.4,
              "battery": 56,
              "isFailed": false
            }
          }
        ],
        "output": {
          "Woonkamer": {
            "currentTemperature": 21.8,
            "battery": 75,
            "isFailed": false
          },
          "Hal": {
            "currentTemperature": 19.5,
            "battery": 48,
            "isFailed": false
          },
          "Bijkeuken": {
            "currentTemperature": 18.4,
            "battery": 56,
            "isFailed": false
          }
        }
      }
    ],
    "identifier": 66588112
  },
  {
    "context": [
      "Can anyone help me to write a script to take the output of:\r\n\r\n    `curl --silent &quot;https://api.surfshark.com/v3/server/clusters&quot; | jq` \r\n\r\nand list the number of servers in each **countryCode** and the **min** and **max** loadings on those servers, **sorted by countryCode**?\r\n```\r\n.countryCode &#39;count of number of servers&#39; &#39;lowest .load&#39; &#39;highest .load&#39;\r\nAU    5    13%       30%\r\nUK   10    35%       88%\r\nUS   25    12%       50%\r\n```",
      "You could do the `group_by` first and then derive the rest of the fields from there\r\n\r\n```\r\ngroup_by(.countryCode) \r\n  | map([ .[0].countryCode, length, min_by(.load).load, max_by(.load).load])\r\n```\r\n**EDIT**: Removed the redundant sort as pointed out by @peak\r\n\r\nYou could optionally add `.[] | @tsv` to get the table structure that you have in the question"
    ],
    "utterance": "Count the number of items in each group by countryCode, and list the lowest and highest load for each group, sorted by countryCode.",
    "expressions": [
      "sort_by(.countryCode) | group_by(.countryCode) | map([ .[0].countryCode, length, min_by(.load).load, max_by(.load).load ])",
      "group_by(.countryCode) | map([ .[0].countryCode, length, min_by(.load).load, max_by(.load).load ])"
    ],
    "data": [
      {
        "input": [
          {
            "country": "Albania",
            "countryCode": "AL",
            "region": "Europe",
            "regionCode": "EU",
            "load": 12,
            "id": "4c333aa2-d08b-4d11-9073-61c351ce1c1e",
            "coordinates": {
              "longitude": 19.8188889,
              "latitude": 41.3275
            },
            "info": [
              {
                "id": "55994450-0c87-4df3-b585-3836c67a863d",
                "entry": {
                  "value": "U2FsdGVkX1/VX5IKc3H3ruClgbw7JgnqW7Eacumx8aM="
                }
              }
            ],
            "type": "generic",
            "location": "Tirana",
            "connectionName": "al-tia.prod.surfshark.com"
          },
          {
            "country": "Albania",
            "countryCode": "AL",
            "region": "Europe",
            "regionCode": "EU",
            "load": 30,
            "id": "another-id",
            "coordinates": {
              "longitude": 19.8188889,
              "latitude": 41.3275
            },
            "info": [],
            "type": "generic",
            "location": "Tirana",
            "connectionName": "al-tia2.prod.surfshark.com"
          },
          {
            "country": "United Kingdom",
            "countryCode": "UK",
            "region": "Europe",
            "regionCode": "EU",
            "load": 88,
            "id": "uk-id-1",
            "coordinates": {
              "longitude": -0.1278,
              "latitude": 51.5074
            },
            "info": [],
            "type": "generic",
            "location": "London",
            "connectionName": "uk-lon1.prod.surfshark.com"
          },
          {
            "country": "United Kingdom",
            "countryCode": "UK",
            "region": "Europe",
            "regionCode": "EU",
            "load": 35,
            "id": "uk-id-2",
            "coordinates": {
              "longitude": -0.1278,
              "latitude": 51.5074
            },
            "info": [],
            "type": "generic",
            "location": "London",
            "connectionName": "uk-lon2.prod.surfshark.com"
          }
        ],
        "output": [
          [
            "AL",
            2,
            12,
            30
          ],
          [
            "UK",
            2,
            35,
            88
          ]
        ]
      }
    ],
    "identifier": 66579607
  },
  {
    "context": [
      "I am using `@tsv` but getting an error `object ({\"release\":...) cannot be tsv-formatted, only array`.",
      "How can I get the below output display?",
      "Both `@csv` and `@tsv` expect an array as input, so you could just append the following to your jq filter:\n```\n| [.release, .Installed.version, .Latest.version, .outdated, .deprecated]\n| @tsv\n```"
    ],
    "utterance": "Display fields release, Installed.version, Latest.version, outdated, and deprecated as tab-separated values for objects that are outdated or deprecated and whose release does not start with update or upgrade.",
    "expressions": [
      ".test[] | select((.outdated or .deprecated) and ((.release|startswith(\"update\")) | not) and ((.release|startswith(\"upgrade\")) | not)) | [.release, .Installed.version, .Latest.version, .outdated, .deprecated] | @tsv"
    ],
    "data": [
      {
        "input": {
          "test": [
            {
              "release": "myapp1",
              "Installed": {
                "version": "0.3.0",
                "appVersion": "v1.2.6"
              },
              "Latest": {
                "version": "",
                "appVersion": ""
              },
              "outdated": false,
              "deprecated": false
            },
            {
              "release": "myapp2",
              "Installed": {
                "version": "6.5.13",
                "appVersion": "1.9.1"
              },
              "Latest": {
                "version": "",
                "appVersion": ""
              },
              "outdated": false,
              "deprecated": false
            },
            {
              "release": "test-app",
              "Installed": {
                "version": "1.0.0",
                "appVersion": ""
              },
              "Latest": {
                "version": "2.0.0",
                "appVersion": ""
              },
              "outdated": true,
              "deprecated": false
            },
            {
              "release": "update-app",
              "Installed": {
                "version": "1.0.0",
                "appVersion": ""
              },
              "Latest": {
                "version": "3.0.0",
                "appVersion": ""
              },
              "outdated": true,
              "deprecated": false
            },
            {
              "release": "upgrade-app",
              "Installed": {
                "version": "2.0.0",
                "appVersion": ""
              },
              "Latest": {
                "version": "2.0.0",
                "appVersion": ""
              },
              "outdated": false,
              "deprecated": true
            }
          ]
        },
        "output": "test-app\t1.0.0\t2.0.0\ttrue\tfalse"
      }
    ],
    "identifier": 66592859
  },
  {
    "context": [
      "I'm trying to get the value(s) of `cpu`.",
      "The 'hw' value is a string, but it actually contains JSON data as a string.",
      "cat sfstest.json | jq -r '.rows[]|.display_name,.name,.meta.\"socket-hostname\",.hw.cpu' ... Cannot index string with string \"cpu\"",
      "But if I throw that 'hw' \"value\" line into a file, I can act on it as I would expect.. just not as part of the total `jq` line.",
      "cat hw | jq '.cpu.mhz' \u2014 \"2397.223\""
    ],
    "utterance": "Extract the value of the mhz field nested under cpu from the hw field, where hw is a JSON-formatted string.",
    "expressions": [
      ".rows[].hw | fromjson | .cpu.mhz"
    ],
    "data": [
      {
        "input": {
          "rows": [
            {
              "display_name": "sfsrocks",
              "name": "sfs",
              "is_muted": false,
              "mute_timeout": null,
              "meta": {
                "socket-hostname": "sfssocket"
              },
              "host_id": 449792622,
              "hw": "{\"cpu\":{\"cache_size\":\"15360 KB\",\"cpu_cores\":\"4\",\"cpu_logical_processors\":\"4\",\"family\":\"6\",\"mhz\":\"2397.223\",\"model\":\"58\",\"model_name\":\"Intel(R) Xeon(R) CPU E5-2620 v3 @ 2.40GHz\",\"stepping\":\"0\",\"vendor_id\":\"GenuineIntel\"}}",
              "pythonV": "n/a",
              "processor": "Intel(R) Xeon(R) CPU E5-2620 v3 @ 2.40GHz",
              "socket-fqdn": "sofree.us.",
              "agent_version": "6.1.1"
            }
          ]
        },
        "output": "2397.223"
      }
    ],
    "identifier": 66594074
  },
  {
    "context": [
      "I have a set of JSON files. I want to be able to use jq or a command line that can help me unify the files into one single file.",
      "For example:\n\nFile 1, has the following format:\n\n    {\n      \"Interactions\": [ ... ]\n    }\n\nFile 2:\n\n    {\n      \"Interactions\": [ ... ]\n    }\n\nAnd this is my expected result in a third file:\n\n    {\n      \"Interactions\": [ ... ]\n    }",
      "Try something like the following:\n\n    jq -n '{ Interactions: [ inputs.Interactions ] | add }' file1.json file2.json"
    ],
    "utterance": "Combine the Interactions arrays from multiple files into a single array inside one object with the Interactions key, preserving all elements.",
    "expressions": [
      "jq -n '{ Interactions: [ inputs.Interactions ] | add }' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          {
            "Interactions": [
              {
                "ID": "ispring://presentations/F7385CB7-DFDC-4D05-90FA-B927DB3D170D/quizzes/",
                "Type": "2",
                "TimestampUtc": "8/27/2020 12:09:54 PM",
                "Timestamp": "8/27/2020 12:09:54 PM",
                "Weighting": "",
                "Result": "1",
                "Latency": "1000",
                "Description": "What is the purpose of Summarizing next steps?\n\nSelect the correct box or boxes",
                "LearnerResponse": "0_correct_answer[,]1_Rectangle_2",
                "ScormActivityId": "12392705",
                "InteractionIndex": "3",
                "AULMRID": "38093846"
              }
            ]
          },
          {
            "Interactions": [
              {
                "ID": "ispring://presentations/CAA34147-7B48-40C6-84FD-5CE8077DB2BF/quizzes/",
                "Type": "2",
                "TimestampUtc": "12/8/2020 6:19:12 PM",
                "Timestamp": "12/8/2020 6:19:12 PM",
                "Weighting": "",
                "Result": "1",
                "Latency": "1300",
                "Description": "'Can't do' language tends to relay this impression...\n\nSelect one.",
                "LearnerResponse": "4_All_of_the_above",
                "ScormActivityId": "13334358",
                "InteractionIndex": "3",
                "AULMRID": "40715598"
              }
            ]
          }
        ],
        "output": {
          "Interactions": [
            {
              "ID": "ispring://presentations/F7385CB7-DFDC-4D05-90FA-B927DB3D170D/quizzes/",
              "Type": "2",
              "TimestampUtc": "8/27/2020 12:09:54 PM",
              "Timestamp": "8/27/2020 12:09:54 PM",
              "Weighting": "",
              "Result": "1",
              "Latency": "1000",
              "Description": "What is the purpose of Summarizing next steps?\n\nSelect the correct box or boxes",
              "LearnerResponse": "0_correct_answer[,]1_Rectangle_2",
              "ScormActivityId": "12392705",
              "InteractionIndex": "3",
              "AULMRID": "38093846"
            },
            {
              "ID": "ispring://presentations/CAA34147-7B48-40C6-84FD-5CE8077DB2BF/quizzes/",
              "Type": "2",
              "TimestampUtc": "12/8/2020 6:19:12 PM",
              "Timestamp": "12/8/2020 6:19:12 PM",
              "Weighting": "",
              "Result": "1",
              "Latency": "1300",
              "Description": "'Can't do' language tends to relay this impression...\n\nSelect one.",
              "LearnerResponse": "4_All_of_the_above",
              "ScormActivityId": "13334358",
              "InteractionIndex": "3",
              "AULMRID": "40715598"
            }
          ]
        }
      }
    ],
    "identifier": 66591472
  },
  {
    "context": [
      "I only want to display on values that have `outdated` or `deprecated` = `true` but ommit from result if `relase` = `never-update-app` or `never-upgrade-app`.",
      "([\"ReleaseName\",\"Installed\",\"Latest\",\"Old\",\"Deprecated\"] | @tsv), (.test[] | select(   (.outdated==true or .deprecated==true) and ((.release==\"never-update-app\" or .release==\"never-upgrade-app\") | not)   ) | \"\\(.release) \\(.Installed.version) \\(.Latest.version) \\(.outdated) \\(.deprecated)\" / \" \" | @tsv)"
    ],
    "utterance": "List all entries where either 'outdated' or 'deprecated' is true, excluding any where 'release' is 'never-update-app' or 'never-upgrade-app', and show selected fields formatted as a table.",
    "expressions": [
      "([\"ReleaseName\",\"Installed\",\"Latest\",\"Old\",\"Deprecated\"] | @tsv), (.test[] | select(   (.outdated==true or .deprecated==true) and ((.release==\"never-update-app\" or .release==\"never-upgrade-app\") | not)   ) | \"\\(.release) \\(.Installed.version) \\(.Latest.version) \\(.outdated) \\(.deprecated)\" / \" \" | @tsv)",
      ".test[] | select((.outdated or .deprecated) and .release != \"never-update-app\" and .release != \"never-upgrade-app\")",
      ".test[] | select((.outdated or .deprecated) and (.release|startswith(\"never-\")|not))"
    ],
    "data": [
      {
        "input": {
          "test": [
            {
              "release": "myapp1",
              "Installed": {
                "version": "0.3.0",
                "appVersion": "v1.2.6"
              },
              "Latest": {
                "version": "",
                "appVersion": ""
              },
              "outdated": false,
              "deprecated": false
            },
            {
              "release": "myapp2",
              "Installed": {
                "version": "6.5.13",
                "appVersion": "1.9.1"
              },
              "Latest": {
                "version": "",
                "appVersion": ""
              },
              "outdated": false,
              "deprecated": false
            },
            {
              "release": "test-app",
              "Installed": {
                "version": "1.0.0",
                "appVersion": ""
              },
              "Latest": {
                "version": "2.0.0",
                "appVersion": ""
              },
              "outdated": true,
              "deprecated": false
            },
            {
              "release": "never-update-app",
              "Installed": {
                "version": "1.0.0",
                "appVersion": ""
              },
              "Latest": {
                "version": "3.0.0",
                "appVersion": ""
              },
              "outdated": true,
              "deprecated": false
            },
            {
              "release": "never-upgrade-app",
              "Installed": {
                "version": "2.0.0",
                "appVersion": ""
              },
              "Latest": {
                "version": "2.0.0",
                "appVersion": ""
              },
              "outdated": false,
              "deprecated": true
            }
          ]
        },
        "output": "ReleaseName\tInstalled\tLatest\tOld\tDeprecated\ntest-app\t1.0.0\t2.0.0\ttrue\tfalse"
      }
    ],
    "identifier": 66591547
  },
  {
    "context": [
      "How can I include the value of the application key?",
      "I would like an output of:\r\n\r\n    \"computer1.domain.local Microsoft Office WINWORD.EXE\"",
      "You can add application to the constructed structure:\r\n\r\n    jq '.data[]\r\n       | .computers[] + .file + {application}\r\n       | \"\\(.hostname) \\(.application) \\(.filename)\"'"
    ],
    "utterance": "Output concatenated values of hostname, application, and filename for each computer entry.",
    "expressions": [
      ".data[] | .computers[] + .file + {application} | \"\\(.hostname) \\(.application) \\(.filename)\""
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "application": "Microsoft Office",
              "computers": [
                {
                  "active": true,
                  "hostname": "computer1.domain.local"
                }
              ],
              "file": {
                "filename": "WINWORD.EXE",
                "identity": {
                  "sha256": "270fe88cca8156912303ebdf9481de99e4265c878cfd41964b2a94131f6c41ad"
                }
              }
            }
          ]
        },
        "output": "computer1.domain.local Microsoft Office WINWORD.EXE"
      }
    ],
    "identifier": 66606261
  },
  {
    "context": [
      "I am trying to get jq to render a json object into tsv format. I came across a way to generate headers dynamically using the key name.",
      "I am getting this error: \n\n> object ({\"version\":...) is not valid in a csv row",
      "I am guessing this is due to some fields being arrays: `Installed` and `Latest`. How can I make this work with those fields?",
      "Desired output:\n\n    RELEASE         INSTALLED    LATEST    OUTDATED      DEPRACATED\n    test-app        1.0.0        2.0.0     true          false   \n    test-app2       3.0.0        3.5.0     true          false",
      "map({release, installed: .Installed.version, latest: .Latest.version, deprecated})",
      "| ( .[0] | keys_unsorted | map(ascii_upcase)),\n  (.[] | [.[]])\n| @tsv"
    ],
    "utterance": "Produce a TSV with upper-cased headers and show only the release name, Installed.version, Latest.version, and deprecated fields, flattening nested objects' version fields as needed.",
    "expressions": [
      "map({release, installed: .Installed.version, latest: .Latest.version, deprecated})\n| (.[0] | keys_unsorted | map(ascii_upcase)),\n  (.[] | [.[]])\n| @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "release": "test-app",
            "Installed": {
              "version": "1.0.0",
              "appVersion": ""
            },
            "Latest": {
              "version": "2.0.0",
              "appVersion": ""
            },
            "outdated": true,
            "deprecated": false
          },
          {
            "release": "test-app2",
            "Installed": {
              "version": "3.0.0",
              "appVersion": ""
            },
            "Latest": {
              "version": "3.5.0",
              "appVersion": ""
            },
            "outdated": true,
            "deprecated": false
          }
        ],
        "output": "RELEASE\tINSTALLED\tLATEST\tDEPRECATED\ntest-app\t1.0.0\t2.0.0\tfalse\ntest-app2\t3.0.0\t3.5.0\tfalse"
      }
    ],
    "identifier": 66595618
  },
  {
    "context": [
      "So, instead of \n\n    jq -r '&#39;\".Credentials.AccessKeyId\"' mysession.json\n\nYou'll need to escape double quotes, then change single quotes to double.\n\n    jq -r \"\\\".Credentials.AccessKeyId\\\"\" mysession.json",
      "\"when using the Windows command shell (cmd.exe) it's best to use\ndouble quotes around your jq program when given on the command-line\n(instead of the -f program-file option), but then double-quotes in the\njq program need backslash escaping.\""
    ],
    "utterance": "Extract the value of the Credentials.AccessKeyId field from mysession.json in Windows CMD.",
    "expressions": [
      "jq -r \"\\\".Credentials.AccessKeyId\\\"\" mysession.json"
    ],
    "identifier": 66606742
  },
  {
    "context": [
      "However, I am running into a problem when displaying values for a field that's empty. I am using the `//` alternative operator but it is not returning the desired output. What is the right way to handle empty strings with jq?",
      "Desired Output:\n\n    RELEASE    INSTALLED  LATEST  DEPRECATED\n    test-app   1.0.0      2.0.0   false\n    test-app2  3.0.0      -        true",
      "jq -r 'map({release, installed: .Installed.version, latest: (if .Latest.version == \"\" then \"-\" else .Latest.version end), deprecated}) | ( .[0] | keys_unsorted | map(ascii_upcase)), (.[] | [.[]]) | @tsv' data.json | column -t",
      ".Latest.version // \"\" | select(. != \"\") // \"-\"",
      ".Latest.version // \"\" | if . == \"\" then \"-\" else . end"
    ],
    "utterance": "Replace empty string values in the Latest.version field with '-' when displaying the data.",
    "expressions": [
      "map({release, installed: .Installed.version, latest: (if .Latest.version == \"\" then \"-\" else .Latest.version end), deprecated})",
      ".Latest.version // \"\" | select(. != \"\") // \"-\"",
      ".Latest.version // \"\" | if . == \"\" then \"-\" else . end"
    ],
    "data": [
      {
        "input": [
          {
            "release": "test-app",
            "Installed": {
              "version": "1.0.0",
              "appVersion": ""
            },
            "Latest": {
              "version": "2.0.0",
              "appVersion": ""
            },
            "outdated": true,
            "deprecated": false
          },
          {
            "release": "test-app2",
            "Installed": {
              "version": "3.0.0",
              "appVersion": ""
            },
            "Latest": {
              "version": "",
              "appVersion": ""
            },
            "outdated": false,
            "deprecated": true
          }
        ],
        "output": [
          {
            "release": "test-app",
            "installed": "1.0.0",
            "latest": "2.0.0",
            "deprecated": false
          },
          {
            "release": "test-app2",
            "installed": "3.0.0",
            "latest": "-",
            "deprecated": true
          }
        ]
      }
    ],
    "identifier": 66603976
  },
  {
    "context": [
      "VALUE=$(jq '.device.value' $JSON_FILE)",
      "Value: \"0x5\"",
      "MASK=$(jq '.device.mask' $JSON_FILE)",
      "Mask: \"0x4\"",
      "Use jq's -r command-line option to stop jq from emitting the characters strings as JSON strings, i.e. with quotation marks."
    ],
    "utterance": "Extract the value of the 'device.value' key as a raw string without surrounding quotes.",
    "expressions": [
      ".device.value",
      "-r .device.value"
    ],
    "data": [
      {
        "input": {
          "device": {
            "value": "0x5",
            "mask": "0x4"
          }
        },
        "output": "0x5"
      }
    ],
    "identifier": 66610232
  },
  {
    "context": [
      "I'm trying to define some custom filter functions and one thing I need to be able to do is pass a list of strings to a filter and get the corresponding values of the input object.",
      "jq -n '{name: \"Chris\", age: 25, city: \"Chicago\"} | myFilter([\"name\", \"age\"])'",
      "should return:",
      "{\"name\": \"Chris\", \"age\": 25}",
      "You could easily define your `myFilter` using `reduce`:",
      "def myFilter($keys):\n  . as $in\n  | reduce $keys[] as $k (null; . + {($k): $in[$k]} );"
    ],
    "utterance": "Return an object containing only the keys specified in a provided list of strings, along with their corresponding values from the input object.",
    "expressions": [
      "def myFilter($keys): . as $in | reduce $keys[] as $k (null; . + {($k): $in[$k]} );"
    ],
    "data": [
      {
        "input": {
          "name": "Chris",
          "age": 25,
          "city": "Chicago"
        },
        "output": {
          "name": "Chris",
          "age": 25
        }
      }
    ],
    "identifier": 66645317
  },
  {
    "context": [
      "The goal is to retrieve the parent text for an element.\r\nFor example:\r\n - searching acca --> acc\r\n - searching  acc --> ac",
      "getpath(\r\n  paths(strings\r\n    | select(. == \"acca\")\r\n  )[:-3]\r\n) .text",
      "paths(objects | select(.text == $needle)) as $p\r\n| getpath($p[:-2]).text"
    ],
    "utterance": "Given a target text value such as 'acca', find and return the text value of its parent node.",
    "expressions": [
      "getpath(paths(strings | select(. == \"acca\"))[:-3]).text",
      "paths(objects | select(.text == $needle)) as $p | getpath($p[:-2]).text"
    ],
    "data": [
      {
        "input": {
          "all": {
            "text": "a",
            "children": [
              {
                "text": "aa",
                "children": []
              },
              {
                "text": "ab",
                "children": []
              },
              {
                "text": "ac",
                "children": [
                  {
                    "text": "aca",
                    "children": []
                  },
                  {
                    "text": "acb",
                    "children": []
                  },
                  {
                    "text": "acc",
                    "children": [
                      {
                        "text": "acca",
                        "children": []
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": "acc"
      }
    ],
    "identifier": 66639380
  },
  {
    "context": [
      "I am using `jq` to parse it. I'm trying to extract the values of only the keys which are provided in a BASH variable. I tried this with one key in the variable and it works.",
      "However when I tried the same with `KEY=coord.lat` the output is `null` and I'm stumped when the number of keys isn't a given.",
      "For example, if the variable is\n\n    KEYS=id,name\n\nthen the output should be\n\n    707860,\"Hurzuf\"\n\nor, if the variable is\n\n    KEYS=coord.lon,coord.lat\n\nthen the output should be\n\n     34.283333,44.549999",
      "Split `$key` into individual paths and convert each to a format `getpath` could understand. Then you can collect values they point to in an array and join them by commas.",
      "[getpath(($key / \",\")[] / \".\")] | join(\",\")",
      "$ jq -r '[getpath(($key / \",\")[] / \".\")] | join(\",\")' file --arg key \"$KEYS\""
    ],
    "utterance": "Extract the values corresponding to multiple, potentially nested keys specified as a comma-separated string variable (e.g., 'id,coord.lon,coord.lat') and output them as a comma-separated list in order.",
    "expressions": [
      "[getpath(($key / \",\")[] / \".\")] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "id": 707860,
          "name": "Hurzuf",
          "country": "UA",
          "coord": {
            "lon": 34.283333,
            "lat": 44.549999
          }
        },
        "output": "707860,34.283333,44.549999"
      },
      {
        "input": {
          "id": 707860,
          "name": "Hurzuf",
          "country": "UA",
          "coord": {
            "lon": 34.283333,
            "lat": 44.549999
          }
        },
        "output": "707860,\"Hurzuf\""
      },
      {
        "input": {
          "id": 707860,
          "name": "Hurzuf",
          "country": "UA",
          "coord": {
            "lon": 34.283333,
            "lat": 44.549999
          }
        },
        "output": "34.283333,44.549999"
      }
    ],
    "identifier": 66621445
  },
  {
    "context": [
      "I am trying to convert the following JSON into a csv which has each unique \"name\" and the total count (i.e: number of times that name appears).",
      "## Current data:",
      "[{\"name\": \"test\"}, {\"name\": \"hello\"}, {\"name\": \"hello\"}]",
      "## Ideal output:",
      "[{\"name\": \"hello\", \"count\": 2}, {\"name\": \"test\", \"count\": 1}]",
      "group_by(.name) \n    | map({name: .[0].name, count: length})"
    ],
    "utterance": "List each unique name with the number of times it appears in the data.",
    "expressions": [
      "group_by(.name) | map({name: .[0].name, count: length})",
      "group_by (.name)[] | {name: .[0].name, count: length} | jq -s"
    ],
    "data": [
      {
        "input": [
          {
            "name": "test"
          },
          {
            "name": "hello"
          },
          {
            "name": "hello"
          }
        ],
        "output": [
          {
            "name": "hello",
            "count": 2
          },
          {
            "name": "test",
            "count": 1
          }
        ]
      }
    ],
    "identifier": 66641816
  },
  {
    "context": [
      "I want to check `content-type` of each `Url` with `curl` and add it to each object. So, I'll get:",
      "while read url ; do\n    curl -sSL \"$url\" -o /dev/null -w '%{content_type}'\ndone < <(jq -r .data[].Url input.json) | \njq -Rn --argfile json input.json '\n  [inputs] as $in\n  | $json\n  | .data |= reduce range(0;length) as $i (.;\n               .[$i].ContentType = $in[$i])\n'",
      "jq '.data[].Url' input.json |\\\nxargs -n1 curl -sSL -o /dev/null -w '%{content_type}\\n' |\\\njq --slurp --raw-input 'split(\"\\n\")[:-1] | map({\"Content-Type\": .})' |\\\njq -n --argfile in1 input.json --argfile in2 /dev/stdin '$in1 | .data |= ([., $in2] | transpose| map(add))'"
    ],
    "utterance": "Add a ContentType field to each data object, setting its value to the content-type of its Url as returned from curl.",
    "expressions": [
      "jq -Rn --argfile json input.json '[inputs] as $in | $json | .data |= reduce range(0;length) as $i (.; .[$i].ContentType = $in[$i])'",
      "jq -n --argfile in1 input.json --argfile in2 /dev/stdin '$in1 | .data |= ([., $in2] | transpose| map(add))'"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "Name": "name 1",
              "Url": "https://some-content.com"
            },
            {
              "Name": "name 2",
              "Url": "https://soming-else.com"
            }
          ]
        },
        "output": {
          "data": [
            {
              "Name": "name 1",
              "Url": "https://some-content.com",
              "ContentType": "video"
            },
            {
              "Name": "name 2",
              "Url": "https://soming-else.com",
              "ContentType": "text"
            }
          ]
        }
      }
    ],
    "identifier": 66647704
  },
  {
    "context": [
      "That I need to extract the .content where fieldTag is \"b\" or \"l\". In the example, I've removed many fields, and the fields I seek will not always be present.",
      "If I cat the file into \n\n    cat myfile |jq -r '.entries[] |\n            .varFields[] |select(.fieldTag==\"l\") | .content // \"\"\n    '\n\nworks exactly as expected but \n\n    cat myfile|jq -r '.entries[] |\n            .varFields[] |select(.fieldTag==\"l\") | .content // \"\", \n            .varFields[] |select(.fieldTag==\"b\") | .content // \"\" \n    '\n\nreturns `jq: error (at <stdin>:37): Cannot index string with string \"fieldTag\"`.",
      "In your query, you would need parentheses for correct grouping:\n```\n.entries[] |\n (.varFields[] | select(.fieldTag==\"l\") | .content // \"\"), \n (.varFields[] | select(.fieldTag==\"b\") | .content // \"\")\n```",
      "or to avoid scanning .varFields redundantly:\n```\n.entries[]\n| (INDEX(.varFields[]; .fieldTag) | map_values(.content)) as $dict\n| $dict[\"l\",\"b\"]\n| . // \"\"\n```",
      "If ordering is unimportant and if both \"l\" and \"b\" are known to be present, you could alternatively write:\n```\n.entries[]\n| .varFields[] \n| select(.fieldTag | . == \"l\" or . == \"b\" ) \n| .content // \"\"\n```",
      "The disjunctive \"select\" immediately above could also be written even more DRYly as:\n\n`select(.fieldTag | IN(\"l\",\"b\" ))`"
    ],
    "utterance": "Extract the content values from varFields entries where fieldTag is either \"b\" or \"l\", returning an empty string if not present.",
    "expressions": [
      ".entries[] | (.varFields[] | select(.fieldTag==\"l\") | .content // \"\"), (.varFields[] | select(.fieldTag==\"b\") | .content // \"\")",
      ".entries[] | (INDEX(.varFields[]; .fieldTag) | map_values(.content)) as $dict | $dict[\"l\",\"b\"] | . // \"\"",
      ".entries[] | .varFields[] | select(.fieldTag == \"l\" or .fieldTag == \"b\") | .content // \"\"",
      ".entries[] | .varFields[] | select(.fieldTag | IN(\"l\",\"b\")) | .content // \"\""
    ],
    "data": [
      {
        "input": {
          "total": 2000,
          "start": 0,
          "entries": [
            {
              "updatedDate": "2021-03-12T13:00:05Z",
              "createdDate": "2010-06-17T05:34:42Z",
              "deleted": false,
              "suppressed": false,
              "names": [
                "Doe, John"
              ],
              "barcodes": [
                "23082599944"
              ],
              "expirationDate": "2022-05-06",
              "emails": [
                "name@uni.edu"
              ],
              "patronType": 14,
              "patronCodes": {
                "pcode1": "-",
                "pcode2": 0
              },
              "varFields": [
                {
                  "fieldTag": "b",
                  "content": "23082501799944"
                },
                {
                  "fieldTag": "l",
                  "content": "jdoe"
                }
              ]
            }
          ]
        },
        "output": [
          "jdoe",
          "23082501799944"
        ]
      }
    ],
    "identifier": 66608197
  },
  {
    "context": [
      "when I parse this with jq I get this error",
      "parse error: Invalid numeric literal at line 1, column 493",
      "I think this is because \"id\": UUID(\"82088a94-16c2-4aa2-92d8-c557e74049a1\")",
      "If you want to use jq with your data, you will first have to convert it to (or render it as) JSON. This can be done in various ways, e.g. using `mongoexport`:"
    ],
    "utterance": "Convert MongoDB output with extended types (like UUID and NumberLong) into standard format so that it can be processed without parse errors.",
    "expressions": [],
    "data": [
      {
        "input": {
          "inprog": [
            {
              "host": "DESKTOP-LTB3QQ5:27017",
              "desc": "conn25",
              "connectionId": 25,
              "client": "127.0.0.1:38354",
              "appName": "MongoDB Shell",
              "clientMetadata": {
                "application": {
                  "name": "MongoDB Shell"
                },
                "driver": {
                  "name": "MongoDB Internal Client",
                  "version": "3.6.8"
                },
                "os": {
                  "type": "Linux",
                  "name": "Ubuntu",
                  "architecture": "x86_64",
                  "version": "20.04"
                }
              },
              "active": true,
              "currentOpTime": "2021-03-16T11:01:14.599+0530",
              "opid": 3135,
              "lsid": {
                "id": "UUID(\"82088a94-16c2-4aa2-92d8-c557e74049a1\")",
                "uid": "BinData(0,\"47DEQpj8HBSa+/TImW+5JCeuQeRkm5NMpJWZG3hSuFU=\")"
              },
              "secs_running": "NumberLong(0)",
              "microsecs_running": "NumberLong(65)",
              "op": "command",
              "ns": "admin.$cmd.aggregate",
              "command": {
                "currentOp": 1,
                "lsid": {
                  "id": "UUID(\"82088a94-16c2-4aa2-92d8-c557e74049a1\")"
                },
                "$db": "admin"
              },
              "numYields": 0,
              "locks": {},
              "waitingForLock": false,
              "lockStats": {}
            }
          ],
          "ok": 1
        }
      }
    ],
    "identifier": 66649822
  },
  {
    "context": [
      "I have a bit of a problem. I&#39;ve tried so many different iterations of `jq -r` against a large set of json files being spit out by an object detector but I just can&#39;t make it happy enough to give me a csv file.",
      "the names of things like \"book\", \"person\", \"animal\" are ever changing among the scripts, so if there is a way to do this without hardcoding the keys in the command, that would be most desirous but not requiredous",
      "Ideally, I&#39;d like to make a csv file whose tabular format would look something like this:  ",
      "keys_unsorted as $ids | ( .[ $ids[0] ] | keys_unsorted ) as $fields | ( [ \"id\", $fields[] ], ( $ids[] | [ ., $data[.][$fields[]] ] ) ) | @csv",
      "keys_unsorted as $ids | ( .[ $ids[0] ] | keys_unsorted ) as $fields | ( [ \"id\", $fields[] ], ( to_entries[] | [ .key, .value[$fields[]] ] ) ) | @csv",
      "The following solution is a bit trickier than it might otherwise be because it is \"data-driven\" (no key names other than \"File\" are hard-coded in the jq program) while not assuming that the inner keys are ordered consistently:",
      "keys_unsorted as $outer | (.[$outer[0]] | keys_unsorted) as $inner | [\"File\"] + ($inner|map((.[:1]|ascii_upcase) + .[1:])), ($outer[] as $k | [$k] + [.[$k] | .[$inner[]]]) | @tsv"
    ],
    "utterance": "Produce a CSV or TSV table where each outer key is a row and each inner key is a column, with headers generated dynamically rather than hardcoded, regardless of the specific inner key names.",
    "expressions": [
      ". as $data |\nkeys_unsorted as $ids |\n( .[ $ids[0] ] | keys_unsorted ) as $fields |\n(\n   [ \"id\", $fields[] ],\n   ( $ids[] | [ ., $data[.][$fields[]] ] )\n) | @csv",
      "keys_unsorted as $ids |\n( .[ $ids[0] ] | keys_unsorted ) as $fields |\n(\n   [ \"id\", $fields[] ],\n   ( to_entries[] | [ .key, .value[$fields[]] ] )\n) | @csv",
      "keys_unsorted as $ids |\n( .[ $ids[0] ] | keys_unsorted ) as $fields |\n(\n   [ \"id\", $fields[] ],\n   ( $ids[] as $id | [ $id, .[$id][$fields[]] ] )\n) | @csv",
      "keys_unsorted as $outer\n| (.[$outer[0]] | keys_unsorted) as $inner\n| [\"File\"] + ($inner|map((.[:1]|ascii_upcase) + .[1:])),\n  ($outer[] as $k\n   | [$k] + [.[$k] | .[$inner[]]])\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "/src/files/image_1.png": {
            "book": 0.01711445301771164,
            "person": 0.0003305590655332636,
            "place": 0.9814764857292175,
            "animal": 1.8662762158783153e-05,
            "vehicle": 0.0010597968939691782
          },
          "/src/files/image_2.png": {
            "book": 0.23741412162780762,
            "person": 0.1587823033328247,
            "place": 0.59659236669504,
            "animal": 0.0036556862760335207,
            "vehicle": 0.003555471543222666
          }
        },
        "output": [
          [
            "id",
            "book",
            "person",
            "place",
            "animal",
            "vehicle"
          ],
          [
            "/src/files/image_1.png",
            0.01711445301771164,
            0.0003305590655332636,
            0.9814764857292175,
            1.8662762158783153e-05,
            0.0010597968939691782
          ],
          [
            "/src/files/image_2.png",
            0.23741412162780762,
            0.1587823033328247,
            0.59659236669504,
            0.0036556862760335207,
            0.003555471543222666
          ]
        ]
      }
    ],
    "identifier": 66633378
  },
  {
    "context": [
      "Given a couple of pipe delimited text files:\r\n\r\nfile 1:\r\n\r\n`data1|data2|data3|data4`\r\n\r\nfile 2:\r\n\r\n`label1|label2|label3|label4`",
      "I&#39;m looking to create json output like this:\r\n\r\n`{\r\n  &quot;label1&quot;: &quot;data1&quot;,\r\n  &quot;label2&quot;: &quot;data2&quot;,\r\n  &quot;label3&quot;: &quot;data3&quot;,\r\n  &quot;label4&quot;: &quot;data4&quot;\r\n}`",
      "jq -Rn '[inputs|split(\"|\")] | transpose | map({(.[0]): .[1]}) | add' labels.psv data.psv",
      "jq -nR '\r\n  # From the web:\r\n  def objectify($keys):\r\n    [$keys, .] | transpose | map({(.[0]): .[1]}) | add;\r\n\r\n  (input|split(\"|\")) as $keys\r\n  | inputs | split(\"|\") | objectify($keys)\r\n' labels.psv data.psv"
    ],
    "utterance": "Combine values from a pipe-delimited data file and a pipe-delimited label file to produce an object mapping each label to its corresponding value.",
    "expressions": [
      "jq -Rn '[inputs|split(\"|\")] | transpose | map({(.[0]): .[1]}) | add' labels.psv data.psv",
      "jq -nR '\n  def objectify($keys):\n    [$keys, .] | transpose | map({(.[0]): .[1]}) | add;\n  (input|split(\"|\")) as $keys\n  | inputs | split(\"|\") | objectify($keys)\n' labels.psv data.psv"
    ],
    "data": [
      {
        "input": {
          "labels.psv": "label1|label2|label3|label4",
          "data.psv": "data1|data2|data3|data4"
        },
        "output": {
          "label1": "data1",
          "label2": "data2",
          "label3": "data3",
          "label4": "data4"
        }
      }
    ],
    "identifier": 66657350
  },
  {
    "context": [
      "I would like to transform this into,\r\n\r\n```\r\nname: \"My Pets\"\r\npets:\r\n- name: \"cat\"\r\n  age: 8\r\n  shots: cat.upToDate\r\n- name: \"dog\"\r\n  age: 3\r\n  shots: dog.upToDate\r\n- name: \"mouse\"\r\n  age: 1\r\n  shots: mouse.upToDate\r\n```",
      "where we add a `shots` property to each element of `pets`. The value of `shots` should be whatever the `name` value is, dot, `upToDate`.",
      "Use `|=`, e.g. like so:\r\n\r\n```\r\nyq eval '.pets[] |= (.shots = (.name + \".upToDate\"))' pets.yaml\r\n```"
    ],
    "utterance": "For each element in the 'pets' array, add a 'shots' property whose value is the pet's 'name' followed by '.upToDate'.",
    "expressions": [
      ".pets[] |= (.shots = (.name + \".upToDate\"))"
    ],
    "data": [
      {
        "input": {
          "name": "My Pets",
          "pets": [
            {
              "name": "cat",
              "age": 8
            },
            {
              "name": "dog",
              "age": 3
            },
            {
              "name": "mouse",
              "age": 1
            }
          ]
        },
        "output": {
          "name": "My Pets",
          "pets": [
            {
              "name": "cat",
              "age": 8,
              "shots": "cat.upToDate"
            },
            {
              "name": "dog",
              "age": 3,
              "shots": "dog.upToDate"
            },
            {
              "name": "mouse",
              "age": 1,
              "shots": "mouse.upToDate"
            }
          ]
        }
      }
    ],
    "identifier": 66682183
  },
  {
    "context": [
      "I just want to parse the value key of each of them if it is a string that yields valid json (let's ignore the invalid cases for now, they can return null).",
      "$ jq -n '[{key: \"one\", value: 1},{key: \"two\", value: \"{\\\"object\\\":true}\"}] | map(.value |= try fromjson)'",
      "The good news is that the following will work in jq 1.5 and later:",
      "map(.value = (.value | . as $v | try fromjson catch $v))",
      "or equivalently:",
      "map(.value as $v | .value = try ($v|fromjson) catch $v)"
    ],
    "utterance": "For each object in an array, convert its value field to parsed data only if it is a valid JSON string; otherwise leave it unchanged.",
    "expressions": [
      "map(.value = (.value | . as $v | try fromjson catch $v))",
      "map(.value as $v | .value = try ($v|fromjson) catch $v)"
    ],
    "data": [
      {
        "input": [
          {
            "key": "one",
            "value": 1
          },
          {
            "key": "two",
            "value": "{\"object\":true}"
          }
        ],
        "output": [
          {
            "key": "one",
            "value": 1
          },
          {
            "key": "two",
            "value": {
              "object": true
            }
          }
        ]
      }
    ],
    "identifier": 66700469
  },
  {
    "context": [
      "\"My original schema and the field in question look like this",
      "\"and desired output",
      "\"but the issue is that .metrics[] runs more than one and I end up having 36 rows (instead of 6)",
      "Presumably you mean:",
      "```\r\n.metrics[] | { \"valueQuantity\" : { \"unit\" : .unit, \"value\" : .value}, \"category\" : .type }\r\n```",
      "which can be shortened to:",
      "```\r\n.metrics[] | { valueQuantity: {unit, value}, category: .type }\r\n```"
    ],
    "utterance": "For each object in metrics, extract unit and value as valueQuantity and type as category at the top level.",
    "expressions": [
      ".metrics[] | { \"valueQuantity\": { \"unit\": .unit, \"value\": .value }, \"category\": .type }",
      ".metrics[] | { valueQuantity: {unit, value}, category: .type }"
    ],
    "data": [
      {
        "input": {
          "metrics": [
            {
              "type": "active_duration",
              "unit": "s",
              "value": 135.0
            },
            {
              "type": "basal_energy_burned",
              "unit": "kcal",
              "value": 2371.7412956
            },
            {
              "type": "distance",
              "unit": "m",
              "value": 1510.36558533
            },
            {
              "type": "active_energy_burned",
              "unit": "kcal",
              "value": 295.203469907
            },
            {
              "type": "steps",
              "unit": "count",
              "value": 1877
            },
            {
              "type": "energy_burned",
              "unit": "kcal",
              "value": 2666.944765507
            }
          ]
        },
        "output": [
          {
            "valueQuantity": {
              "unit": "s",
              "value": 135.0
            },
            "category": "active_duration"
          },
          {
            "valueQuantity": {
              "unit": "kcal",
              "value": 2371.7412956
            },
            "category": "basal_energy_burned"
          },
          {
            "valueQuantity": {
              "unit": "m",
              "value": 1510.36558533
            },
            "category": "distance"
          },
          {
            "valueQuantity": {
              "unit": "kcal",
              "value": 295.203469907
            },
            "category": "active_energy_burned"
          },
          {
            "valueQuantity": {
              "unit": "count",
              "value": 1877
            },
            "category": "steps"
          },
          {
            "valueQuantity": {
              "unit": "kcal",
              "value": 2666.944765507
            },
            "category": "energy_burned"
          }
        ]
      }
    ],
    "identifier": 66694992
  },
  {
    "context": [
      "how to get OS name *Debian* from line  *\"ansible_distribution_file_variety\": \"Debian\"*, from the result of the command:",
      "To avoid having to navigate to the relevant object, you could let jq do the walking:",
      "jq '.. | objects | .ansible_distribution_file_variety // empty' data.json"
    ],
    "utterance": "Extract the value of the ansible_distribution_file_variety field with value Debian from an arbitrarily nested structure.",
    "expressions": [
      ".. | objects | .ansible_distribution_file_variety // empty"
    ],
    "data": [
      {
        "input": {
          "custom_stats": {},
          "global_custom_stats": {},
          "plays": [
            {
              "play": {
                "duration": {
                  "end": "2021-03-17T19:44:59.156229Z",
                  "start": "2021-03-17T19:44:55.293502Z"
                },
                "id": "080027fa-0b32-fdef-8eef-000000000007",
                "name": "Ansible Ad-Hoc"
              },
              "tasks": [
                {
                  "hosts": {
                    "localhost": {
                      "_ansible_no_log": false,
                      "_ansible_verbose_override": true,
                      "action": "setup",
                      "ansible_facts": {
                        "ansible_distribution": "Ubuntu",
                        "ansible_distribution_file_parsed": true,
                        "ansible_distribution_file_path": "/etc/os-release",
                        "ansible_distribution_file_variety": "Debian",
                        "ansible_distribution_major_version": "16",
                        "ansible_distribution_release": "xenial",
                        "ansible_distribution_version": "16.04",
                        "discovered_interpreter_python": "/usr/bin/python"
                      },
                      "changed": false,
                      "deprecations": [
                        {
                          "msg": "Distribution Ubuntu 16.04 on host localhost should use /usr/bin/python3, but is using /usr/bin/python for backward compatibility with prior Ansible releases. A future Ansible release will default to using the discovered platform python for this host. See https://docs.ansible.com/ansible/2.9/reference_appendices/interpreter_discovery.html for more information",
                          "version": "2.12"
                        }
                      ],
                      "invocation": {
                        "module_args": {
                          "fact_path": "/etc/ansible/facts.d",
                          "filter": "ansible_distribution*",
                          "gather_subset": [
                            "all"
                          ],
                          "gather_timeout": 10
                        }
                      }
                    }
                  },
                  "task": {
                    "duration": {
                      "end": "2021-03-17T19:44:59.156229Z",
                      "start": "2021-03-17T19:44:55.361244Z"
                    },
                    "id": "080027fa-0b32-fdef-8eef-000000000009",
                    "name": "setup"
                  }
                }
              ]
            }
          ],
          "stats": {
            "localhost": {
              "changed": 0,
              "failures": 0,
              "ignored": 0,
              "ok": 1,
              "rescued": 0,
              "skipped": 0,
              "unreachable": 0
            }
          }
        },
        "output": "Debian"
      }
    ],
    "identifier": 66680372
  },
  {
    "context": [
      "I would like to use **jq** to display the value of 801.170.101 in the following JSON string:",
      "What is the correct syntax to retrieve the value of 801.170.101 (33)?",
      "Just put the keys in quotes `\"..\"`,",
      "jq '.\"801\".\"170\".\"101\"'",
      "or use `argjson` to make the path configurable to select on",
      "jq --argjson path '[\"801\", \"170\", \"101\"]' 'getpath($path)'"
    ],
    "utterance": "Retrieve the value under the nested keys 801 \u2192 170 \u2192 101, where all keys are numeric strings and the value should be 33.",
    "expressions": [
      ".\"801\".\"170\".\"101\"",
      "getpath([\"801\", \"170\", \"101\"])"
    ],
    "data": [
      {
        "input": {
          "801": {
            "170": {
              "100": "abc",
              "101": 33,
              "102": 55
            }
          }
        },
        "output": 33
      }
    ],
    "identifier": 66712560
  },
  {
    "context": [
      "Looking to try to group and average the following json",
      "Looking for the output to look something like,",
      "{\r\n    \"AvailabilityZone\": \"ap-southeast\",\r\n    \"InstanceType\": \"t4g.small\",\r\n    \"ProductDescription\": \"Linux/UNIX\",\r\n    \"SpotPrice\": \"0.00306\"\r\n}",
      "group_by each InstanceType",
      "map each SpotPrice, add those values by using add, devide by map length to get avarage",
      "(map(.SpotPrice | tonumber) | add / length)",
      ".SpotPriceHistory | group_by(.InstanceType)[] | { \"InstanceType\": .[0].InstanceType, \"SpotPrice\": (map(.SpotPrice | tonumber) | add / length) }",
      "{\r\n  \"InstanceType\": \"m1.large\",\r\n  \"SpotPrice\": 0.028300000000000002\r\n}\r\n{\r\n  \"InstanceType\": \"r5ad.24xlarge\",\r\n  \"SpotPrice\": 1.6444\r\n}\r\n{\r\n  \"InstanceType\": \"t4g.small\",\r\n  \"SpotPrice\": 0.0030666666666666668\r\n}"
    ],
    "utterance": "Group records by InstanceType and return the average SpotPrice for each group.",
    "expressions": [
      ".SpotPriceHistory | group_by(.InstanceType)[] | { \"InstanceType\": .[0].InstanceType, \"SpotPrice\": (map(.SpotPrice | tonumber) | add / length) }"
    ],
    "data": [
      {
        "input": {
          "SpotPriceHistory": [
            {
              "AvailabilityZone": "ap-southeast-1c",
              "InstanceType": "t4g.small",
              "ProductDescription": "Linux/UNIX",
              "SpotPrice": "0.001200",
              "Timestamp": "2021-03-17T18:27:08+00:00"
            },
            {
              "AvailabilityZone": "ap-southeast-1a",
              "InstanceType": "t4g.small",
              "ProductDescription": "Linux/UNIX",
              "SpotPrice": "0.002400",
              "Timestamp": "2021-03-17T18:27:08+00:00"
            },
            {
              "AvailabilityZone": "ap-southeast-1b",
              "InstanceType": "t4g.small",
              "ProductDescription": "Linux/UNIX",
              "SpotPrice": "0.005600",
              "Timestamp": "2021-03-17T18:27:08+00:00"
            },
            {
              "AvailabilityZone": "ap-southeast-1a",
              "InstanceType": "m1.large",
              "ProductDescription": "Linux/UNIX",
              "SpotPrice": "0.033300",
              "Timestamp": "2021-03-17T18:20:33+00:00"
            },
            {
              "AvailabilityZone": "ap-southeast-1b",
              "InstanceType": "m1.large",
              "ProductDescription": "Linux/UNIX",
              "SpotPrice": "0.023300",
              "Timestamp": "2021-03-17T18:20:33+00:00"
            },
            {
              "AvailabilityZone": "ap-southeast-1b",
              "InstanceType": "r5ad.24xlarge",
              "ProductDescription": "Linux/UNIX",
              "SpotPrice": "1.644400",
              "Timestamp": "2021-03-17T18:20:20+00:00"
            }
          ]
        },
        "output": [
          {
            "InstanceType": "m1.large",
            "SpotPrice": 0.028300000000000002
          },
          {
            "InstanceType": "r5ad.24xlarge",
            "SpotPrice": 1.6444
          },
          {
            "InstanceType": "t4g.small",
            "SpotPrice": 0.0030666666666666668
          }
        ]
      }
    ],
    "identifier": 66696632
  },
  {
    "context": [
      "I have JSON like this:\n\n```\n{\n    \"speakers\": [\n        {\n            \"firstName\": \"Abe\",\n            \"lastName\": \"Abraham\"\n        },\n        {\n            \"firstName\": \"Max\",\n            \"lastName\": \"Miller\"\n        }\n    ]\n}\n```",
      "Expected output:\n\n```\nAbe Abraham and Max Miller\n```",
      "What you want is a single array containing all so that you can join them, which is done like this:\n```\n.speakers | map(\"\\(.firstName) \\(.lastName)\") | join(\" and \")\n```",
      "$ jq -r '[ .speakers[] | \"\\(.firstName) \\(.lastName)\" ] | join(\" and \")' speakers.json\nAbe Abraham and Max Miller",
      "$ jq -r '[.speakers[] | join(\" \")] | join(\" and \")' speakers.json \nAbe Abraham and Max Miller"
    ],
    "utterance": "Produce a single line string concatenating each speaker's firstName and lastName, separated by ' and '.",
    "expressions": [
      ".speakers | map(\"\\(.firstName) \\(.lastName)\") | join(\" and \")",
      "[ .speakers[] | \"\\(.firstName) \\(.lastName)\" ] | join(\" and \")",
      "[.speakers[] | join(\" \")] | join(\" and \")"
    ],
    "data": [
      {
        "input": {
          "speakers": [
            {
              "firstName": "Abe",
              "lastName": "Abraham"
            },
            {
              "firstName": "Max",
              "lastName": "Miller"
            }
          ]
        },
        "output": "Abe Abraham and Max Miller"
      }
    ],
    "identifier": 66725582
  },
  {
    "context": [
      "The expected output is to get the keys and corresponding json object values.",
      "With to_entries the spaces between the string values are breaking the logic.",
      "Desired output: \nkey: \"parkey1\"\nvalue: {\n      \"parkey1subkey1\":\"sub val1\",\n      \"parkey1subkey2\":\"sub val2\"\n   }\n\nkey: parkey2\nvalue: {\n      \"parkey2subkey1\":{\n         \"subsubkey1\":\"val with space\",\n         \"subsubkey2\":{\n            \"subsubval3\":\"val space\"\n         }\n      }\n   }",
      "jq 'to_entries[]' | sed -e 's/^[{}]//' -e 's/^  //'"
    ],
    "utterance": "Output each top-level key and its associated object value, including keys and values that contain spaces, in a readable key/value display.",
    "expressions": [
      "to_entries[] | \"key: \"+(.key)+\"\\nvalue: \"+(.value|tostring)"
    ],
    "data": [
      {
        "input": {
          "parkey1": {
            "parkey1subkey1": "sub val1",
            "parkey1subkey2": "sub val2"
          },
          "parkey2": {
            "parkey2subkey1": {
              "subsubkey1": "val with space",
              "subsubkey2": {
                "subsubval3": "val space"
              }
            }
          }
        },
        "output": [
          "key: parkey1\nvalue: {\"parkey1subkey1\":\"sub val1\",\"parkey1subkey2\":\"sub val2\"}",
          "key: parkey2\nvalue: {\"parkey2subkey1\":{\"subsubkey1\":\"val with space\",\"subsubkey2\":{\"subsubval3\":\"val space\"}}}"
        ]
      }
    ],
    "identifier": 66745739
  },
  {
    "context": [
      "jq -r '.Attendees[1:4][].Name'",
      "So first find their respective indices:",
      "  .Attendees\n  | map(.Name)\n  | index(\"Jasmine\") as $first\n  | index(\"Mark\") as $last\n  | select($first and $last))      # if both must be present\n  | .[$first: $last+1][]",
      "  .Attendees | map(.Name)\n  | (index(\"Jasmine\") // 0) as $first\n  | (index(\"Mark\") // length) as $last\n  | .[ range($first; $last+1) ]"
    ],
    "utterance": "Select and output only the Name values of attendees starting from Jasmine up to and including Mark.",
    "expressions": [
      ".Attendees[1:4][].Name",
      ".Attendees | map(.Name) | .[index(\"Jasmine\"):index(\"Mark\")+1][]"
    ],
    "data": [
      {
        "input": {
          "Attendees": [
            {
              "Name": "Joseph",
              "CreationDate": "2019-08-13T08:35:17+00:00"
            },
            {
              "Name": "Jasmine",
              "CreationDate": "2019-01-07T03:24:01+00:00"
            },
            {
              "Name": "Rebecca",
              "CreationDate": "2020-05-19T13:20:58+00:00"
            },
            {
              "Name": "Mark",
              "CreationDate": "2019-01-30T15:09:39+00:00"
            }
          ]
        },
        "output": [
          "Jasmine",
          "Rebecca",
          "Mark"
        ]
      }
    ],
    "identifier": 66758677
  },
  {
    "context": [
      "In the following json I need to rewrite the `configURL` values and add `staging.` after(and only) `https://` - and ignore 'http://'. The thing is some of the values stored by `configURL` key are arrays.",
      "You\u2019re already checking an object's `type` once -- just do it again:",
      "def camel:\n  if type == \"string\" then\n    gsub( \"https://\"; \"https://staging.\")\n  else\n    .[] |= camel\n  end;",
      "walk( if type==\"object\" and .configURL then (.configURL |= camel) else . end)"
    ],
    "utterance": "Rewrite each configURL value by inserting staging. immediately after https://, both for string and array values, skipping entries that start with http://.",
    "expressions": [
      "jq -r 'def camel: if type == \"string\" then gsub(\"https://\"; \"https://staging.\") else .[] |= camel end; walk( if type==\"object\" and .configURL then (.configURL |= camel) else . end)'",
      "jq -r '(.. | .configURL? | select(.) | (.[]? // .)) |= sub(\"^https://\"; \"https://staging.\")'"
    ],
    "data": [
      {
        "input": {
          "app1.json": {
            "content": "app-config",
            "updates": 2,
            "configURL": "https://companyX.com/app1/config.json"
          },
          "app2.json": {
            "content": "app-config",
            "updates": 2,
            "configURL": [
              "https://some-company.com/app2/config.json",
              "https://some-company.com/app2/config-resources.json",
              "http://some-company.com/app2/config-resources.json"
            ]
          },
          "app3.ini": {
            "content": "binaries",
            "scope": "deploy",
            "configURL": "https://staging.app4.com/app4/installs/binaries.ini",
            "resources": [
              "https://app4.com/resource",
              "https://app4.com/resource.bin",
              "https://app4.com/resource2.bin"
            ]
          },
          "app4.json": {
            "content": "app-config",
            "updates": 3,
            "configURL": [
              "https://different-company.com/app3/config.json",
              "https://different-company.com/app3/config-resources.json",
              "https://different-company.com/app3/config-binaries.json"
            ],
            "resources": [
              "https://different-company.com/resource",
              "https://different-company.com/resource.bin",
              "https://different-company.com/resource2.bin"
            ]
          }
        },
        "output": {
          "app1.json": {
            "content": "app-config",
            "updates": 2,
            "configURL": "https://staging.companyX.com/app1/config.json"
          },
          "app2.json": {
            "content": "app-config",
            "updates": 2,
            "configURL": [
              "https://staging.some-company.com/app2/config.json",
              "https://staging.some-company.com/app2/config-resources.json"
            ]
          },
          "app3.ini": {
            "content": "binaries",
            "scope": "deploy",
            "configURL": "https://staging.staging.app4.com/app4/installs/binaries.ini",
            "resources": [
              "https://app4.com/resource",
              "https://app4.com/resource.bin",
              "https://app4.com/resource2.bin"
            ]
          },
          "app4.json": {
            "content": "app-config",
            "updates": 3,
            "configURL": [
              "https://staging.different-company.com/app3/config.json",
              "https://staging.different-company.com/app3/config-resources.json",
              "https://staging.different-company.com/app3/config-binaries.json"
            ],
            "resources": [
              "https://different-company.com/resource",
              "https://different-company.com/resource.bin",
              "https://different-company.com/resource2.bin"
            ]
          }
        }
      }
    ],
    "identifier": 66723014
  },
  {
    "context": [
      "I would like the changes to the array be reflected in that file",
      "remove the second element in the array using jq where ID= \"dimes-snapshot\" and time= 2017-01-09T22:41:46.229000+00:00",
      "The array is in a snapshot.json file",
      "I've tried this command but it doesn't work",
      "jq \"del(.[] | select(.id == $ID))\" snapshots.json"
    ],
    "utterance": "Remove the object with ID equal to \"dimes-snapshot\" and Time equal to \"2017-01-09T22:41:46.229000+00:00\" from the top-level array in the file.",
    "expressions": [
      "del(.[[] | select(.ID == \"dimes-snapshot\" and .Time == \"2017-01-09T22:41:46.229000+00:00\") | . as $i | index($i)))",
      "del(.[] | select(.ID == \"dimes-snapshot\" and .Time == \"2017-01-09T22:41:46.229000+00:00\"))",
      "map(select(.ID != \"dimes-snapshot\" or .Time != \"2017-01-09T22:41:46.229000+00:00\"))"
    ],
    "data": [
      {
        "input": [
          {
            "ID": "delete-05032019",
            "Time": "2019-05-03T18:01:12.375000+00:00"
          },
          {
            "ID": "dimes-snapshot",
            "Time": "2017-01-09T22:41:46.229000+00:00"
          },
          {
            "ID": "dimes-snapshot-2",
            "Time": "2018-02-28T16:06:09.091000+00:00"
          }
        ],
        "output": [
          {
            "ID": "delete-05032019",
            "Time": "2019-05-03T18:01:12.375000+00:00"
          },
          {
            "ID": "dimes-snapshot-2",
            "Time": "2018-02-28T16:06:09.091000+00:00"
          }
        ]
      }
    ],
    "identifier": 66752932
  },
  {
    "context": [
      "I have following json and want to remove keys if the \"value\" matches specific pattern. Name of the keys are not fixed or pre-determined.",
      "After removal of the following keys as values matched timestamp format.",
      "\"(?x:\n   ^\n   (?: \\\\d{4}-\\\\d{2}-\\\\d{2}T\n   |   \\\\w{3},[ ][\\\\d ]\\\\d[ ]\\\\w{3}[ ]\\\\d{4}\n   )\n)\" as $date_pattern |\n\n( .. | select(type == \"object\") ) |= del(.[\n   . as $o |\n   keys_unsorted[] |\n   select( $o[.] | type == \"string\" and test($date_pattern) )\n])",
      "walk(if type==\"object\"\n     then with_entries(if .value|matches then empty else . end)\n     else . end)",
      "def matches:\n  type == \"string\"\n  and test(\"^[1-9]\\\\d{3}-\\\\d+-\\\\d|[1-9]\\\\d{3} \\\\d{2}:\\\\d{2}:\\\\d{2}\");"
    ],
    "utterance": "Remove all keys whose value is a string matching a timestamp or date pattern, regardless of the key name.",
    "expressions": [
      "\"(?x:\\n   ^\\n   (?: \\\\d{4}-\\\\d{2}-\\\\d{2}T\\n   |   \\\\w{3},[ ][\\\\d ]\\\\d[ ]\\\\w{3}[ ]\\\\d{4}\\n   )\\n)\" as $date_pattern |\\n\\n( .. | select(type == \\\"object\\\") ) |= del(.[\\n   . as $o |\\n   keys_unsorted[] |\\n   select( $o[.] | type == \\\"string\\\" and test($date_pattern) )\\n])",
      "def matches: type == \"string\" and test(\"^[1-9]\\\\d{3}-\\\\d+-\\\\d|[1-9]\\\\d{3} \\\\d{2}:\\\\d{2}:\\\\d{2}\");\\nwalk(if type==\"object\"\\n     then with_entries(if .value|matches then empty else . end)\\n     else . end)"
    ],
    "data": [
      {
        "input": {
          "resources": [
            {
              "tags": null,
              "properties": {
                "customerId": "1234-cbd9-42bc-9193-f6432a6ef0d4",
                "provisioningState": "Succeeded",
                "sku": {
                  "maxCapacityReservationLevel": 3000,
                  "lastSkuUpdate": "Fri, 19 Mar 2021 16:38:12 GMT"
                },
                "createdDate": "Fri, 19 Mar 2021 16:38:12 GMT",
                "modifiedDate": "Fri, 19 Mar 2021 17:27:54 GMT",
                "status": {
                  "events": [
                    {
                      "count": 1,
                      "firstTimestamp": "2021-03-19T16:40:59Z",
                      "lastTimestamp": "2021-03-19T16:40:59Z",
                      "name": "Pulling",
                      "type": "Normal"
                    }
                  ]
                }
              }
            }
          ]
        },
        "output": {
          "resources": [
            {
              "tags": null,
              "properties": {
                "customerId": "1234-cbd9-42bc-9193-f6432a6ef0d4",
                "provisioningState": "Succeeded",
                "sku": {
                  "maxCapacityReservationLevel": 3000
                },
                "status": {
                  "events": [
                    {
                      "count": 1,
                      "name": "Pulling",
                      "type": "Normal"
                    }
                  ]
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 66727605
  },
  {
    "context": [
      "I want to create another json file two.json with the below output",
      "The difference between file one and file two is the value of \"name\" is replaced with details[0].name in each instance recursively.",
      "map(.name = .details[0].name)",
      "Set `name` key to the `name` of the `0`'st index in `details` array"
    ],
    "utterance": "For each object, replace the value of the top-level key 'name' with the value at details[0].name.",
    "expressions": [
      "map(.name = .details[0].name)"
    ],
    "data": [
      {
        "input": [
          {
            "session": "One",
            "name": "First Session",
            "details": [
              {
                "name": "Session One"
              }
            ]
          },
          {
            "session": "Two",
            "name": "Second Session",
            "details": [
              {
                "name": "Session Two"
              }
            ]
          }
        ],
        "output": [
          {
            "session": "One",
            "name": "Session One",
            "details": [
              {
                "name": "Session One"
              }
            ]
          },
          {
            "session": "Two",
            "name": "Session Two",
            "details": [
              {
                "name": "Session Two"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 66767971
  },
  {
    "context": [
      "I have 2 locale file and want to group different words into same key",
      "en.json\n{\n    \"name\": \"Apple\",\n    \"error\": {\n        \"payment\": {\n            \"value1\": \"v1\"\n        }\n    }\n}",
      "zh.json\n{\n    \"name\": \"orange\",\n    \"error\": {\n        \"payment\": {\n            \"value1\": \"v2\",\n            \"value2\": \"v5\"\n        }\n    }\n}",
      "expected result\n{\n    \"name\": \"Apple\\norange\",\n    \"error\": {\n        \"payment\": {\n            \"value1\": \"v1\\nv2\",\n            \"value2\": \"v5\"\n        }\n    }\n}",
      "jq -n '\n  input as $one\n  | input as $two\n  | reduce ($two | paths(scalars)) as $p  ($one;\n      getpath($p) as $v\n      | ($two | getpath($p)) as $x\n      | if $v\n        then setpath($p; \"\\($v)\\n\\($x)\")\n        else setpath($p; $x)\n        end)\n' en.json zh.json",
      "[inputs | tostream | select(length==2)] #1\n  | group_by(.[0]) #2\n  | map({\n      path: .[0][0],\n      values: [.[][1]]\n    }) #3\n  | reduce .[] as {$path, $values} (\n      {};\n      setpath($path; $values | join(\"\\n\"))\n    ) #4"
    ],
    "utterance": "Merge two locale files by concatenating all values for each matching key path using a newline, and including all keys present in either file.",
    "expressions": [
      "jq -n '\n  input as $one\n  | input as $two\n  | reduce ($two | paths(scalars)) as $p  ($one;\n      getpath($p) as $v\n      | ($two | getpath($p)) as $x\n      | if $v\n        then setpath($p; \"\\($v)\\n\\($x)\")\n        else setpath($p; $x)\n        end)\n' en.json zh.json",
      "jq -n '\n[inputs | tostream | select(length==2)]\n  | group_by(.[0])\n  | map({\n      path: .[0][0],\n      values: [.[][1]]\n    })\n  | reduce .[] as {$path, $values} (\n      {};\n      setpath($path; $values | join(\"\\n\"))\n    )\n' en.json zh.json"
    ],
    "data": [
      {
        "input": {
          "en.json": {
            "name": "Apple",
            "error": {
              "payment": {
                "value1": "v1"
              }
            }
          },
          "zh.json": {
            "name": "orange",
            "error": {
              "payment": {
                "value1": "v2",
                "value2": "v5"
              }
            }
          }
        },
        "output": {
          "name": "Apple\norange",
          "error": {
            "payment": {
              "value1": "v1\nv2",
              "value2": "v5"
            }
          }
        }
      }
    ],
    "identifier": 66758755
  },
  {
    "context": [
      "I have ve got JSON structured like this:",
      "{\n   \"a\": [1, 2, 3, 4 ...],\n   \"b\": [\n      {\n         \"x\": 1000,\n         \"value\": 1\n      },\n      {\n         \"x\": 1000,\n         \"value\": 2\n      },\n      {\n         \"x\": 1000,\n         \"value\": 3\n      }\n      ...\n   ]\n}",
      "I am wondering how I can achieve result like this with jq:",
      "[\n   {\n      \"value\": 1,\n      \"from\": \"a\",\n   },\n   {\n      \"value\": 2,\n      \"from\": \"a\"\n   },\n   ...\n   {\n      \"value\": 1,\n      \"from\": \"b\"\n   },\n   {\n      \"value\": 2,\n      \"from\": \"b\"\n   }\n   ...\n]",
      "jq '[.a[] | {value:(.), from: \"a\"}] + [.b[] | del(.x) + {from: \"b\"}]'",
      "map_values( if type == \"array\" \n            then map(if type == \"object\" then .value else . end) \n            else . end)\n| [ keys_unsorted[] as $k\n    | .[$k][] as $v\n    | { value: $v, from: $k } ]"
    ],
    "utterance": "Merge array 'a' and array 'b', extracting the value from each, and produce a single array of objects each with 'value' as the number and 'from' as the source array name.",
    "expressions": [
      "[.a[] | {value:(.), from: \"a\"}] + [.b[] | del(.x) + {from: \"b\"}]",
      "map_values( if type == \"array\" then map(if type == \"object\" then .value else . end) else . end) | [ keys_unsorted[] as $k | .[$k][] as $v | { value: $v, from: $k } ]"
    ],
    "data": [
      {
        "input": {
          "a": [
            1,
            2,
            3
          ],
          "b": [
            {
              "x": 1000,
              "value": 1
            },
            {
              "x": 1000,
              "value": 2
            },
            {
              "x": 1000,
              "value": 3
            }
          ]
        },
        "output": [
          {
            "value": 1,
            "from": "a"
          },
          {
            "value": 2,
            "from": "a"
          },
          {
            "value": 3,
            "from": "a"
          },
          {
            "value": 1,
            "from": "b"
          },
          {
            "value": 2,
            "from": "b"
          },
          {
            "value": 3,
            "from": "b"
          }
        ]
      }
    ],
    "identifier": 66762135
  },
  {
    "context": [
      "I want to 'recognise' the pattern ... and change it into ...",
      "Let's take as example: ... which I'd like to turn into ...",
      "Given the input shown, the following jq program produces the expected output and seems to conform with the general requirements, and should be easy to modify according to your more detailed requirements:",
      "walk(if type==\"object\" and (.allOf | (type == \"array\") and (length == 2))\n     then {\"$ref\": .allOf[0][\"$ref\"]}\n     else . end)"
    ],
    "utterance": "Replace objects with an 'allOf' array of length two, where the first item contains a '$ref' field and the second item contains a 'description', with a new object containing only the '$ref' value from the first array item.",
    "expressions": [
      "walk(if type==\"object\" and (.allOf | (type == \"array\") and (length == 2)) then {\"$ref\": .allOf[0][\"$ref\"]} else . end)"
    ],
    "data": [
      {
        "input": {
          "components": {
            "schemas": {
              "ObjectStatusType": {
                "required": [
                  "status",
                  "type",
                  "agreement"
                ],
                "type": "object",
                "properties": {
                  "agreement": {
                    "description": "An agreement",
                    "maxLength": 5,
                    "type": "string"
                  },
                  "status": {
                    "allOf": [
                      {
                        "$ref": "#/components/schemas/Status"
                      },
                      {
                        "description": "Status"
                      }
                    ]
                  },
                  "type": {
                    "allOf": [
                      {
                        "$ref": "#/components/schemas/Type"
                      },
                      {
                        "description": "Type"
                      }
                    ]
                  }
                }
              },
              "BallType": {
                "required": [
                  "colour",
                  "type",
                  "physics"
                ],
                "type": "object",
                "properties": {
                  "colour": {
                    "description": "Ball colour",
                    "maxLength": 5,
                    "type": "string"
                  },
                  "type": {
                    "allOf": [
                      {
                        "$ref": "#/components/schemas/Type"
                      },
                      {
                        "description": "Type"
                      }
                    ]
                  },
                  "physics": {
                    "allOf": [
                      {
                        "$ref": "#/components/schemas/Physics"
                      },
                      {
                        "description": "Physics"
                      }
                    ]
                  }
                }
              }
            }
          }
        },
        "output": {
          "components": {
            "schemas": {
              "ObjectStatusType": {
                "required": [
                  "status",
                  "type",
                  "agreement"
                ],
                "type": "object",
                "properties": {
                  "agreement": {
                    "description": "An agreement",
                    "maxLength": 5,
                    "type": "string"
                  },
                  "status": {
                    "$ref": "#/components/schemas/Status"
                  },
                  "type": {
                    "$ref": "#/components/schemas/Type"
                  }
                }
              },
              "BallType": {
                "required": [
                  "colour",
                  "type",
                  "physics"
                ],
                "type": "object",
                "properties": {
                  "colour": {
                    "description": "Ball colour",
                    "maxLength": 5,
                    "type": "string"
                  },
                  "type": {
                    "$ref": "#/components/schemas/Type"
                  },
                  "physics": {
                    "$ref": "#/components/schemas/Physics"
                  }
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 66703892
  },
  {
    "context": [
      "I have a JSON array that I'm trying to unpack into a single element using jq (needed to be able to be read by another program), but I'm struggling to find the solution.",
      "I would like to make it look like this, as an example:",
      "{\r\n  \"values\": {\r\n    \"usrwww_size\": false,\r\n    \"architecture\": \"amd64\",\r\n    \"bios_version\": \"rel-1.11.2-0-gf9626ccb91-prebuilt.qemu-project.org\",\r\n    \"blockdevices\": \"sr0,vda\"\r\n  }\r\n}",
      "You can add the outer `{ values: }` wrapping needed.",
      "jq '{ values: .[].facts.data | add }'"
    ],
    "utterance": "Combine all key-value pairs from the 'facts.data' array of the first array element into a single object under the field 'values'.",
    "expressions": [
      "{ values: .[].facts.data | add }"
    ],
    "data": [
      {
        "input": [
          {
            "timestamp": "2021-03-24T06:15:42.437Z",
            "facts": {
              "data": [
                {
                  "usrwww_size": false
                },
                {
                  "architecture": "amd64"
                },
                {
                  "bios_version": "rel-1.11.2-0-gf9626ccb91-prebuilt.qemu-project.org"
                },
                {
                  "blockdevices": "sr0,vda"
                }
              ]
            }
          }
        ],
        "output": {
          "values": {
            "usrwww_size": false,
            "architecture": "amd64",
            "bios_version": "rel-1.11.2-0-gf9626ccb91-prebuilt.qemu-project.org",
            "blockdevices": "sr0,vda"
          }
        }
      }
    ],
    "identifier": 66777394
  },
  {
    "context": [
      "i want to produce an output grouped by loc containing loc as a header and name + mem field underneath.",
      "what i want is:\nlxd1 ---------------------\nghjk 293\nqwer 1140\nzxcv 1505\nlxd2 ---------------------\nasdf 316\ntyui 257\nbnml 46",
      "jq -rs 'group_by(.loc)[] | ([.[].loc] | first) + \" ---------------------\",(.[] | \"\\(.name) \\(.mem/1024/1024|floor)\")  ' /tmp/data1.json",
      "You need to address each element first and then pipe the info you want to show, you already have everything inside each single object of the array."
    ],
    "utterance": "Group objects by their 'loc' field, print the group header, then for each object under that group, concatenate the 'name' field and the 'mem' value converted to megabytes (by dividing by 1024 twice and applying floor).",
    "expressions": [
      "group_by(.loc)[] | ([.[].loc] | first) + \" ---------------------\", (.[] | \"\\(.name) \\(.mem/1024/1024|floor)\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "asdf",
            "loc": "lxd2",
            "mem": 332320768
          },
          {
            "name": "ghjk",
            "loc": "lxd1",
            "mem": 307908608
          },
          {
            "name": "qwer",
            "loc": "lxd1",
            "mem": 1195794432
          },
          {
            "name": "tyui",
            "loc": "lxd2",
            "mem": 269889536
          },
          {
            "name": "zxcv",
            "loc": "lxd1",
            "mem": 1578475520
          },
          {
            "name": "bnml",
            "loc": "lxd2",
            "mem": 48967680
          }
        ],
        "output": [
          "lxd1 ---------------------",
          "ghjk 293",
          "qwer 1140",
          "zxcv 1505",
          "lxd2 ---------------------",
          "asdf 316",
          "tyui 257",
          "bnml 46"
        ]
      }
    ],
    "identifier": 66777320
  },
  {
    "context": [
      "I would like to parse this and have a css output that looks something like this:",
      "\"authType, status, attribute 1, attribute 2, attribute 3, attribute 4",
      "\"1\", \"active\", \"value1\", \"value2\", \"value3\",\"\"",
      "\"1\", \"active\", \"value1\", \"value2\", \"value3\",\"value 4\"",
      "Some records don't have all the attributes. Some have all 4 yet some only have 1. I am hoping to show a null value in the csv for the records that don't have the attribute.",
      "With your sample input, the following program, which does not depend on the ordering of the \"attribute\" keys:",
      "jq -r '\n[\"Attribute 1\", \"Attribute 2\", \"Attribute 3\", \"Attribute 4\"] as $attributes\n# Header row\n| [\"authType\", \"status\"] \n  + ($attributes | map( (.[:1] | ascii_upcase) + .[1:])),\n# Data rows:\n  (.[]\n   | (INDEX(.userCustomAttributes[]; .customAttributeName)\n      | map_values(.customAttributeValue)) as $dict\n   | [.auth, .status] + [ $dict[ $attributes[] ] ]\n   )\n| @csv\n'"
    ],
    "utterance": "Generate CSV rows with columns authType, status, Attribute 1, Attribute 2, Attribute 3, and Attribute 4, filling missing attribute columns with null.",
    "expressions": [
      "[\"Attribute 1\", \"Attribute 2\", \"Attribute 3\", \"Attribute 4\"] as $attributes\n| [\"authType\", \"status\"] + ($attributes | map( (.[:1] | ascii_upcase) + .[1:])),\n  (.[]\n   | (INDEX(.userCustomAttributes[]; .customAttributeName)\n      | map_values(.customAttributeValue)) as $dict\n   | [.auth, .status] + [ $dict[ $attributes[] ] ]\n   )\n| @csv"
    ],
    "data": [
      {
        "input": [
          {
            "auth": 1,
            "status": "Active",
            "userCustomAttributes": [
              {
                "customAttributeName": "Attribute 1",
                "customAttributeValue": "Value 1"
              },
              {
                "customAttributeName": "Attribute 2",
                "customAttributeValue": "Value 2"
              },
              {
                "customAttributeName": "Attribute 3",
                "customAttributeValue": "Value 3"
              }
            ]
          },
          {
            "auth": 1,
            "status": "Active",
            "userCustomAttributes": [
              {
                "customAttributeName": "Attribute 1",
                "customAttributeValue": "Value 1"
              },
              {
                "customAttributeName": "Attribute 2",
                "customAttributeValue": "Value 2"
              },
              {
                "customAttributeName": "Attribute 3",
                "customAttributeValue": "Value 3"
              },
              {
                "customAttributeName": "Attribute 4",
                "customAttributeValue": "Value 4"
              }
            ]
          }
        ],
        "output": "\"authType\",\"status\",\"Attribute 1\",\"Attribute 2\",\"Attribute 3\",\"Attribute 4\"\n1,\"Active\",\"Value 1\",\"Value 2\",\"Value 3\",\n1,\"Active\",\"Value 1\",\"Value 2\",\"Value 3\",\"Value 4\""
      }
    ],
    "identifier": 66770114
  },
  {
    "context": [
      "flip the coordinates lines",
      "change the \"type\" key to \"layer\"",
      "To flip the coordinates, we can now simply write:",
      "```\n.features[].geometry |= flip\n```",
      "change the \"type\" key to \"layer\"\n```\n{layer: .type} + .\n| del(.type)\n```",
      "Putting it together\n```\n{layer:.type} + .\n| del(.type)\n| .features[].geometry |= flip\n```"
    ],
    "utterance": "Swap the order of each coordinate pair in all features' geometry and rename the root 'type' key to 'layer', removing 'type'.",
    "expressions": [
      "def flip: .coordinates |= map(map(reverse));\n{layer:.type} + . | del(.type) | .features[].geometry |= flip"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "name": "Almoxarifado / Patrim\u00f4nio"
              },
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      -52.163317,
                      -32.075462
                    ],
                    [
                      -52.163884,
                      -32.075467
                    ],
                    [
                      -52.163883,
                      -32.075336
                    ],
                    [
                      -52.163321,
                      -32.075332
                    ],
                    [
                      -52.163317,
                      -32.075462
                    ]
                  ]
                ]
              }
            }
          ]
        },
        "output": {
          "layer": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "name": "Almoxarifado / Patrim\u00f4nio"
              },
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      -32.075462,
                      -52.163317
                    ],
                    [
                      -32.075467,
                      -52.163884
                    ],
                    [
                      -32.075336,
                      -52.163883
                    ],
                    [
                      -32.075332,
                      -52.163321
                    ],
                    [
                      -32.075462,
                      -52.163317
                    ]
                  ]
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 66770884
  },
  {
    "context": [
      "I want recursively merge with * the configurePresets elements that inherit themselves for a specific entry name. I have example a node with name arm and want to have resulting json object with resolved inheritance.",
      "Assuming the inheritance hierarchy contains no loops, as is the case with the example, we can break the problem down into the pieces shown below:",
      "INDEX(.configurePresets[]; .name) as $dict\n| $dict[\"arm\"] \n| reduce inherits_from($dict) as $x ({};  $x * .)\n| del(.inherits)",
      "Writing a recursive function is actually simple, once you get the hang of it:\n\njq --arg name \"$1\" '\n\tdef _get_in(input; n):\n\t\t(input[] | select(.name == n)) |\n\t\t(if .inherits then .inherits as $n | _get_in(input; $n) else {} end) * .;\n\tdef get(name):\n\t\t.configurePresets as $input | _get_in($input; name);\n\tget($name)\n' \"$presetfile\""
    ],
    "utterance": "Recursively merge all configurePresets entries following inheritance for the entry with name \"arm\", resolving parent fields by merging until the root.",
    "expressions": [
      "INDEX(.configurePresets[]; .name) as $dict | $dict[\"arm\"] | reduce (recurse(select(.inherits) | $dict[.inherits])) as $x ({}; $x * .) | del(.inherits)",
      "def _get_in(input; n): (input[] | select(.name == n)) | (if .inherits then .inherits as $n | _get_in(input; $n) else {} end) * .; def get(name): .configurePresets as $input | _get_in($input; name); get(\"arm\")"
    ],
    "data": [
      {
        "input": {
          "configurePresets": [
            {
              "name": "default",
              "hidden": true,
              "generator": "Ninja",
              "binaryDir": "${sourceDir}/_build/${presetName}",
              "cacheVariables": {
                "YIO_DEV": "1",
                "BUILD_TESTING": "1"
              }
            },
            {
              "name": "debug",
              "inherits": "default",
              "cacheVariables": {
                "CMAKE_BUILD_TYPE": "Debug"
              }
            },
            {
              "name": "release",
              "inherits": "default",
              "binaryDir": "${sourceDir}/_build/Debug",
              "cacheVariables": {
                "CMAKE_BUILD_TYPE": "Release"
              }
            },
            {
              "name": "arm",
              "inherits": "debug",
              "cacheVariables": {
                "CMAKE_TOOLCHAIN_FILE": "${sourceDir}/cmake/Toolchain/arm-none-eabi-gcc.cmake"
              }
            }
          ]
        },
        "output": {
          "name": "arm",
          "hidden": true,
          "generator": "Ninja",
          "binaryDir": "${sourceDir}/_build/${presetName}",
          "cacheVariables": {
            "YIO_DEV": "1",
            "BUILD_TESTING": "1",
            "CMAKE_BUILD_TYPE": "Debug",
            "CMAKE_TOOLCHAIN_FILE": "${sourceDir}/cmake/Toolchain/arm-none-eabi-gcc.cmake"
          }
        }
      }
    ],
    "identifier": 66786315
  },
  {
    "context": [
      "I have the list of docker images in json, for example:\n\n    {\n      \"name\": \"chart1\",\n      \"version\": \"1.1.0\",\n      \"appVersion\": \"1.1.0\",\n      \"dependencies\": [\n      {\n        \"name\": \"name1\",\n        \"version\": \"10000.1.wew2133\"\n       },\n       {\n        \"name\": \"name2\",\n        \"version\": \"10001.1.wew2133\"\n       }\n      ]\n    }",
      "I need to convert this to list:\n\n    name1:10000.1.wew2133\n    name2:10001.1.wew2133\n\nHow can I do this?",
      "jq --raw-output '.dependencies[] | join(\":\")'",
      "name1:10000.1.wew2133\nname2:10001.1.wew2133"
    ],
    "utterance": "Produce a list of strings in the format name:version for each element of the dependencies array.",
    "expressions": [
      ".dependencies[] | join(\":\")",
      ".dependencies[] | \"\u007f{name}:\u007f{version}\""
    ],
    "data": [
      {
        "input": {
          "name": "chart1",
          "version": "1.1.0",
          "appVersion": "1.1.0",
          "dependencies": [
            {
              "name": "name1",
              "version": "10000.1.wew2133"
            },
            {
              "name": "name2",
              "version": "10001.1.wew2133"
            }
          ]
        },
        "output": [
          "name1:10000.1.wew2133",
          "name2:10001.1.wew2133"
        ]
      }
    ],
    "identifier": 66852251
  },
  {
    "context": [
      "If want to filter elements of an input file based on the presence of a specific value in an entry",
      "The expected result should be something like:\n \n\n\n    [{\n      \"id\":\"type 1 is great\"\n    },{\n     \"id\":\"type 2\"\n    },\n    {\n      \"id\":\"this is another type 2\" \n    }]",
      "how to write it correctly to check if an entry contains one of the string of another array?",
      "def acceptable($array): any(contains($array[]); .);\n\n  [inputs] as $substrings\n  | $json \n  | map( select(.id | acceptable($substrings)) )"
    ],
    "utterance": "Filter objects whose id contains any of the strings listed in another file.",
    "expressions": [
      "[inputs] as $substrings | $json | map( select(.id | any($substrings[]; contains(.))) )",
      "def acceptable($array): any($array[]; . as $sub | contains($sub)); [inputs] as $substrings | $json | map(select(.id | acceptable($substrings)))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "type 1 is great"
          },
          {
            "id": "type 2"
          },
          {
            "id": "this is another type 2"
          },
          {
            "id": "type 4"
          }
        ],
        "output": [
          {
            "id": "type 1 is great"
          },
          {
            "id": "type 2"
          },
          {
            "id": "this is another type 2"
          }
        ]
      }
    ],
    "identifier": 66820040
  },
  {
    "context": [
      "I can extract both ids and URL which contains the string \"gallica\" using the following command: ",
      "jq '[ .items[] | select(.edmIsShownBy[] | contains (\"gallica\")) |  {id: .id, link: .edmIsShownBy[] }]'"
    ],
    "utterance": "Extract id and link fields from all items where any edmIsShownBy entry contains the substring 'gallica'.",
    "expressions": [
      "[ .items[] | select(.edmIsShownBy[] | contains(\"gallica\")) | {id: .id, link: .edmIsShownBy[]} ]"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "completeness": 5,
              "dcLanguageLangAware": {
                "def": [
                  "de"
                ]
              },
              "edmIsShownBy": [
                "https://gallica.example/image/2IC6BQAEGWUEG4OP7AYBDGIGYAX62KZ6H366KXP2IKVAF4LKY37Q/presentation_images/5591be60-01fc-11e6-8e10-fa163e091926/node-3/image/SBB/Berliner_B\u00f6rsenzeitung/1920/02/27/F_065_098_0/F_SBB_00007_19200227_065_098_0_001/full/full/0/default.jpg"
              ],
              "id": "/9200355/BibliographicResource_3000117730632",
              "type": "TEXT",
              "ugc": [
                false
              ]
            }
          ]
        },
        "output": [
          {
            "id": "/9200355/BibliographicResource_3000117730632",
            "link": "https://gallica.example/image/2IC6BQAEGWUEG4OP7AYBDGIGYAX62KZ6H366KXP2IKVAF4LKY37Q/presentation_images/5591be60-01fc-11e6-8e10-fa163e091926/node-3/image/SBB/Berliner_B\u00f6rsenzeitung/1920/02/27/F_065_098_0/F_SBB_00007_19200227_065_098_0_001/full/full/0/default.jpg"
          }
        ]
      }
    ],
    "identifier": 66843336
  },
  {
    "context": [
      "Desired output for the first item:",
      "expected 404 Not Found\nError in test endpoint\n   at Test._assertStatus",
      "Desired output for the second item:",
      "Example fo test\n    Expect 4 and got 5",
      "$ jq -r '.[0].failure_system_out' /tmp/1",
      "$ jq -r '.[1].failure_system_out' /tmp/1",
      "$ jq -r '.[] | .name as $test_name | .failure_system_out as $system_error | $system_error' /tmp/1",
      "If the goal is simply to emit the values of `.failure_system_out` then:\n\n     jq -r '.[].failure_system_out' test.json\n\nwould do it.",
      "Thought I'd still share this [tag:jq] only solution:\n```bash\nprintf \"%s\\n\" \"$(jq -r -c '.[] | .failure_system_out' test.json)\"\n```"
    ],
    "utterance": "Output all values of the field failure_system_out from every object in the array, preserving embedded linebreaks and tabs.",
    "expressions": [
      ".[].failure_system_out",
      ".[] | .failure_system_out",
      ".[] | .name as $test_name | .failure_system_out as $system_error | $system_error"
    ],
    "data": [
      {
        "input": [
          {
            "classname": "Test endpoint",
            "name": "expect failure",
            "failure_system_out": "expected 404 Not Found\nError in test endpoint\n\tat Test._assertStatus"
          },
          {
            "classname": "Test inner functions",
            "name": "expect failure",
            "failure_system_out": "Example fo test\n\tExpect 4 and got 5"
          }
        ],
        "output": "expected 404 Not Found\nError in test endpoint\n\tat Test._assertStatus\nExample fo test\n\tExpect 4 and got 5"
      }
    ],
    "identifier": 66854922
  }
]