[
  {
    "context": [
      "Basically creating a single dictionary with only the `name` and `value` keys from the input dictionaries.",
      "It converts an array of objects to a single object with given key/value pairs. It takes the field name from a field called `key`, `Key`, `name` or `Name` and the value from a field called `value` or `Value`",
      "from_entries"
    ],
    "utterance": "Combine an array of objects into a single object mapping each object's 'name' field to its 'value' field.",
    "expressions": [
      "from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "constant_id": 5,
            "object_id": 2,
            "object_type": "delimited_file",
            "name": "data_file_pattern",
            "value": "list_of_orders.csv",
            "insert_date": "2021-11-23T10:24:16.568Z",
            "update_date": null
          },
          {
            "constant_id": 6,
            "object_id": 2,
            "object_type": "delimited_file",
            "name": "header_count",
            "value": "1",
            "insert_date": "2021-11-23T10:24:16.568Z",
            "update_date": null
          }
        ],
        "output": {
          "data_file_pattern": "list_of_orders.csv",
          "header_count": "1"
        }
      }
    ],
    "identifier": 70086757
  },
  {
    "context": [
      "I want to get rid of the \"group\" arrays in",
      "desired output",
      "The line  `'walk(if type==\"array\" and length==1  then .[0] else . end)'` additionally removes the array from the single \"data\" object.",
      "Ok I got it. I can manually add the walk function such as:\n    'def walk(f):\n                                       . as $in\n                                     | if type == \"object\" then\n                                     reduce keys_unsorted[] as $key\n                                     ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\n                                     elif type == \"array\" then map( walk(f) ) | f\n                                     else f\n                                     end; walk(if type==\"object\"\n                                               and has(\"group\")\n                                               and (.group | type)==\"array\"\n                                               and (.group | length)==1\n                                               then .group = .group[0]\n                                               else . end)'",
      "We could operate one level higher in the nesting hierarchy, and test for `\"group\"` being a key, then update accordingly `.group = .group[0]` instead of `. = .[0]`",
      "jq 'walk(if type==\"object\"\n          and has(\"group\") \n          and (.group | type)==\"array\" \n          and (.group | length)==1 \n          then .group = .group[0] \n          else . end)'"
    ],
    "utterance": "Collapse all single-element arrays that occur as values for the \"group\" key, but do not collapse other arrays.",
    "expressions": [
      "def walk(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys_unsorted[] as $key\n        ({}; . + { ($key): ($in[$key] | walk(f)) }) | f\n    elif type == \"array\" then\n      map(walk(f)) | f\n    else f\n    end;\nwalk(if type==\"object\" and has(\"group\") and (.group | type)==\"array\" and (.group | length)==1 then .group = .group[0] else . end)",
      "walk(if type==\"object\"\n      and has(\"group\") \n      and (.group | type)==\"array\" \n      and (.group | length)==1 \n      then .group = .group[0] \n      else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "id2": "A",
            "group": [
              {
                "data": [
                  {
                    "id1": 1,
                    "group": [
                      {
                        "data": [
                          {
                            "a": 1,
                            "b": 1
                          },
                          {
                            "a": 2,
                            "b": 2
                          }
                        ],
                        "type": "test"
                      }
                    ],
                    "type": "B"
                  }
                ],
                "type": "C"
              }
            ]
          },
          {
            "id2": "C",
            "group": [
              {
                "data": [
                  {
                    "id1": 3,
                    "group": [
                      {
                        "data": [
                          {
                            "a": 1,
                            "b": 1
                          }
                        ],
                        "type": "test"
                      }
                    ],
                    "type": "B"
                  }
                ],
                "type": "C"
              }
            ]
          }
        ],
        "output": [
          {
            "id2": "A",
            "group": {
              "data": [
                {
                  "id1": 1,
                  "group": {
                    "data": [
                      {
                        "a": 1,
                        "b": 1
                      },
                      {
                        "a": 2,
                        "b": 2
                      }
                    ],
                    "type": "test"
                  },
                  "type": "B"
                }
              ],
              "type": "C"
            }
          },
          {
            "id2": "C",
            "group": {
              "data": [
                {
                  "id1": 3,
                  "group": {
                    "data": [
                      {
                        "a": 1,
                        "b": 1
                      }
                    ],
                    "type": "test"
                  },
                  "type": "B"
                }
              ],
              "type": "C"
            }
          }
        ]
      }
    ],
    "identifier": 70063816
  },
  {
    "context": [
      "How can I filter and flatten a tree-like json object using `jq` so that it's only applied to leaves of the tree? In the example below I'd like jq to return something like `[{\"name\": \"foo1\"}, {\"name\": \"bar\"}]`",
      "[ recurse(.nodes[]?) | select(has(\"nodes\")|not) ]",
      "[recurse(.nodes[]?) | select(has(\"nodes\") | not) | {name:.name}]",
      "ouput:\n[{\"name\":\"foo1\"},{\"name\":\"bar\"}]"
    ],
    "utterance": "Extract all objects from the tree that are leaves (do not have a 'nodes' field), returning their 'name' fields.",
    "expressions": [
      "[recurse(.nodes[]?) | select(has(\"nodes\") | not) | {name:.name}]",
      "[ recurse(.nodes[]?) | select(has(\"nodes\")|not) ]"
    ],
    "data": [
      {
        "input": {
          "name": "root",
          "nodes": [
            {
              "name": "foo1"
            },
            {
              "name": "foo2",
              "nodes": [
                {
                  "name": "bar"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "foo1"
          },
          {
            "name": "bar"
          }
        ]
      }
    ],
    "identifier": 70035232
  },
  {
    "context": [
      "KRB=$(gcloud compute instances get-serial-port-output ${HOSTNAME} --project=${ID} --zone=${ZONE} --port=4 | jq -r -c --arg MODULUS $MODULUS 'select(.modulus == $MODULUS) | .encryptedPassword')",
      "jq -n --arg passwd \"$PAS\" '{\"password\":$passwd}'"
    ],
    "utterance": "Print an object with key 'password' and the value held in the variable 'PAS'.",
    "expressions": [
      "jq -n --arg passwd \"$PAS\" '{\"password\":$passwd}'"
    ],
    "identifier": 70202278
  },
  {
    "context": [
      "I'd like to get something like this:",
      "`address` array field string values has to be mapped joining its values using \"|\" character. Example: `\"string-value1|string-value2\"`",
      "`identifiers` array field objects have to be mapped to `\"n-field-header\"`. Example: `\"identifier0_system\",\"identifier0_value\",\"identifier1_system\",\"identifier1_value\",\"identifier2_system\",\"identifier2_value,...\"`",
      "To prepend a header row with the number of `identifierX_system` and `identifierX_value` field pairs in it matching the length of the input's longest `identifier` array, try this",
      "jq -rs '[\n  \n  \"id\",\n  \"meta_versionId\", \"meta_lastUpdated\",\n  \"address\",\n  (\n    range([.[].identifier | length] | max)\n    | \"identifier\\(.)_system\", \"identifier\\(.)_value\"\n  )\n\n], (.[] | [\n\n  .id,\n  (.meta | .versionId, .lastUpdated),\n  (.address | join(\"|\")),\n  (.identifier[] | .system, .value)\n\n]) | @csv'"
    ],
    "utterance": "Produce a CSV where each record has id, meta.versionId, meta.lastUpdated, address values joined by '|', and for each identifier element, system and value fields as separate columns up to the maximum number of identifiers found; omit trailing fields if there are fewer identifiers in a record.",
    "expressions": [
      "jq -rs '[\n  \"id\",\n  \"meta_versionId\", \"meta_lastUpdated\",\n  \"address\",\n  (\n    range([.[].identifier | length] | max)\n    | \"identifier\\(.)_system\", \"identifier\\(.)_value\"\n  )\n], (.[] | [\n  .id,\n  (.meta | .versionId, .lastUpdated),\n  (.address | join(\"|\")),\n  (.identifier[] | .system, .value)\n]) | @csv'"
    ],
    "data": [
      {
        "input": [
          {
            "id": "2261026",
            "meta": {
              "versionId": "1",
              "lastUpdated": "2021-11-08T15:13:39.318+01:00"
            },
            "address": [
              "string-value1",
              "string-value2"
            ],
            "identifier": [
              {
                "system": "urn:oid:2.16.724.4.9.20.93",
                "value": "6209"
              },
              {
                "system": "urn:oid:2.16.724.4.9.20.2",
                "value": "00042"
              },
              {
                "system": "urn:oid:2.16.724.4.9.20.90",
                "value": "UAB2"
              }
            ]
          },
          {
            "id": "2261027",
            "meta": {
              "versionId": "1",
              "lastUpdated": "2021-11-08T15:13:39.318+01:00"
            },
            "address": [
              "string-value1",
              "string-value2",
              "string-value3",
              "string-value4"
            ],
            "identifier": [
              {
                "system": "urn:oid:2.16.724.4.9.20.93",
                "value": "6205"
              },
              {
                "system": "urn:oid:2.16.724.4.9.20.2",
                "value": "05041"
              }
            ]
          }
        ],
        "output": "\"id\",\"meta_versionId\",\"meta_lastUpdated\",\"address\",\"identifier0_system\",\"identifier0_value\",\"identifier1_system\",\"identifier1_value\",\"identifier2_system\",\"identifier2_value\"\n\"2261026\",\"1\",\"2021-11-08T15:13:39.318+01:00\",\"string-value1|string-value2\",\"urn:oid:2.16.724.4.9.20.93\",\"6209\",\"urn:oid:2.16.724.4.9.20.2\",\"00042\",\"urn:oid:2.16.724.4.9.20.90\",\"UAB2\"\n\"2261027\",\"1\",\"2021-11-08T15:13:39.318+01:00\",\"string-value1|string-value2|string-value3|string-value4\",\"urn:oid:2.16.724.4.9.20.93\",\"6205\",\"urn:oid:2.16.724.4.9.20.2\",\"05041\",,"
      }
    ],
    "identifier": 70039008
  },
  {
    "context": [
      "I want to convert the following JSON content stored in a file input.json",
      "into a CSV output",
      "\"field1\",\"field2\",\"field3\"\n\"value1-1\",\"value1-2\",\"value1-3\"\n\"value2-1\",\"value2-2\",\"value2-3\"\n\"value3-1\",\"value3-2\",\"value3-3\"",
      "Use `map(.field)` only on the `first` item, and `map(.value)` on all items `.[]`:",
      "jq -r '.results | (first | map(.field)), (.[] | map(.value)) | @csv' input.json"
    ],
    "utterance": "Produce a CSV where the first row lists all fields and each subsequent row contains the corresponding values from each entry.",
    "expressions": [
      ".results | (first | map(.field)), (.[] | map(.value)) | @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            [
              {
                "field": "field1",
                "value": "value1-1"
              },
              {
                "field": "field2",
                "value": "value1-2"
              },
              {
                "field": "field3",
                "value": "value1-3"
              }
            ],
            [
              {
                "field": "field1",
                "value": "value2-1"
              },
              {
                "field": "field2",
                "value": "value2-2"
              },
              {
                "field": "field3",
                "value": "value2-3"
              }
            ],
            [
              {
                "field": "field1",
                "value": "value3-1"
              },
              {
                "field": "field2",
                "value": "value3-2"
              },
              {
                "field": "field3",
                "value": "value3-3"
              }
            ]
          ]
        },
        "output": "\"field1\",\"field2\",\"field3\"\n\"value1-1\",\"value1-2\",\"value1-3\"\n\"value2-1\",\"value2-2\",\"value2-3\"\n\"value3-1\",\"value3-2\",\"value3-3\""
      }
    ],
    "identifier": 70031566
  },
  {
    "context": [
      "I want to use that list in `jq` to filter out JSON values by a certain key value, which coincides with one value from the list",
      "I tried `in` operator",
      "and `includes` operator",
      "I need to pass the strings as argument and then split it by comma and unbracket them like this:",
      "jq --arg classes $classes '.result.coverage.coverage[] | select(.name == ($classes | split(\",\")[])) | .totalLines'",
      "Another option using `inside()` ... to check if `.name` exist in an array.",
      "jq '[ .result.coverage.coverage[] | select([ .name ] | inside($find | split(\",\") ) ) | . ]' tests.json"
    ],
    "utterance": "Select all objects whose name matches any value from a provided comma-separated list of class names",
    "expressions": [
      ".result.coverage.coverage[] | select(.name == ($classes | split(\",\")[]))",
      "[ .result.coverage.coverage[] | select([ .name ] | inside($find | split(\",\") ) ) | . ]"
    ],
    "data": [
      {
        "input": {
          "status": 0,
          "result": {
            "summary": {
              "outcome": "Passed",
              "testsRan": 13,
              "passing": 13,
              "failing": 0,
              "skipped": 0,
              "passRate": "100%",
              "failRate": "0%"
            },
            "tests": [],
            "coverage": {
              "coverage": [
                {
                  "name": "ApexClass1",
                  "totalLines": 25,
                  "lines": {},
                  "totalCovered": 23,
                  "coveredPercent": 92
                },
                {
                  "name": "ApexClass2",
                  "totalLines": 25,
                  "lines": {},
                  "totalCovered": 23,
                  "coveredPercent": 92
                },
                {
                  "name": "ApexClass3",
                  "totalLines": 25,
                  "lines": {},
                  "totalCovered": 23,
                  "coveredPercent": 92
                }
              ],
              "records": []
            }
          }
        },
        "output": [
          {
            "name": "ApexClass1",
            "totalLines": 25,
            "lines": {},
            "totalCovered": 23,
            "coveredPercent": 92
          },
          {
            "name": "ApexClass3",
            "totalLines": 25,
            "lines": {},
            "totalCovered": 23,
            "coveredPercent": 92
          }
        ]
      }
    ],
    "identifier": 70145294
  },
  {
    "context": [
      "Expected output is:\r\n\r\n    u1      0001    -\r\n    u2      0002    G1,G2\r\n    u3      0003    G1\r\n",
      "How to have on output also objects having no of the *groups* keys and avoid duplicates as showed above?",
      "The following `jq` should give you the desired result -\r\n\r\n```\r\njq -r 'def groups(d): if d | length > 0 then d | map(.name) | join(\",\") else \"-\" end; map(\"\\(.user)     \\(.id)     \\(groups(.groups))\") | .[]'\r\n```\r\n",
      "u1     0001     -\r\nu2     0002     G1,G2\r\nu3     0003     G1\r\n"
    ],
    "utterance": "Print user and id, and if groups is missing or empty, print '-', otherwise print the names of groups joined by commas, for each object in the input list.",
    "expressions": [
      "def groups(d): if d | length > 0 then d | map(.name) | join(\",\") else \"-\" end; map(\"\\(.user)     \\(.id)     \\(groups(.groups))\") | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "user": "u1",
            "id": "0001"
          },
          {
            "user": "u2",
            "id": "0002",
            "groups": [
              {
                "id": "100001",
                "name": "G1"
              },
              {
                "id": "100002",
                "name": "G2"
              }
            ]
          },
          {
            "user": "u3",
            "id": "0003",
            "groups": [
              {
                "id": "100001",
                "name": "G1"
              }
            ]
          }
        ],
        "output": "u1     0001     -\nu2     0002     G1,G2\nu3     0003     G1"
      }
    ],
    "identifier": 70112581
  },
  {
    "context": [
      "Issue is that when `pick_extension(url)` doesn't pick any object, it returns empty.",
      "Desired output I need would be:\n\n[null, null, null, null]\n[null, null, null, null]\n...\n",
      "`// {\"url\":null}` works for me:\n\ndef pick_extension($url):    .extension[] | select( .url == $url);  [  (( pick_extension( \"http://catsalut.gencat.cat/fhir/StructureDefinition/patient-occupation\" ) // {\"url\":null})  | .url , ( .valueCodeableConcept.coding[0] | .system, .code) ) ]"
    ],
    "utterance": "Return an array of four values, replacing missing or unmatched extension data with nulls instead of leaving the array empty.",
    "expressions": [
      "def pick_extension($url): .extension[] | select( .url == $url);\n[ (( pick_extension( \"http://catsalut.gencat.cat/fhir/StructureDefinition/patient-occupation\" ) // {\"url\":null}) | .url , ( .valueCodeableConcept.coding[0] | .system, .code) ) ]"
    ],
    "data": [
      {
        "input": {
          "resourceType": "Patient",
          "id": "14426955",
          "meta": {
            "versionId": "1",
            "lastUpdated": "2021-12-01T14:24:11.387+01:00",
            "source": "#XbZyfGxZj4fZygTv"
          },
          "extension": [
            {
              "url": "http://hl7.org/fhir/StructureDefinition/patient-nationality",
              "extension": [
                {
                  "url": "code",
                  "valueCodeableConcept": {
                    "coding": [
                      {
                        "system": "urn:iso:std:iso:3166",
                        "code": "724"
                      }
                    ]
                  }
                }
              ]
            },
            {
              "url": "http://catsalut.gencat.cat/fhir/StructureDefinition/patient-status",
              "valueCodeableConcept": {
                "coding": [
                  {
                    "system": "http://catsalut.gencat.cat/fhir/EstatRegistre",
                    "code": "alta"
                  }
                ]
              }
            }
          ]
        },
        "output": [
          null,
          null,
          null,
          null
        ]
      }
    ],
    "identifier": 70195277
  },
  {
    "context": [
      "I want to get key/value from `\"Name\"`, `\"--enable-continuous-cloudwatch-log\": \"\"` and `\"--enable-metrics\": \"\"`. So, I need to show the info like this:\n\n```\n\"Name\" \"sample_job\"\n\"--enable-continuous-cloudwatch-log\" \"\"\n\"--enable-metrics\" \"\"\n```",
      "We use string interpolation to show the desired output:\n```none\nName sample_job\n--enable-continuous-cloudwatch-log test_1\n--enable-metrics \n```",
      "jq --raw-output '\"Name \\(.Job.Name)\\n--enable-continuous-cloudwatch-log \\(.DefaultArguments.\"--enable-continuous-cloudwatch-log\")\\n--enable-metrics \\(.DefaultArguments.\"--enable-metrics\")\"'"
    ],
    "utterance": "Display the values for Name, --enable-continuous-cloudwatch-log, and --enable-metrics as key-value pairs, each on a new line, with each value in double quotes.",
    "expressions": [
      "jq -r '\"\\\"Name\\\" \\\"\\(.Job.Name)\\\"\\n\\\"--enable-continuous-cloudwatch-log\\\" \\\"\\(.Job.DefaultArguments[\"--enable-continuous-cloudwatch-log\"])\\\"\\n\\\"--enable-metrics\\\" \\\"\\(.Job.DefaultArguments[\"--enable-metrics\"])\\\"\"'"
    ],
    "data": [
      {
        "input": {
          "Job": {
            "Name": "sample_job",
            "Description": "",
            "Role": "arn:aws:iam::00000000000:role/sample_role",
            "CreatedOn": "2021-10-21T23:35:23.660000-03:00",
            "LastModifiedOn": "2021-10-21T23:45:41.771000-03:00",
            "ExecutionProperty": {
              "MaxConcurrentRuns": 1
            },
            "Command": {
              "Name": "glueetl",
              "ScriptLocation": "s3://aws-sample-s3/scripts/sample.py",
              "PythonVersion": "3"
            },
            "DefaultArguments": {
              "--TempDir": "s3://aws-sample-s3/temporary/",
              "--class": "GlueApp",
              "--enable-continuous-cloudwatch-log": "true",
              "--enable-glue-datacatalog": "true",
              "--enable-metrics": "true",
              "--enable-spark-ui": "true",
              "--job-bookmark-option": "job-bookmark-enable",
              "--job-insights-byo-rules": "",
              "--job-language": "python",
              "--spark-event-logs-path": "s3://aws-sample-s3/logs"
            },
            "MaxRetries": 0,
            "AllocatedCapacity": 100,
            "Timeout": 2880,
            "MaxCapacity": 100.0,
            "WorkerType": "G.1X",
            "NumberOfWorkers": 100,
            "GlueVersion": "2.0"
          }
        },
        "output": "\"Name\" \"sample_job\"\n\"--enable-continuous-cloudwatch-log\" \"true\"\n\"--enable-metrics\" \"true\""
      }
    ],
    "identifier": 70035615
  },
  {
    "context": [
      "I am trying to get JSON data where a child key match exists, but I want to exclude data from other child elements that don't match.",
      "trying to return `id` from the parent and `quantity` from the child, where the child `catalog_object_id` \"VJXWCBDL\":",
      "When I use `select` based on the object id, it returns the values for the other ids as well.",
      "Try\n```sh\njq --arg q \"VJXWCBDL\" '\n  .[] | [.id] + (.line_items[] | select(.catalog_object_id == $q) | [.quantity])\n' test.json\n```",
      "[\n  \"a\",\n  \"1\"\n]\n[\n  \"c\",\n  \"2\"\n]\n[\n  \"d\",\n  \"4\"\n]"
    ],
    "utterance": "For each order, return the parent id and the quantity of line_items where catalog_object_id is \"VJXWCBDL\", excluding unmatched items.",
    "expressions": [
      ".[] | [.id] + (.line_items[] | select(.catalog_object_id == \"VJXWCBDL\") | [.quantity])",
      "jq --arg q \"VJXWCBDL\" '.[] | [.id] + (.line_items[] | select(.catalog_object_id == $q) | [.quantity])'"
    ],
    "data": [
      {
        "input": [
          {
            "id": "a",
            "line_items": [
              {
                "catalog_object_id": "IKF7HPIP",
                "quantity": "5"
              },
              {
                "catalog_object_id": "VJXWCBDL",
                "quantity": "1"
              }
            ]
          },
          {
            "id": "b",
            "line_items": [
              {
                "catalog_object_id": "JXOACUE",
                "quantity": "4"
              }
            ]
          },
          {
            "id": "c",
            "line_items": [
              {
                "catalog_object_id": "VJXWCBDL",
                "quantity": "2"
              },
              {
                "catalog_object_id": "RGQMKXKL",
                "quantity": "3"
              }
            ]
          },
          {
            "id": "d",
            "line_items": [
              {
                "catalog_object_id": "VJXWCBDL",
                "quantity": "4"
              }
            ]
          }
        ],
        "output": [
          [
            "a",
            "1"
          ],
          [
            "c",
            "2"
          ],
          [
            "d",
            "4"
          ]
        ]
      }
    ],
    "identifier": 70191184
  },
  {
    "context": [
      "How can I add a custom header array, something like:\n[ \"test\", \"foo\", \"bar\" ] | join(\"&\")\n\nSo that\n * The `group_by` and everything behind it isn't changed\n * `column` can parse the output",
      "Enclose your expression in brackets and add `| [\"test&foo&bar\"] + . | .[]` at the end.",
      "[group_by(.type)[][] | \"\\(if \"type\" == \"foo\" then \"oof\" else \"rab\" end)&\\(.name)\"] | [\"test&foo&bar\"] + . | .[]"
    ],
    "utterance": "Add a static header line 'test&foo&bar' before the transformed output lines, without changing the grouping or data lines.",
    "expressions": [
      "[group_by(.type)[][] | \"\\(if .type == \\\"foo\\\" then \\\"oof\\\" else \\\"rab\\\" end)&\\(.name)\"] | [\"test&foo&bar\"] + . | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "type": "foo",
            "name": "test_1"
          },
          {
            "type": "bar",
            "name": "test_2"
          },
          {
            "type": "bar",
            "name": "test_3"
          }
        ],
        "output": [
          "test&foo&bar",
          "rab&test_2",
          "rab&test_3",
          "oof&test_1"
        ]
      }
    ],
    "identifier": 70034818
  },
  {
    "context": [
      "curl         \\\n    -X POST \\\n    -d 'client_id=app' \\\n    -d 'username=username' \\\n    -d 'password=password' \\\n    -d 'grant_type=password' \\\n    -d \"client_secret=$APP_SECRET\" \\\n    'http://localhost:9000/auth/realms/realm/protocol/openid-connect/token' \\\n| \\\njq -r '.access_token' \\\n| \\\ncurl \\\n    -X GET \\\n    -H \"Accept: application/json\" \\\n    -H \"Authorization: Bearer @-\" \\ # <- read header value from stdin\n    -u \"username:password\" \\\n    \"http://localhost:8080/app/api/\"",
      "token=$(curl \\\n    -X POST \\\n    -d 'client_id=app' \\\n    -d 'username=username' \\\n    -d 'password=password' \\\n    -d 'grant_type=password' \\\n    -d \"client_secret=$APP_SECRET\" \\\n    'http://localhost:9000/auth/realms/realm/protocol/openid-connect/token' \\\n| jq -r '.access_token')",
      "-H \"Authorization: Bearer $(\n    curl                               \\\n        -X POST                        \\\n        -d \"client_id=app\"             \\\n        -d \"username=username\"         \\\n        -d \"password=password\"         \\\n        -d \"grant_type=password\"       \\\n        -d \"client_secret=$APP_SECRET\" \\\n        \"http://localhost:9000/auth/realms/realm/protocol/openid-connect/token\" \\\n    | jq -r .access_token\n)\""
    ],
    "utterance": "Extract the value of the access_token property and use it as a Bearer token in an HTTP Authorization header.",
    "expressions": [
      ".access_token"
    ],
    "data": [
      {
        "input": {
          "access_token": "abcdef123456",
          "refresh_token": "xyz987654",
          "expires_in": 3600
        },
        "output": "abcdef123456"
      }
    ],
    "identifier": 70187582
  },
  {
    "context": [
      "This is my JSON data input:\r\n```json\r\n[\r\n  {\r\n    \"creator\": \"M.W. Seo\",\r\n    \"co_author\": [\r\n      \"H.W. Lee\",\r\n      \"S.H. Jeon\",\r\n      \"M.W. Seo\"\r\n    ]\r\n  },\r\n  {\r\n    \"creator\": \"Jeffrey A. Laman\",\r\n    \"co_author\": [\r\n      \"Jeffrey A. Laman\",\r\n      \"Mike\",\r\n      \"Jackson\"\r\n    ]\r\n  }\r\n]\r\n```",
      "This is my desired JSON data output:\r\n```json\r\n[\r\n  {\r\n    \"creator\": \"M.W. Seo\",\r\n    \"co_author\": [\r\n      \"H.W. Lee\",\r\n      \"S.H. Jeon\"\r\n    ]\r\n  },\r\n  {\r\n    \"creator\": \"Jeffrey A. Laman\",\r\n    \"co_author\": [\r\n      \"Mike\",\r\n      \"Jackson\"\r\n    ]\r\n  }\r\n]\r\n```",
      "Subtract `.creator` directly from the array in `.co_author` and apply this to all elements of the top-level array using `map`:\r\n```sh\r\njq 'map(.co_author -= [.creator])' test_4.json \r\n```"
    ],
    "utterance": "Remove from each object's co_author array any element that matches the creator value.",
    "expressions": [
      "map(.co_author -= [.creator])"
    ],
    "data": [
      {
        "input": [
          {
            "creator": "M.W. Seo",
            "co_author": [
              "H.W. Lee",
              "S.H. Jeon",
              "M.W. Seo"
            ]
          },
          {
            "creator": "Jeffrey A. Laman",
            "co_author": [
              "Jeffrey A. Laman",
              "Mike",
              "Jackson"
            ]
          }
        ],
        "output": [
          {
            "creator": "M.W. Seo",
            "co_author": [
              "H.W. Lee",
              "S.H. Jeon"
            ]
          },
          {
            "creator": "Jeffrey A. Laman",
            "co_author": [
              "Mike",
              "Jackson"
            ]
          }
        ]
      }
    ],
    "identifier": 70196458
  },
  {
    "context": [
      "I was able to  get the first value using the following commands: ",
      "curl \"https://waterservices.usgs.gov/nwis/dv/?sites=04092440&format=json&period=P520W\" | jq .'value.timeSeries[3].values[0].value[0].value'",
      "However there are total 478 values. I am wondering how can I print all the values.",
      "With the JSON from the curl call, the query:",
      "jq '.value.timeSeries[].values[].value[].value'",
      "returns 9,029 values."
    ],
    "utterance": "Print all water temperature values from the specified site and period.",
    "expressions": [
      ".value.timeSeries[].values[].value[].value"
    ],
    "identifier": 70092405
  },
  {
    "context": [
      "But how can I count how much values was selected?",
      "You could use `jq --arg ...` option to pass values and build a valid `jq` request like this:",
      ".[] | select(.user.login==$user_login) | .user.login",
      "| wc -l",
      "Full `jq` solution:",
      "[select(.[].user.login == $user_login)] | length"
    ],
    "utterance": "Count the number of pull requests authored by a given user login.",
    "expressions": [
      ".[] | select(.user.login==$user_login) | .user.login",
      "[.[] | select(.user.login==$user_login)] | length"
    ],
    "data": [
      {
        "input": [
          {
            "url": "https://api.github.com/repos/datamove/linux-git2/pulls/315",
            "id": 771895341,
            "user": {
              "login": "nicknazarov",
              "id": 16031089
            }
          },
          {
            "url": "https://api.github.com/repos/datamove/linux-git2/pulls/316",
            "id": 771895342,
            "user": {
              "login": "alice",
              "id": 12345
            }
          }
        ],
        "output": 1
      }
    ],
    "identifier": 69961877
  },
  {
    "context": [
      "I need to delete all elements of `instances` that are either set to \"three\" or \"five\".",
      "In your case you could do:\n\n.vars.instances -= [\"three\", \"five\"]"
    ],
    "utterance": "Remove all elements equal to \"three\" or \"five\" from the `instances` array under `vars`.",
    "expressions": [
      ".vars.instances -= [\"three\", \"five\"]"
    ],
    "data": [
      {
        "input": {
          "address": "localhost",
          "name": "local",
          "vars": {
            "instances": [
              "one",
              "two",
              "three",
              "four",
              "five"
            ]
          }
        },
        "output": {
          "address": "localhost",
          "name": "local",
          "vars": {
            "instances": [
              "one",
              "two",
              "four"
            ]
          }
        }
      }
    ],
    "identifier": 70026357
  },
  {
    "context": [
      "Is there any way to get only first 3 elements od `.identifier`?",
      ".identifier[:3] | map({system, value})"
    ],
    "utterance": "Select the first 3 elements from the identifier field and return only their system and value properties.",
    "expressions": [
      ".identifier[:3] | map({system, value})"
    ],
    "data": [
      {
        "input": {
          "resourceType": "Practitioner",
          "id": "328001",
          "meta": {
            "versionId": "1",
            "lastUpdated": "2021-11-08T12:47:51.239+01:00",
            "source": "#BUkX5uagwf3PcHzd"
          },
          "identifier": [
            {
              "use": "official",
              "system": "urn:oid:1.3.6.1.4.1.19126.3",
              "value": "00396185X"
            },
            {
              "use": "official",
              "system": "urn:oid:2.16.724.4.9.10.2",
              "value": "0831515"
            },
            {
              "use": "official",
              "system": "urn:oid:2.16.724.4.9.10.2",
              "value": "0831515"
            },
            {
              "use": "official",
              "system": "urn:oid:2.16.724.4.9.10.2",
              "value": "0831515"
            }
          ],
          "active": true,
          "name": [
            {
              "use": "official",
              "text": "JULIAN RODRIGUEZ LARREA",
              "family": "RODRIGUEZ",
              "_family": {
                "extension": [
                  {
                    "url": "http://hl7.org/fhir/StructureDefinition/humanname-mothers-family",
                    "valueString": "LARREA"
                  }
                ]
              },
              "given": [
                "JULIAN"
              ]
            }
          ],
          "qualification": [
            {
              "code": {
                "coding": [
                  {
                    "system": "urn:oid:2.16.840.1.113883.6.96",
                    "code": "62247001"
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "system": "urn:oid:1.3.6.1.4.1.19126.3",
            "value": "00396185X"
          },
          {
            "system": "urn:oid:2.16.724.4.9.10.2",
            "value": "0831515"
          },
          {
            "system": "urn:oid:2.16.724.4.9.10.2",
            "value": "0831515"
          }
        ]
      }
    ],
    "identifier": 70100534
  },
  {
    "context": [
      "I need to get those fields:",
      ".id, .meta.lastUpdated, .identifier[0].value, .identifier[1].value, .identifier[2].value, .code[0].coding[0].code",
      "And extract them as `id, lastUpdated, identifier1, identifier2, identifier3, code` in csv format.",
      "You can construct an array and then use `@csv` directly:",
      "$ jq -r '[.id,.meta.lastUpdated,.identifier[0].value,.identifier[1].value,.identifier[2].value,.code[0].coding[0].code] | @csv' file.txt"
    ],
    "utterance": "Extract the fields id, meta.lastUpdated, identifier[0].value, identifier[1].value, identifier[2].value, and code[0].coding[0].code from each object and output as rows in CSV format.",
    "expressions": [
      "[.id,.meta.lastUpdated,.identifier[0].value,.identifier[1].value,.identifier[2].value,.code[0].coding[0].code] | @csv"
    ],
    "data": [
      {
        "input": {
          "resourceType": "PractitionerRole",
          "id": "2261026",
          "meta": {
            "versionId": "1",
            "lastUpdated": "2021-11-08T15:13:39.318+01:00",
            "source": "#wcktDPNPRW67Ths4"
          },
          "identifier": [
            {
              "system": "urn:oid:2.16.724.4.9.20.93",
              "value": "6209"
            },
            {
              "system": "urn:oid:2.16.724.4.9.20.2",
              "value": "00042"
            },
            {
              "system": "urn:oid:2.16.724.4.9.20.90",
              "value": "UAB2"
            }
          ],
          "active": true,
          "practitioner": {
            "reference": "Practitioner/1046220"
          },
          "code": [
            {
              "coding": [
                {
                  "system": "http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rol-professional",
                  "code": "MG"
                }
              ]
            }
          ]
        },
        "output": "\"2261026\",\"2021-11-08T15:13:39.318+01:00\",\"6209\",\"00042\",\"UAB2\",\"MG\""
      },
      {
        "input": {
          "resourceType": "PractitionerRole",
          "id": "2261027",
          "meta": {
            "versionId": "1",
            "lastUpdated": "2021-11-08T15:13:39.140+01:00",
            "source": "#l6DwTkxasiJQmfBJ"
          },
          "identifier": [
            {
              "system": "urn:oid:2.16.724.4.9.20.93",
              "value": "6734"
            },
            {
              "system": "urn:oid:2.16.724.4.9.20.2",
              "value": "01785"
            },
            {
              "system": "urn:oid:2.16.724.4.9.20.91",
              "value": "IN013"
            }
          ],
          "active": true,
          "practitioner": {
            "reference": "Practitioner/1045804"
          },
          "code": [
            {
              "coding": [
                {
                  "system": "http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rol-professional",
                  "code": "INF"
                }
              ]
            }
          ]
        },
        "output": "\"2261027\",\"2021-11-08T15:13:39.140+01:00\",\"6734\",\"01785\",\"IN013\",\"INF\""
      }
    ],
    "identifier": 70034146
  },
  {
    "context": [
      "Using jq I want to be able to search using one of the orgs, so for example 'Service A' and return only the recipients information",
      "Instead off `contains` you&#39;ll need `index` ... to check if there&#39;s an index with the value `Service A`:",
      "We can extend that to output only the `recipients` like so:",
      "`.groups[] | select(.orgs | index(\"Service A\")) | .recipients | first`"
    ],
    "utterance": "Return the first recipient for any group where the orgs array includes the string \"Service A\".",
    "expressions": [
      ".groups[] | select(.orgs | index(\"Service A\")) | .recipients | first"
    ],
    "data": [
      {
        "input": {
          "default": [
            {
              "name": "Joe Bloggs",
              "email": "joe.bloggs@business.org"
            }
          ],
          "groups": [
            {
              "recipients": [
                {
                  "name": "Jane Bloggs",
                  "email": "jane.bloggs@business.org"
                }
              ],
              "orgs": [
                "Service A",
                "Service B",
                "Service C"
              ]
            },
            {
              "recipients": [
                {
                  "name": "Bill Gates",
                  "email": "bill.gates@business.org"
                }
              ],
              "orgs": [
                "Service D",
                "Service E"
              ]
            },
            {
              "recipients": [
                {
                  "name": "Steve Jobs",
                  "email": "steve.jobs@me.com"
                }
              ],
              "orgs": [
                "Service F",
                "Service G"
              ]
            }
          ]
        },
        "output": {
          "name": "Jane Bloggs",
          "email": "jane.bloggs@business.org"
        }
      }
    ],
    "identifier": 70187417
  },
  {
    "context": [
      "My `jq` extract expression is getting too much large and I&#39;m getting unconfortable using it:",
      "We can also move the address line searching logic into a function. With the code isolated, it&#39;s easier to make it better. In the process, I improved it to split first, and to handle multiple matching lines better.",
      "def addr_special_field($field):\n   [ .line[]? | split(\"^\") | select( .[0] == $field ) ] | .[0][1]?;\n\n[\n   .id,\n   .meta.lastUpdated,\n   .identifier[0].use,\n   .identifier[0].system,\n   .identifier[0].value,\n   .identifier[1].use,\n   .identifier[1].system,\n   .identifier[1].value,\n   .identifier[2].use,\n   .identifier[2].system,\n   .identifier[2].value,\n   .identifier[2].assigner.reference,\n   .active,\n   .name[0].use,\n   .name[0].text,\n   .name[0].given[0],\n   .name[0].family,\n   .name[0]._family.extension[0].valueString,\n   .address[0].extension[0].valueString,\n   .address[0].type,\n   ( .address[0] | addr_special_field( \"TV\"  ) ),\n   ( .address[0] | addr_special_field( \"NV\"  ) ),\n   ( .address[0] | addr_special_field( \"NVI\" ) ),\n   .address[0].city,\n   .address[0].state,\n   .address[0].postalCode,\n   .address[0].country,\n   .qualification[0].code.coding[0].system,\n   .qualification[0].code.coding[0].code\n] | @csv",
      "Another thing we could do is factor out common terms, though I&#39;m not sure it truly helps.\n\ndef addr_special_field($field):\n   [ .line[]? | split(\"^\") | select( .[0] == $field ) ] | .[0][1]?;\n\n[\n   .id,\n   .meta.lastUpdated,\n   ( .identifier[0] | .use, .system, .value ),\n   ( .identifier[1] | .use, .system, .value ),\n   ( .identifier[2] | .use, .system, .value, .assigner.reference ),\n   .active,\n   ( .name[0] | .use, .text, .given[0], .family, ._family.extension[0].valueString ),\n   ( .address[0] |\n      .extension[0].valueString,\n      .type,\n      addr_special_field( \"TV\"  ),\n      addr_special_field( \"NV\"  ),\n      addr_special_field( \"NVI\" ),\n      .city,\n      .state,\n      .postalCode,\n      .country\n   ),\n   ( .qualification[0].code.coding[0] | .system, .code )\n] | @csv"
    ],
    "utterance": "Extract a CSV row with fields including .id, .meta.lastUpdated, several nested identifier and name fields, first address's type, extension, and city/state/etc, and from address[0].line[] the substring after '^' for fields starting with 'TV', 'NV', or 'NVI'.",
    "expressions": [
      "def addr_special_field($field):\n   [ .line[]? | split(\"^\") | select( .[0] == $field ) ] | .[0][1]?;\n\n[\n   .id,\n   .meta.lastUpdated,\n   .identifier[0].use,\n   .identifier[0].system,\n   .identifier[0].value,\n   .identifier[1].use,\n   .identifier[1].system,\n   .identifier[1].value,\n   .identifier[2].use,\n   .identifier[2].system,\n   .identifier[2].value,\n   .identifier[2].assigner.reference,\n   .active,\n   .name[0].use,\n   .name[0].text,\n   .name[0].given[0],\n   .name[0].family,\n   .name[0]._family.extension[0].valueString,\n   .address[0].extension[0].valueString,\n   .address[0].type,\n   ( .address[0] | addr_special_field( \"TV\"  ) ),\n   ( .address[0] | addr_special_field( \"NV\"  ) ),\n   ( .address[0] | addr_special_field( \"NVI\" ) ),\n   .address[0].city,\n   .address[0].state,\n   .address[0].postalCode,\n   .address[0].country,\n   .qualification[0].code.coding[0].system,\n   .qualification[0].code.coding[0].code\n] | @csv",
      "def addr_special_field($field):\n   [ .line[]? | split(\"^\") | select( .[0] == $field ) ] | .[0][1]?;\n\n[\n   .id,\n   .meta.lastUpdated,\n   ( .identifier[0] | .use, .system, .value ),\n   ( .identifier[1] | .use, .system, .value ),\n   ( .identifier[2] | .use, .system, .value, .assigner.reference ),\n   .active,\n   ( .name[0] | .use, .text, .given[0], .family, ._family.extension[0].valueString ),\n   ( .address[0] |\n      .extension[0].valueString,\n      .type,\n      addr_special_field( \"TV\"  ),\n      addr_special_field( \"NV\"  ),\n      addr_special_field( \"NVI\" ),\n      .city,\n      .state,\n      .postalCode,\n      .country\n   ),\n   ( .qualification[0].code.coding[0] | .system, .code )\n] | @csv"
    ],
    "identifier": 70095177
  },
  {
    "context": [
      "Here I&#39;m trying to write jq command that should ignore the message `check failed for material:` and `Error while scheduling`, and print the rest.",
      "We need to write a jq cmd that should ignore the mentioned message and print the rest/changing content.",
      "```jq\r\nmap(select(\r\n   .message |\r\n   contains(\"check failed for material:\") or contains(\"Error while scheduling\") |\r\n   not\r\n))\r\n```",
      "Or for exact matches,\r\n\r\n```jq\r\nmap(select(\r\n   .message |\r\n   . != \"check failed for material:\" and . != \"Error while scheduling\"\r\n))\r\n```"
    ],
    "utterance": "Return all objects except those where the message is \"check failed for material:\" or \"Error while scheduling\".",
    "expressions": [
      "map(select(.message | contains(\"check failed for material:\") or contains(\"Error while scheduling\") | not))",
      "map(select(.message != \"check failed for material:\" and .message != \"Error while scheduling\"))"
    ],
    "data": [
      {
        "input": [
          {
            "message": "check failed for material:",
            "detail": "Error performing",
            "level": "ERROR"
          },
          {
            "message": "check failed for material:",
            "detail": "Error performing command",
            "level": "ERROR"
          },
          {
            "message": "Error while scheduling",
            "detail": "Maximum limit reached",
            "level": "ERROR"
          },
          {
            "message": "Error while scheduling",
            "detail": "Maximum limit reached",
            "level": "ERROR"
          },
          {
            "message": "Duplicate error",
            "detail": "Found a mapping value where it is not allowed",
            "level": "ERROR"
          },
          {
            "message": "Invalid Merged Configuration",
            "detail": "Number of errors: 44",
            "level": "ERROR"
          }
        ],
        "output": [
          {
            "message": "Duplicate error",
            "detail": "Found a mapping value where it is not allowed",
            "level": "ERROR"
          },
          {
            "message": "Invalid Merged Configuration",
            "detail": "Number of errors: 44",
            "level": "ERROR"
          }
        ]
      }
    ],
    "identifier": 70265041
  },
  {
    "context": [
      "I am looking for an efficient way to calculate, whether one JSON-document is a subtree/subset of another one.",
      "I want to determine, whether `b` is a subset of `a`",
      "As a result, I expect a single boolean (or something like {'match': true}) indicating that `b` is a subset of `a`.",
      "def subtree_of($b):\n  def isScalar: type | . != \"array\" and . != \"object\";\n\n  # direct_subtree_of($b) checks that every path/atomic-value pair of $a is also in $b\n  def direct_subtree_of($b):\n    . as $a\n    | first( ($a|paths(scalars)) as $p\n        | ($a | getpath($p)) as $va\n        | ([try ($b|getpath($p)) // empty]) as $vb\n        | if ($vb |length > 0) \n             and (($va == $vb[0])\n                  or ($va | subtree_of($vb[0]))\n                  or ($va | elementOf($b | getpath( $p[:-1] ))))\n          then empty\n          else 0\n          end) // 1\n      | . == 1 ;\n    \n  . as $a\n  | if isScalar then $a == $b\n    else direct_subtree_of($b)\n         or (max($a|paths|length) as $ma\n            | max($b|paths|length) as $mb\n            | ($mb - $ma) as $diff\n            | any(range(1; 1+$diff);\n\t              any(. as $i | $a | subtree_of($b | shift($i)); . )) )\n    end ;\n",
      "a | subtree_of(b)\n\nevaluates to `true`."
    ],
    "utterance": "Determine whether document b is a subtree or subset of document a and return a boolean indicating the result.",
    "expressions": [
      "def max(s): reduce s as $x (0; if . == null or $x > . then $x else . end);\n\ndef elementOf($x):\n  . as $in\n  | if ($x|type) == \"array\"\n    then $x|index($in)\n    else false end;\n\ndef shift($n):\n  if $n == 0 then .\n  elif type | (. != \"object\" and . != \"array\") then empty\n  elif $n == 1 then .[]\n  else .[] | shift($n - 1)\n  end;\n\ndef subtree_of($b):\n  def isScalar: type | . != \"array\" and . != \"object\";\n  def direct_subtree_of($b):\n    . as $a\n    | first( ($a|paths(scalars)) as $p\n        | ($a | getpath($p)) as $va\n        | ([try ($b|getpath($p)) // empty]) as $vb\n        | if ($vb |length > 0) \n             and (($va == $vb[0])\n                  or ($va | subtree_of($vb[0]))\n                  or ($va | elementOf($b | getpath( $p[:-1] ))))\n          then empty\n          else 0\n          end) // 1\n      | . == 1 ;\n  . as $a\n  | if isScalar then $a == $b\n    else direct_subtree_of($b)\n         or (max($a|paths|length) as $ma\n            | max($b|paths|length) as $mb\n            | ($mb - $ma) as $diff\n            | any(range(1; 1+$diff); any(. as $i | $a | subtree_of($b | shift($i)); . )) )\n    end ;",
      "a | subtree_of(b)"
    ],
    "data": [
      {
        "input": {
          "a": {
            "a": {
              "a": {
                "aa": [
                  "uvw",
                  "abc"
                ]
              },
              "b": {
                "ba": {
                  "baa": [
                    "none",
                    "1"
                  ],
                  "bab": [
                    "0"
                  ]
                },
                "bb": {
                  "baa": [
                    "yyy"
                  ],
                  "bab": [
                    "some_string"
                  ]
                }
              },
              "c": {
                "ca": [
                  "dd",
                  "cc"
                ],
                "cb": 2,
                "cc": "-"
              }
            },
            "e": "abc",
            "d": 45678
          },
          "b": {
            "a": {
              "a": {
                "aa": [
                  "abc"
                ]
              },
              "b": {
                "ba": {
                  "baa": [
                    "none"
                  ],
                  "bab": [
                    "0"
                  ]
                },
                "bb": {
                  "bab": [
                    "some_string"
                  ]
                }
              },
              "c": {
                "ca": [
                  "cc"
                ]
              }
            },
            "e": "abc"
          }
        },
        "output": true
      }
    ],
    "identifier": 70265019
  },
  {
    "context": [
      "How i can print **id object** by jq utility **as string**? Object value must be (with double quotas):",
      "Use the `tostring` (or the `@text`) builtin to convert into a string:",
      "jq '.ssh_key | .id |= tostring'",
      "{\"id\": \"123\"}"
    ],
    "utterance": "Output the 'id' field from the 'ssh_key' object, ensuring the value is a string.",
    "expressions": [
      ".ssh_key | .id |= tostring"
    ],
    "data": [
      {
        "input": {
          "ssh_key": {
            "id": 123
          }
        },
        "output": {
          "id": "123"
        }
      }
    ],
    "identifier": 70138230
  },
  {
    "context": [
      "Given the following JSON-document\n```\n{\"a\": true, \"b\": [1, 2], \"c\": {\"a\": {\"aa\":1, \"bb\": 2}, \"b\": \"blue\"}}\n```\nI want to calculate the result `6`.",
      "So, how can I only count the document's elements/leaf-nodes?",
      "Here\u2019s a filter that counts scalars:\n\n```\n[..|scalars]|length\n```\nOutput:\n```\n6\n```"
    ],
    "utterance": "Count the number of leaf nodes that are scalar values in the nested structure where the input is {\"a\": true, \"b\": [1, 2], \"c\": {\"a\": {\"aa\":1, \"bb\": 2}, \"b\": \"blue\"}} and the expected count is 6.",
    "expressions": [
      "[..|scalars]|length"
    ],
    "data": [
      {
        "input": {
          "a": true,
          "b": [
            1,
            2
          ],
          "c": {
            "a": {
              "aa": 1,
              "bb": 2
            },
            "b": "blue"
          }
        },
        "output": 6
      }
    ],
    "identifier": 70263140
  },
  {
    "context": [
      "But sometimes field \"version\" or \"group\" maybe empty. I need to write with the following condition - if the string is null, then it is not necessary to write it.",
      "To skip the null fields, just pipe your previous filter to below\n\nwith_entries(select(.value!=null))",
      "the whole filter being below\u2026\n(.spec.rules[0].match.resources.kinds[] / \"/\")\n| [select(.[1])[0] // null, select(.[2])[1] // null, last]\n  as [$version,$group,$kind]\n| {$version,$group,$kind} \n| with_entries(select(.value!=null))",
      "you may pick just the ones that are not null using [{$version},{$group},{$kind} | select(.[])] | add",
      "modify the [...] as {...} part directly to generate what you need, for instance: \n(.spec.rules[0].match.resources.kinds[] / \"/\")\n| ({version:select(.[1])[0]} // {})\n  + ({group:select(.[2])[1]} // {})\n  + {kind: last}"
    ],
    "utterance": "Return an object with version, group, and kind fields extracted from each kind path, omitting any fields that are null.",
    "expressions": [
      "(.spec.rules[0].match.resources.kinds[] / \"/\")\n| [select(.[1])[0] // null, select(.[2])[1] // null, last]\n  as [$version,$group,$kind]\n| {$version,$group,$kind}\n| with_entries(select(.value!=null))",
      "(.spec.rules[0].match.resources.kinds[] / \"/\")\n| [select(.[1])[0] // null, select(.[2])[1] // null, last]\n  as [$version,$group,$kind]\n| [{$version},{$group},{$kind} | select(.[])] | add",
      "(.spec.rules[0].match.resources.kinds[] / \"/\")\n| ({version:select(.[1])[0]} // {})\n  + ({group:select(.[2])[1]} // {})\n  + {kind: last}"
    ],
    "data": [
      {
        "input": {
          "spec": {
            "background": true,
            "failurePolicy": "Fail",
            "rules": [
              {
                "exclude": {
                  "resources": {}
                },
                "generate": {
                  "clone": {}
                },
                "match": {
                  "resources": {
                    "kinds": [
                      "networking.k8s.io/v1/NetworkPolicy"
                    ]
                  }
                },
                "mutate": {},
                "name": "validate-nodeport",
                "validate": {
                  "message": "Services of type NodePort are not allowed.",
                  "pattern": {
                    "spec": {
                      "type": "!NodePort"
                    }
                  }
                }
              }
            ],
            "validationFailureAction": "audit"
          },
          "status": {
            "ready": true
          }
        },
        "output": {
          "version": "networking.k8s.io",
          "group": "v1",
          "kind": "NetworkPolicy"
        }
      }
    ],
    "identifier": 70062602
  },
  {
    "context": [
      "I try to use\n```\njq -r '.[] | .DBSnapshotIdentifier'\n```\n\nBut it doesn't work for me",
      "You first need to select the `DBSnapshots` object, try:\n```\n.DBSnapshots[] | .DBSnapshotIdentifier\n```\n\nThis will output:\n```none\n\"auto-lims-final-snapshot\"\n\"automation-lims-before-postgres-12-5\"\n```"
    ],
    "utterance": "Extract all DBSnapshotIdentifier values within the DBSnapshots array.",
    "expressions": [
      ".DBSnapshots[] | .DBSnapshotIdentifier"
    ],
    "data": [
      {
        "input": {
          "DBSnapshots": [
            {
              "DBSnapshotIdentifier": "auto-lims-final-snapshot",
              "DBInstanceIdentifier": "auto-lims",
              "SnapshotCreateTime": "2018-08-15T09:59:23.332000+00:00",
              "Engine": "postgres",
              "AllocatedStorage": 50,
              "Status": "available",
              "Port": 5432,
              "AvailabilityZone": "us-east-2a",
              "VpcId": "vpc-e799fc8f",
              "InstanceCreateTime": "2018-04-09T08:28:03.565000+00:00",
              "MasterUsername": "postgres",
              "EngineVersion": "9.6.6",
              "LicenseModel": "postgresql-license",
              "SnapshotType": "manual",
              "OptionGroupName": "default:postgres-9-6",
              "PercentProgress": 100,
              "StorageType": "gp2",
              "Encrypted": false,
              "DBSnapshotArn": "arn:aws:rds:us-east-2:833682533595:snapshot:auto-lims-final-snapshot",
              "IAMDatabaseAuthenticationEnabled": false,
              "ProcessorFeatures": [],
              "DbiResourceId": "db-ZL5T2TA2PJVG6CVOJRO7HUOAXQ",
              "TagList": [
                {
                  "Key": "Environment",
                  "Value": "auto"
                },
                {
                  "Key": "Application",
                  "Value": "LIMS"
                }
              ],
              "SnapshotTarget": "region"
            },
            {
              "DBSnapshotIdentifier": "automation-lims-before-postgres-12-5",
              "DBInstanceIdentifier": "automation-lims",
              "Engine": "postgres",
              "AllocatedStorage": 500,
              "Status": "available",
              "Port": 5432,
              "AvailabilityZone": "us-east-2b",
              "VpcId": "vpc-09fa88d2884ee2083",
              "InstanceCreateTime": "2019-12-26T11:19:41.947000+00:00",
              "MasterUsername": "lims",
              "EngineVersion": "9.6.20",
              "LicenseModel": "postgresql-license",
              "SnapshotType": "manual",
              "OptionGroupName": "default:postgres-9-6",
              "PercentProgress": 100
            }
          ]
        },
        "output": [
          "auto-lims-final-snapshot",
          "automation-lims-before-postgres-12-5"
        ]
      }
    ],
    "identifier": 70261491
  },
  {
    "context": [
      "I want to put the ID into the tasks where tasks are not empty.",
      "I would like to get the tasks array updated to look like\n\n    [\n      {\n        \"id\": 1961126,\n        \"tasks\": [\n          {\n            \"sId\":1961126,\n            \"id\": 70340700,\n            \"title\": \"Test1\",\n          },",
      "Save the ID in a variable and add it as a new field to each array member.",
      "jq 'map(.id as $sId | .tasks[] += {$sId})' file.json",
      "if you want to have the propagated ID shown first, as seen in your expected output, you could try to replace '+= {$sId}' (which by itself is shorthand for '|= . + {$sId}') with '|= {$sId} + .'"
    ],
    "utterance": "For each object, add a new key sId with the parent object's id to every task in its tasks array, but leave tasks unchanged if it is empty.",
    "expressions": [
      "map(.id as $sId | .tasks[] += {$sId})",
      "map(.id as $sId | .tasks |= map({sId: $sId} + .))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1961126,
            "tasks": [
              {
                "id": 70340700,
                "title": "Test1"
              },
              {
                "id": 69801130,
                "title": "Test15A"
              }
            ]
          },
          {
            "id": 1961126,
            "tasks": []
          }
        ],
        "output": [
          {
            "id": 1961126,
            "tasks": [
              {
                "sId": 1961126,
                "id": 70340700,
                "title": "Test1"
              },
              {
                "sId": 1961126,
                "id": 69801130,
                "title": "Test15A"
              }
            ]
          },
          {
            "id": 1961126,
            "tasks": []
          }
        ]
      }
    ],
    "identifier": 69941773
  },
  {
    "context": [
      "Set the string to search for in key \"expr\"",
      "exprStrSearch=\"10.32.0.4:8055 10.32.0.7:8055\"",
      "echo \"${_metadatadashjson}\" | jq -r --arg EXPRSTRSEARCH \"$exprStrSearch\" '.dashboard.panels[] | select(.targets[].expr | contains($EXPRSTRSEARCH)) | .targets[].expr'",
      "You could pass multiple strings to contains(), using a bash array:",
      "strings=(\"10.32.0.4:8055\" \"10.32.0.7:8055\")",
      "echo \"${_metadatadashjson}\" |\njq -r --args '.dashboard.panels[] | select(.targets[].expr | contains($ARGS.positional[])) | .targets[].expr' \"${strings[@]}\"",
      "With test, that won't happen. Here's how you can add the |s between multiple strings, and pass them in a single jq variable (as well as escape all the dots):",
      "strings=(\"10.32.0.4:8055\" \"10.32.0.7:8055\")\nIFS=\\|\necho \"${_metadatadashjson}\" |\njq -r --arg str \"${strings[*]//./\\\\.}\" '.dashboard.panels[] | select(.targets[].expr | test($str)) | .targets[].expr'",
      "Both examples print this:\n\n    jvm_threads_current{instance=\"10.32.0.4:8055\",job=\"prometheus_gyrex\"}\n    jvm_threads_current{instance=\"10.32.0.7:8055\",job=\"prometheus_gyrex\"}"
    ],
    "utterance": "Select all panels where any target expr field contains either '10.32.0.4:8055' or '10.32.0.7:8055', and print those expr values.",
    "expressions": [
      ".dashboard.panels[] | select(.targets[].expr | contains($ARGS.positional[])) | .targets[].expr",
      ".dashboard.panels[] | select(.targets[].expr | test($str)) | .targets[].expr"
    ],
    "data": [
      {
        "input": {
          "meta": {
            "provisionedExternalId": ""
          },
          "dashboard": {
            "liveNow": false,
            "panels": [
              {
                "collapsed": false,
                "title": "Gyrex Thread Count Gauges",
                "type": "row",
                "targets": [
                  {
                    "expr": "jvm_threads_current{instance=\"192.1.50.22:8055\",job=\"prometheus_gyrex\"}",
                    "refId": "B"
                  }
                ]
              },
              {
                "datasource": "Prometheus_16_Docker",
                "targets": [
                  {
                    "exemplar": true,
                    "expr": "jvm_threads_current{instance=\"10.32.0.4:8055\",job=\"prometheus_gyrex\"}"
                  }
                ],
                "title": ".16 : 3279",
                "type": "gauge"
              },
              {
                "description": "",
                "targets": [
                  {
                    "expr": "jvm_threads_current{instance=\"10.32.0.7:8055\",job=\"prometheus_gyrex\"}",
                    "refId": "B"
                  }
                ],
                "title": ".16 : 3288",
                "type": "graph"
              },
              {
                "description": "",
                "targets": [
                  {
                    "expr": "jvm_threads_current{instance=\"192.168.2.16:3288\",job=\"prometheus_gyrex\"}",
                    "refId": "C"
                  }
                ],
                "title": ".16 : 3288",
                "type": "graph"
              }
            ],
            "version": 55
          }
        },
        "output": [
          "jvm_threads_current{instance=\"10.32.0.4:8055\",job=\"prometheus_gyrex\"}",
          "jvm_threads_current{instance=\"10.32.0.7:8055\",job=\"prometheus_gyrex\"}"
        ]
      }
    ],
    "identifier": 69965595
  },
  {
    "context": [
      "I want to delete the entire object where `.data[].hash` == `0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q` to produce:",
      "You can use **del** along with **select** function such as\n```\njq 'del(.data[] | select(.hash == \"0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q\"))'\n```",
      "then you could use `walk` like so:\n```\nwalk(if type==\"object\" and\n          .hash == \"0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q\"\n     then empty else . end)\n```"
    ],
    "utterance": "Remove all objects from the data array where the hash key equals 0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q.",
    "expressions": [
      "del(.data[] | select(.hash == \"0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q\"))",
      "walk(if type==\"object\" and .hash == \"0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q\" then empty else . end)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
              "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
              "hash": "DTU1GGfR0eU15hv6KiV_bg6FOJXfUWz4TjIq1H7TGy4",
              "timestamp": "2020-08-28T01:29:46.000000Z"
            },
            {
              "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
              "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
              "hash": "l3EQR6AJ6R1qE1meHyafDnNF8vJ-X-rH1pujxQRTds4",
              "timestamp": "2020-08-28T00:50:44.000000Z"
            },
            {
              "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
              "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
              "hash": "5fQJY9MprH9b3IstVU1SdfBteUWoF_sdsVuiARPBtTY",
              "timestamp": "2020-08-27T19:01:48.000000Z"
            },
            {
              "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
              "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
              "hash": "0M0fudEmzW9dmAsO3dcWT286tTL6wTX9sllXtsyz-0Q",
              "timestamp": "2020-08-27T18:15:17.000000Z"
            }
          ]
        },
        "output": {
          "data": [
            {
              "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
              "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
              "hash": "DTU1GGfR0eU15hv6KiV_bg6FOJXfUWz4TjIq1H7TGy4",
              "timestamp": "2020-08-28T01:29:46.000000Z"
            },
            {
              "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
              "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
              "hash": "l3EQR6AJ6R1qE1meHyafDnNF8vJ-X-rH1pujxQRTds4",
              "timestamp": "2020-08-28T00:50:44.000000Z"
            },
            {
              "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
              "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
              "hash": "5fQJY9MprH9b3IstVU1SdfBteUWoF_sdsVuiARPBtTY",
              "timestamp": "2020-08-27T19:01:48.000000Z"
            }
          ]
        }
      }
    ],
    "identifier": 70255282
  },
  {
    "context": [
      "however I need to parse the list \"com.src.main.client.details\" and pipe it to another file.",
      "I tried below command but it fails.",
      "$> `jq \".result[0].com.src.main.client.details\" temp.json > result.json`",
      "`null`",
      "Use double quotes for keys that contain non-alphanumeric characters:",
      ".results[0].\"com.src.main.client.details\""
    ],
    "utterance": "Extract the value of the key com.src.main.client.details from the first object in the results array.",
    "expressions": [
      ".results[0].\"com.src.main.client.details\""
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "com.src.main.client.details": {
                "doc": "string",
                "details": [
                  {
                    "amount": null,
                    "output": null,
                    "properties": [
                      {
                        "characteristic": [],
                        "component": null,
                        "period": null,
                        "internals": {
                          "Currency": "EUR",
                          "value": 0
                        }
                      }
                    ]
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "doc": "string",
          "details": [
            {
              "amount": null,
              "output": null,
              "properties": [
                {
                  "characteristic": [],
                  "component": null,
                  "period": null,
                  "internals": {
                    "Currency": "EUR",
                    "value": 0
                  }
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 70135560
  },
  {
    "context": [
      "I'd like to iterate over an array inside a JSON file by index using bash jq, and get for example only the name from each object inside that array:",
      "jq -r '.items[] | .name' object.json",
      "where `-r` option is used to remove double quotes wrapping up the name values."
    ],
    "utterance": "Extract the name property from every object in the items array.",
    "expressions": [
      ".items[] | .name",
      ".items[].name"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "name": "item1",
              "year": "2021"
            },
            {
              "name": "item2",
              "year": "2020"
            }
          ]
        },
        "output": [
          "item1",
          "item2"
        ]
      }
    ],
    "identifier": 70249669
  },
  {
    "context": [
      "As long as *each line* that your `python` script outputs is a _complete_ JSON object by itself, you can use a [`ForEach-Object`](https://learn.microsoft.com/powershell/module/microsoft.powershell.core/foreach-object) call to process each output line as it is being received by PowerShell and call [`ConvertFrom-Json`](https://learn.microsoft.com/powershell/module/microsoft.powershell.utility/convertfrom-json) for _each_:",
      "python .\\dir_json.py | ForEach-Object { ConvertFrom-JSON $_ }"
    ],
    "utterance": "Process each line of the output as it is received when each line is a complete object and convert each to an object as soon as it is emitted.",
    "expressions": [
      "ForEach-Object { ConvertFrom-JSON $_ }"
    ],
    "data": [
      {
        "input": "{ \"name\": \"foo\" }\n{ \"name\": \"bar\" }",
        "output": [
          {
            "name": "foo"
          },
          {
            "name": "bar"
          }
        ]
      }
    ],
    "identifier": 69923050
  },
  {
    "context": [
      "I want to find their intersection. I expect to get the following JSON-document which only contains those key-value-pairs JSON-objects that are present in both inputs:",
      "Assuming $a holds the contents of one of your JSON entities and $b holds the other, then the following will perform the type of intersection you describe:",
      "Footnote 2:\nTo handle arrays using array-intersection, you might wish to consider the following, but please be aware that in some cases, this hybrid approach will probably produce results that you might not expect:"
    ],
    "utterance": "Find all key-value pairs that are present and equal in both input objects, recursively, including intersecting arrays by their common elements.",
    "expressions": [
      "reduce ($a|paths) as $p (null;\n  ($a|getpath($p)) as $va\n  | [try ($b|getpath($p)) // empty] as $vb\n  | if ($vb | length > 0) and ($va == $vb[0])\n    then setpath($p;$va) else . end)",
      "def special_intersection($a;$b):\n  def i(x;y): x - (x-y);\n  reduce ($a|paths) as $p (null;\n    ($a|getpath($p)) as $va\n    | [try ($b|getpath($p)) // empty] as $vb\n    | if ($vb | length > 0)\n      then if ($va == $vb[0])\n           then setpath($p;$va)\n           elif ($va|type == \"array\") and ($vb[0]|type) == \"array\"\n           then setpath($p; i($va; $vb[0]))\n\t       else . end\n      else . end) ;"
    ],
    "data": [
      {
        "input": [
          {
            "a": 0,
            "b": [
              "ba",
              {
                "bb": {
                  "bba": "a",
                  "bbc": [
                    1,
                    2
                  ]
                }
              },
              {
                "bc": {
                  "bca": [
                    2
                  ],
                  "bcb": 5
                }
              }
            ],
            "c": 1
          },
          {
            "a": 1,
            "b": [
              "ba",
              {
                "bb": {
                  "bba": "a",
                  "bbc": [
                    1,
                    3
                  ]
                }
              }
            ],
            "c": 1
          }
        ],
        "output": {
          "b": [
            "ba",
            {
              "bb": {
                "bba": "a",
                "bbc": [
                  1
                ]
              }
            }
          ],
          "c": 1
        }
      }
    ],
    "identifier": 70243586
  },
  {
    "context": [
      "I have a directory of json files, for example:",
      "[\n    { \"name\": \"John\" },\n    { \"name\": \"Mary\" }\n]",
      "[\n    { \"name\": \"Nick\" },\n    { \"name\": \"Luke\" }\n]",
      "\"I'm struggling to index the json files then combine them. Something like:\n[\n    {\n        \"key\": 0,\n        \"value\": { \"name\": \"John\" }\n    },\n    {\n        \"key\": 1,\n        \"value\": { \"name\": \"Mary\" }\n    },\n    {\n        \"key\": 0,\n        \"value\": { \"name\": \"Nick\" }\n    },\n    {\n        \"key\": 1,\n        \"value\": { \"name\": \"Luke\" }\n    }\n]\"",
      "cat mock[12].json | jq -s 'map(to_entries) | flatten'",
      "jq to_entries mock[12].json | jq -s flatten"
    ],
    "utterance": "Combine all files containing arrays so the output is an array of indexed entries, each as { \"key\": <index>, \"value\": <element> } for every element in every file.",
    "expressions": [
      "cat mock[12].json | jq -s 'map(to_entries) | flatten'",
      "jq to_entries mock[12].json | jq -s flatten"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "John"
            },
            {
              "name": "Mary"
            }
          ],
          [
            {
              "name": "Nick"
            },
            {
              "name": "Luke"
            }
          ]
        ],
        "output": [
          {
            "key": 0,
            "value": {
              "name": "John"
            }
          },
          {
            "key": 1,
            "value": {
              "name": "Mary"
            }
          },
          {
            "key": 0,
            "value": {
              "name": "Nick"
            }
          },
          {
            "key": 1,
            "value": {
              "name": "Luke"
            }
          }
        ]
      }
    ],
    "identifier": 70242323
  },
  {
    "context": [
      "In this example I would like to filter where id = 54f and show the Timestamp (Unixtime converted to local time), Body and Source fields that match, ideally as shown below. \r\n[Timestamp]    Orange     827261\r\n[Timestamp]    Apple      137261",
      "Then you can go with this\r\n- `localtime` (available since jq 1.6) converts a timestamp of seconds (so, divide yours by 1000) since the Unix epoch into a so-called \"broken down time\" object ... With `.[:3] | .[1] += 1 | join(\"-\")` I provided a rather primitive example for demonstration purposes which concatenates its first three items (year, month, day) with dashes in between...",
      "    jq -r '.[] | select(.id == \"54f\")\r\n        | [(.timestamp / 1000 | localtime | strftime(\"%Y-%m-%d\")), .body, .source]\r\n        | @tsv' file.json",
      "The use of `strftime(\"%Y-%m-%d\")` is critical to both displaying the correct month and formatting the date with leading zeroes on single-digit months and days."
    ],
    "utterance": "Find all records with id equal to \"54f\" and display timestamp (converted to local time in YYYY-MM-DD format), body, and source, tab-separated.",
    "expressions": [
      ".[] | select(.id == \"54f\") | [(.timestamp / 1000 | localtime | .[:3] | join(\"-\")), .body, .source] | @tsv",
      ".[] | select(.id == \"54f\") | [(.timestamp / 1000 | localtime | strftime(\"%Y-%m-%d\")), .body, .source] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "timestamp": 1638550971085,
            "id": "54f",
            "body": "Orange",
            "source": "827261"
          },
          {
            "timestamp": 1638550971096,
            "id": "54f",
            "body": "Apple",
            "source": "137261"
          },
          {
            "timestamp": 1638550971126,
            "id": "5da",
            "body": "Pear",
            "source": "1da61"
          }
        ],
        "output": "2021-12-03\tOrange\t827261\n2021-12-03\tApple\t137261"
      }
    ],
    "identifier": 70220159
  },
  {
    "context": [
      "Request your kind help tweaking the command to print $filename. thanks!",
      "For a jq-internal solution use `input_filename` as @peak suggested.",
      "Here\u2019s an external solution which iterates over your input files and passes the file name as variable into jq.",
      "jq --arg f \"$f\" '. as $data | ... (use $f here) ...' \"$f\""
    ],
    "utterance": "Find all values in multiple files matching the email regex and output each hit with its associated file name.",
    "expressions": [
      "jq --arg f \"$f\" '. as $data | [path(..| select(scalars and (tostring | test(\"^[a-zA-Z0-9+_.-]+@[a-zA-Z0-9.-]+$\", \"ixn\")))) ] | map({ \"file\": $f, (.|join(\".\")): (. as $path | .=$data | getpath($path)) }) | reduce .[] as $item ({}; . * $item)' \"$f\"",
      "jq '. as $data | [path(..| select(scalars and (tostring | test(\"^[a-zA-Z0-9+_.-]+@[a-zA-Z0-9.-]+$\", \"ixn\")))) ] | map({ \"file\": input_filename, (.|join(\".\")): (. as $path | .=$data | getpath($path)) }) | reduce .[] as $item ({}; . * $item)' file1.json file2.json"
    ],
    "identifier": 70091006
  },
  {
    "context": [
      "echo '{\"p\":2}{\"q\":3}' | jq '.'",
      "How do I select the first object? I want the object below:",
      "{\"p\":2}",
      "jq -n 'first(inputs)'"
    ],
    "utterance": "Select the first object from a stream of concatenated objects where the first is {\"p\":2}.",
    "expressions": [
      "jq -n 'first(inputs)'"
    ],
    "data": [
      {
        "input": "{\"p\":2}{\"q\":3}",
        "output": {
          "p": 2
        }
      }
    ],
    "identifier": 70108930
  },
  {
    "context": [
      "The app `flv` then verify the streamname `mystrame` is active and extract `meta.video.height`",
      "For jq, try\n```\njq '\n  .applications\n  | map(select(.name == \"flv\"))[].live.streams\n  | map(select(.name == \"mystream\" and .active))[].meta.video.height\n'\n```",
      "720"
    ],
    "utterance": "Retrieve the video height from 'meta.video.height' for the stream named 'mystream' in the 'flv' application, only if the stream is active.",
    "expressions": [
      ".applications | map(select(.name == \"flv\"))[].live.streams | map(select(.name == \"mystream\" and .active))[].meta.video.height"
    ],
    "data": [
      {
        "input": {
          "port": 1935,
          "server_index": 0,
          "applications": [
            {
              "name": "hls",
              "live": {
                "streams": [
                  {
                    "name": "donbosco",
                    "time": 2380739,
                    "bw_in": 2112440,
                    "bytes_in": 541618713,
                    "bw_out": 0,
                    "bytes_out": 0,
                    "bw_audio": 35544,
                    "bw_video": 2076888,
                    "clients": [
                      {
                        "id": 453,
                        "address": "127.0.0.1",
                        "time": 2380959,
                        "flashver": "FMLE/3.0 (compatible; Lavf57.83.100)",
                        "dropped": 0,
                        "avsync": 28,
                        "timestamp": 2382635,
                        "publishing": true,
                        "active": true
                      }
                    ],
                    "records": [],
                    "meta": {
                      "video": {
                        "width": 1168,
                        "height": 720,
                        "frame_rate": 25,
                        "codec": "H264",
                        "profile": "High",
                        "level": 3.1
                      },
                      "audio": {
                        "codec": "AAC",
                        "profile": "LC",
                        "channels": 2,
                        "sample_rate": 16000
                      }
                    },
                    "nclients": 1,
                    "publishing": true,
                    "active": true
                  }
                ],
                "nclients": 1
              },
              "recorders": {
                "count": 0,
                "lists": []
              }
            },
            {
              "name": "flv",
              "live": {
                "streams": [
                  {
                    "name": "mystream",
                    "time": 2382811,
                    "bw_in": 2059096,
                    "bytes_in": 541841549,
                    "bw_out": 2059096,
                    "bytes_out": 543351459,
                    "bw_audio": 35472,
                    "bw_video": 2023624,
                    "clients": [
                      {
                        "id": 452,
                        "address": "127.0.0.1",
                        "time": 2382727,
                        "flashver": "LNX 9,0,124,2",
                        "dropped": 0,
                        "avsync": -12,
                        "timestamp": 2384520,
                        "publishing": false,
                        "active": true
                      },
                      {
                        "id": 451,
                        "address": "127.0.0.1",
                        "time": 2383031,
                        "flashver": "FMLE/3.0 (compatible; Lavf58.74.100)",
                        "dropped": 0,
                        "avsync": -12,
                        "timestamp": 2384520,
                        "publishing": true,
                        "active": true
                      }
                    ],
                    "records": [],
                    "meta": {
                      "video": {
                        "width": 1168,
                        "height": 720,
                        "frame_rate": 25,
                        "codec": "H264",
                        "profile": "High",
                        "level": 3.1
                      },
                      "audio": {
                        "codec": "AAC",
                        "profile": "LC",
                        "channels": 2,
                        "sample_rate": 16000
                      }
                    },
                    "nclients": 2,
                    "publishing": true,
                    "active": true
                  }
                ],
                "nclients": 2
              },
              "recorders": {
                "count": 0,
                "lists": []
              }
            }
          ]
        },
        "output": 720
      }
    ],
    "identifier": 70238232
  },
  {
    "context": [
      "End Result: using jq to count duplicate entries for src/dst ip address and dst port and ADD the cumulative duration of the connections.",
      "targeted jq output...\n10.xxx.xxx.21 | 18.xx1.xx1.158 | 45.6606 <--time is shown cumulative duration",
      "jq -sr '\n  group_by([.\"id.orig_h\", .\"id.resp_h\"])[]\n  | [(first|.\"id.orig_h\", .\"id.resp_h\"), (map(.duration)|add)]\n  | @csv\n'",
      "group_by([.\"id.orig_h\", .\"id.resp_h\"]) | map(\n    [(first|.\"id.orig_h\", .\"id.resp_h\"), (map(.duration)|add)]\n    | select(.[2] > 0)\n  )\n  | sort_by(-.[2])[]\n  | @csv"
    ],
    "utterance": "Find unique pairs of source and destination IP addresses, count the number of occurrences for each pair, and sum their total duration, then output each pair with their cumulative duration.",
    "expressions": [
      "group_by([.\"id.orig_h\", .\"id.resp_h\"])[] | [(first|.\"id.orig_h\", .\"id.resp_h\"), (map(.duration)|add)] | @csv",
      "group_by([.\"id.orig_h\", .\"id.resp_h\"]) | map([(first|.\"id.orig_h\", .\"id.resp_h\"), (map(.duration)|add)] | select(.[2] > 0)) | sort_by(-.[2])[] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "ts": 1636,
            "uid": "hex_code",
            "id.orig_h": "10.x.x.11",
            "id.orig_p": 42996,
            "id.resp_h": "10.x.x.123",
            "id.resp_p": 53,
            "proto": "udp",
            "service": "dns",
            "duration": 0.01117664844,
            "conn_state": "SF",
            "local_orig": true,
            "local_resp": true,
            "missed_bytes": 0,
            "history": "Dd",
            "orig_pkts": 1,
            "orig_ip_bytes": 71,
            "resp_pkts": 1,
            "resp_ip_bytes": 71
          },
          {
            "ts": 1,
            "uid": "hex_code",
            "id.orig_h": "10.x.x.11",
            "id.orig_p": 36299,
            "id.resp_h": "10.x.x.123",
            "id.resp_p": 53,
            "proto": "udp",
            "service": "dns",
            "duration": 0.00857415966797,
            "conn_state": "SF",
            "local_orig": true,
            "local_resp": true,
            "missed_bytes": 0,
            "history": "Dd",
            "orig_pkts": 1,
            "orig_ip_bytes": 74,
            "resp_pkts": 1,
            "resp_ip_bytes": 74
          }
        ],
        "output": [
          "\"10.x.x.11\",\"10.x.x.123\",0.01975080810797"
        ]
      }
    ],
    "identifier": 69917808
  },
  {
    "context": [
      "I have a 1GB JSON file I like to convert to CSV format. The file contains information about UK company people with significant control (PSC).",
      "im getting the following error: jq: error (at in.json:0): Cannot index string with string \"company_number\"",
      "As your input consists of a stream of JSON objects, let's start with a function for reading one of those objects:",
      "def get:\n  {company_number} as $number\n  | .data\n  | (.address | {address_line_1,country,locality,postal_code,premises}) as $address\n  | {ceased_on,country_of_residence} as $details\n  | (.date_of_birth | {month, year}) as $dob\n  | $number + $address + $details + $dob + {etag,kind}\n  ;",
      "(input|get)\n| keys_unsorted,\n  [.[]],\n  (inputs | getRow)\n| @csv"
    ],
    "utterance": "Extract fields company_number, address_line_1, country, locality, postal_code, premises, ceased_on, country_of_residence, month, year, etag, and kind from each top-level object and create a CSV where each row corresponds to a person\u2019s record.",
    "expressions": [
      "def get: {company_number} as $number | .data | (.address | {address_line_1,country,locality,postal_code,premises}) as $address | {ceased_on,country_of_residence} as $details | (.date_of_birth | {month, year}) as $dob | $number + $address + $details + $dob + {etag,kind}; def getRow: get | [.[]]; (input|get) | keys_unsorted, [.[]], (inputs | getRow) | @csv"
    ],
    "data": [
      {
        "input": {
          "company_number": "04502074",
          "data": {
            "address": {
              "address_line_1": "Grove Hall",
              "address_line_2": "Ashbourne Green",
              "locality": "Ashbourne",
              "postal_code": "DE6 1JD",
              "region": "Derbyshire"
            },
            "country_of_residence": "England",
            "date_of_birth": {
              "month": 11,
              "year": 1964
            },
            "etag": "f9a632332f63b61f004569f99d6b15e3e6d28192",
            "kind": "individual-person-with-significant-control",
            "links": {
              "self": "/company/04502074/persons-with-significant-control/individual/34zTsx2BFGMyn0lJe2REL656U8w"
            },
            "name": "Mr Philip Anthony Donlan",
            "name_elements": {
              "forename": "Philip",
              "middle_name": "Anthony",
              "surname": "Donlan",
              "title": "Mr"
            },
            "nationality": "British",
            "natures_of_control": [
              "ownership-of-shares-50-to-75-percent"
            ],
            "notified_on": "2016-04-06"
          }
        },
        "output": "\"company_number\",\"address_line_1\",\"country\",\"locality\",\"postal_code\",\"premises\",\"ceased_on\",\"country_of_residence\",\"month\",\"year\",\"etag\",\"kind\"\n\"04502074\",\"Grove Hall\",null,\"Ashbourne\",\"DE6 1JD\",null,null,\"England\",11,1964,\"f9a632332f63b61f004569f99d6b15e3e6d28192\",\"individual-person-with-significant-control\""
      }
    ],
    "identifier": 70231403
  },
  {
    "context": [
      "My current json file is basically like this and goes on and on and on (i've stripped most of it out as the keys don't really matter for what I'm asking...)",
      "When I use this, it drills down to .results[], it displays everything fine, but removes the comma inbetween the objects and adds my \"provider name, language, updated and shortformvideos\" to every object. Now I need to keep the commas inbetween the objects and only display the provider/language/date/shortform at the top of the file as I continue to manipulate the object to be in the correct format that ROKU wants.",
      "Now I'm just now starting to noodle around with jq, and this is what I'm trying to get... (desired example output shown)",
      "To clarify what is wrong with your approach: `.results[] | ...` executes the filter once per element of `results`. The result of each filter is output as a separate JSON object \u2013 or as you call it \u2013 \"stripping commas\".",
      "My approach embeds the `.results[]` inside the resulting object. If you find it more readable, you can also do `.results | map({...}) | {providerName: ......., shortFormVideos: .}`",
      "# header\n{providerName: \"CrozTest\", language: \"en-us\", lastUpdated: (.results[].timestamp | max)} +\n# the bit after the | is repeated for every element of results\n{shortFormVideos: [.results[] |\n  {title, thumbnail, id,\n   longDescription: .short_description,\n   shortDescription: .short_description,\n   releaseDate: .timestamp,\n   genres: [\"technology\"], \n   tags: [.branch],\n   content:\n    {duration,\n     dateAdded: .timestamp, \n     videos: [{url: .hls_url,\n               quality: \"HD\",\n               videoType: \"HLS\",\n               dateAdded: .publishdate}]}\n}]}"
    ],
    "utterance": "Transform the data so providerName, language, lastUpdated are top-level fields and shortFormVideos is an array composed from .results, all within a single object.",
    "expressions": [
      "{providerName: \"CrozTest\", language: \"en-us\", lastUpdated: (.results[].timestamp | max)} + {shortFormVideos: [.results[] | {title, thumbnail, id, longDescription: .short_description, shortDescription: .short_description, releaseDate: .timestamp, genres: [\"technology\"], tags: [.branch], content: {duration, dateAdded: .timestamp, videos: [{url: .hls_url, quality: \"HD\", videoType: \"HLS\", dateAdded: .publishdate}]}}]}"
    ],
    "data": [
      {
        "input": {
          "page_info": {
            "total_results": 1000,
            "results_per_page": 50
          },
          "results": [
            {
              "category": "B-Roll",
              "aspect_ratio": "16:9",
              "duration": 1851,
              "hd": true,
              "title": "Title",
              "id": "video:822667",
              "type": "video",
              "keywords": "removed",
              "credit": "Removed",
              "country": "United States",
              "city": "",
              "hls_url": "file",
              "timestamp": "2021-11-21T18:21:04.353Z",
              "publishdate": "2021-11-21T18:19:31Z",
              "thumbnail": null,
              "short_description": null,
              "branch": "tag"
            },
            {
              "category": "B-Roll",
              "aspect_ratio": "16:9",
              "duration": 1851,
              "hd": true,
              "title": "Title",
              "id": "video:822412",
              "type": "video",
              "keywords": "removed",
              "credit": "Removed",
              "country": "United States",
              "city": "",
              "hls_url": "file",
              "timestamp": "2021-11-21T18:21:04.353Z",
              "publishdate": "2021-11-21T18:19:31Z",
              "thumbnail": null,
              "short_description": null,
              "branch": "tag"
            }
          ]
        },
        "output": {
          "providerName": "CrozTest",
          "language": "en-us",
          "lastUpdated": "2021-11-21T18:21:04.353Z",
          "shortFormVideos": [
            {
              "title": "Title",
              "thumbnail": null,
              "id": "video:822667",
              "longDescription": null,
              "shortDescription": null,
              "releaseDate": "2021-11-21T18:21:04.353Z",
              "genres": [
                "technology"
              ],
              "tags": [
                "tag"
              ],
              "content": {
                "duration": 1851,
                "dateAdded": "2021-11-21T18:21:04.353Z",
                "videos": [
                  {
                    "url": "file",
                    "quality": "HD",
                    "videoType": "HLS",
                    "dateAdded": "2021-11-21T18:19:31Z"
                  }
                ]
              }
            },
            {
              "title": "Title",
              "thumbnail": null,
              "id": "video:822412",
              "longDescription": null,
              "shortDescription": null,
              "releaseDate": "2021-11-21T18:21:04.353Z",
              "genres": [
                "technology"
              ],
              "tags": [
                "tag"
              ],
              "content": {
                "duration": 1851,
                "dateAdded": "2021-11-21T18:21:04.353Z",
                "videos": [
                  {
                    "url": "file",
                    "quality": "HD",
                    "videoType": "HLS",
                    "dateAdded": "2021-11-21T18:19:31Z"
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 70074192
  },
  {
    "context": [
      "and I want to do something like (pseudo-code):\n\nif [ (epoch 15 minutes ago) -le timestamp ]; then \n   name=uniqueId; value_total=value(total); uniqueId_count=(uniqueId(count_total))\nfi",
      "Is there a way to simplify this without using a for loop to iterate over each object by calling `jq 'select() ...'` over and over?",
      "jq -s --argjson delta $((15*60)) --argjson addvalue 10 '\n\n (now - $delta) as $pivot\n | map(select(.timestamp >= $pivot))\n | group_by(.uniqueId)\n | map({\n    name: first.uniqueId,\n    value_total: map(.value) | (add + $addvalue),\n    uniqueId_count: length\n  })\n\n' "
    ],
    "utterance": "For objects whose timestamp is within the last 15 minutes, group by uniqueId, then for each group report the uniqueId, the sum of value plus 10, and the count of uniqueId.",
    "expressions": [
      "(now - $delta) as $pivot | map(select(.timestamp >= $pivot)) | group_by(.uniqueId) | map({ name: first.uniqueId, value_total: map(.value) | (add + $addvalue), uniqueId_count: length })"
    ],
    "data": [
      {
        "input": [
          {
            "timestamp": 1636601959,
            "uniqueId": "Foo",
            "value": 10
          },
          {
            "timestamp": 1636601859,
            "uniqueId": "Bar",
            "value": 13
          }
        ]
      }
    ],
    "identifier": 69922985
  },
  {
    "context": [
      "I\u2019d like to populate a `json-data.json` json data objects using a `json-template.json`.",
      "My desired result would be:",
      "{ key1: \"value1\", key2: \"value2\", name: \"John\", familyName: \"Smith\" }, ...",
      "def fillin($template):",
      ". as $in | reduce ($template|keys_unsorted[]) as $k ($template; if $in|has($k) then .[$k] = $in[$k] else . end);",
      "map(fillin(template))",
      "def fillin($template):",
      ". as $in | reduce ($template|keys_unsorted[]) as $k ($template; if $in|has($k) then .[$k] = $in[$k] else . end);",
      "map(fillin($t))"
    ],
    "utterance": "For each object in the input array, produce a new object based on a template, where keys from the input overwrite corresponding keys in the template and other template keys are retained.",
    "expressions": [
      "def fillin($template): . as $in | reduce ($template|keys_unsorted[]) as $k ($template; if $in|has($k) then .[$k] = $in[$k] else . end); map(fillin(template))",
      "def fillin($template): . as $in | reduce ($template|keys_unsorted[]) as $k ($template; if $in|has($k) then .[$k] = $in[$k] else . end); map(fillin($t))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "John",
            "familyName": "Smith"
          },
          {
            "name": "Samuel",
            "familyName": "Schnaider"
          }
        ],
        "output": [
          {
            "key1": "value1",
            "key2": "value2",
            "name": "John",
            "familyName": "Smith"
          },
          {
            "key1": "value1",
            "key2": "value2",
            "name": "Samuel",
            "familyName": "Schnaider"
          }
        ]
      }
    ],
    "identifier": 69921044
  },
  {
    "context": [
      "Now I want to transform it to a \"flat\" CSV, such that for every key in my object the list in the value is expanded to `n` rows with `n` being the number of entries in the respective list.",
      "### Expected Output",
      "foo;asd",
      "foo;fgh",
      "bar;abc",
      "bar;xyz",
      "bar;ert",
      "baz;something",
      "keys_unsorted[] as $k | \"\\($k);\\( .[$k][] )\""
    ],
    "utterance": "For each key and each value in its list, produce a line with the key and the value separated by a semicolon.",
    "expressions": [
      "keys_unsorted[] as $k | \"\\($k);\\(.[$k][])\""
    ],
    "data": [
      {
        "input": {
          "foo": [
            "asd",
            "fgh"
          ],
          "bar": [
            "abc",
            "xyz",
            "ert"
          ],
          "baz": [
            "something"
          ]
        },
        "output": [
          "foo;asd",
          "foo;fgh",
          "bar;abc",
          "bar;xyz",
          "bar;ert",
          "baz;something"
        ]
      }
    ],
    "identifier": 70022570
  },
  {
    "context": [
      "I am trying to extract unique values between two JSON files.",
      "Both of my files are in the same format:",
      "I would like to create a 3rd file which contains only unique values. If I must choose a single value to declare as unique, then I would select 'signature.'",
      "Choose a field that will be compared (e.g. `.signature`) and filter by that using `unique_by` in the comprehensive array obtained by using the option `--slurp` or `-s`:",
      "jq -s 'unique_by(.signature)[]' file*.txt"
    ],
    "utterance": "Obtain all objects with unique 'signature' values from two input files.",
    "expressions": [
      "jq -s 'unique_by(.signature)[]' file*.txt"
    ],
    "data": [
      {
        "input": [
          {
            "time": "2021-10-01T04:00:38.161Z",
            "Number": 2,
            "signature": "e03756fa67a30d52837d3743d4d87e9a810c5e2ddf11061a976c386a742fa"
          },
          {
            "time": "2021-10-01T04:01:38.164Z",
            "Number": 2,
            "signature": "3b4d746ac2da2543047d8cc981db2464d4993065993449b321fc15d7f0aa6"
          }
        ]
      }
    ],
    "identifier": 69918777
  },
  {
    "context": [
      "file.log properly contains ethereal and new, but they are on the same line instead of appending.",
      "Instead of the dubious:\r\n\r\n    echo $(_jq '.dependencies[].name')\r\n\r\nwrite:\r\n\r\n    _jq '.dependencies[].name'",
      "IOW, KIS."
    ],
    "utterance": "Output each value of dependencies[].name, with one name per line.",
    "expressions": [
      ".dependencies[].name"
    ],
    "data": [
      {
        "input": {
          "florecipe-v": "1.0",
          "name": "web3updater",
          "dependencies": [
            {
              "name": "ethereal",
              "version": "2.6.0",
              "source": {
                "ipfs": "QmWmxakbb7msHFaD9QmGXBAmLpUHTdZG64BWhQg8dyx8gM",
                "github": "https://github.com/wealdtech/ethereal.git"
              },
              "linux-amd64": {
                "ipfs": "QmbwABiXz4U5MrmJLisfxaHEG7CyJKEnNECRjXogS7eAFw",
                "github": "https://github.com/wealdtech/ethereal/releases/download/v2.6.0/ethereal-2.6.0-linux-amd64.tar.gz"
              },
              "linux-arm64": {
                "ipfs": "QmV9agwSZuVXMJNYV1NhU8SY8TRg73z8RgTw4QaYrVxtrr",
                "github": "https://github.com/wealdtech/ethereal/releases/download/v2.6.0/ethereal-2.6.0-linux-arm64.tar.gz"
              },
              "windows-i386": {
                "ipfs": "",
                "github": ""
              }
            },
            {
              "name": "new",
              "version": "",
              "source": {
                "ipfs": "",
                "github": ""
              },
              "linux-amd64": {
                "ipfs": "",
                "github": ""
              },
              "linux-arm64": {
                "ipfs": "",
                "github": ""
              },
              "windows-i386": {
                "ipfs": "",
                "github": ""
              }
            }
          ]
        },
        "output": [
          "ethereal",
          "new"
        ]
      }
    ],
    "identifier": 69921626
  },
  {
    "context": [
      "How to recreate the array with the last object item (from each sub-array) removed?",
      "EDIT: `[.[][:-1]]` should do it."
    ],
    "utterance": "Remove the last object from each sub-array in a nested array structure.",
    "expressions": [
      "[.[][:-1]]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "type": "strip",
              "output": "debian-7-x86_64-strip"
            },
            {
              "type": "compress",
              "output": "debian-7-x86_64-compress"
            },
            {
              "type": "full",
              "output": "debian-7-x86_64"
            }
          ],
          [
            {
              "type": "strip",
              "output": "debian-8-strip"
            },
            {
              "type": "compress",
              "output": "debian-8-compress"
            }
          ]
        ],
        "output": [
          [
            {
              "type": "strip",
              "output": "debian-7-x86_64-strip"
            },
            {
              "type": "compress",
              "output": "debian-7-x86_64-compress"
            }
          ],
          [
            {
              "type": "strip",
              "output": "debian-8-strip"
            }
          ]
        ]
      }
    ],
    "identifier": 70104513
  },
  {
    "context": [
      "I need to parse this string `\"networking.k8s.io/v1/NetworkPolicy\"`, BUT its can be looks like `Kind` or `Version/Kind` or `Version/Group/Kind`.",
      "I need more universal command for split string to \"/\", but in some cases there may be one \"/\" and in some cases two. I need to parse it correctly and write a command with the condition",
      "(.spec.rules[0].match.resources.kinds / \"/\")\n| [select(.[1])[0] // null, select(.[2])[1] // null, last]\n  as [$version,$group,$kind]\n| {$version,$group,$kind}"
    ],
    "utterance": "Extract version, group, and kind by splitting each element of the kinds array at '/', correctly handling cases with one or two slashes.",
    "expressions": [
      "(.spec.rules[0].match.resources.kinds[] / \"/\") | [select(.[1])[0] // null, select(.[2])[1] // null, last] as [$version,$group,$kind] | {$version,$group,$kind}"
    ],
    "data": [
      {
        "input": {
          "spec": {
            "background": true,
            "failurePolicy": "Fail",
            "rules": [
              {
                "exclude": {
                  "resources": {}
                },
                "generate": {
                  "clone": {}
                },
                "match": {
                  "resources": {
                    "kinds": [
                      "networking.k8s.io/v1/NetworkPolicy",
                      "v1/Pod",
                      "Service"
                    ]
                  }
                },
                "mutate": {},
                "name": "validate-nodeport",
                "validate": {
                  "message": "Services of type NodePort are not allowed.",
                  "pattern": {
                    "spec": {
                      "type": "!NodePort"
                    }
                  }
                }
              }
            ],
            "validationFailureAction": "audit"
          },
          "status": {
            "ready": true
          }
        },
        "output": [
          {
            "$version": "networking.k8s.io",
            "$group": "v1",
            "$kind": "NetworkPolicy"
          },
          {
            "$version": "v1",
            "$group": null,
            "$kind": "Pod"
          },
          {
            "$version": null,
            "$group": null,
            "$kind": "Service"
          }
        ]
      }
    ],
    "identifier": 70021792
  },
  {
    "context": [
      "I want to change John's age to 44, and then return the entire blob. I'm looking for the following output:",
      "Additionally, if \"age\" is not there, I would like to add it.",
      ".results |= map(if .name == \"John\" then .age = 44 else . end)",
      "( .results[] | select(.name == \"John\") | .age) |= 44",
      "( .results[] | select(.age | not )) += { \"age\": 1 }",
      "( .results[] | select(.age | not )) += { \"age\": 1 } | ( .results[] | select(.name == \"John\") | .age) |= 44",
      "(.results[] | select(.name == \"John\")).age = 44"
    ],
    "utterance": "Update the object in the results array where name is \"John\" so that age is set to 44, and if age is missing, add it.",
    "expressions": [
      ".results |= map(if .name == \"John\" then .age = 44 else . end)",
      "( .results[] | select(.name == \"John\") | .age) |= 44",
      "(.results[] | select(.name == \"John\")).age = 44",
      "( .results[] | select(.age | not )) += { \"age\": 1 } | ( .results[] | select(.name == \"John\") | .age) |= 44"
    ],
    "data": [
      {
        "input": {
          "timestamp": 1234567890,
          "report": "Age Report",
          "results": [
            {
              "name": "John",
              "age": 43,
              "city": "TownA"
            },
            {
              "name": "Jane",
              "age": 10,
              "city": "TownB"
            }
          ]
        },
        "output": {
          "timestamp": 1234567890,
          "report": "Age Report",
          "results": [
            {
              "name": "John",
              "age": 44,
              "city": "TownA"
            },
            {
              "name": "Jane",
              "age": 10,
              "city": "TownB"
            }
          ]
        }
      },
      {
        "input": {
          "timestamp": 1234567890,
          "report": "Age Report",
          "results": [
            {
              "name": "John",
              "city": "TownA"
            },
            {
              "name": "Jane",
              "age": 10,
              "city": "TownB"
            }
          ]
        },
        "output": {
          "timestamp": 1234567890,
          "report": "Age Report",
          "results": [
            {
              "name": "John",
              "age": 44,
              "city": "TownA"
            },
            {
              "name": "Jane",
              "age": 10,
              "city": "TownB"
            }
          ]
        }
      }
    ],
    "identifier": 70203451
  },
  {
    "context": [
      "I have a bunch of JSON files (fixtures) from which I need to delete a field if the \"current\" object happens to match a `select` filter.",
      "I'm able to match the desired objects but I'm not sure how to perform the deletion of the field so that the object is modified in-place.",
      "For \"in-place\" deletion of a key, you might find `walk` quite congenial:",
      "walk(if type == \"object\" and .__typename == \"MyType\" \n     then del(.delete_me) else . end)"
    ],
    "utterance": "Delete the field delete_me from each object where __typename is exactly MyType.",
    "expressions": [
      "walk(if type == \"object\" and .__typename == \"MyType\" then del(.delete_me) else . end)"
    ],
    "identifier": 69936884
  },
  {
    "context": [
      "I&#39;m trying to get the dicts with the name `foo`, so the expecting output is:",
      "jq '.[] | select(.name == \"foo\")'"
    ],
    "utterance": "Extract all objects from the input where the name field has the value 'foo'.",
    "expressions": [
      ".[] | select(.name == \"foo\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "value": 1
          },
          {
            "name": "bar",
            "value": 1
          },
          {
            "name": "foo",
            "value": 2
          }
        ],
        "output": [
          {
            "name": "foo",
            "value": 1
          },
          {
            "name": "foo",
            "value": 2
          }
        ]
      }
    ],
    "identifier": 70019429
  },
  {
    "context": [
      "I want to find all users belonging to specific group (searching by group `name` or group `id` in the `groups` array)",
      "jq: error (at json:27): Cannot iterate over null (null)",
      "Desired output format when searching of example group *G1* would be:\r\n\r\n    u2\r\n    u3",
      "Using `?` as the [Optional Object Identifier-Index][1] operator, you could do a select as below\r\n\r\n```none\r\nmap(select(.groups[].name == \"G1\")? | .user)",
      "jq -r --arg id \"\" --arg name \"G1\" '\r\n  .[] | select(.groups | map(.id == $id or .name == $name) | any)? | .user\r\n'"
    ],
    "utterance": "List users whose groups array contains a group with name G1 or a specified id.",
    "expressions": [
      "map(select(.groups[].name == \"G1\")? | .user)[]",
      ".[] | select(.groups | map(.id == \"100001\" or .name == \"G1\") | any)? | .user"
    ],
    "data": [
      {
        "input": [
          {
            "user": "u1"
          },
          {
            "user": "u2",
            "groups": [
              {
                "id": "100001",
                "name": "G1"
              },
              {
                "id": "100002",
                "name": "G2"
              }
            ]
          },
          {
            "user": "u3",
            "groups": [
              {
                "id": "100001",
                "name": "G1"
              }
            ]
          }
        ],
        "output": [
          "u2",
          "u3"
        ]
      }
    ],
    "identifier": 70077412
  },
  {
    "context": [
      "What I would like to do is get the objects that are unique by their `.hash` The idea is to sum up the total amounts that fall within the given date",
      "One way to remove the duplicates would be to use `unique_by/1` in conjunction with the -s command-line option.",
      "jq -s --arg this \"$(date +%Y-%m-%dT%H:%M:%S)\" '\n  map(.data[] | select(.timestamp >= $this) | {hash, amount})\n  | unique_by(.hash)[]\n  | .amount\n' input.json"
    ],
    "utterance": "Select objects with distinct hash values where timestamp is on or after a given date, and retrieve their amount values.",
    "expressions": [
      "map(.data[] | select(.timestamp >= $this) | {hash, amount}) | unique_by(.hash)[] | .amount"
    ],
    "data": [
      {
        "input": [
          {
            "data": [
              {
                "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
                "amount": 7885016,
                "block": 470788,
                "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
                "hash": "DTU1GGfR0eU15hv6KiV_bg6FOJXfUWz4TjIq1H7TGy4",
                "timestamp": "2020-08-28T01:29:46.000000Z"
              }
            ]
          },
          {
            "data": [
              {
                "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
                "amount": 7885016,
                "block": 470788,
                "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
                "hash": "DTU1GGfR0eU15hv6KiV_bg6FOJXfUWz4TjIq1H7TGy4",
                "timestamp": "2020-08-28T01:29:46.000000Z"
              }
            ]
          },
          {
            "data": [
              {
                "account": "12xUoMKwf12ABjNx4VCvYcNkX79gW1kzz2JnBLxkFbjswRczRvM",
                "amount": 8623955,
                "block": 470509,
                "gateway": "113kQU96zqePySTahB7PEde9ZpoWK76DYK1f57wyhjhXCBoAu88",
                "hash": "5fQJY9MprH9b3IstVU1SdfBteUWoF_sdsVuiARPBtTY",
                "timestamp": "2020-08-27T19:01:48.000000Z"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 70015029
  },
  {
    "context": [
      "I want to split `RequestToUploadFileList[0].Url` into two parts: before `?sv=` and the remaining string.",
      "{ReferenceNumber:.ReferenceNumber}\n + (.RequestToUploadFileList[0]\n    | (.Url|index(\"?sv=\")) as $ix\n    | {URI:.Url,\n        URI_ABS: .Url[0:$ix],\n        URI_SAS: .Url[$ix:],\n        FILE: .FileName,\n        Key: .HeaderList[0].Value } )",
      "Instead of using `index`, you might wish to consider using `capture`:\n(.Url|capture( \"(?<head>.*)(?<tail>\\\\?sv=.*)\" )) as $url ..."
    ],
    "utterance": "Extract the value of ReferenceNumber, the entire Url, the substring of Url before '?sv=', the substring of Url starting from '?sv=', the FileName, and the first HeaderList Value from the first item of RequestToUploadFileList.",
    "expressions": [
      "{ReferenceNumber:.ReferenceNumber} + (.RequestToUploadFileList[0] | (.Url|index(\"?sv=\")) as $ix | {URI:.Url, URI_ABS: .Url[0:$ix], URI_SAS: .Url[$ix:], FILE: .FileName, Key: .HeaderList[0].Value })",
      "{ReferenceNumber:.ReferenceNumber} + (.RequestToUploadFileList[0] | (.Url|capture(\"(?<head>.*)(?<tail>\\\\?sv=.*)\")) as $url | {URI:.Url, URI_ABS: $url.head, URI_SAS: $url.tail, FILE: .FileName, Key: .HeaderList[0].Value })"
    ],
    "data": [
      {
        "input": {
          "ReferenceNumber": "d4fd41850323d2f6000000b013016327",
          "TimeoutInSec": 900,
          "RequestToUploadFileList": [
            {
              "BlobName": "8377ed3d-1b05-4c76-b718-6fddd46fd298",
              "FileName": "jpk_vat_100-01.xml.zip.aes",
              "Url": "https://taxdocumentstorage09tst.blob.core.windows.net/d4fd41850323d2f6000000b013016327/8377ed3d-1b05-4c76-b718-6fddd46fd298?sv=2015-07-08&sr=b&si=d4fd41850323d2f6000000b013016327&sig=yFXyJdsPPkbE0iQwVs5ccLEYEU0lxQHldbVyPfPciXw%3D",
              "Method": "PUT",
              "HeaderList": [
                {
                  "Key": "Content-MD5",
                  "Value": "eXkPLHMM+dHB5GCFoeAvsA=="
                },
                {
                  "Key": "x-ms-blob-type",
                  "Value": "BlockBlob"
                }
              ]
            }
          ]
        },
        "output": {
          "ReferenceNumber": "d4fd41850323d2f6000000b013016327",
          "URI": "https://taxdocumentstorage09tst.blob.core.windows.net/d4fd41850323d2f6000000b013016327/8377ed3d-1b05-4c76-b718-6fddd46fd298?sv=2015-07-08&sr=b&si=d4fd41850323d2f6000000b013016327&sig=yFXyJdsPPkbE0iQwVs5ccLEYEU0lxQHldbVyPfPciXw%3D",
          "URI_ABS": "https://taxdocumentstorage09tst.blob.core.windows.net/d4fd41850323d2f6000000b013016327/8377ed3d-1b05-4c76-b718-6fddd46fd298",
          "URI_SAS": "?sv=2015-07-08&sr=b&si=d4fd41850323d2f6000000b013016327&sig=yFXyJdsPPkbE0iQwVs5ccLEYEU0lxQHldbVyPfPciXw%3D",
          "FILE": "jpk_vat_100-01.xml.zip.aes",
          "Key": "eXkPLHMM+dHB5GCFoeAvsA=="
        }
      }
    ],
    "identifier": 69966355
  },
  {
    "context": [
      "Json data: \n```\n{\n \"main\": [\n  {\n   \"firstKey\": \"ABCD\",\n   \"id\": \"12345\",\n   \"data\": [\n    {\n     \"name\": \"first_id\",\n     \"value\": \"first_id_value\"\n    },\n    {\n     \"name\": \"second_id\",\n     \"value\": \"second_id_value\"\n    },\n    {\n     \"name\": \"third_id\",\n     \"value\": \"third_id_value\"\n    }\n   ]\n  }\n ]\n}\n```",
      "**Expected OUTPUT**:\n```\n{\n \"firstKey\": \"ABCD\",\n \"id\": \"12345\",\n \"data.name.first_id\": \"first_id_value\",\n \"data.name.second_id\": \"second_id_value\",\n \"data.name.third_id\": \"third_id_value\"\n}\n```",
      "But I want the **objects of data to be under the same braces** as 'firstKey' and 'id'.",
      "Since your structure is so rigid, you can cheat and use the built-in `from_entries`, which takes a list of `{key, value}` pairs and constructs an object:\n```\n.main[] |\n{firstKey, id} +\n  (.data | map({key: \"data.name.\\(.name)\", value}) |\n   from_entries)\n```"
    ],
    "utterance": "Flatten each entry under main so that firstKey and id are preserved, and each data item's name and value become new top-level key-value pairs with keys like data.name.first_id and values being their corresponding value.",
    "expressions": [
      ".main[] |\n{firstKey, id} +\n  (.data | map({key: \"data.name.\\(.name)\", value}) |\n   from_entries)"
    ],
    "data": [
      {
        "input": {
          "main": [
            {
              "firstKey": "ABCD",
              "id": "12345",
              "data": [
                {
                  "name": "first_id",
                  "value": "first_id_value"
                },
                {
                  "name": "second_id",
                  "value": "second_id_value"
                },
                {
                  "name": "third_id",
                  "value": "third_id_value"
                }
              ]
            }
          ]
        },
        "output": {
          "firstKey": "ABCD",
          "id": "12345",
          "data.name.first_id": "first_id_value",
          "data.name.second_id": "second_id_value",
          "data.name.third_id": "third_id_value"
        }
      }
    ],
    "identifier": 70034893
  },
  {
    "context": [
      "I wanted to get the data from `jq -c .results[i].\"com.src.main.client.details\"` into a json file to process further.",
      "Desire Output:",
      "[\n  {\n    \"doc\": \"string\",\n    \"details\": [\n      {\n        \"amount\": null,\n        \"output\": null,\n        \"properties\": [],\n        \"characteristic\": [],\n        \"component\": null,\n        \"period\": null,\n        \"internals\": {\n          \"Currency\": \"EUR\",\n          \"value\": 0\n        }\n      }\n    ]\n  },\n  {\n    \"doc\": \"string\",\n    \"details\": [\n      {\n        \"amount\": null,\n        \"output\": null,\n        \"properties\": [\n          {\n            \"characteristic\": [],\n            \"component\": null,\n            \"period\": null,\n            \"internals\": {\n              \"Currency\": \"EUR\",\n              \"value\": 0\n            }\n          }\n        ]\n      }\n    ]\n  }\n]\n",
      ".results[i] should be .results[]",
      "The following produces a stream of JSON objects:\n\n```\n.results[].\"com.src.main.client.details\"\n```",
      "To get an array, use\n\n```\n[ .results[].\"com.src.main.client.details\" ]\n```",
      "or\n\n```\n.results | map(.\"com.src.main.client.details\")\n```"
    ],
    "utterance": "Extract all objects from the array at results, returning only each object's com.src.main.client.details property as an array.",
    "expressions": [
      "[ .results[].\"com.src.main.client.details\" ]",
      ".results | map(.\"com.src.main.client.details\")"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "requestID": "89279f54-2f18-4301-b94d-1c413be1cb68",
            "signature": {
              "*": "*"
            }
          },
          "results": [
            {
              "com.src.main.client.details": {
                "doc": "string",
                "details": [
                  {
                    "amount": null,
                    "output": null,
                    "properties": [],
                    "characteristic": [],
                    "component": null,
                    "period": null,
                    "internals": {
                      "Currency": "EUR",
                      "value": 0
                    }
                  }
                ]
              }
            },
            {
              "com.src.main.client.details": {
                "doc": "string",
                "details": [
                  {
                    "amount": null,
                    "output": null,
                    "properties": [
                      {
                        "characteristic": [],
                        "component": null,
                        "period": null,
                        "internals": {
                          "Currency": "EUR",
                          "value": 0
                        }
                      }
                    ]
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "doc": "string",
            "details": [
              {
                "amount": null,
                "output": null,
                "properties": [],
                "characteristic": [],
                "component": null,
                "period": null,
                "internals": {
                  "Currency": "EUR",
                  "value": 0
                }
              }
            ]
          },
          {
            "doc": "string",
            "details": [
              {
                "amount": null,
                "output": null,
                "properties": [
                  {
                    "characteristic": [],
                    "component": null,
                    "period": null,
                    "internals": {
                      "Currency": "EUR",
                      "value": 0
                    }
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 70215572
  },
  {
    "context": [
      "How to I create 1 large CSV for every folder of JSONs (containing tens of thousands; in this example 54k) 1 JSON for every row in the CSV using JSON element names to create column's.",
      "Here is a fast solution using jq.  It requires hardly any memory, but there is general caveat and one potential complication.",
      "The following has been tested with this invocation of jq in the directory in which all the .json files reside:\n```bash\njq -Mnrf combine.jq *.json > wash.csv\n```",
      "### combine.jq\n```jq\ndef topKeys: {\n  resource_url,\n  id,\n  absolute_url,\n  cluster,\n  author,\n  joined_by,\n  author_str,\n  per_curiam,\n  date_created,\n  date_modified,\n  type,\n  sha1,\n  page_count,\n  download_url,\n  local_path,\n  plain_text,\n  html,\n  html_lawbox,\n  html_columbia,\n  html_with_citations,\n  extracted_by_ocr\n}\n  | .joined_by |= (if type == \"array\" then join(\"; \") else . end)\n;\n\ndef header:\n (topKeys|keys_unsorted) + [range(1; 1 + (.opinions_cited | length)) ];\n\ndef row:\n  [topKeys[]] + .opinions_cited;\n\n# s should be a stream of arrays\n# For each item in the stream, a counter (starting at 1) is inserted before the other items\ndef insert_counter(s): foreach s as $x (0; .+1; [.] + $x);\n\n# Read the first file for the headers\ninput\n| ([\"record\"] + header),\n   insert_counter( (., inputs) | row )\n| @csv\n```"
    ],
    "utterance": "Combine tens of thousands of files, each representing a law opinion, into a single CSV with each file as a row and columns named after the file's top-level keys, flattening the joined_by array as a string, and adding a row counter instead of the original id.",
    "expressions": [
      "def topKeys: {\n  resource_url,\n  id,\n  absolute_url,\n  cluster,\n  author,\n  joined_by,\n  author_str,\n  per_curiam,\n  date_created,\n  date_modified,\n  type,\n  sha1,\n  page_count,\n  download_url,\n  local_path,\n  plain_text,\n  html,\n  html_lawbox,\n  html_columbia,\n  html_with_citations,\n  extracted_by_ocr\n}\n  | .joined_by |= (if type == \"array\" then join(\"; \") else . end)\n;\n\ndef header:\n (topKeys|keys_unsorted) + [range(1; 1 + (.opinions_cited | length)) ];\n\ndef row:\n  [topKeys[]] + .opinions_cited;\n\ndef insert_counter(s): foreach s as $x (0; .+1; [.] + $x);\n\ninput\n| ([\"record\"] + header),\n   insert_counter( (., inputs) | row )\n| @csv"
    ],
    "identifier": 70011869
  },
  {
    "context": [
      "I\u2019ve got 2 json files and want to merge them into one unique file, but with additional key, for example \"first_key\" and \"second_key\"",
      "expected result :\n\n    { \n      \"first_key\" : {\n        \"timestamp\": 1382461861,\n        \"value\": {\n            \"aaa\": {\n                \"value1\": \"v1\",\n                \"value2\": \"v2\"\n            },\n            \"bbb\": {\n                \"value1\": \"v1\",\n                \"value2\": \"v2\"\n            },\n            \"ccc\": {\n                \"value1\": \"v1\",\n                \"value2\": \"v2\"\n            }\n         }\n      },\n      \"second_key\": {\n        \"timestamp\": 138246330,\n        \"value\": {\n            \"ddd\": {\n                \"value1\": \"v1\",\n                \"value2\": \"v2\"\n            },\n            \"eee\": {\n                \"value1\": \"v1\",\n                \"value2\": \"v2\"\n            },\n            \"fff\": {\n                \"value1\": \"v1\",\n                \"value2\": \"v2\"\n            }\n         }\n      }\n    }",
      "jq --slurp '{first_key:.[0], second_key:.[1]}' file1 file2",
      "jq --null-input '{first_key:input, second_key:input}' file1 file2",
      "jq --null-input '[inputs] | {first_key:.[0], second_key:.[1]}' file1 file2",
      "jq --null-input --argfile f1 file1 --argfile f2 file2 '{first_key:$f1, second_key:$f2}'",
      "jq --null-input --argjson f1 \"$(<file1)\" --argjson f2 \"$(<file2)\" '{first_key:$f1, second_key:$f2}'",
      "jq --null-input --slurpfile f1 file1 --slurpfile f2 file2 '{first_key:$f1[0], second_key:$f2[0]}'",
      "jq --null-input --slurpfile f <(cat file1 file2) '{first_key:$f[0], second_key:$f[1]}'"
    ],
    "utterance": "Combine two files into a single object with the first wrapped under 'first_key' and the second under 'second_key'.",
    "expressions": [
      "{first_key: .[0], second_key: .[1]}",
      "{first_key: input, second_key: input}",
      "[inputs] | {first_key: .[0], second_key: .[1]}",
      "{first_key: $f1, second_key: $f2}",
      "{first_key: $f1, second_key: $f2}",
      "{first_key: $f1[0], second_key: $f2[0]}",
      "{first_key: $f[0], second_key: $f[1]}"
    ],
    "data": [
      {
        "input": [
          {
            "timestamp": 1382461861,
            "value": {
              "aaa": {
                "value1": "v1",
                "value2": "v2"
              },
              "bbb": {
                "value1": "v1",
                "value2": "v2"
              },
              "ccc": {
                "value1": "v1",
                "value2": "v2"
              }
            }
          },
          {
            "timestamp": 138246330,
            "value": {
              "ddd": {
                "value1": "v1",
                "value2": "v2"
              },
              "eee": {
                "value1": "v1",
                "value2": "v2"
              },
              "fff": {
                "value1": "v1",
                "value2": "v2"
              }
            }
          }
        ],
        "output": {
          "first_key": {
            "timestamp": 1382461861,
            "value": {
              "aaa": {
                "value1": "v1",
                "value2": "v2"
              },
              "bbb": {
                "value1": "v1",
                "value2": "v2"
              },
              "ccc": {
                "value1": "v1",
                "value2": "v2"
              }
            }
          },
          "second_key": {
            "timestamp": 138246330,
            "value": {
              "ddd": {
                "value1": "v1",
                "value2": "v2"
              },
              "eee": {
                "value1": "v1",
                "value2": "v2"
              },
              "fff": {
                "value1": "v1",
                "value2": "v2"
              }
            }
          }
        }
      }
    ],
    "identifier": 70039380
  },
  {
    "context": [
      "I have this JSON Object",
      "And I want an output like this",
      "How do I achieve this with bash script and jq?",
      "Here&#39;s a solution using jq&#39;s --stream option:",
      "jq -n --stream '\n  def stream:\n    foreach ((inputs | select(length==2)), null) as $kv (null;\n      if $kv == null then .emit = .value\n      else .emit = null\n      | $kv[0][0] as $k\n      | if .k and ($k != .k) \n        then .emit = .value | .value = null \n        else . \n        end\n      | .value |= setpath($kv[0]; $kv[1])\n      | .k = $k\n      end;\n    select(.emit).emit);\n\n  [stream] | add\n' input.json"
    ],
    "utterance": "Combine separate entries with the same top-level key so each key contains all its nested days as subkeys.",
    "expressions": [
      "jq -n --stream '\n  def stream:\n    foreach ((inputs | select(length==2)), null) as $kv (null;\n      if $kv == null then .emit = .value\n      else .emit = null\n      | $kv[0][0] as $k\n      | if .k and ($k != .k) \n        then .emit = .value | .value = null \n        else . \n        end\n      | .value |= setpath($kv[0]; $kv[1])\n      | .k = $k\n      end;\n    select(.emit).emit);\n\n  [stream] | add\n'"
    ],
    "data": [
      {
        "input": {
          "id_1": {
            "day_2": {
              "loc_sec": 575,
              "int_sec": null
            }
          },
          "id_2": {
            "day_2": {
              "loc_sec": 138,
              "int_sec": null
            }
          }
        },
        "output": {
          "id_1": {
            "day_1": {
              "loc_sec": 886,
              "int_sec": null
            },
            "day_2": {
              "loc_sec": 575,
              "int_sec": null
            }
          },
          "id_2": {
            "day_1": {
              "loc_sec": 140,
              "int_sec": null
            },
            "day_2": {
              "loc_sec": 138,
              "int_sec": null
            }
          }
        }
      }
    ],
    "identifier": 69968773
  },
  {
    "context": [
      "Using JQ I want to add a key value pair to the first (or all) entries in the `myValues` array, that have the `filterableValue==\"y\"`.",
      "The result should have the same structure (still contain both `foo` and `myValues`) but have a modified entry where `filterableValue==\"y\"`.",
      "How can I modify a filtered entry as above _and_ contain the original structure?",
      "Enclose the whole selector on the LHS within parentheses:",
      "(.myValues[] | select(.filterableValue == \"y\")).this = \"has been added\"",
      "( .myValues[] | select(.filterableValue==\"y\") ) |= ( .this = \"has been added\" )"
    ],
    "utterance": "Add a key-value pair {\"this\":\"has been added\"} to all entries in the myValues array where filterableValue is \"y\", preserving the original object structure.",
    "expressions": [
      "(.myValues[] | select(.filterableValue == \"y\")).this = \"has been added\"",
      "( .myValues[] | select(.filterableValue==\"y\") ) |= ( .this = \"has been added\" )"
    ],
    "data": [
      {
        "input": {
          "myValues": [
            {
              "filterableValue": "x",
              "something": "else"
            },
            {
              "filterableValue": "y",
              "another key": "another value"
            },
            {
              "filterableValue": "z"
            }
          ],
          "foo": "bar"
        },
        "output": {
          "myValues": [
            {
              "filterableValue": "x",
              "something": "else"
            },
            {
              "filterableValue": "y",
              "another key": "another value",
              "this": "has been added"
            },
            {
              "filterableValue": "z"
            }
          ],
          "foo": "bar"
        }
      }
    ],
    "identifier": 70006317
  },
  {
    "context": [
      "I wan to to add json items to the end of current array \"issues\".",
      "I try this in bash:",
      "now I try to add resultIssues to the end of array issues.",
      "Why some json items  **out of** array \"**issues**\"?",
      "read -r resultIssues <<(curl -s -XGET \"$BASE_URL/issues/search?componentKeys=$PROJECT_KEY&p=$pageNumber&ps=$PAGE_SIZE\" | jq '.issues')",
      "currentReportContent=$(jq --argjson resultIssues \"$resultIssues\" '.issues |= . + $resultIssues' <<< \"$currentReportContent\") "
    ],
    "utterance": "Append all items from resultIssues to the end of the issues array in the existing structure.",
    "expressions": [
      ".issues |= . + $resultIssues"
    ],
    "identifier": 70004565
  },
  {
    "context": [
      "But I&#39;ld like to add the company name and country code for example, and I don&#39;t kown to do this, with this king of data in second \"level\".",
      "I&#39;ld to obtain something like that:\r\n\r\n    \"eventDate\",\"ruleCode\",\"ruleName\",\"summary\",\"oldValue\",\"newValue\",\"companyName\", \"companyCountryCode\"\r\n    \"2021-11-22T00:00:00\",704,\"New Accounts\",\"Explanations...\",,,\"My_company_name\", \"US\"\r\n    \"2021-11-22T00:00:00\",701,\"Hello\",\"otherExplanations...\",,,\"My_company_name 2\", \"UK\"",
      "jq --raw-output '[\r\n  \"eventDate\",\r\n  \"ruleCode\",\r\n  \"ruleName\",\r\n  \"summary\",\r\n  \"oldValue\",\r\n  \"newValue\",\r\n  \"company.name\",\r\n  \"company.countryCode\"\r\n] as $h\r\n| $h, (.data[] | [getpath($h[] / \".\")])\r\n| @csv'"
    ],
    "utterance": "Produce a CSV with columns eventDate, ruleCode, ruleName, summary, oldValue, newValue, company name, and company country code, extracting company fields from a nested object.",
    "expressions": [
      "[\n  \"eventDate\",\n  \"ruleCode\",\n  \"ruleName\",\n  \"summary\",\n  \"oldValue\",\n  \"newValue\",\n  \"company.name\",\n  \"company.countryCode\"\n] as $h\n| $h, (.data[] | [getpath($h[] / \".\")])\n| @csv"
    ],
    "data": [
      {
        "input": {
          "totalCount": 4440,
          "data": [
            {
              "company": {
                "name": "My_company_name",
                "countryCode": "US",
                "portfolioName": "My_portfolio"
              },
              "eventDate": "2021-11-22T00:00:00",
              "newValue": null,
              "oldValue": null,
              "ruleCode": 704,
              "ruleName": "New Accounts",
              "summary": "Explanations..."
            },
            {
              "company": {
                "name": "My_company_name 2",
                "countryCode": "UK",
                "portfolioName": "My_portfolio"
              },
              "eventDate": "2021-10-22T00:00:00",
              "newValue": null,
              "oldValue": null,
              "ruleCode": 701,
              "ruleName": "Hello",
              "summary": "otherExplanations..."
            }
          ]
        },
        "output": "\"eventDate\",\"ruleCode\",\"ruleName\",\"summary\",\"oldValue\",\"newValue\",\"company.name\",\"company.countryCode\"\n\"2021-11-22T00:00:00\",704,\"New Accounts\",\"Explanations...\",,,\"My_company_name\",\"US\"\n\"2021-10-22T00:00:00\",701,\"Hello\",\"otherExplanations...\",,,\"My_company_name 2\",\"UK\""
      }
    ],
    "identifier": 70068440
  },
  {
    "context": [
      "which I'd like to convert to MD-like list:\r\n\r\n```markdown\r\n* project1\r\n  * task1a\r\n  * task1b\r\n* project2\r\n  * task2a\r\n  * task2b\r\n  * task2c\r\n```",
      "jq -r 'to_entries[] | \"* \\(.key)\\n  * \\(.value | join(\"\\n  * \"))\"' input",
      "jq -r 'to_entries[] | \"* \\(.key)\", \"  * \\(.value[])\"'"
    ],
    "utterance": "Format each project as a Markdown list item, with its tasks as indented sub-list items.",
    "expressions": [
      "jq -r '. | to_entries | .[] | .value |= \"  * \"+join(\"\\n  * \") | .key = \"* \"+.key | .key, .value'",
      "jq -r 'to_entries[] | \"* \\(.key)\\n  * \\(.value | join(\"\\n  * \"))\"'",
      "jq -r 'to_entries[] | \"* \\(.key)\", \"  * \\(.value[])\"'"
    ],
    "data": [
      {
        "input": {
          "project1": [
            "task1a",
            "task1b"
          ],
          "project2": [
            "task2a",
            "task2b",
            "task2c"
          ]
        },
        "output": "* project1\n  * task1a\n  * task1b\n* project2\n  * task2a\n  * task2b\n  * task2c"
      }
    ],
    "identifier": 70216698
  },
  {
    "context": [
      "The values which I need from this json is: id, description, project.id, project.description, project.url.",
      "I need to separate them and generate my csv like below.",
      "jq -r '\n  [.id, .description] + (.project[] | [.id, .description, .url])\n  | @csv\n' ",
      "jq -r '\n  .project[] as $p\n  | [.id, .description, $p.id, $p.description, $p.url]\n  | @csv\n' "
    ],
    "utterance": "Extract each object's id and description plus each project sub-object's id, description, and url, outputting one CSV row per project.",
    "expressions": [
      "[.id, .description] + (.project[] | [.id, .description, .url]) | @csv",
      ".project[] as $p | [.id, .description, $p.id, $p.description, $p.url] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "id": 15,
            "description": "package",
            "active": true,
            "name": "linux",
            "project": [
              {
                "id": 1762,
                "description": "This Red Hat Server 7 is built from the Redhat Official",
                "path": "x86_24",
                "url": "some url"
              },
              {
                "id": 1663,
                "description": "This Ubuntu 20.04 is built from the Ubuntu Official",
                "path": "x86_24",
                "url": "some url"
              },
              {
                "id": 1557,
                "description": "This Centos 7 is built from the Centos Official",
                "path": "x86_24",
                "url": "some url"
              }
            ]
          },
          {
            "id": 22,
            "description": "exe",
            "active": true,
            "name": "windows",
            "project": []
          },
          {
            "id": 34,
            "description": "brew",
            "active": true,
            "name": "mac",
            "project": []
          }
        ],
        "output": [
          "15,\"package\",1762,\"This Red Hat Server 7 is built from the Redhat Official\",\"some url\"",
          "15,\"package\",1663,\"This Ubuntu 20.04 is built from the Ubuntu Official\",\"some url\"",
          "15,\"package\",1557,\"This Centos 7 is built from the Centos Official\",\"some url\""
        ]
      }
    ],
    "identifier": 69999734
  },
  {
    "context": [
      "I need to extract some values from \"Devices\", and I need to get one value from the \"CustomAttributes\" array. The big problem is that the position of the data I need isn't fixed within this array, so I have to find the right object based on the name.",
      "The expected output is :\n\n    SerialNumber: \"aaabbbccc\" \n    \n    EnrollmentUserName:\"Donald\"\n     \n    os_vers: \"10.15.7\"",
      "This lists all triplets and a header row formatted as CSV:",
      "jq --raw-output '\n  [ \"SerialNumber\", \"EnrollmentUserName\", \"os_vers\" ], # header\n  ( .Devices[]\n    | [ .SerialNumber, .EnrollmentUserName,\n        (.CustomAttributes[] | select(.Name == \"os_vers\").Value)\n      ]\n  )\n  | @csv\n' input.json"
    ],
    "utterance": "Extract SerialNumber, EnrollmentUserName, and the value of the CustomAttributes object where Name is \"os_vers\" from each device as CSV rows.",
    "expressions": [
      "[ \"SerialNumber\", \"EnrollmentUserName\", \"os_vers\" ],\n( .Devices[]\n  | [ .SerialNumber, .EnrollmentUserName,\n      (.CustomAttributes[] | select(.Name == \"os_vers\").Value)\n    ]\n)\n| @csv"
    ],
    "data": [
      {
        "input": {
          "Devices": [
            {
              "DeviceId": 111,
              "Udid": "a813bf407aa55ed686f3d3ade3e6d3c4",
              "SerialNumber": "aaabbbccc",
              "EnrollmentUserName": "Donald",
              "AssetNumber": "A813BF407AA55ED686F3D3ADE3E6D3C4",
              "CustomAttributes": [
                {
                  "Name": "reinstall",
                  "Value": "false",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "reinstall_keys",
                  "Value": "false",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "msc_version",
                  "Value": "4.1.4.3949",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "reinstall_ssh_log",
                  "Value": "false",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "cert_date",
                  "Value": "20210422",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "model_id",
                  "Value": "iMac14,2",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "cfengine",
                  "Value": "disabled",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "os_vers",
                  "Value": "10.15.7",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "xprotect_vers",
                  "Value": "2149",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "powerpoint",
                  "Value": "true",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                }
              ]
            },
            {
              "DeviceId": 178,
              "Udid": "72893dbe48755ac99641ab2a3b8a5228",
              "SerialNumber": "CCCBBBAAA",
              "EnrollmentUserName": "Mickey",
              "AssetNumber": "",
              "CustomAttributes": [
                {
                  "Name": "MobileAccount",
                  "Value": "false",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "reinstall",
                  "Value": "false",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "reinstall_keys",
                  "Value": "false",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "reinstall_ssh_log",
                  "Value": "false",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "cert_date",
                  "Value": "20210422",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "model_id",
                  "Value": "MacBookPro12,1",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "dep_check",
                  "Value": "checked",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "cfengine",
                  "Value": "disabled",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                },
                {
                  "Name": "os_vers",
                  "Value": "11.5.2",
                  "Source": "Device Sourced",
                  "Application": "AirWatchAgent"
                }
              ]
            }
          ],
          "Page": 0,
          "PageSize": 5,
          "Total": 1831
        },
        "output": [
          "\"SerialNumber\",\"EnrollmentUserName\",\"os_vers\"",
          "\"aaabbbccc\",\"Donald\",\"10.15.7\"",
          "\"CCCBBBAAA\",\"Mickey\",\"11.5.2\""
        ]
      }
    ],
    "identifier": 69988561
  },
  {
    "context": [
      "And I want to change all dependencies with keys starting with \"com.company1\" to \"0.2\".",
      "I would like to get the whole initial JSON with only this value changed. Like so:",
      "setpath(path(.dependencies[]) | select(.[1] | startswith(\"com.company1\")); \"0.2\")",
      "jq '.dependencies |= with_entries(select(.key | startswith(\"com.company1\")).value = \"0.2\")'"
    ],
    "utterance": "Update all dependency values whose keys start with \"com.company1\" to \"0.2\" while leaving the rest of the object unchanged.",
    "expressions": [
      "setpath(path(.dependencies[]) | select(.[1] | startswith(\"com.company1\")); \"0.2\")",
      ".dependencies |= with_entries(select(.key | startswith(\"com.company1\")).value = \"0.2\")"
    ],
    "data": [
      {
        "input": {
          "name": "com.company1.package1",
          "version": "0.2",
          "dependencies": {
            "com.company1.package2": "0.1",
            "com.company2.package1": "2.3"
          }
        },
        "output": {
          "name": "com.company1.package1",
          "version": "0.2",
          "dependencies": {
            "com.company1.package2": "0.2",
            "com.company2.package1": "2.3"
          }
        }
      }
    ],
    "identifier": 70218616
  },
  {
    "context": [
      "You can even use it to unescape a given string using the `--raw-output` option like so:",
      "jq --raw-output '.desc' input.txt",
      "Necklace 18\" long",
      "Necklace 18\" long"
    ],
    "utterance": "Extract the desc field values as unescaped strings from a file containing lines of objects, including those with escaped quotes.",
    "expressions": [
      "jq --raw-output '.desc' input.txt"
    ],
    "data": [
      {
        "input": [
          {
            "sku": "1234",
            "desc": "Necklace 18\\\" long",
            "img": "https://provider.com/12345.jpg",
            "imgView": "A"
          },
          {
            "sku": "1234",
            "desc": "Necklace 18\\\" long",
            "img": "https://provider.com/12346.jpg",
            "imgView": "B"
          }
        ],
        "output": [
          "Necklace 18\" long",
          "Necklace 18\" long"
        ]
      }
    ],
    "identifier": 69984441
  },
  {
    "context": [
      "fromyml=\"$(cat files.yml | grep name | cut -d '\"' -f2 | jq -Rnc '[inputs]')\"",
      "fromcurl=\"$(curl -sX GET \"XXXX\" | jq -c 'map(.name)')\"",
      "diff=\"$(jq -nr --argjson fromyml \"$fromyml\" --argjson fromcurl \"$fromcurl\" '\n  $fromcurl - $fromyml | .[]\n')\"",
      "The Bash variable diff now contains a list of names only present in the curl output ($fromcurl - $fromyml), one per line"
    ],
    "utterance": "List all names in the endpoint data that are not present in the local YAML file.",
    "expressions": [
      "$fromcurl - $fromyml | .[]"
    ],
    "data": [
      {
        "input": {
          "endpoint": [
            {
              "hosts": [
                "server1"
              ],
              "id": "qz9o847b-f07c-49d1-b1fa-e5ed0b2f0519",
              "name": "toto"
            },
            {
              "hosts": [
                "server2"
              ],
              "id": "a6aa847b-f07c-49d1-b1fa-e5ed0b2f0519",
              "name": "tata"
            },
            {
              "hosts": [
                "server3"
              ],
              "id": "a6d9ee7b-f07c-49d1-b1fa-e5ed0b2f0519",
              "name": "titi"
            }
          ],
          "yml_names": [
            "toto",
            "tata"
          ]
        },
        "output": [
          "titi"
        ]
      }
    ],
    "identifier": 70216065
  },
  {
    "context": [
      "But now I want do the same but via variable `currentIssuesArr`",
      "jq '.issues[.issues| length] |= . + $currentIssuesArr' $FILE_REPORT_RESULT >test.json",
      "jq: error: $currentIssuesArr is not defined at <top-level>",
      "You set the shell's `currentIssuesArr` but not `jq`'s. Use:",
      "jq --argjson currentIssuesArr \"$currentIssuesArr\" '...'",
      "jq --argjson currentIssuesArr \"$currentIssuesArr\" '.issues += [ $currentIssuesArr ]'"
    ],
    "utterance": "Append the value held in the shell variable currentIssuesArr as a new item to the issues array in a file, passing the value into jq as a variable.",
    "expressions": [
      "jq --argjson currentIssuesArr \"$currentIssuesArr\" '.issues += [ $currentIssuesArr ]'"
    ],
    "identifier": 69975333
  },
  {
    "context": [
      "When I try and get multiple fields out of a sub-dictionary, it does a cross product. I'm expecting 2 lines back in this example, but I get 4.",
      "I then pass it through this filter:\n.Products[] | { sku: .SKU, desc: .Description, img_url: .Images[].FullUrl, img_angle: .Images[].Angle }",
      "Is this what you are looking for:\n\n```\n.Products[] | {sku: .SKU, desc: .Description} + (\n  .Images[] | {img_url: .FullUrl, img_angle: .Angle}\n)\n```",
      ".Products[] |\n.Images[] as $img |\n{ sku: .SKU, desc: .Description, img_url: $img.FullUrl, img_angle: $img.Angle }"
    ],
    "utterance": "For each product, extract sku and desc, and for each image, include the corresponding img_url and img_angle together in one object without creating a cross product.",
    "expressions": [
      ".Products[] | {sku: .SKU, desc: .Description} + (.Images[] | {img_url: .FullUrl, img_angle: .Angle})",
      ".Products[] | .Images[] as $img | { sku: .SKU, desc: .Description, img_url: $img.FullUrl, img_angle: $img.Angle }"
    ],
    "data": [
      {
        "input": {
          "Products": [
            {
              "SKU": "1234",
              "Description": "Pink Ring",
              "RingSize": 7,
              "Images": [
                {
                  "FullUrl": "https://provider.com/rings/1234_A",
                  "SortOrder": 1,
                  "Angle": "ViewA"
                },
                {
                  "FullUrl": "https://provider.com/rings/1234_B",
                  "SortOrder": 2,
                  "Angle": "ViewB"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "sku": "1234",
            "desc": "Pink Ring",
            "img_url": "https://provider.com/rings/1234_A",
            "img_angle": "ViewA"
          },
          {
            "sku": "1234",
            "desc": "Pink Ring",
            "img_url": "https://provider.com/rings/1234_B",
            "img_angle": "ViewB"
          }
        ]
      }
    ],
    "identifier": 69973010
  },
  {
    "context": [
      "For the cbq command, you can use the --quiet option to disable the startup connection messages and the --pretty=false to disable pretty-print.  Then, to extract just the documents in cbimport json lines format, I used jq.",
      "cbq --quiet --pretty=false -u Administrator -p password --script='select * from `travel-sample`._default._default' | jq --compact-output '.results|.[]|._default' > docs.json"
    ],
    "utterance": "Extract only the document data from the array of 'results' returned by the command, omitting metadata fields like 'requestID', 'metrics', and 'status', and output each as a compact object for line-by-line import.",
    "expressions": [
      ".results|.[]|._default"
    ],
    "data": [
      {
        "input": {
          "requestID": "6ef38b8a-8e70-4c3d-b3b4-b73518a09c62",
          "signature": {
            "*": "*"
          },
          "results": [
            {
              "_default": {
                "id": 123,
                "name": "John Doe"
              }
            }
          ],
          "status": "success",
          "metrics": {
            "elapsedTime": "4.517031ms",
            "executionTime": "4.365976ms",
            "resultCount": 1,
            "resultSize": 24926
          }
        },
        "output": {
          "id": 123,
          "name": "John Doe"
        }
      }
    ],
    "identifier": 70134550
  },
  {
    "context": [
      "I want to convert the following JSON content stored in a file tmp.json ... into a CSV output ...",
      "When I use this jq command, however, ... I get this result: ... How should the jq command be written to get the desired CSV result?",
      "If newlines are the only thing you can handle, maybe you can do a string replacement.",
      "For a jq-only solution, you can use `gsub(\"\\n\"; \"\\\\n\")`. I'd go with something like this:",
      "Using your JSON and invoking this with the -r command line option yields:\n\"field1\",\"field2\"\n\"value1-1\",\"value1-2\\n\"\n\"value2-1\",\"value2-2\\n\"\n"
    ],
    "utterance": "Export an array of objects containing values with embedded newlines to CSV, escaping newline characters as literal \\n in the output values.",
    "expressions": [
      ".results | (first | map(.field)), (.[] | map(.value | gsub(\"\\n\"; \"\\\\n\"))) | @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            [
              {
                "field": "field1",
                "value": "value1-1"
              },
              {
                "field": "field2",
                "value": "value1-2\n"
              }
            ],
            [
              {
                "field": "field1",
                "value": "value2-1"
              },
              {
                "field": "field2",
                "value": "value2-2\n"
              }
            ]
          ]
        },
        "output": [
          "\"field1\",\"field2\"",
          "\"value1-1\",\"value1-2\\n\"",
          "\"value2-1\",\"value2-2\\n\""
        ]
      }
    ],
    "identifier": 70091433
  },
  {
    "context": [
      "How can I change a flat key-value pair (with concatenated key) to a nested group. I want to split a key at the `___` and use the new sub-key as key of the nested object.",
      "Source (Input) file, with flat key-value pair",
      "Target format, as nested object",
      "jq 'to_entries | map(.key |= split(\"___\")) | reduce .[] as $obj({}; setpath($obj.key; $obj.value))'",
      "The `reduce` builds up the object by applying `setpath` with input element's key/value in turn"
    ],
    "utterance": "Convert flat key-value pairs where keys are concatenated with triple underscores into a nested object, splitting each key at every '___'.",
    "expressions": [
      "to_entries | map(.key |= split(\"___\")) | reduce .[] as $obj({}; setpath($obj.key; $obj.value))"
    ],
    "data": [
      {
        "input": {
          "key1___subkey1-2-foo": "Value 1a",
          "key1___subkey1-2-bar": "Value 1b",
          "key2___subkey2-2___subkey2-3": "Value 2, Level 3",
          "key3": "Value 3"
        },
        "output": {
          "key1": {
            "subkey1-2-foo": "Value 1a",
            "subkey1-2-bar": "Value 1b"
          },
          "key2": {
            "subkey2-2": {
              "subkey2-3": "Value 2, Level 3"
            }
          },
          "key3": "Value 3"
        }
      }
    ],
    "identifier": 69972477
  },
  {
    "context": [
      "I want to extract the first \u201cItemTitle\u201d and the first \u201cArtist\u201d and save them as variables.",
      "In this example the result I am looking for would be:\nItemTitle=Sometimes It Hurts\n\nArtist=Voost",
      "But you say you want these values in the KEY=VALUE form.  This can be achieved by modifying the basic query, e.g. as follows:\n.Result|\"ItemTitle=\\(first(.[].ItemTitle))\", \"Artist=\\(first(.[].Artists[]))\""
    ],
    "utterance": "Extract the first item's ItemTitle and the first artist and print them as ItemTitle=... and Artist=... lines.",
    "expressions": [
      ".Result|\"ItemTitle=\\(first(.[].ItemTitle))\", \"Artist=\\(first(.[].Artists[]))\""
    ],
    "data": [
      {
        "input": {
          "Result": [
            {
              "ItemTitle": "Sometimes It Hurts",
              "Artists": [
                "Voost"
              ],
              "MediaEnd": "00:02:15.8490000",
              "Extro": "00:02:12.8200000",
              "MediaId": 9551,
              "ActualLength": "00:02:12.8200000",
              "ItemType": "Song"
            },
            {
              "ItemTitle": "Been a Long Time (Full Intention 2021 Remix)",
              "Artists": [
                "The Fog"
              ],
              "MediaEnd": "00:03:11.3170000",
              "IntroEnd": "00:00:07.4700000",
              "Extro": "00:03:08.6300000",
              "MediaId": 9489,
              "ActualLength": "00:03:08.6300000",
              "ItemType": "Song"
            }
          ],
          "ExceptionMessage": null,
          "FailMessage": null,
          "ExceptionTypeName": null
        },
        "output": [
          "ItemTitle=Sometimes It Hurts",
          "Artist=Voost"
        ]
      }
    ],
    "identifier": 70098897
  },
  {
    "context": [
      "Now I want to extract keys: `\"total\", \"issues\", \"facets.values\"`.",
      "But result is:",
      "The \"**facetsArr**\" must be:",
      "facetsArr  : [ { \"val\": \"CRITICAL\", \"count\": 5818 }, { \"val\": \"MAJOR\", \"count\": 1459 }, { \"val\": \"BLOCKER\", \"count\": 1286 }, { \"val\": \"MINOR\", \"count\": 1163 }, { \"val\": \"INFO\", \"count\": 331 } ]",
      "Applying those fixes, the script will look like:",
      "read -r -d '' totalIssues facetsArr issuesArr <<< \"$( jq -r '\"\\(.total)\\n\\(.facets[].values)\\n\\(.issues[])\"' input)\"",
      "total=$(jq '.total' <<< \"$response\")",
      "issues=$(jq '.issues' <<< \"$response\")",
      "facets=$(jq '.facets[].values' <<< \"$response\")"
    ],
    "utterance": "Extract the values of the top-level fields total and issues, and the array of objects under facets[].values.",
    "expressions": [
      ".total",
      ".issues",
      ".facets[].values"
    ],
    "data": [
      {
        "input": {
          "total": 10057,
          "p": 1,
          "ps": 1,
          "paging": {
            "pageIndex": 1,
            "pageSize": 1,
            "total": 10057
          },
          "effortTotal": 51031,
          "issues": [
            {
              "key": "AX0NVCNfENszTAxEgX5e",
              "rule": "java:S122",
              "severity": "MINOR",
              "component": "my_project:SomeFile.java",
              "project": "my_project",
              "line": 241,
              "hash": "1111111111",
              "textRange": {
                "startLine": 241,
                "endLine": 241,
                "startOffset": 0,
                "endOffset": 46
              },
              "flows": [],
              "status": "OPEN",
              "message": "At most one statement is allowed per line, but 2 statements were found on this line.",
              "effort": "1min",
              "debt": "1min",
              "author": "eugeniur",
              "tags": [
                "convention"
              ],
              "creationDate": "2021-11-11T06:40:05+0200",
              "updateDate": "2021-11-11T06:40:05+0200",
              "type": "CODE_SMELL",
              "scope": "MAIN"
            }
          ],
          "components": [
            {
              "key": "my_project",
              "enabled": true,
              "qualifier": "TRK",
              "name": "Parent",
              "longName": "Parent"
            },
            {
              "key": "my_project:MyFile.java",
              "enabled": true,
              "qualifier": "FIL",
              "name": "XStartDServerComponent.java",
              "longName": "MyFile.java",
              "path": "MyFile.java"
            }
          ],
          "facets": [
            {
              "property": "severities",
              "values": [
                {
                  "val": "CRITICAL",
                  "count": 5818
                },
                {
                  "val": "MAJOR",
                  "count": 1459
                },
                {
                  "val": "BLOCKER",
                  "count": 1286
                },
                {
                  "val": "MINOR",
                  "count": 1163
                },
                {
                  "val": "INFO",
                  "count": 331
                }
              ]
            }
          ]
        },
        "output": [
          10057,
          [
            {
              "key": "AX0NVCNfENszTAxEgX5e",
              "rule": "java:S122",
              "severity": "MINOR",
              "component": "my_project:SomeFile.java",
              "project": "my_project",
              "line": 241,
              "hash": "1111111111",
              "textRange": {
                "startLine": 241,
                "endLine": 241,
                "startOffset": 0,
                "endOffset": 46
              },
              "flows": [],
              "status": "OPEN",
              "message": "At most one statement is allowed per line, but 2 statements were found on this line.",
              "effort": "1min",
              "debt": "1min",
              "author": "eugeniur",
              "tags": [
                "convention"
              ],
              "creationDate": "2021-11-11T06:40:05+0200",
              "updateDate": "2021-11-11T06:40:05+0200",
              "type": "CODE_SMELL",
              "scope": "MAIN"
            }
          ],
          [
            {
              "val": "CRITICAL",
              "count": 5818
            },
            {
              "val": "MAJOR",
              "count": 1459
            },
            {
              "val": "BLOCKER",
              "count": 1286
            },
            {
              "val": "MINOR",
              "count": 1163
            },
            {
              "val": "INFO",
              "count": 331
            }
          ]
        ]
      }
    ],
    "identifier": 69927048
  },
  {
    "context": [
      "Need to find the difference between TradeCloseTime and TradeOpenTime time in dd:hh:mm format for the Exposure column in the following script.",
      "With your JSON sample,\n```\n.trades[]\n| [ .orders[1].placedTime, .orders[0].placedTime]\n| map(fromdateiso8601)\n| .[0] - .[1]\n```",
      "here's a function for converting seconds to \"hh:mm:ss\" format:\n```\ndef hhmmss:\n  def l: tostring | if length < 2 then \"0\\(.)\" else . end;\n  (. % 60) as $ss\n  | ((. / 60) | floor) as $mm\n  | (($mm / 60) | floor) as $hh\n  | ($mm % 60) as $mm\n  | [$hh, $mm, $ss] | map(l) | join(\":\");\n```",
      "You can do it all (extracts, conversions and formatting) with one `jq` call:\n...\n    (\n      (.orders[1].placedTime | fromdate) - (.orders[0].placedTime | fromdate)\n      | (. / 86400 | floor | tostring) + (. % 86400 | strftime(\":%H:%M\"))\n    )",
      "output:\n```csv\nTradeNo,TradeOpenType,TradeCloseType,TradeOpenSource,TradeCloseSource,TradeOpenTime,TradeCloseTime,PNL,Exposure\n0,\"Long\",\"CloseLong\",\"SIGNAL\",\"SIGNAL\",\"2018-12-16 21:34:46\",\"2019-09-17 20:15:00\",-0.549085,\"274:22:40\"\n```"
    ],
    "utterance": "Output the difference between TradeCloseTime and TradeOpenTime in dd:hh:mm format as the Exposure column for each trade.",
    "expressions": [
      ".trades[]\n| [ .orders[1].placedTime, .orders[0].placedTime]\n| map(fromdateiso8601)\n| .[0] - .[1]",
      ".trades[]\n| [\n  .tradeNo,\n  .orders[0].side,\n  .orders[1].side,\n  .orders[0].source,\n  .orders[1].source,\n  (.orders[0].placedTime | fromdate | strftime(\"%Y-%m-%d %H:%M:%S\")),\n  (.orders[1].placedTime | fromdate | strftime(\"%Y-%m-%d %H:%M:%S\")),\n  .profitPercentage * 100,\n  (\n    (.orders[1].placedTime | fromdate) - (.orders[0].placedTime | fromdate)\n    | (. / 86400 | floor | tostring) + (. % 86400 | strftime(\":%H:%M\"))\n  )\n] | @csv"
    ],
    "data": [
      {
        "input": {
          "trades": [
            {
              "tradeNo": 0,
              "profitPercentage": -0.00549085,
              "orders": [
                {
                  "side": "Long",
                  "placedTime": "2018-12-16T21:34:46Z",
                  "source": "SIGNAL"
                },
                {
                  "side": "CloseLong",
                  "placedTime": "2019-09-17T19:15:00Z",
                  "source": "SIGNAL"
                }
              ]
            }
          ]
        },
        "output": [
          "0,\"Long\",\"CloseLong\",\"SIGNAL\",\"SIGNAL\",\"2018-12-16 21:34:46\",\"2019-09-17 20:15:00\",-0.549085,\"274:22:40\""
        ]
      }
    ],
    "identifier": 70092053
  },
  {
    "context": [
      "The field names are actually stored in **.headerData.methodNames** and most of the values are stored in **.lightValueObjects[].data**.",
      "There should be 24 fields returned per device, but only 11 are being shown.",
      "I have not been able to figure out how to merge the named values in .lightValueObjects to the final output.",
      "Here is an example of what I am trying to make the output show, (To keep things simple, I am only showing 1 device)",
      "give this a try:\n```\n.headerData.methodNames as $header\n| .lightValueObjects | map(\n  ( [$header, .data]\n    | transpose\n    | map({(first): last})\n    | add\n  ) + del(.data)\n)\n```",
      "If you want to replace empty strings `\"\"` with `null`, as you did in your approach, replace `last` from my solution with either `(last | select(. != \"\") // null)` or, more explicitly, with  `(last | if . == \"\" then null else . end)`."
    ],
    "utterance": "Transform input where field names are stored in an array and device data is an array of arrays, outputting objects where each device's values are mapped to their field names and merged with their related device metadata; replace empty string values with null.",
    "expressions": [
      ".headerData.methodNames as $header | .lightValueObjects | map(([$header, .data] | transpose | map({(first): last}) | add) + del(.data))",
      ".headerData.methodNames as $header | .lightValueObjects | map(([$header, .data] | transpose | map({(first): (last | select(. != \"\") // null)}) | add) + del(.data))",
      ".headerData.methodNames as $header | .lightValueObjects | map(([$header, .data] | transpose | map({(first): (last | if . == \"\" then null else . end)}) | add) + del(.data))"
    ],
    "data": [
      {
        "input": {
          "headerData": {
            "objectTypeName": "device",
            "methodNames": [
              "name",
              "accessIp",
              "deviceType",
              "version",
              "discoverTime",
              "discoverMethod",
              "status",
              "department",
              "description",
              "perfMonStatus",
              "eventLogStatus",
              "maintenance",
              "location",
              "agentStatus",
              "policyName",
              "policyId",
              "agentType",
              "templateIds",
              "agentId",
              "decommission",
              "accountId",
              "instanceId",
              "agentVersion",
              "parserName"
            ]
          },
          "lightValueObjects": [
            {
              "objectId": 17657,
              "custId": 1,
              "parentId": null,
              "collectorId": null,
              "data": [
                "super",
                "192.168.128.222",
                "leader",
                null,
                1637092568000,
                "LOG",
                1,
                "Super",
                null,
                "",
                "Normal",
                "",
                null,
                "",
                "",
                "",
                null,
                "",
                null,
                false,
                "",
                "",
                null,
                ""
              ],
              "extData": null,
              "naturalId": "lead%2dsuper",
              "aoSys": false
            },
            {
              "objectId": 883252,
              "custId": 1,
              "parentId": null,
              "collectorId": null,
              "data": [
                "fw01",
                "192.168.128.1",
                "fw",
                "ANY",
                1637098725000,
                "LOG",
                1,
                "Super",
                null,
                "",
                "Normal",
                "",
                null,
                "",
                "",
                "",
                null,
                "",
                null,
                false,
                "",
                "",
                null,
                ""
              ],
              "extData": null,
              "naturalId": "fw01",
              "aoSys": false
            }
          ],
          "errCode": 0,
          "errObj": null,
          "dataType": "Device",
          "totalCount": 0
        },
        "output": [
          {
            "name": "super",
            "accessIp": "192.168.128.222",
            "deviceType": "leader",
            "version": null,
            "discoverTime": 1637092568000,
            "discoverMethod": "LOG",
            "status": 1,
            "department": "Super",
            "description": null,
            "perfMonStatus": null,
            "eventLogStatus": "Normal",
            "maintenance": null,
            "location": null,
            "agentStatus": null,
            "policyName": null,
            "policyId": null,
            "agentType": null,
            "templateIds": null,
            "agentId": null,
            "decommission": false,
            "accountId": null,
            "instanceId": null,
            "agentVersion": null,
            "parserName": null,
            "objectId": 17657,
            "custId": 1,
            "parentId": null,
            "collectorId": null,
            "extData": null,
            "naturalId": "lead%2dsuper",
            "aoSys": false
          },
          {
            "name": "fw01",
            "accessIp": "192.168.128.1",
            "deviceType": "fw",
            "version": "ANY",
            "discoverTime": 1637098725000,
            "discoverMethod": "LOG",
            "status": 1,
            "department": "Super",
            "description": null,
            "perfMonStatus": null,
            "eventLogStatus": "Normal",
            "maintenance": null,
            "location": null,
            "agentStatus": null,
            "policyName": null,
            "policyId": null,
            "agentType": null,
            "templateIds": null,
            "agentId": null,
            "decommission": false,
            "accountId": null,
            "instanceId": null,
            "agentVersion": null,
            "parserName": null,
            "objectId": 883252,
            "custId": 1,
            "parentId": null,
            "collectorId": null,
            "extData": null,
            "naturalId": "fw01",
            "aoSys": false
          }
        ]
      }
    ],
    "identifier": 70085640
  },
  {
    "context": [
      "The problem is when getting it with a variable I cannot seem to escape the special characters in the url key. **Nothing is returned**.",
      "curl --location --request GET \"$TRAEFIK_URL\" --header \"$TRAEFIK_AUTH_HEADER\" | jq -r '.serverStatus[\"${NEW_ENV_URL}\"]'",
      "Use the option `--arg` to pass arguments to `jq`.",
      "jq --arg url http://172.18.0.17:3000 -r '.serverStatus[$url]'",
      "One of the preferred ways to pass specific environment variables into jq is using the `--arg` command-line option; in your case:",
      "jq -r --arg url \"${NEW_ENV_URL}\"  '.serverStatus[$url]'"
    ],
    "utterance": "Retrieve the status value from the serverStatus object using a dynamic URL key stored in a shell variable, ensuring special characters are handled correctly.",
    "expressions": [
      "jq --arg url \"$NEW_ENV_URL\" -r '.serverStatus[$url]'",
      "jq -r --arg url \"$NEW_ENV_URL\" '.serverStatus[$url]'"
    ],
    "data": [
      {
        "input": {
          "loadBalancer": {
            "servers": [
              {
                "url": "http://172.18.0.19:3000"
              },
              {
                "url": "http://172.18.0.17:3000"
              },
              {
                "url": "http://172.20.0.3:3000"
              }
            ],
            "healthCheck": {
              "path": "/health",
              "interval": "10s",
              "timeout": "10s",
              "followRedirects": true
            },
            "passHostHeader": true
          },
          "status": "enabled",
          "serverStatus": {
            "http://172.18.0.17:3000": "UP",
            "http://172.18.0.19:3000": "UP",
            "http://172.20.0.3:3000": "DOWN"
          },
          "provider": "docker",
          "type": "loadbalancer"
        },
        "output": "UP"
      }
    ],
    "identifier": 69939211
  },
  {
    "context": [
      "Is there a way with jq to combine file1.json with file2.json so that the output looks like desired.json?",
      "file1.json\n[\n  [\n    \"1\",\n    \"2\"\n  ],\n  [\n    \"a\",\n    \"b\"\n  ]\n]\n",
      "file2.json\n[\n  [\n    \"3\"\n  ],\n  [\n    \"c\"\n  ]\n]\n",
      "desired.json\n[\n  [\n    \"1\",\n    \"2\",\n    \"3\"\n  ],\n  [\n    \"a\",\n    \"b\",\n    \"c\"\n  ]\n]",
      "jq -s '[map(.[0][]),map(.[1][])]'  file1.json file2.json",
      "jq -s 'transpose | map(flatten)'  file*.json",
      "jq -s 'transpose | map(add)' file*.json"
    ],
    "utterance": "Combine two files, each containing an array of arrays, so that for each index the subarrays are merged into a single subarray at the corresponding position.",
    "expressions": [
      "jq -s '[map(.[0][]),map(.[1][])]' file1.json file2.json",
      "jq -s 'transpose | map(flatten)' file*.json",
      "jq -s 'transpose | map(add)' file*.json"
    ],
    "data": [
      {
        "input": [
          [
            [
              "1",
              "2"
            ],
            [
              "a",
              "b"
            ]
          ],
          [
            [
              "3"
            ],
            [
              "c"
            ]
          ]
        ],
        "output": [
          [
            "1",
            "2",
            "3"
          ],
          [
            "a",
            "b",
            "c"
          ]
        ]
      }
    ],
    "identifier": 69935407
  },
  {
    "context": [
      "Looking to parse stream of objects from a json log file and output the total number of times \"id.orig_h\" connects to \"id.resp_h\" based on certain conditions and show the total count.",
      "I believe the conditions part is good\n```\n    jq -r '. | select(.resp_ip_bytes > 0 and .orig_ip_bytes > 0 and .duration > 0 and .orig_bytes > 0 and .resp_bytes >0)'\n```",
      "group_by([.\"id.orig_h\", .\"id.resp_h\"]), \ngetting --> Cannot index number with string \"id.orig_h\"",
      "Desired Output:\n```\n1.1.1.1 -> 2.2.2.2 | XXXX <- # of times\n```",
      "jq --slurp --raw-output '\n  map(select(.resp_ip_bytes > 0 ... your conditions here ...))\n  | group_by([.\"id.orig_h\", .\"id.resp_h\"])\n  | map(length as $count | .[] | .count = $count)\n  | sort_by([-.count, -.resp_ip_bytes]) | first\n  | [.\"id.orig_h\", \"->\", .\"id.resp_h\", \"|\", .count]\n  | join(\" \")\n'",
      "GROUPS_BY(inputs\n          | select(.resp_ip_bytes > 0 and\n                   .orig_ip_bytes > 0 and\n                   .duration > 0 and .orig_bytes > 0 and\n                   .resp_bytes >0);\n          [.\"id.orig_h\", .\"id.resp_h\"] ) \n| (first | \"\\(.\"id.orig_h\") -> \\(.\"id.resp_h\")\" ) +\n  ( .[]  | \" | \\(length)\" )"
    ],
    "utterance": "Show the pair of origin and response hosts that meet specific byte and duration conditions, and the total number of their connections, in the format 'origin -> response | count', prioritizing the pair with the most connections.",
    "expressions": [
      "map(select(.resp_ip_bytes > 0 and .orig_ip_bytes > 0 and .duration > 0 and .orig_bytes > 0 and .resp_bytes >0))\n| group_by([.\"id.orig_h\", .\"id.resp_h\"])\n| map(length as $count | .[] | .count = $count)\n| sort_by([-.count, -.resp_ip_bytes]) | first\n| [.\"id.orig_h\", \"->\", .\"id.resp_h\", \"|\", .count]\n| join(\" \")",
      "GROUPS_BY(inputs\n          | select(.resp_ip_bytes > 0 and\n                   .orig_ip_bytes > 0 and\n                   .duration > 0 and .orig_bytes > 0 and\n                   .resp_bytes >0);\n          [.\"id.orig_h\", .\"id.resp_h\"] ) \n| (first | \"\\(.\"id.orig_h\") -> \\(.\"id.resp_h\")\" ) +\n  ( .[]  | \" | \\(length)\" )"
    ],
    "data": [
      {
        "input": [
          {
            "ts": 1636606.998991,
            "uid": "CgbTrLvhqHAa",
            "id.orig_h": "10.8.21.11",
            "id.orig_p": 54858,
            "id.resp_h": "10.8.21.66",
            "id.resp_p": 5044,
            "proto": "tcp",
            "conn_state": "S0",
            "local_orig": true,
            "local_resp": true,
            "missed_bytes": 0,
            "history": "S",
            "orig_pkts": 1,
            "orig_ip_bytes": 60,
            "resp_pkts": 0,
            "resp_ip_bytes": 0
          },
          {
            "ts": 1636638.028568,
            "uid": "CFNumGx3XYWW7",
            "id.orig_h": "fe80::ba:61:fe3f:80",
            "id.orig_p": 130,
            "id.resp_h": "ff02::1",
            "id.resp_p": 131,
            "proto": "icmp",
            "duration": 3420.447889374,
            "orig_bytes": 2608,
            "resp_bytes": 0,
            "conn_state": "OTH",
            "local_orig": false,
            "local_resp": false,
            "missed_bytes": 0,
            "orig_pkts": 163,
            "orig_ip_bytes": 11736,
            "resp_pkts": 0,
            "resp_ip_bytes": 0
          },
          {
            "ts": 1636526872.598889,
            "uid": "Cq9JTE1OweOW6mi",
            "id.orig_h": "fe::63:88:14f5:b5",
            "id.orig_p": 131,
            "id.resp_h": "ff02::fb",
            "id.resp_p": 130,
            "proto": "icmp",
            "duration": 81086.88094513,
            "orig_bytes": 64000,
            "resp_bytes": 0,
            "conn_state": "OTH",
            "local_orig": false,
            "local_resp": false,
            "missed_bytes": 0,
            "orig_pkts": 4000,
            "orig_ip_bytes": 288000,
            "resp_pkts": 0,
            "resp_ip_bytes": 0
          },
          {
            "ts": 1636604547.798971,
            "uid": "Cs41IjaZTAdF7f",
            "id.orig_h": "fe::63:88:14f5:b5",
            "id.orig_p": 131,
            "id.resp_h": "ff02::1:ff:b5",
            "id.resp_p": 130,
            "proto": "icmp",
            "duration": 3414.3990546265,
            "orig_bytes": 2608,
            "resp_bytes": 0,
            "conn_state": "OTH",
            "local_orig": false,
            "local_resp": false,
            "missed_bytes": 0,
            "orig_pkts": 163,
            "orig_ip_bytes": 11736,
            "resp_pkts": 0,
            "resp_ip_bytes": 0
          }
        ],
        "output": []
      }
    ],
    "identifier": 69931773
  },
  {
    "context": [
      "i can't print only 1 object **{\"id\":123}** with jq",
      "This is the working solution:\n```\njq '.ssh_key | {id}'\n```\nwhich outputs:\n```\n{\n  \"id\": 123\n}\n```"
    ],
    "utterance": "Extract only the id key with its value from the ssh_key object.",
    "expressions": [
      ".ssh_key | {id}"
    ],
    "data": [
      {
        "input": {
          "ssh_key": {
            "id": 123,
            "public_key": "ssh-rsa 1233123333333333333dafseg345345345",
            "name": "MY.PUB.KEY",
            "fingerprint": "94:45:54:22:3f:55:ff:55"
          }
        },
        "output": {
          "id": 123
        }
      }
    ],
    "identifier": 70116658
  },
  {
    "context": [
      "I'd like to transform a \"raw\" json data transforming to other json structure.",
      "My data.json is:",
      "[ { \"id\": \"id1\", \"practitioner\": { \"practitionerKey1\": \"practitionerValue1\", \"practitionerKey2\": \"practitionerValue2\" }, \"name\": \"John\", \"familyName\": \"Smith\" }, { \"id\": \"id2\", \"practitioner\": { \"practitionerKey1\": \"practitionerValue1\", \"practitionerKey2\": \"practitionerValue2\" }, \"patientName\": \"Samuel\", \"patientFamilyName\": \"Schnaider\" } ]",
      "My desired result would be:",
      "[ { \"id\": \"id1\", \"practitioner\": { \"practitionerKey1\": \"practitionerValue1\", \"practitionerKey2\": \"practitionerValue2\" }, \"patient\": { \"name\": \"John\", \"familyName\": \"Smith\" } }, { \"id\": \"id2\", \"practitioner\": { \"practitionerKey1\": \"practitionerValue1\", \"practitionerKey2\": \"practitionerValue2\" }, \"patient\": { \"name\": \"Samuel\", \"familyName\": \"Schnaider\" } } ]",
      "why not simply calling\n\n```sh\njq 'map(\n  .patient = {name: .patientName, familyName: .patientFamilyName}\n  | del(.patientName, .patientFamilyName)\n)' data.json\n```",
      "map(fillin(template))"
    ],
    "utterance": "Transform each object by moving 'patientName' and 'patientFamilyName' (or 'name' and 'familyName') into a nested 'patient' object with 'name' and 'familyName' keys, preserving 'id' and 'practitioner', and removing the original name fields.",
    "expressions": [
      "map(.patient = {name: .patientName, familyName: .patientFamilyName} | del(.patientName, .patientFamilyName))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "id1",
            "practitioner": {
              "practitionerKey1": "practitionerValue1",
              "practitionerKey2": "practitionerValue2"
            },
            "name": "John",
            "familyName": "Smith"
          },
          {
            "id": "id2",
            "practitioner": {
              "practitionerKey1": "practitionerValue1",
              "practitionerKey2": "practitionerValue2"
            },
            "patientName": "Samuel",
            "patientFamilyName": "Schnaider"
          }
        ],
        "output": [
          {
            "id": "id1",
            "practitioner": {
              "practitionerKey1": "practitionerValue1",
              "practitionerKey2": "practitionerValue2"
            },
            "patient": {
              "name": "John",
              "familyName": "Smith"
            }
          },
          {
            "id": "id2",
            "practitioner": {
              "practitionerKey1": "practitionerValue1",
              "practitionerKey2": "practitionerValue2"
            },
            "patient": {
              "name": "Samuel",
              "familyName": "Schnaider"
            }
          }
        ]
      }
    ],
    "identifier": 69924653
  },
  {
    "context": [
      "My code is not replacing the --arg with the value of the argument, but the literal text of the argument name.",
      "jq --arg ad \"192.168.5.5\" -r '.name = \"Addr $ad\"' address.tmpl",
      "This outputs:\n{\n    \"name\": \"Addr $ad\"\n}",
      "jq --arg ad 192.168.5.5 -r '.name = \"Addr \" + $ad' address.tmpl",
      "you can use string interpolation \"Addr \\($ad)\", or concatenation (as above)",
      "jq --arg ad \"192.168.5.5\" -r '.name = \"Addr \\($ad)\"'"
    ],
    "utterance": "Set the value of the field 'name' to 'Addr 192.168.5.5', using a variable provided with --arg.",
    "expressions": [
      ".name = \"Addr \" + $ad",
      ".name = \"Addr \\($ad)\""
    ],
    "data": [
      {
        "input": {
          "name": ""
        },
        "output": {
          "name": "Addr 192.168.5.5"
        }
      }
    ],
    "identifier": 69930540
  },
  {
    "context": [
      "I don't quite figure out how to workaround it using a default `null` object.",
      "What I'm trying to get is this:",
      ".generalPractitioner[0].extension[0].url // null, .generalPractitioner[0].extension[0].valueCodeableConcept.coding[0].system // null, .generalPractitioner[0].extension[0].valueCodeableConcept.coding[0].code // null, .generalPractitioner[0].reference // null,",
      "Any ideas?",
      "As you want to generate the columns by iterating over an array (`.generalPractitioner[]`) while interweaving the output with a constant from a specific iteration step (`.generalPractitioner[0]`) in every fourth column starting with the second, you will have to store that value in a variable (`$system`) to access it from within the iteration.",
      "jq -r '\n  [\n    .generalPractitioner\n    | .[0].extension[0].valueCodeableConcept.coding[0].system as $system\n    | .[range(4)]\n    | (.extension[0] | .url, $system, .valueCodeableConcept.coding[0].code),\n      .reference\n  ]\n  | @csv\n'"
    ],
    "utterance": "Extract up to four generalPractitioner elements, using null for missing elements, and output for each: extension[0].url, extension[0].valueCodeableConcept.coding[0].system from the first element, extension[0].valueCodeableConcept.coding[0].code, and reference, as CSV columns.",
    "expressions": [
      "jq -r '[.generalPractitioner | .[0].extension[0].valueCodeableConcept.coding[0].system as $system | .[range(4)] | (.extension[0] | .url, $system, .valueCodeableConcept.coding[0].code), .reference] | @csv'"
    ],
    "data": [
      {
        "input": {
          "generalPractitioner": [
            {
              "extension": [
                {
                  "url": "http://catsalut.gencat.cat/fhir/StructureDefinition/patient-tipus-relacio",
                  "valueCodeableConcept": {
                    "coding": [
                      {
                        "system": "http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rel-organitzacio",
                        "code": "UPAPASSIG"
                      }
                    ]
                  }
                }
              ],
              "reference": "Organization/132336"
            },
            {
              "extension": [
                {
                  "url": "http://catsalut.gencat.cat/fhir/StructureDefinition/patient-tipus-relacio",
                  "valueCodeableConcept": {
                    "coding": [
                      {
                        "system": "http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rel-organitzacio",
                        "code": "UPAPTERRI"
                      }
                    ]
                  }
                }
              ],
              "reference": "Organization/132346"
            }
          ]
        }
      },
      {
        "input": {
          "generalPractitioner": [
            {
              "extension": [
                {
                  "url": "http://catsalut.gencat.cat/fhir/StructureDefinition/patient-tipus-relacio",
                  "valueCodeableConcept": {
                    "coding": [
                      {
                        "system": "http://catsalut.gencat.cat/fhir/StructureDefinition/tipus-rel-organitzacio",
                        "code": "UPAPASSIG"
                      }
                    ]
                  }
                }
              ],
              "reference": "Organization/132336"
            }
          ]
        }
      }
    ],
    "identifier": 70183182
  },
  {
    "context": [
      "pfName = sh (script: \"jq -r '.component.name' <<< '${stageTwoList}' \")",
      "pfKey = sh (script: \"jq -r '.component.key' <<< '${stageTwoList}' \")",
      "+ jq -r .component.name",
      "+ jq -r .component.key",
      "pfName = sh(script: \"jq -r '.component.name' <<< '${stageTwoList}' \", returnStdout: true)",
      "pfKey = sh(script: \"jq -r '.component.key' <<< '${stageTwoList}' \", returnStdout: true)"
    ],
    "utterance": "Extract the values of the 'name' and 'key' fields inside the 'component' object from the input.",
    "expressions": [
      ".component.name",
      ".component.key"
    ],
    "data": [
      {
        "input": {
          "component": {
            "name": "digital-hot-wallet-gateway",
            "key": "dhwg"
          }
        },
        "output": {
          "name": "digital-hot-wallet-gateway",
          "key": "dhwg"
        }
      }
    ],
    "identifier": 69920097
  },
  {
    "context": [
      "But, I get an error:\n\n    error: data/0 is not defined at <top-level>, line 1:\n        data.attributes.bearerToken\n        jq: 1 compile error",
      "If you are trying to access the \"data\" property of an object, you need to use ... These filters always start with a `.`:\n\n    jq '.data.attributes.bearerToken'"
    ],
    "utterance": "Extract the value of the bearerToken field nested under attributes inside the data object from the response.",
    "expressions": [
      ".data.attributes.bearerToken"
    ],
    "identifier": 69928771
  },
  {
    "context": [
      "I have this data:\r\n\r\n```json\r\n[\r\n  { \"path\": \"x\", \"types\": [\"a\", \"b\"] },\r\n  { \"path\": \"y\", \"types\": [\"c\", \"d\"] }\r\n]\r\n```",
      "And I am looking to obtain this output:\r\n\r\n```json\r\n{ \"path\": \"x\", \"type\": \"a\" }\r\n{ \"path\": \"x\", \"type\": \"b\" }\r\n{ \"path\": \"y\", \"type\": \"c\" }\r\n{ \"path\": \"y\", \"type\": \"d\" }\r\n```",
      "Try \r\n```\r\n.[] | {path, type: .types[]}\r\n```",
      "```json\r\n{\"path\":\"x\",\"type\":\"a\"}\r\n{\"path\":\"x\",\"type\":\"b\"}\r\n{\"path\":\"y\",\"type\":\"c\"}\r\n{\"path\":\"y\",\"type\":\"d\"}\r\n```"
    ],
    "utterance": "For each object in an array, create separate objects combining the object's path with each value in its types array as the type field.",
    "expressions": [
      ".[] | {path, type: .types[]}"
    ],
    "data": [
      {
        "input": [
          {
            "path": "x",
            "types": [
              "a",
              "b"
            ]
          },
          {
            "path": "y",
            "types": [
              "c",
              "d"
            ]
          }
        ],
        "output": [
          {
            "path": "x",
            "type": "a"
          },
          {
            "path": "x",
            "type": "b"
          },
          {
            "path": "y",
            "type": "c"
          },
          {
            "path": "y",
            "type": "d"
          }
        ]
      }
    ],
    "identifier": 70176007
  },
  {
    "identifier": 70042813
  },
  {
    "context": [
      "So you can loop over the array using [] to return the .url and .valueString for each object in side the .extension array:",
      "._birthDate.extension[0] | .url, ( .extension[:2][] | .url, .valueString )",
      "However, since .extension is an array with only 2 indexes, the :2 part doesn't do anything useful in your example, so why not simplify it to:",
      "._birthDate.extension[0] | .url, ( .extension[] | .url, .valueString )",
      "If you only need to keep the strings then you can use .. to recursively traverse your document and strings to filter out non-strings yielded along the way:",
      ".. | strings"
    ],
    "utterance": "Extract all string values located at specific nested paths, including the .url and .valueString fields inside ._birthDate.extension[0] and its child .extension array.",
    "expressions": [
      "._birthDate.extension[0] | .url, (.extension[] | .url, .valueString)",
      "._birthDate.extension[0] | .url, (.extension[:2][] | .url, .valueString)",
      ".. | strings"
    ],
    "data": [
      {
        "input": {
          "_birthDate": {
            "extension": [
              {
                "url": "http://catsalut.gencat.cat/fhir/StructureDefinition/patient-dataBirhtDeath",
                "extension": [
                  {
                    "url": "country",
                    "valueString": "724"
                  },
                  {
                    "url": "state",
                    "valueString": "08"
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "http://catsalut.gencat.cat/fhir/StructureDefinition/patient-dataBirhtDeath",
          "country",
          "724",
          "state",
          "08"
        ]
      }
    ],
    "identifier": 70168107
  },
  {
    "context": [
      "I have an input file which type may vary from array to object, one of the following inputs expected:\r\n\r\n    [{\"version\": \"1.0\"}]\r\n    {version: \"1.0\"}\r\n\r\n How can I construct jq expression for the output to be always converted into array.",
      "You can check the input's `type` directly:\r\n```sh\r\njq 'if type == \"object\" then [.] else . end'\r\n```",
      "Or use the deconstruction alternative operator `?//` (available since [jq 1.6](https://stedolan.github.io/jq/manual/v1.6)):\r\n```sh\r\njq '. as [$v] ?// $v | [$v]'\r\n```",
      "The `arrays` function selects an input if it is an array. Combined with `//` you can handle the case where it isn't:\r\n\r\n```sh\r\n$ jq -c 'arrays // [.]' versions.json \r\n[{\"version\":\"1.0\"}]\r\n[{\"version\":\"2.0\"}]\r\n```"
    ],
    "utterance": "Ensure that the input, if it is an object, is wrapped in an array, and if it is already an array, leave it unchanged.",
    "expressions": [
      "if type == \"object\" then [.] else . end",
      "arrays // [.]"
    ],
    "data": [
      {
        "input": {
          "version": "1.0"
        },
        "output": [
          {
            "version": "1.0"
          }
        ]
      },
      {
        "input": [
          {
            "version": "1.0"
          }
        ],
        "output": [
          {
            "version": "1.0"
          }
        ]
      }
    ],
    "identifier": 70057777
  },
  {
    "context": [
      "My aim is to get the following JSON, by deleting all key1 and key2 items recursively using a jq command:",
      "Or remove what you don't need ([Demo](https://jqplay.org/s/LUusoASVEm)):",
      "jq 'map(del(.key1,.key2))'"
    ],
    "utterance": "Remove the key1 and key2 properties from all objects in an array.",
    "expressions": [
      "map(del(.key1, .key2))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "key1": "val1",
            "key2": "val2",
            "name": "someone",
            "age": 39
          },
          {
            "id": "1234",
            "key1": "val1",
            "key2": "val2",
            "name": "someone",
            "age": 39
          },
          {
            "id": "4567",
            "key1": "val1",
            "key2": "val2",
            "name": "someone",
            "age": 60
          }
        ],
        "output": [
          {
            "id": "1",
            "name": "someone",
            "age": 39
          },
          {
            "id": "1234",
            "name": "someone",
            "age": 39
          },
          {
            "id": "4567",
            "name": "someone",
            "age": 60
          }
        ]
      }
    ],
    "identifier": 70154852
  },
  {
    "context": [
      "What I would like to get is:\r\n\r\n```\r\n\"url1\",\"system1\",\"url2\",\"system2\"\r\n\"url3\",\"system3\",,\r\n```",
      "Flip the table twice using `transpose | transpose` to fill up the slots missing from the unrigged square shape with `null`:\r\n\r\n```sh\r\njq -rs 'map(.extension) | transpose | transpose[] | map(.url, .system) | @csv' \r\n```",
      "A fairly efficient solution: \r\n```\r\ndef pad:\r\n  (map(length)|max) as $mx\r\n  | map( . + [range(length;$mx)|null] );\r\n\r\n[inputs | [.extension[] | (.url, .system)]]\r\n| pad[]\r\n| @csv\r\n```\r\nThis of course should be used with the -n command-line option."
    ],
    "utterance": "Produce rows where each row contains the url and system values for each extension, with rows padded with empty fields so they align across multiple objects with different extension lengths.",
    "expressions": [
      "jq -rs 'map(.extension) | transpose | transpose[] | map(.url, .system) | @csv'",
      "jq -n '[inputs | [.extension[] | (.url, .system)]] | (def pad: (map(length)|max) as $mx | map(. + [range(length;$mx)|null]); pad[]) | @csv'"
    ],
    "data": [
      {
        "input": [
          {
            "extension": [
              {
                "url": "url1",
                "system": "system1"
              },
              {
                "url": "url2",
                "system": "system2"
              }
            ]
          },
          {
            "extension": [
              {
                "url": "url3",
                "system": "system3"
              }
            ]
          }
        ],
        "output": [
          "\"url1\",\"system1\",\"url2\",\"system2\"",
          "\"url3\",\"system3\",,"
        ]
      }
    ],
    "identifier": 70182418
  },
  {
    "context": [
      "done < <(jq -r '.[] | .id, .serverinfos.hostname | @text' $jsonlist)",
      "This seems a behavior of jq with the raw output. each result is in a new line.",
      "Actually, in 1.5 it's already the case that you can use -j to stop newlines being printed, but it does put jq into raw-output mode.",
      "done < <(jq -r '.[] | .id, .serverinfos.hostname | @text' \"$jsonlist\")"
    ],
    "utterance": "Output each object's id and serverinfos.hostname as plain text values from a file containing an array of objects.",
    "expressions": [
      ".[] | .id, .serverinfos.hostname | @text"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "childofid": null,
            "parentofids": [
              null
            ],
            "infosupdatedat": "2021-11-27",
            "serverinfos": {
              "hostname": "flowmox",
              "description": "Proxmox - Host for vm's and more",
              "status": "ready",
              "servertype": "physisch",
              "category": "vm-host",
              "productname": "ProLiant DL380 G7",
              "Model": "589150-421",
              "Serialnumber": "",
              "managementtype": "ILO3"
            }
          }
        ],
        "output": [
          "1",
          "flowmox"
        ]
      }
    ],
    "identifier": 70145572
  },
  {
    "context": [
      "I want to convert the following JSON content stored in a file tmp.json ... into CSV output:",
      "\"field1\",\"field2\"\n\"value1-1\",\"value1-2\"\n\"value2-1\",\"value2-2\"\n\"value3-1\",\"value3-2\"",
      "The closest jq expression I've come up with is this:\ncat ./tmp.json | jq -r '.results | [ .[] | del(last) ] | (first | map(.field)), (.[] | map(.value)) | @csv'",
      "It works for jq version 1.6, but for version 1.5, the last \"column\" is still included in the CSV result. How do I edit the jq code so that it works for version 1.5?",
      "Note that the number of columns is not limited to 3; it can be more. The jq code should be able to remove the last column in the final CSV result.",
      "You can use the [slice operator][1] to extract the sub-elements of the array inside each field and put into an array and use the `@csv`",
      "[ .results[][:-1] ] | (first | map(.field)), (.[] | map(.value)) | @csv",
      "The part `.results[][:-1]` extracts all the elements except the last one in the array."
    ],
    "utterance": "Remove the last element from each array in the 'results' array, then output a CSV where the first row contains the 'field' values and subsequent rows contain the corresponding 'value' values.",
    "expressions": [
      ".results | [ .[][:-1] ] | (first | map(.field)), (.[] | map(.value)) | @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            [
              {
                "field": "field1",
                "value": "value1-1"
              },
              {
                "field": "field2",
                "value": "value1-2"
              },
              {
                "field": "field3",
                "value": "value1-3"
              }
            ],
            [
              {
                "field": "field1",
                "value": "value2-1"
              },
              {
                "field": "field2",
                "value": "value2-2"
              },
              {
                "field": "field3",
                "value": "value2-3"
              }
            ],
            [
              {
                "field": "field1",
                "value": "value3-1"
              },
              {
                "field": "field2",
                "value": "value3-2"
              },
              {
                "field": "field3",
                "value": "value3-3"
              }
            ]
          ]
        },
        "output": "\"field1\",\"field2\"\n\"value1-1\",\"value1-2\"\n\"value2-1\",\"value2-2\"\n\"value3-1\",\"value3-2\""
      }
    ],
    "identifier": 70150515
  },
  {
    "context": [
      "I want to create a two new keys assigneeId and assigneeName.  Where the assigneeName is the firstName and lastName combined.  The original nested assignee key can be discarded.",
      "from the epics key I would like to create and epicsID key with a value of id from epics.  The rest of the keys in the nested key can be discarded.",
      "I would like to create following output.",
      "[ { \"id\": 1111111111, \"assigneeId\": 1234, \"assingeeName\": \"John Doe\", \"epicsid\": 111, \"location\": \"Nerdville\" } ]",
      "the following produces the required result:\nmap( {id,\n      assigneeId: .assignee.id,\n      assigneeName: (.assignee | .firstName + \" \" + .lastName),\n      epicsid: .epics[0].id,\n      location } )"
    ],
    "utterance": "For each object, extract assignee.id as assigneeId, combine assignee.firstName and assignee.lastName as assigneeName, set epicsid to the id of the first item in epics, retain id and location, and remove the nested assignee and epics keys.",
    "expressions": [
      "map({id, assigneeId: .assignee.id, assigneeName: (.assignee.firstName + \" \" + .assignee.lastName), epicsid: .epics[0].id, location})"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1111111111,
            "assignee": {
              "id": 1234,
              "firstName": "John",
              "lastName": "Doe",
              "email": "Doe@doe.com"
            },
            "epics": [
              {
                "id": 111,
                "title": "Big Code Issues",
                "version": 16
              }
            ],
            "location": "Nerdville"
          }
        ],
        "output": [
          {
            "id": 1111111111,
            "assigneeId": 1234,
            "assigneeName": "John Doe",
            "epicsid": 111,
            "location": "Nerdville"
          }
        ]
      }
    ],
    "identifier": 69937562
  },
  {
    "context": [
      "Each key of a JSON should be combined with `_` (or any valid JSON symbol). To have a simple key-value list.",
      "I have the following structure. A few JSON groups (no arrays), inside the groups there are key-value pairs. I need to flat them to a single key-value-list.",
      "So it should be `\"key_subkey_subsubkey\": \"value\"`",
      "and I want to have",
      "{\r\n    \"welcome_title\" : \"Hello World\",\r\n\t\"block1_header\": \"My Header\",\r\n\t\"block1_body\": \"My BODY of block 1\",\r\n\t\"block1_footer\": \"My Footer\",\r\n\t\"multi_level-01-A_head\": \"Head Section\",\r\n\t\"multi_level-01-A_foot\": \"Foot Section\",\r\n\t\t\r\n\t\"multi_level-01-A_level-02-A_head\": \"Head Section Level 1 A\",\r\n\t\"multi_level-01-A_level-02-A_fead\": \"Foot Section Level 1 A\",\r\n\t\"multi_level-01-A_level-02-B_head\": \"Head Section Level 1 B\",\r\n\t\"multi_level-01-A_level-02-B_fead\": \"Foot Section Level 1 B\",\r\n\t\"multi_level-01-B_head\": \"Head Section\",\r\n\t\"multi_level-01-B_foot\": \"Foot Section\",\r\n\t\"multi_no-level\" : \"Foo Bar\"\r\n}",
      "[ paths(scalars) as $p | { \"key\": $p | join(\"_\"), \"value\": getpath($p) } ] | from_entries",
      "Will generate",
      "{\r\n  \"welcome_title\": \"Hello World\",\r\n  \"block1_header\": \"My Header\",\r\n  \"block1_body\": \"My BODY of block 1\",\r\n  \"block1_footer\": \"My Footer\",\r\n  \"multi_level-01-A_head\": \"Head Section\",\r\n  \"multi_level-01-A_foot\": \"Foot Section\",\r\n  \"multi_level-01-A_level-02-A_head\": \"Head Section Level 2 A\",\r\n  \"multi_level-01-A_level-02-A_fead\": \"Foot Section Level 2 A\",\r\n  \"multi_level-01-A_level-02-B_head\": \"Head Section Level 2 B\",\r\n  \"multi_level-01-A_level-02-B_fead\": \"Foot Section Level 2 B\",\r\n  \"multi_level-01-B_head\": \"Head Section\",\r\n  \"multi_level-01-B_foot\": \"Foot Section\",\r\n  \"multi_no-level\": \"Foo Bar\"\r\n}"
    ],
    "utterance": "Flatten a nested structure into a single-level key-value mapping where keys are the nested path joined with underscores.",
    "expressions": [
      "[ paths(scalars) as $p | { \"key\": $p | join(\"_\"), \"value\": getpath($p) } ] | from_entries"
    ],
    "data": [
      {
        "input": {
          "welcome": {
            "title": "Hello World"
          },
          "block1": {
            "header": "My Header",
            "body": "My BODY of block 1",
            "footer": "My Footer"
          },
          "multi": {
            "level-01-A": {
              "head": "Head Section",
              "foot": "Foot Section",
              "level-02-A": {
                "head": "Head Section Level 2 A",
                "fead": "Foot Section Level 2 A"
              },
              "level-02-B": {
                "head": "Head Section Level 2 B",
                "fead": "Foot Section Level 2 B"
              }
            },
            "level-01-B": {
              "head": "Head Section",
              "foot": "Foot Section"
            },
            "no-level": "Foo Bar"
          }
        },
        "output": {
          "welcome_title": "Hello World",
          "block1_header": "My Header",
          "block1_body": "My BODY of block 1",
          "block1_footer": "My Footer",
          "multi_level-01-A_head": "Head Section",
          "multi_level-01-A_foot": "Foot Section",
          "multi_level-01-A_level-02-A_head": "Head Section Level 2 A",
          "multi_level-01-A_level-02-A_fead": "Foot Section Level 2 A",
          "multi_level-01-A_level-02-B_head": "Head Section Level 2 B",
          "multi_level-01-A_level-02-B_fead": "Foot Section Level 2 B",
          "multi_level-01-B_head": "Head Section",
          "multi_level-01-B_foot": "Foot Section",
          "multi_no-level": "Foo Bar"
        }
      }
    ],
    "identifier": 69942402
  },
  {
    "context": [
      "I am trying to get an array of all possible paths in a JSON Document.",
      "Given the document:\r\n\r\n    {\r\n      &quot;a&quot;: &quot;bar&quot;,\r\n      &quot;b&quot;: [\r\n       {&quot;c&quot;: 3}, {&quot;d&quot;: 6},\r\n       {&quot;c&quot;: 7}, {&quot;d&quot;: 5}\r\n      ]\r\n    }",
      "I&#39;d like the output to be:\r\n  [&quot;&quot;,&quot;a&quot;,&quot;b&quot;,&quot;b/0&quot;,&quot;b/0/c&quot;,&quot;b/1&quot;,&quot;b/1/d&quot;,&quot;b/2&quot;,&quot;b/2/c&quot;,&quot;b/3&quot;,&quot;b/3/d&quot;]",
      "Try \r\n```sh\r\njq &#39;[&quot;&quot;, (paths | join(&quot;/&quot;))]&#39;\r\n```"
    ],
    "utterance": "List all possible paths in the input, represented as slash-separated strings, and collect them into a single array including the root path as an empty string.",
    "expressions": [
      "[\"\", (paths | join(\"/\"))]"
    ],
    "data": [
      {
        "input": {
          "a": "bar",
          "b": [
            {
              "c": 3
            },
            {
              "d": 6
            },
            {
              "c": 7
            },
            {
              "d": 5
            }
          ]
        },
        "output": [
          "",
          "a",
          "b",
          "b/0",
          "b/0/c",
          "b/1",
          "b/1/d",
          "b/2",
          "b/2/c",
          "b/3",
          "b/3/d"
        ]
      }
    ],
    "identifier": 70039341
  },
  {
    "context": [
      "This is how I am grabbing all the NVME volumes:\r\n\r\n    all_nvme_volumes=$(sudo nvme list -o json | jq .Devices[].DevicePath)",
      "How do I loop thru them process them individually?",
      "mapfile -d '' all_nvme_volumes < <(\n  sudo nvme list --output-format=json |\n  jq --join-output '.Devices[].DevicePath + \"\\u0000\"'\n)",
      "sudo nvme list -o json | jq -r '[ .Devices[].DevicePath ] | @tsv'",
      "sudo nvme list -o json | jq -j '.Devices[].DevicePath + \"\\u0000\"'"
    ],
    "utterance": "Extract all values of DevicePath from the Devices array as separate elements to populate a bash array or loop through each value individually.",
    "expressions": [
      ".Devices[].DevicePath",
      "-j '.Devices[].DevicePath + \"\\u0000\"'",
      "-r '[ .Devices[].DevicePath ] | @tsv'"
    ],
    "identifier": 70220217
  },
  {
    "context": [
      "I want to check the values for each key, if they have a \"$\" character in them, replace them with their respective environment variable(which is already present in the shell) so that my JSON template is rendered with the correct environment variables.",
      "Then you can go with:\n```sh\njq -n 'with_entries((.value | select(startswith(\"$\"))) |= env[.[1:]])'\n```",
      "Here is a method that replaces all variables in the file regardless of their nesting level. It keeps the values as they are if they are not defined in the environment.",
      "$ cat test.json | NAME=Joe jq 'walk( if type == \"string\" and test(\"^\\$[A-Z_-]+$\") then . |= env[.[1:]] // . else . end )'"
    ],
    "utterance": "Replace values that start with '$' with the corresponding environment variable, at any nesting level, leaving unchanged if the variable is not set.",
    "expressions": [
      "with_entries((.value | select(startswith(\"$\"))) |= env[.[1:]])",
      "walk( if type == \"string\" and test(\"^\\$[A-Z_-]+$\") then . |= env[.[1:]] // . else . end )"
    ],
    "data": [
      {
        "input": {
          "host1": "$PROJECT1",
          "host2": "$PROJECT2",
          "host3": "xyz",
          "host4": "$PROJECT4"
        },
        "output": {
          "host1": "randomtext1",
          "host2": "randomtext2",
          "host3": "xyz",
          "host4": "randomtext3"
        }
      },
      {
        "input": {
          "name": "$NAME",
          "address": [
            {
              "street": "$STREET",
              "other": "$not_matching"
            }
          ]
        },
        "output": {
          "name": "Joe",
          "address": [
            {
              "street": "$STREET",
              "other": "$not_matching"
            }
          ]
        }
      }
    ],
    "identifier": 70217481
  }
]