[
  {
    "context": [
      "but i need it to be like this :",
      "| version | GPU_driver | miner    | gpu  |  rigname  |",
      "| ------- | ---------- | -------- | ---- |-----------|",
      "| 1.2.3   | nvidia     | ethminer | 2/2  |  0d6b27   |",
      "| 1.2.4   | amdgpu     | ethminer | 1/1  |  50dc35   |"
    ],
    "utterance": "Print each rig's version, driver, miner, GPU summary, and the rig's name as columns in a table.",
    "expressions": [
      "to_entries[] | [.value.version, .value.driver, .value.miner, \"\\(.value.gpus)/\\(.value.miner_instance)\", .key] | @csv"
    ],
    "identifier": 46430810
  },
  {
    "context": [
      "But how to select several `id`'s, i.e. the items with `id in (1,2)`?",
      "Try this:",
      ".[] | select(.id == \"3\" or .id == \"2\") | .name,.value"
    ],
    "utterance": "Select the name and value of all items where the id is either \"1\" or \"2\".",
    "expressions": [
      ".[] | select(.id == \"1\" or .id == \"2\") | .name,.value"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "name": "sausage",
            "value": 100
          },
          {
            "id": "2",
            "name": "spam",
            "value": 200
          },
          {
            "id": "3",
            "name": "eggs",
            "value": 300
          }
        ],
        "output": [
          "sausage",
          100,
          "spam",
          200
        ]
      }
    ],
    "identifier": 46530167
  },
  {
    "context": [
      "How can I extract all key names, even in nested objects with jq?",
      "I want to get list:\na, b, b.c",
      "jq -r '[paths | join(\".\")]'  jsonfile",
      "paths function outputs the paths to all the elements in its input",
      "join(\".\") - to concatenate keys within hierarchical paths",
      "jq '[\npaths |\nmap(select(type!=\"number\")) |\nselect(length > 0) |\njoin(\".\")\n] | unique' foo.json",
      "outputs\n[\n  \"a\",\n  \"b\",\n  \"b.c\"\n]"
    ],
    "utterance": "List all key names, including nested keys, as dot-separated paths.",
    "expressions": [
      "[paths | join(\".\")]",
      "[paths | map(select(type != \"number\")) | select(length > 0) | join(\".\")] | unique"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": {
            "c": 2
          }
        },
        "output": [
          "a",
          "b",
          "b.c"
        ]
      },
      {
        "input": {
          "a": 1,
          "b": [
            {
              "c": 2
            }
          ]
        },
        "output": [
          "a",
          "b",
          "b.c"
        ]
      }
    ],
    "identifier": 46564720
  },
  {
    "context": [
      "What I would like is to get the values as strings (with the trailing zeros) i.e. \"34.284606710\" and \"12.543774500\"",
      "Here is a solution using a `pad` function:",
      "def pad(n):\"\\(.)\"|(split(\".\"))+[\"0\"])[:2]|.[1]|=(.+\"0\"*n)[:n]| join(\".\");\n\"\\(.lat|pad(9)) \\(.lon|pad(9))\"",
      "With your sample data in `data.json` and the above filter in `filter.jq` the command\n\n    $ jq -r -f filter.jq data.json \n\nproduces\n\n    34.284606710 -12.543774500"
    ],
    "utterance": "Return latitude and longitude as strings with precisely nine digits after the decimal point, preserving all trailing zeros.",
    "expressions": [
      "def pad(n): \"\\(.)\" | (split(\".\")+[\"0\"])[:2] | .[1] |= (.+ \"0\"*n)[:n] | join(\".\"); \"\\(.lat|pad(9)) \\(.lon|pad(9))\""
    ],
    "data": [
      {
        "input": {
          "lat": 34.28460671,
          "lon": -12.5437745
        },
        "output": "34.284606710 -12.543774500"
      }
    ],
    "identifier": 46580748
  },
  {
    "context": [
      "I want to use jq to move a nested key:value pair up one level. So given a geojson array of objects like this: ... I want to return the exact same object, but with `\"group\":\"car\"` in the `features` object.",
      "jq '.features[0].properties.group = .features[0].properties.activities[0].group\n | del(.features[0].properties.activities[0].group)' input.json",
      ".features[0].properties |= (.group = .activities[0].group)\n| del(.features[0].properties.activities[0].group)",
      ".features[0].properties |=\n  ((.group = .activities[0].group) | del(.activities[0].group))",
      "def update_activity:\n   if .activities|length<1 then .\n   else \n        .group = .activities[0].group\n      | del(.activities[0].group)\n   end\n;\n\n.features[].properties |= update_activity",
      "def up(apath):\n  def trim:\n    if .[-1] | type == \"number\" then .[0:-2] | trim\n    else .\n    end;\n\n. as $in\n| (null | path(apath)) as $p\n| ($p|last) as $last\n| $in\n| getpath($p) as $v\n| setpath(($p[0:-1]|trim) + [$last]; $v)\n| del(apath)\n;\n\nup( .features[0].properties.activities[0].group )"
    ],
    "utterance": "Move the group key and value from the first activities object up to the properties object of each feature and remove it from activities.",
    "expressions": [
      ".features[0].properties.group = .features[0].properties.activities[0].group | del(.features[0].properties.activities[0].group)",
      ".features[0].properties |= (.group = .activities[0].group) | del(.features[0].properties.activities[0].group)",
      ".features[0].properties |= ((.group = .activities[0].group) | del(.activities[0].group))",
      "def update_activity: if .activities|length<1 then . else .group = .activities[0].group | del(.activities[0].group) end; .features[].properties |= update_activity",
      "def up(apath): def trim: if .[-1] | type == \"number\" then .[0:-2] | trim else . end; . as $in | (null | path(apath)) as $p | ($p|last) as $last | $in | getpath($p) as $v | setpath(($p[0:-1]|trim) + [$last]; $v) | del(apath); up( .features[0].properties.activities[0].group )"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiLineString",
                "coordinates": [
                  [
                    [
                      -74,
                      40
                    ],
                    [
                      -73,
                      40
                    ]
                  ]
                ]
              },
              "properties": {
                "startTime": "20160123T162547-0500",
                "endTime": "20160123T164227-0500",
                "activities": [
                  {
                    "activity": "car",
                    "group": "car"
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "MultiLineString",
                "coordinates": [
                  [
                    [
                      -74,
                      40
                    ],
                    [
                      -73,
                      40
                    ]
                  ]
                ]
              },
              "properties": {
                "startTime": "20160123T162547-0500",
                "endTime": "20160123T164227-0500",
                "activities": [
                  {
                    "activity": "car"
                  }
                ],
                "group": "car"
              }
            }
          ]
        }
      }
    ],
    "identifier": 46497058
  },
  {
    "context": [
      "I want to modify this JSON to add a nested key/value as following:\r\n\r\n    {\r\n\t\"service\": [{\r\n\t\t\t\"name\": \"web\",\r\n\t\t\t\"tags\": [\r\n\t\t\t\t\"contact_points\"\r\n\t\t\t],\r\n\t\t\t\"check\": {\r\n\t\t\t\t\"script\": \"tmp/status_check.py > /dev/null 2>&1\",\r\n\t\t\t\t\"interval\": \"10s\"\r\n\t\t\t}\r\n\t\t},\r\n\t\t{\r\n\t\t\t\"name\": \"tomcat\",\r\n\t\t\t\"tags\": [\r\n\t\t\t\t\"contact_points\"\r\n\t\t\t],\r\n\t\t\t\"check\": {\r\n\t\t\t\t\"script\": \"tmp/status_check.py > /dev/null 2>&1\",\r\n\t\t\t\t\"interval\": \"10s\"\r\n\t\t\t}\r\n\t\t}\r\n\t]\r\n}",
      "def as_array:if type==\"object\" then [.] else . end;\r\n\r\n    .service |= as_array + [\r\n       {\r\n         \"name\": \"tomcat\",\r\n         \"tags\": [\r\n           \"contact_points\"\r\n         ],\r\n         \"check\": {\r\n            \"script\": \"tmp/status_check.py > /dev/null 2>&1\",\r\n            \"interval\": \"10s\"\r\n         }\r\n       }\r\n    ]",
      ".service |= [., .name = \"tomcat\"]"
    ],
    "utterance": "Convert the 'service' object into an array containing the original entry and an additional entry with the same structure except 'name' is set to 'tomcat'.",
    "expressions": [
      "def as_array: if type==\"object\" then [.] else . end; .service |= as_array + [{\"name\": \"tomcat\", \"tags\": [\"contact_points\"], \"check\": {\"script\": \"tmp/status_check.py > /dev/null 2>&1\", \"interval\": \"10s\"}}]",
      ".service |= [., .name = \"tomcat\"]"
    ],
    "data": [
      {
        "input": {
          "service": {
            "name": "web",
            "tags": [
              "contact_points"
            ],
            "check": {
              "script": "tmp/status_check.py > /dev/null 2>&1",
              "interval": "10s"
            }
          }
        },
        "output": {
          "service": [
            {
              "name": "web",
              "tags": [
                "contact_points"
              ],
              "check": {
                "script": "tmp/status_check.py > /dev/null 2>&1",
                "interval": "10s"
              }
            },
            {
              "name": "tomcat",
              "tags": [
                "contact_points"
              ],
              "check": {
                "script": "tmp/status_check.py > /dev/null 2>&1",
                "interval": "10s"
              }
            }
          ]
        }
      }
    ],
    "identifier": 46576926
  },
  {
    "context": [
      "Not sure what needs to be done to enable proper json highlighting.",
      "this is an idiosyncrasy of jq Windows implementation, forcing the color output with -C option, as hinted by several commenters above, resolved the issue for me:"
    ],
    "utterance": "Display colored output when formatting command-line results in the Windows terminal.",
    "expressions": [
      "jq -C"
    ],
    "identifier": 46626756
  },
  {
    "context": [
      "how to extract .title and \"value\" of  .eye.four.watcher1[].name==\"cat\" for blocks having \"group\": \"A\"?",
      "$ jq '. | select(.group==\"A\") |  .title +\" \"+.eye.four.watcher1[].name' test.json",
      "but how to print only the titte and value of the \"cat\" of the blocks with \"group\": \"A\",?",
      "jq -r '.[] | select(.group==\"A\") | .title +\" \"+ (.eye.four.watcher1[] | select(.name==\"cat\")).value' test.json",
      "select(.group == \"A\")\n   | .title as $t\n   | .eye.four.watcher1[]\n   | select(.name == \"cat\")\n   | \"\\($t) \\(.value)\"",
      "produces\n\n    ProfileXXX bbbb"
    ],
    "utterance": "Return the title and value for entries with group equal to A where any watcher1 has name equal to cat.",
    "expressions": [
      ".[] | select(.group==\"A\") | .title +\" \"+ (.eye.four.watcher1[] | select(.name==\"cat\")).value",
      "select(.group == \"A\") | .title as $t | .eye.four.watcher1[] | select(.name == \"cat\") | \"\u007f$t) \u007f(.value)\""
    ],
    "data": [
      {
        "input": {
          "title": "ProfileXXX",
          "pagelen": 10,
          "group": "A",
          "size": 1,
          "eye": {
            "one": "git",
            "two": false,
            "three": "...",
            "four": {
              "watcher1": [
                {
                  "name": "dog",
                  "value": "aaaa"
                },
                {
                  "name": "cat",
                  "value": "bbbb"
                },
                {
                  "name": "mouse",
                  "value": "cccc"
                }
              ],
              "watcher2": {
                "type": "B",
                "href": "2..."
              },
              "watcher3": {
                "type": "C",
                "href": "3..."
              },
              "values": [
                {
                  "five": "git",
                  "six": false,
                  "seven": "...",
                  "eight": {
                    "watchers": {
                      "href": "..."
                    },
                    "forks": {
                      "href": "..."
                    },
                    "clone": [
                      {
                        "href": "...",
                        "name": "https"
                      },
                      {
                        "href": "...",
                        "name": "ssh"
                      }
                    ],
                    "pullrequests": {
                      "href": "..."
                    }
                  },
                  "fourteen": false,
                  "fiveteen": {
                    "username": "...",
                    "display_name": "...",
                    "uuid": "...",
                    "links": {
                      "self": {
                        "href": "..."
                      },
                      "html": {
                        "href": "..."
                      },
                      "avatar": {
                        "href": "..."
                      }
                    }
                  },
                  "updated_on": "...",
                  "size": 2328936,
                  "is_private": true,
                  "uuid": "..."
                }
              ]
            }
          }
        },
        "output": "ProfileXXX bbbb"
      }
    ],
    "identifier": 46429896
  },
  {
    "context": [
      "I have a query:\r\n\r\n    .modules[].resources | select (.[]!=null)\r\n\r\nand after it I have got:\r\n\r\n    { somestuff } { somestuff } { somestuff }\r\n\r\nwhen I add legth after all:\r\n\r\n    .modules[].resources | select (.[]!=null) | length\r\n\r\nI have got:\r\n\r\n    1 1 1\r\n\r\nbut I need to count elements, so I need 3 in an output. How can I implement it ?",
      "You can put the results of the query into a list and get the length of this list:\r\n\r\n    [ .modules[].resources | select (.[]!=null) ] | length",
      "What you may want instead is\r\n\r\n       .modules[].resources \r\n     | map(select(.!=null))",
      "to get the length, just add length:\r\n\r\n      .modules[].resources\r\n    | map(select(.!=null))\r\n    | length",
      "Because `map(f)` is defined as `[ .[] | f ]` the above filter is really\r\n\r\n      .modules[].resources\r\n    | [\r\n          .[]\r\n        | select(.!=null)\r\n      ]\r\n    | length",
      "Note also that jq provides a built-in [values](https://stedolan.github.io/jq/manual/#arrays,objects,iterables,booleans,numbers,normals,finites,strings,nulls,values,scalars) filter which is defined as `select(.!=null)` so this example could be further simplified to just\r\n\r\n      .modules[].resources\r\n    | map(values)\r\n    | length",
      "With this definition, you should be able simply to wrap `count(...)` around your query since it produces a stream:\r\n\r\n    count(.modules[].resources | select (.[]!=null))",
      "Or maybe you want something closer to:\r\n\r\n    count(.modules[].resources | objects)"
    ],
    "utterance": "Count the number of non-null resources inside all modules.",
    "expressions": [
      "[ .modules[].resources | select (.[]!=null) ] | length",
      ".modules[].resources | map(select(.!=null)) | length",
      ".modules[].resources | [ .[] | select(.!=null) ] | length",
      ".modules[].resources | map(values) | length",
      "count(.modules[].resources | select (.[]!=null))",
      "count(.modules[].resources | objects)"
    ],
    "data": [
      {
        "input": {
          "modules": [
            {
              "resources": [
                {
                  "type": "openstack_compute_instance_v2",
                  "primary": {
                    "id": "5edfe2bf-94df-49d5-8118-3e91fb52946b",
                    "attributes": {
                      "name": "jumpbox"
                    }
                  }
                },
                {
                  "type": "openstack_compute_floatingip_associate_v2",
                  "primary": {
                    "attributes": {
                      "instance_id": "5edfe2bf-94df-49d5-8118-3e91fb52946b",
                      "floating_ip": "10.120.241.21"
                    }
                  }
                }
              ]
            }
          ]
        },
        "output": 2
      }
    ],
    "identifier": 46460631
  },
  {
    "context": [
      "Assuming you put your mapping into `procedures.json` and you change your filter a bit as so:\n\n      procedure: $procedures[0][.Procedure],",
      "then you can use --slurpfile:\n\n    $ jq --slurpfile procedures procedures.json -f jq-filter.jq temp.json"
    ],
    "utterance": "Replace the Procedure field in each object with a mapped value from an external file containing procedure mappings.",
    "expressions": [
      "$ jq --slurpfile procedures procedures.json -f jq-filter.jq temp.json"
    ],
    "data": [
      {
        "input": [
          {
            "Nmarch\u00e9": "2013-90006",
            "SIRETMandataire": null,
            "LibelleEntiteMandataire": "R\u00e9gion Bretagne",
            "SIRETAcheteur": null,
            "LibelleAcheteur": null,
            "Nature": null,
            "Objet": "PBF Formation qualifiante 2013 Monteur en construction bois lot 4",
            "CodeCPV": null,
            "Type ": "Services",
            "Procedure": "MAPA - art 30 - au dessus des seuils",
            "CodePostalCommuneExecution": 35000.0,
            "NomCommuneExecution": "Rennes",
            "CodeINSEEExecution": null,
            "GranulariteINSEEExecution": null,
            "MillesimeMandatement": 2013,
            "DateNotification": "2013-10-01",
            "Montant mandate TTC": 245526,
            "Montant mandate HT": null,
            "Montant attribue TTC": 245526,
            "Montant attribue HT": null,
            "Date de cloture": null,
            "Duree": null,
            "SIRETContractant": 300599123,
            "DenominationSociale": "AFPA DIRECTION REGIONALE BRETAGNE",
            "Role": "Titulaire",
            "CodePostal": 35208,
            "Dpt ID ": 35,
            "D\u00e9partement": "Ille-et-Vilaine",
            "Commune": "RENNES",
            "Taille": "10 000 et plus",
            "Taille des entreprises par categorie officielle": "Grande entreprise",
            "Code NAF": 8559,
            "Libelle NAF": "ENSEIGNEMENT",
            "Libelle SBA": "Administration publique/enseignement",
            "Libelle CCI": "Tertiaire non marchand",
            "geolocalisation": null
          }
        ],
        "output": {
          "$schema": "../../sch\u00e9mas/json/paquet.json",
          "marches": [
            {
              "id": "2013-90006",
              "acheteur": {
                "id": null,
                "nom": "R\u00e9gion Bretagne"
              },
              "nature": null,
              "objet": "PBF Formation qualifiante 2013 Monteur en construction bois lot 4",
              "codeCPV": null,
              "procedure": "Proc\u00e9dure adapt\u00e9e",
              "lieuExecution": {
                "code": 35000.0,
                "nom": "Rennes",
                "typeCode": "Code postal"
              },
              "dateNotification": "2013-10-01",
              "montant": null,
              "dureeMois": null,
              "titulaires": {
                "id": 300599123,
                "denominationSociale": "AFPA DIRECTION REGIONALE BRETAGNE"
              }
            }
          ]
        }
      }
    ],
    "identifier": 46553593
  },
  {
    "context": [
      "Now I try to get the \"ID_WEB\" and \"ID_ACC\" propertie into the objects of data.json, using the mapping of ID_EXT_LARGE and ID_EXT.",
      "The problem is, that ID_EXT only contains the first characters of ID_EXT_LARGE.",
      "Expected result - (should be the extended data.json file):",
      "[ {\"ID_EXT_LARGE\":\"aaa_1234411\",\"ID_WEB\":30,\"ID_ACC\":\"one\",\"xy\":\"xyz\"}, {\"ID_EXT_LARGE\":\"bbb_1474411\",\"ID_WEB\":40,\"ID_ACC\":\"two\",\"xy\":\"cfg\"}, {\"ID_EXT_LARGE\":\"ccc_8944411\",\"ID_WEB\":50,\"ID_ACC\":\"three\",\"xy\":\"drt\"}, {\"ID_EXT_LARGE\":\"aaa_1234411\",\"ID_WEB\":30,\"ID_ACC\":\"one\",\"xy\":\"kai\"} ]",
      "def maketable:\n  reduce $id_array[] as $i (\n    {}\n  ; .[$i.ID_EXT] = ($i | {ID_WEB,ID_ACC})\n  )\n;",
      "def getkey: .ID_EXT_LARGE | split(\"_\")[0] ;",
      "maketable as $idtable\n| map( . + $idtable[ getkey ] )"
    ],
    "utterance": "For each object, add the properties ID_WEB and ID_ACC by matching objects whose ID_EXT_LARGE starts with the ID_EXT value from the mapping list.",
    "expressions": [
      "def maketable: reduce $id_array[] as $i ({}; .[$i.ID_EXT] = ($i | {ID_WEB,ID_ACC}));\ndef getkey: .ID_EXT_LARGE | split(\"_\")[0];\nmaketable as $idtable | map(. + $idtable[getkey])",
      "def maketable: INDEX($id_array[]; .ID_EXT) | map_values(del(.ID_EXT));\ndef getkey: .ID_EXT_LARGE | split(\"_\")[0];\nmaketable as $idtable | map(. + $idtable[getkey])"
    ],
    "data": [
      {
        "input": [
          {
            "ID_EXT_LARGE": "aaa_1234411",
            "xy": "xyz"
          },
          {
            "ID_EXT_LARGE": "bbb_1474411",
            "xy": "cfg"
          },
          {
            "ID_EXT_LARGE": "ccc_8944411",
            "xy": "drt"
          },
          {
            "ID_EXT_LARGE": "aaa_1234411",
            "xy": "kai"
          }
        ],
        "output": [
          {
            "ID_EXT_LARGE": "aaa_1234411",
            "xy": "xyz",
            "ID_WEB": 30,
            "ID_ACC": "one"
          },
          {
            "ID_EXT_LARGE": "bbb_1474411",
            "xy": "cfg",
            "ID_WEB": 40,
            "ID_ACC": "two"
          },
          {
            "ID_EXT_LARGE": "ccc_8944411",
            "xy": "drt",
            "ID_WEB": 50,
            "ID_ACC": "three"
          },
          {
            "ID_EXT_LARGE": "aaa_1234411",
            "xy": "kai",
            "ID_WEB": 30,
            "ID_ACC": "one"
          }
        ]
      },
      {
        "input": [
          {
            "ID_EXT": "aaa",
            "ID_WEB": 30,
            "ID_ACC": "one"
          },
          {
            "ID_EXT": "bbb",
            "ID_WEB": 40,
            "ID_ACC": "two"
          },
          {
            "ID_EXT": "ccc",
            "ID_WEB": 50,
            "ID_ACC": "three"
          }
        ]
      }
    ],
    "identifier": 46634409
  },
  {
    "context": [
      "Option 2: make `jq` output in raw mode, so it doesn't include the enclosing double-quotes around string values.",
      "    err=$(jq -r \".errMsg\" \"$input\")",
      "    if [ \"$err\" = \"\" ]; then echo EMPTY; else echo CONTENT; fi",
      "I recommend this latter option, so that the value of `err` will be the real value. The enclosing double-quotes seem just noise for your purpose."
    ],
    "utterance": "Extract the value of the 'errMsg' field as an unquoted string.",
    "expressions": [
      ".errMsg",
      ".errMsg // empty",
      "-r .errMsg"
    ],
    "data": [
      {
        "input": {
          "projectCode": "145",
          "fullCode": "1",
          "errMsg": ""
        },
        "output": ""
      },
      {
        "input": {
          "projectCode": "145",
          "fullCode": "1",
          "errMsg": "not empty"
        },
        "output": "not empty"
      }
    ],
    "identifier": 46652354
  },
  {
    "context": [
      "look for FLAG: \"?\" in aaa.json",
      "replace this object with matching object from input.json using \"ID\" and \"time_CET\" for mapping.",
      "Keep exisiting valid objects and add objects from input.json that did not exist in aaa.json before (this means only objects starting with \"aaa\" in \"ID\" field)",
      "map(if .FLAG != \"?\" then . else . += lookup($inp) end)\n      | . + getmissing($inp;$xxx)"
    ],
    "utterance": "For all objects with 'ID' starting with 'aaa', replace objects with FLAG == '?' using matching object (same ID and time_CET) from input, keep valid objects, and add new objects from input not present previously.",
    "expressions": [
      "def prefix: input_filename | split(\".\")[0];\ndef selectprefix: select(.ID | startswith(prefix));\ndef pk: [.ID, .time_CET];\ndef lookup($t;$k): $t | getpath($k);\ndef lookup($t): lookup($t;pk);\ndef organize(s): reduce s as $r ({}; setpath($r|pk; $r));\ndef pks: paths | select(length==2);\ndef missing($t1;$t2): [$t1|pks] - [$t2|pks] | .[];\ndef getmissing($t1;$t2): [ missing($t1;$t2) as $p | lookup($t1;$p)];\n\norganize(.[]) as $xxx\n| organize($input_json[] | selectprefix) as $inp\n| map(if .FLAG != \"?\" then . else . += lookup($inp) end)\n| . + getmissing($inp;$xxx)"
    ],
    "data": [
      {
        "input": [
          {
            "ID": "aaa_12301248",
            "time_CET": "00:00:00",
            "VALUE": 10,
            "FLAG": "0"
          },
          {
            "ID": "aaa_12301248",
            "time_CET": "00:15:00",
            "VALUE": 18,
            "FLAG": "0"
          },
          {
            "ID": "aaa_12301248",
            "time_CET": "00:30:00",
            "VALUE": 160,
            "FLAG": "0"
          }
        ],
        "output": [
          {
            "ID": "aaa_12301248",
            "time_CET": "00:00:00",
            "VALUE": 10,
            "FLAG": "0"
          },
          {
            "ID": "aaa_12301248",
            "time_CET": "00:15:00",
            "VALUE": 18,
            "FLAG": "0"
          },
          {
            "ID": "aaa_12301248",
            "time_CET": "00:30:00",
            "VALUE": 160,
            "FLAG": "0"
          },
          {
            "ID": "aaa_12301248",
            "time_CET": "00:55:00",
            "VALUE": 45,
            "FLAG": "0"
          }
        ]
      }
    ],
    "identifier": 46595276
  },
  {
    "context": [
      "I have a very very big JSON and I'd like to check the path to some keys.",
      "Is there a way to know the full path(s) to a given key using the jq tool or any other way?",
      "the [--stream](https://stedolan.github.io/jq/manual/#Streaming) option may be what you want.",
      "the jq program will have `[<path>, <leaf-value>]` (and a few other forms) as inputs."
    ],
    "utterance": "Show the full path(s) to all keys named \"foo\" wherever they appear in a deeply nested structure.",
    "expressions": [
      ". as $in | paths(scalars) as $p | select(getpath($p) == \"foo\") | $p",
      "to_stream | select(.[1]==\"foo\") | .[0]"
    ],
    "identifier": 46687961
  },
  {
    "identifier": 46702550
  },
  {
    "context": [
      "I want to multiply 2 arrays to produce a mixed reduce.  I compare this to using the FOIL method expanding and distributing parenthesized terms between polynomials into a resulting, combined expression in algebra.",
      "In my example I essentially want to use 2 arrays, each containing a pair of terms to be used in an enumeration of states, to create a resulting array that allows me to iterate through 4 total cases.  This is similar to how combinations are calculated.",
      "It sounds like you&#39;re interested in outer-products.  In any case, here is a definition of `outer/2` for forming an outer-product of two arrays:\r\n    \r\n    def outer(a; b): [a[] as $x | b[] as $y | [$x, $y]];",
      "You might want to use this variant (which is similar to outer(A, B, f) in R, for example):\r\n\r\n    def outer(a; b; f):\r\n      [a[] as $x | b[] as $y | [$x, $y] | f];",
      "Perhaps the implicit cartesian product formed when using multiple `[]` iterators will help you express your problem.",
      "[ {x:a1[], y:a2[]} ]\r\n\r\nproduces\r\n\r\n    [\r\n      { &quot;x&quot;: 1, &quot;y&quot;: 3 },\r\n      { &quot;x&quot;: 1, &quot;y&quot;: 4 },\r\n      { &quot;x&quot;: 2, &quot;y&quot;: 3 },\r\n      { &quot;x&quot;: 2, &quot;y&quot;: 4 }\r\n    ]",
      "[\"one\", \"two\"] as $num | [\"a\", \"b\"] as $let | [($num[] | [.]) + ($let[] | [.])]",
      "def outer(a; b): [a[] as $x | b[] as $y | [$x, $y]];"
    ],
    "utterance": "List all combinations of elements from two arrays, pairing each element from the first array with each from the second.",
    "expressions": [
      "def outer(a; b): [a[] as $x | b[] as $y | [$x, $y]];",
      "[{\"x\": a1[], \"y\": a2[]}]",
      "[\"one\", \"two\"] as $num | [\"a\", \"b\"] as $let | [($num[] | [.]) + ($let[] | [.])]"
    ],
    "data": [
      {
        "input": {
          "a1": [
            1,
            2
          ],
          "a2": [
            3,
            4
          ]
        },
        "output": [
          {
            "x": 1,
            "y": 3
          },
          {
            "x": 1,
            "y": 4
          },
          {
            "x": 2,
            "y": 3
          },
          {
            "x": 2,
            "y": 4
          }
        ]
      },
      {
        "input": [
          [
            "one",
            "two"
          ],
          [
            "a",
            "b"
          ]
        ],
        "output": [
          [
            "one",
            "a"
          ],
          [
            "two",
            "a"
          ],
          [
            "one",
            "b"
          ],
          [
            "two",
            "b"
          ]
        ]
      }
    ],
    "identifier": 46638584
  },
  {
    "context": [
      "I am looking to output a JSON array of objects whose keys are composed of known strings (patterns) for the key/value pair bound by a colon (:) indicating the end of a key-phrase and whose next data-value would be the start of the value-phrase. The presence of a trailing space indicates that the data-value should be appended as part of the value-phrase until the trailing space no longer appears in the data-value. At that point the next data-value represents the start of another key-phrase.",
      "To convert that into an object you could add another reduce.  For example this filter\n\n  reduce (\n      tostream\n    | select(length==2) as [$p,$v]\n    | select($p[-1]==\"data\")\n  ) as [$p,$v] (\n      [\"\"]\n    ; .[-1] += $v\n    | if $v|endswith(\" \")|not then . += [\"\"] else . end\n  )\n| map(select(. != \"\"))\n| reduce .[] as $e (\n    {k:\"\", o:{}}\n  ; if $e|endswith(\":\") then .k = $e[:-1] else .o[.k] += $e end\n  )\n| .o",
      "The filter as is will generate\n\n    [\"Company Address:\",\"123 Main St. Smallville KS 606101\"]\n\nTo convert that into an object you could add another reduce.",
      "def extract:\n  [   tostream\n    | select(length==2) as [$p,$v]     # collect values for\n    | select($p[-1]==\"data\")           # paths to \"data\"\n    | $v                               # in an array\n  ]\n;\n\ndef gather:\n  reduce .[] as $v ([\"\"] ; .[-1] += $v | if $v|endswith(\" \")|not then . += [\"\"] else . end ) | map(select(. != \"\"));\n\ndef combine:\n    reduce .[] as $e ({k:\"\", o:{}} ; if $e|endswith(\":\") then .k = $e[:-1] else .o[.k] += $e end ) | .o;\n\n  extract | gather | combine"
    ],
    "utterance": "Combine all objects with a 'data' key into key-value pairs, where each key is concatenated text ending with a colon, and its value is formed by concatenating subsequent text (ending with a space) until a value without a trailing space is reached.",
    "expressions": [
      "reduce (\n    tostream\n  | select(length==2) as [$p,$v]\n  | select($p[-1]==\"data\")\n) as [$p,$v] ([\"\"]; .[-1] += $v | if $v|endswith(\" \")|not then . += [\"\"] else . end )\n| map(select(. != \"\"))\n| reduce .[] as $e ({k:\"\", o:{}}; if $e|endswith(\":\") then .k = $e[:-1] else .o[.k] += $e end )\n| .o",
      "def extract:\n  [   tostream\n    | select(length==2) as [$p,$v]     # collect values for\n    | select($p[-1]==\"data\")           # paths to \"data\"\n    | $v                               # in an array\n  ]\n;\n\ndef gather:\n  reduce .[] as $v ([\"\"] ; .[-1] += $v | if $v|endswith(\" \")|not then . += [\"\"] else . end ) | map(select(. != \"\"));\n\ndef combine:\n    reduce .[] as $e ({k:\"\", o:{}} ; if $e|endswith(\":\") then .k = $e[:-1] else .o[.k] += $e end ) | .o;\n\n  extract | gather | combine"
    ],
    "data": [
      {
        "input": [
          {
            "data": "Company "
          },
          {
            "data": "Address:"
          },
          {
            "data": "123 Main St. "
          },
          {
            "data": "Smallville "
          },
          {
            "data": "KS "
          },
          {
            "data": "606101"
          }
        ],
        "output": {
          "Company Address": "123 Main St. Smallville KS 606101"
        }
      }
    ],
    "identifier": 46490325
  },
  {
    "context": [
      "I want to filter the object based on condition, where `product.type == mobile` and then in matching objects, I just want to the `id` and `service` fields.",
      "map(select(.product.type == \"mobile\")) | .[] | {id: .product.id, service: .product.service}",
      "data[] | .product | select(.type == \"mobile\") | {service, id}",
      "With the input data adjusted as described above, the output would be as shown, namely:\n\n    {\"service\":\"pricing\",\"id\":1}"
    ],
    "utterance": "Return objects where product.type is \"mobile\", keeping only the service and id fields from product.",
    "expressions": [
      "map(select(.product.type == \"mobile\")) | .[] | {id: .product.id, service: .product.service}",
      ".[] | select(.product.type == \"mobile\") | {service: .product.service, id: .product.id}",
      ".[] | .product | select(.type == \"mobile\") | {service, id}",
      "map(select(.product.type == \"mobile\").product | {service, id}) | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "payload": {
              "location": {
                "uid": 1,
                "type": "foo"
              },
              "name": "foo",
              "maxResults": 10
            },
            "product": {
              "uid": "1232323",
              "source": "foo",
              "service": "pricing",
              "version": "0.1",
              "time": 1507602150899,
              "type": "mobile",
              "id": 1
            }
          },
          {
            "payload": {
              "location": {
                "uid": 2,
                "type": "bar"
              },
              "name": "bar",
              "maxResults": 10
            },
            "product": {
              "uid": "244434242",
              "source": "bar",
              "service": "pricing",
              "version": "0.2",
              "time": "1507602ds0899",
              "type": "phone",
              "id": 2
            }
          }
        ],
        "output": {
          "service": "pricing",
          "id": 1
        }
      }
    ],
    "identifier": 46701330
  },
  {
    "context": [
      "I have this json string ... and need to extract the atb elements into prices and amounts together with the id:",
      "[{\"atb_price\": [7.6, 7.2], \"atb_amount\": [35, 25], \"atb_id\": [11111, 11111]}, {\"atb_price\": [1.04, 1.02], \"atb_amount\": [100, 200], \"atb_id\": [22222, 22222]}]",
      "jq '[.mc[0].rc[] | .id as $id | reduce .atb[] as $i  ( {\"atb_price\":[], \"atb_amount\":[], \"atb_id\": []};  .atb_price += [$i[0]] | .atb_amount += [$i[1]] | .atb_id += [$id])]' jsonfile",
      ".mc[].rc[] | .id as $id | .atb | { atb_price:   map(.[0]), atb_amount:  map(.[1]), atb_id:      map($id) }"
    ],
    "utterance": "Extract from each rc element an object with keys atb_price, atb_amount, and atb_id, where atb_price holds a list of prices from atb, atb_amount holds a list of amounts from atb, and atb_id holds a list of the id (repeated to match the length of atb).",
    "expressions": [
      "[.mc[0].rc[] | .id as $id | reduce .atb[] as $i ({\"atb_price\":[], \"atb_amount\":[], \"atb_id\": []}; .atb_price += [$i[0]] | .atb_amount += [$i[1]] | .atb_id += [$id])]",
      ".mc[].rc[] | .id as $id | .atb | { atb_price: map(.[0]), atb_amount: map(.[1]), atb_id: map($id) }"
    ],
    "data": [
      {
        "input": {
          "op": "mcm",
          "clk": "1147179697",
          "pt": 1439869512969,
          "mc": [
            {
              "id": "1.120040663",
              "rc": [
                {
                  "atb": [
                    [
                      7.6,
                      35
                    ],
                    [
                      7.2,
                      25
                    ]
                  ],
                  "id": 11111
                },
                {
                  "atb": [
                    [
                      1.04,
                      100
                    ],
                    [
                      1.02,
                      200
                    ]
                  ],
                  "id": 22222
                }
              ],
              "con": true,
              "img": false
            }
          ]
        },
        "output": [
          {
            "atb_price": [
              7.6,
              7.2
            ],
            "atb_amount": [
              35,
              25
            ],
            "atb_id": [
              11111,
              11111
            ]
          },
          {
            "atb_price": [
              1.04,
              1.02
            ],
            "atb_amount": [
              100,
              200
            ],
            "atb_id": [
              22222,
              22222
            ]
          }
        ]
      }
    ],
    "identifier": 46725770
  },
  {
    "context": [
      "I would like to manipulate the data using `jq` in such a way that for each item in `Items[]` that has a ***new*** value for *property_A* (under ***newProperties*** list) generate an output with the corresponding *id*, *old* and *new* (see desired output below) fields regardless of the value that property has in the ***oldProperties*** list. Moreover, if *property_A* does not exist in the ***oldProperties***, I still need the *old* field to be populated with a `null` (or any fixed string for what it's worth).",
      "Which renders only the *ID_Complete* case, while I need the other as well.",
      "This filter produces the desired output.",
      ".Items\n| map({id:.ID.S, old:.oldProperties|norm, new:.newProperties|norm})[]",
      "{\n  \"id\": \"ID_Complete\",\n  \"old\": \"[property_A : value_A_old]\",\n  \"new\": \"[property_A : value_A_new]\"\n}\n{\n  \"id\": \"ID_Incomplete\",\n  \"old\": null,\n  \"new\": \"[property_A : value_A_new]\"\n}"
    ],
    "utterance": "For each item, produce an object containing id, the value of property_A in newProperties as new, and the value of property_A in oldProperties as old (or null if not present), such that only items with property_A in newProperties are included.",
    "expressions": [
      "def parse: capture(\"(?<key>\\\\w+)\\\\s*:\\\\s*(?<value>\\\\w+)\") ;\ndef print: \"[\\(.key) : \\(.value)]\";\ndef norm:   [.[][][] | parse | select(.key==\"property_A\") | print][0];\n\n  .Items\n| map({id:.ID.S, old:.oldProperties|norm, new:.newProperties|norm})[]"
    ],
    "data": [
      {
        "input": {
          "Items": [
            {
              "ID": {
                "S": "ID_Complete"
              },
              "oldProperties": {
                "L": [
                  {
                    "S": "[property_A : value_A_old]"
                  },
                  {
                    "S": "[property_B : value_B_old]"
                  }
                ]
              },
              "newProperties": {
                "L": [
                  {
                    "S": "[property_A : value_A_new]"
                  },
                  {
                    "S": "[property_B : value_B_new]"
                  }
                ]
              }
            },
            {
              "ID": {
                "S": "ID_Incomplete"
              },
              "oldProperties": {
                "L": [
                  {
                    "S": "[property_B : value_B_old]"
                  }
                ]
              },
              "newProperties": {
                "L": [
                  {
                    "S": "[property_A : value_A_new]"
                  },
                  {
                    "S": "[property_B : value_B_new]"
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "id": "ID_Complete",
            "old": "[property_A : value_A_old]",
            "new": "[property_A : value_A_new]"
          },
          {
            "id": "ID_Incomplete",
            "old": null,
            "new": "[property_A : value_A_new]"
          }
        ]
      }
    ],
    "identifier": 46671563
  },
  {
    "context": [
      "when i have something like this..\n\n    curl 'http://127.0.0.1:8500/v1/health/service/myApp?dc=a&passing=true' \\\n      | jq '[].Checks[1].ServiceTags[]'\n\noutput is..\n\n    \"a\"\n    \"b\"\n    \"c\"\n    \"d\"\n\nI want to know if i could get it as a list. I want the output in this way..\n\n     [\"a\",\"b\",\"c\",\"d\"]",
      "Try\n\n    jq '[.[].Checks[1].ServiceTags[]]'\n\nThe extra `[]` instruct jq to collect the values into an array."
    ],
    "utterance": "Return a single array containing all the elements from Checks[1].ServiceTags for every item.",
    "expressions": [
      "[.[].Checks[1].ServiceTags[]]"
    ],
    "identifier": 46751099
  },
  {
    "context": [
      "Is it possible to sort a particular array of a json document and output the entire document with the sorted content otherwise untouched?",
      "I have seen sorting examples using `jq` and `JMESPath` but only ever seen them output the section being sorted and not the entire document with the sorted section.",
      "This is what I have used to sort the array `| jq '.Statement[].Principal.AWS|sort'` which works, but I'd like to get back into the context of the entire document formatted as it was.",
      "jq '.Statement[0].Principal.AWS |= sort' file",
      "To sort multiple arrays use:",
      "jq '.Statement[].Principal.AWS |= sort' file"
    ],
    "utterance": "Sort each Principal.AWS array inside all Statement objects in place, leaving the rest of the document unchanged.",
    "expressions": [
      ".Statement[].Principal.AWS |= sort"
    ],
    "data": [
      {
        "input": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Sid": "BLAHBLAHBLAH",
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn:aws:iam::346654243625:root",
                  "arn:aws:iam::984895836564:root",
                  "arn:aws:iam::636877599363:root",
                  "arn:aws:iam::577836285792:root",
                  "arn:aws:iam::836666644595:root",
                  "arn:aws:iam::652379234777:root",
                  "arn:aws:iam::339659563489:root",
                  "arn:aws:iam::293576423935:root",
                  "arn:aws:iam::682354689262:root",
                  "arn:aws:iam::349855857558:root",
                  "arn:aws:iam::398259495958:root",
                  "arn:aws:iam::735277384553:root"
                ]
              },
              "Action": "s3:*",
              "Resource": [
                "arn:aws:s3:::blah-blah-blah",
                "arn:aws:s3:::blah-blah-blah/*"
              ]
            }
          ]
        },
        "output": {
          "Version": "2012-10-17",
          "Statement": [
            {
              "Sid": "BLAHBLAHBLAH",
              "Effect": "Allow",
              "Principal": {
                "AWS": [
                  "arn:aws:iam::293576423935:root",
                  "arn:aws:iam::339659563489:root",
                  "arn:aws:iam::346654243625:root",
                  "arn:aws:iam::349855857558:root",
                  "arn:aws:iam::398259495958:root",
                  "arn:aws:iam::577836285792:root",
                  "arn:aws:iam::636877599363:root",
                  "arn:aws:iam::652379234777:root",
                  "arn:aws:iam::682354689262:root",
                  "arn:aws:iam::735277384553:root",
                  "arn:aws:iam::836666644595:root",
                  "arn:aws:iam::984895836564:root"
                ]
              },
              "Action": "s3:*",
              "Resource": [
                "arn:aws:s3:::blah-blah-blah",
                "arn:aws:s3:::blah-blah-blah/*"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 46730446
  },
  {
    "context": [
      "Can anyone please help me with jq query to combine both to give the service tag \"my-app-tag\" for the node \"my-app-1-2-3-4\" in the above the example.",
      "the problem description corresponds to a query of the form:",
      ".[].Checks[] | select(.Node == $NODE) | .ServiceTags[]",
      "with your data, and letting $NODE have the value \"my-ap-1-2-3-4\", the jq query:",
      ".[].Checks[] | select(.Node == \"my-ap-1-2-3-4\") | .ServiceTags[]",
      "yields:\n\n    \"my-app-tag\""
    ],
    "utterance": "Retrieve the service tag \"my-app-tag\" associated with the node named \"my-app-1-2-3-4\".",
    "expressions": [
      ".[].Checks[] | select(.Node == \"my-app-1-2-3-4\") | .ServiceTags[]"
    ],
    "identifier": 46751641
  },
  {
    "context": [
      "How can I filter everything with a bash script, so I get all image URLs of \"smallphoto\" into a text file?",
      "jq '.data[] | .smallphoto' input.json",
      "yields:",
      "\"https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL._SL160_.jpg\"",
      "\"https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL._SL160_.jpg\"",
      "\"https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg\"",
      "Here is another filter which will find `.smallphoto` no matter how deeply nested:",
      ".. | .smallphoto?//empty"
    ],
    "utterance": "Extract all values of the smallphoto field from the data section.",
    "expressions": [
      ".data[] | .smallphoto",
      ".. | .smallphoto?//empty"
    ],
    "data": [
      {
        "input": {
          "error": 0,
          "data": {
            "0": {
              "orderid": "40007600",
              "price": "9.99",
              "listingname": "iPhone 8",
              "smallphoto": "https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL._SL160_.jpg",
              "photo": "https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL.jpg"
            },
            "1": {
              "orderid": "40007598",
              "price": "9.99",
              "listingname": "iPhone 8 Plus",
              "smallphoto": "https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL._SL160_.jpg",
              "photo": "https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL.jpg"
            },
            "4": {
              "orderid": "40007595",
              "price": "9.39",
              "listingname": "Nadelflaschen",
              "smallphoto": "https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg",
              "photo": "https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL.jpg"
            }
          }
        },
        "output": [
          "https://images-eu.ssl-images-amazon.com/images/I/51b5iaLTjgL._SL160_.jpg",
          "https://images-eu.ssl-images-amazon.com/images/I/51CVLqsSNkL._SL160_.jpg",
          "https://images-eu.ssl-images-amazon.com/images/I/41OHDP2rAeL._SL160_.jpg"
        ]
      }
    ],
    "identifier": 46730755
  },
  {
    "context": [
      "However, I would like it to contain always - let's say 10 - numbers.",
      "Therefore the array should be populated with zeroes.",
      "Of course, the initial array could already contain the expected count of ten values. Then, nothing should be changed.",
      "map(.VALUE |= expand(10;0))",
      "jq 'map(.VALUE|=.+[range(length;10)|0])' data.json | sponge data.json"
    ],
    "utterance": "Pad each VALUE array to length 10 with zeros if it contains fewer than 10 elements; leave it unchanged if already 10 or more.",
    "expressions": [
      "map(.VALUE |= . + [range(length;10) | 0])",
      "def expand(n; value): . + [range(length;n) | value]; map(.VALUE |= expand(10;0))"
    ],
    "data": [
      {
        "input": [
          {
            "DATE": "September",
            "VALUE": [
              5,
              17,
              8,
              9
            ]
          }
        ],
        "output": [
          {
            "DATE": "September",
            "VALUE": [
              5,
              17,
              8,
              9,
              0,
              0,
              0,
              0,
              0,
              0
            ]
          }
        ]
      }
    ],
    "identifier": 46759294
  },
  {
    "context": [
      "I have 2 files, both with similar schema for data.  Files A and B, and what I'm hoping to get as output, looks like the following:",
      "I'd like to take all of the pairs under \"properties\" from File B and push those to File A, updating existing property pairs if they exist, or adding them as their own block (with a \"NEW\" tag as shown) if they do not.",
      "jq --argfile A A.json  -f combine.jq  B.json",
      "jq --argfile A A.json 'map((.type as $t|$A[]|select(.type==$t)//{tag:\"NEW\"}) + .)' B.json",
      "(reduce $A[] as $a({};.[$a.type]=$a)) as $t | map( ($t[.type]//{tag:\"NEW\"})*. )"
    ],
    "utterance": "Merge two arrays of objects by \"type\", updating existing objects with values from the second array, and adding non-matching objects from the second array to the result with a tag value of \"NEW\".",
    "expressions": [
      "map((.type as $t|$A[]|select(.type==$t)//{tag:\"NEW\"}) + .)",
      "(reduce $A[] as $a({};.[$a.type]=$a)) as $t | map( ($t[.type]//{tag:\"NEW\"})*. )"
    ],
    "data": [
      {
        "input": [
          [
            {
              "type": "hive-site",
              "tag": 1507894175,
              "properties": {
                "javax.jdo.option.ConnectionPassword": "hortonworks1"
              }
            },
            {
              "type": "admin-properties",
              "tag": 1507894175,
              "properties": {
                "fieldA": "valueA",
                "fieldB": "valueB"
              }
            }
          ],
          [
            {
              "type": "hive-site",
              "properties": {
                "javax.jdo.option.ConnectionPassword": "hortonworks2"
              }
            },
            {
              "type": "admin-properties",
              "properties": {
                "fieldA": "valueA",
                "fieldB": "valueB",
                "fieldC": "valueC"
              }
            },
            {
              "type": "other-type",
              "properties": {
                "newFieldA": "valueA",
                "newFieldB": "valueB"
              }
            }
          ]
        ],
        "output": [
          {
            "type": "hive-site",
            "tag": 1507894175,
            "properties": {
              "javax.jdo.option.ConnectionPassword": "hortonworks2"
            }
          },
          {
            "type": "admin-properties",
            "tag": 1507894175,
            "properties": {
              "fieldA": "valueA",
              "fieldB": "valueB",
              "fieldC": "valueC"
            }
          },
          {
            "type": "other-type",
            "tag": "NEW",
            "properties": {
              "newFieldA": "valueA",
              "newFieldB": "valueB"
            }
          }
        ]
      }
    ],
    "identifier": 46729401
  },
  {
    "context": [
      "I want to compare two json files to see if one can be extracted from the other one.",
      "p1 extends p2 --> true",
      "p2 extends p1 --> false",
      "An array cannot be extracted from the same array with some additional elements",
      "# Usage: $in | extends2($b) iff $in contains $b in a way which ignores the order of array elements",
      "With $P1 and $P2 as shown:\n\n      $P1 | extends2($P2) # yields true",
      "then \n\n      extends(P1;P2)  # returns true\n    , extends(P2;P1)  # returns false"
    ],
    "utterance": "Determine whether one data structure contains all the fields and values (including nested objects and unordered arrays) found in another structure, such that the first is an extension of the second.",
    "expressions": [
      "def extends2($b):\n  def objextends($x):\n    . as $in | all($x|keys[]; . as $k | $in[$k] | extends($x[$k]));\n  def arrayextends($x): ($x|sort) - sort == [];\n  if . == $b then true\n  else . as $in\n  | type as $intype\n  | ($intype == ($b|type)) and\n      (($intype == \"object\" and objextends($b)) or\n       ($intype == \"array\"  and arrayextends($b)))\n  end;",
      "def details:[ tostream | select(length==2) as [$p,$v] | [$p|map(if type==\"number\" then null else . end),$v] ];\ndef extends(a;b): (b|details) - (a|details) == [];"
    ],
    "data": [
      {
        "input": {
          "id": 12,
          "keys": [
            "key1",
            "key2"
          ],
          "body": {
            "height": "180cm",
            "wight": "70kg"
          },
          "name": "Alex"
        },
        "output": true
      },
      {
        "input": {
          "id": 12,
          "keys": [
            "key2",
            "key1"
          ],
          "body": {
            "height": "180cm"
          }
        },
        "output": false
      }
    ],
    "identifier": 46788536
  },
  {
    "context": [
      "I'm trying to use jq to extract the toplevel Attribute names together with the enclosed timestamps.",
      "desired output:\r\n\r\n    [\r\n      {\r\n        \"Something\": \"2016-02-18T12:32:50.276Z\"\r\n      },\r\n      {\r\n        \"OtherThing\": \"2016-03-18T12:32:50.276Z\"\r\n      },\r\n      {\r\n        \"ThirdThing\": \"2016-04-18T12:32:50.276Z\"\r\n      }\r\n    ]",
      "Here is a filter which uses [map_values](https://stedolan.github.io/jq/manual/#map\\(x\\),map_values\\(x\\)) to produce the specified output:",
      "map( map_values(._metadata.timestamp) )"
    ],
    "utterance": "Extract the top-level key names with their enclosed _metadata.timestamp values for each dictionary in the array.",
    "expressions": [
      "map( map_values(._metadata.timestamp) )"
    ],
    "data": [
      {
        "input": [
          {
            "Something": {
              "_metadata": {
                "timestamp": "2016-02-18T12:32:50.276Z"
              }
            }
          },
          {
            "OtherThing": {
              "_metadata": {
                "timestamp": "2016-03-18T12:32:50.276Z"
              }
            }
          },
          {
            "ThirdThing": {
              "_metadata": {
                "timestamp": "2016-04-18T12:32:50.276Z"
              }
            }
          }
        ],
        "output": [
          {
            "Something": "2016-02-18T12:32:50.276Z"
          },
          {
            "OtherThing": "2016-03-18T12:32:50.276Z"
          },
          {
            "ThirdThing": "2016-04-18T12:32:50.276Z"
          }
        ]
      }
    ],
    "identifier": 46794676
  },
  {
    "context": [
      "I am trying to add the index,type line before each of my line.",
      "cat file.json jq -c '.[] | {\"index\": {\"_index\": \"myindex\", \"_type\": \"wiki\", \"_id\": .id}}, .'",
      "cat data.json | jq -c '. | {\"index\": {\"_index\": \"json\", \"_type\": \"json\"}}, .'"
    ],
    "utterance": "For each object, output an index line with given _index and _type values, followed by the original object.",
    "expressions": [
      ". | {\"index\": {\"_index\": \"json\", \"_type\": \"json\"}}, .",
      ".[] | {\"index\": {\"_index\": \"myindex\", \"_type\": \"wiki\", \"_id\": .id}}, ."
    ],
    "data": [
      {
        "input": {
          "title": "April",
          "url": "https://simple.wikipedia.org/wiki/April",
          "abstract": "April is the 4th month of the year, and comes between March and May. It is one of four months to have 30 days.",
          "sections": [
            "The Month",
            "April in poetry",
            "Events in April",
            "Fixed Events",
            "Moveable Events",
            "Selection of Historical Events",
            "Trivia",
            "References"
          ]
        }
      }
    ],
    "identifier": 46794935
  },
  {
    "context": [
      "I have a CSV file which I would like to parse and obtain a Nested JSON using jq.",
      "The first column will have one value always. The second column can have multiple exons (1 or more). You can see that it has 3 values in 2nd row and 5 in 3rd row. Exon bases will be the second last column always, Total bases will be last but one and Fraction of exon bases will be the last column.",
      "PS: - I need to add more information, I have to edit the Exon fields and add \"Chromosomes\", \"Start\" and \"End\" to each Exon. Here i have given same start and end, but in actual scenario it varies for each Exon. Can you please help me with this.",
      "def parse:\n  [\n      inputs                     # read lines\n    | split(\",\")                 # split into columns\n    | select(length>0)           # eliminate blanks\n    | .[:1] + [.[1:-3]] + .[-3:] # normalize columns\n  ]\n;\ndef simple(n;v): {metric:n, value:v|tonumber, type:\"simple\"};\ndef set(n;v):    {metric:n, value:v,          type:\"set\"};\ndef exons(v):    [ v[] | split(\";\") | .[0], {\"chromosome\":.[1], \"start\":.[2], \"end\":.[3]} ];\ndef region:\n  set(.[0]; [\n      set(\"Exons\"; exons(.[1])),\n      simple(\"Fraction of bases\"; .[2]),\n      simple(\"Total_bases\"; .[3])\n    ]\n  )\n;\n\n{ \"Exome regions\": parse | map(region) }"
    ],
    "utterance": "Parse each line of a file where the first column is a gene name, the next columns (except the last three) contain exon fields separated by semicolons with chromosome, start, and end, and the last three columns give numerical metrics; produce a nested object structure where exons are split into name and a chromosome/start/end object, and include the metrics as specified.",
    "expressions": [
      "def parse:\n  [\n      inputs                     # read lines\n    | split(\",\")                 # split into columns\n    | select(length>0)           # eliminate blanks\n    | .[:1] + [.[1:-3]] + .[-3:] # normalize columns\n  ]\n;\ndef simple(n;v): {metric:n, value:v|tonumber, type:\"simple\"};\ndef set(n;v):    {metric:n, value:v,          type:\"set\"};\ndef exons(v):    [ v[] | split(\";\") | .[0], {\"chromosome\":.[1], \"start\":.[2], \"end\":.[3]} ];\ndef region:\n  set(.[0]; [\n      set(\"Exons\"; exons(.[1])),\n      simple(\"Fraction of bases\"; .[2]),\n      simple(\"Total_bases\"; .[3])\n    ]\n  )\n;\n\n{ \"Exome regions\": parse | map(region) }"
    ],
    "data": [
      {
        "input": "PIK3CA,PIK3CA_Exon10;chr1;1000;1500,PIK3CA_Exon13;chr1;1000;1500,PIK3CA_Exon14;chr1;1000;1500,1927879,12993042,0.15\nNRAS,NRAS_Exon4;chr1;1000;1500,NRAS_Amp_369;chr1;1000;1500,NRAS_Amp_371;chr1;1000;1500,NRAS_Amp_374;chr1;1000;1500,NRAS_Amp_379;chr1;1000;1500,884111,8062107,0.11",
        "output": {
          "Exome regions": [
            {
              "metric": "PIK3CA",
              "value": [
                {
                  "metric": "Exons",
                  "value": [
                    "PIK3CA_Exon10",
                    {
                      "chromosome": "chr1",
                      "start": "1000",
                      "end": "1500"
                    },
                    "PIK3CA_Exon13",
                    {
                      "chromosome": "chr1",
                      "start": "1000",
                      "end": "1500"
                    },
                    "PIK3CA_Exon14",
                    {
                      "chromosome": "chr1",
                      "start": "1000",
                      "end": "1500"
                    }
                  ],
                  "type": "set"
                },
                {
                  "metric": "Fraction of bases",
                  "value": 0.15,
                  "type": "simple"
                },
                {
                  "metric": "Total_bases",
                  "value": 1927879,
                  "type": "simple"
                }
              ],
              "type": "set"
            },
            {
              "metric": "NRAS",
              "value": [
                {
                  "metric": "Exons",
                  "value": [
                    "NRAS_Exon4",
                    {
                      "chromosome": "chr1",
                      "start": "1000",
                      "end": "1500"
                    },
                    "NRAS_Amp_369",
                    {
                      "chromosome": "chr1",
                      "start": "1000",
                      "end": "1500"
                    },
                    "NRAS_Amp_371",
                    {
                      "chromosome": "chr1",
                      "start": "1000",
                      "end": "1500"
                    },
                    "NRAS_Amp_374",
                    {
                      "chromosome": "chr1",
                      "start": "1000",
                      "end": "1500"
                    },
                    "NRAS_Amp_379",
                    {
                      "chromosome": "chr1",
                      "start": "1000",
                      "end": "1500"
                    }
                  ],
                  "type": "set"
                },
                {
                  "metric": "Fraction of bases",
                  "value": 0.11,
                  "type": "simple"
                },
                {
                  "metric": "Total_bases",
                  "value": 884111,
                  "type": "simple"
                }
              ],
              "type": "set"
            }
          ]
        }
      }
    ],
    "identifier": 46632107
  },
  {
    "context": [
      "What I get from jq is:",
      "What I would like to see is something more like this:",
      "jq -M . data.json | jq -MRsr 'gsub(\"\\n      +\";\"\")|gsub(\"\\n    ]\";\"]\")'",
      "produces",
      "{",
      "  \"frameGrid\": {",
      "    \"size\": [24,24],",
      "    \"dimensions\": [1,1],",
      "    \"names\": [[\"default\"]]",
      "  }",
      "}"
    ],
    "utterance": "Pretty-print an object so that small arrays appear on a single line within the output instead of across multiple lines.",
    "expressions": [
      "jq -M . data.json | jq -MRsr 'gsub(\"\\n      +\";\"\")|gsub(\"\\n    ]\";\"]\")'"
    ],
    "data": [
      {
        "input": {
          "frameGrid": {
            "size": [
              24,
              24
            ],
            "dimensions": [
              1,
              1
            ],
            "names": [
              [
                "default"
              ]
            ]
          }
        },
        "output": "{\n  \"frameGrid\": {\n    \"size\": [24,24],\n    \"dimensions\": [1,1],\n    \"names\": [[\"default\"]]\n  }\n}"
      }
    ],
    "identifier": 46805833
  },
  {
    "context": [
      "Basically I'm trying to iterate through my AWS security groups to find any CIDR's using 0.0.0.0/0.",
      "If you only want to see a sequence of {\"CidrIp\":...} objects as above you can eliminate the `map` and `any`:",
      ".SecurityGroups[].IpPermissions[].IpRanges[] \n| select(.CidrIp == \"0.0.0.0/0\")",
      "If you would rather collect those objects into an array you could remove the `any` and move some of the iteration into the `map` e.g.",
      ".SecurityGroups \n| map(.IpPermissions[].IpRanges[] | select(.CidrIp == \"0.0.0.0/0\"))",
      ".SecurityGroups \n| [ .[] | .IpPermissions[].IpRanges[] | select(.CidrIp == \"0.0.0.0/0\") ]"
    ],
    "utterance": "Find all IpRanges entries where CidrIp is \"0.0.0.0/0\" from every security group's IpPermissions array.",
    "expressions": [
      ".SecurityGroups[].IpPermissions[].IpRanges[] | select(.CidrIp == \"0.0.0.0/0\")",
      ".SecurityGroups | map(.IpPermissions[].IpRanges[] | select(.CidrIp == \"0.0.0.0/0\"))",
      ".SecurityGroups | [ .[] | .IpPermissions[].IpRanges[] | select(.CidrIp == \"0.0.0.0/0\") ]"
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "IpPermissionsEgress": [],
              "Description": "AWS OpsWorks load balancer - do not change or delete",
              "IpPermissions": [
                {
                  "PrefixListIds": [],
                  "FromPort": 22,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 22,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 80,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 80,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 443,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 443,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                }
              ],
              "GroupName": "AWS-OpsWorks-LB-Server",
              "OwnerId": "056146032236",
              "GroupId": "sg-7dd13739"
            },
            {
              "IpPermissionsEgress": [
                {
                  "IpProtocol": "-1",
                  "PrefixListIds": [],
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                }
              ],
              "Description": "SG for bastion hosts",
              "Tags": [
                {
                  "Value": "bastion-host-sg",
                  "Key": "Name"
                }
              ],
              "IpPermissions": [
                {
                  "PrefixListIds": [],
                  "FromPort": 80,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 80,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 1991,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 1991,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 8080,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 8080,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 1194,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 1194,
                  "IpProtocol": "udp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 22,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 22,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": [
                    {
                      "CidrIpv6": "::/0"
                    }
                  ]
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 30,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": -1,
                  "IpProtocol": "icmp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 1194,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 1194,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 53,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 53,
                  "IpProtocol": "udp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 53,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 53,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 443,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 443,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 8,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": -1,
                  "IpProtocol": "icmp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                }
              ],
              "GroupName": "bastion-host-sg",
              "VpcId": "vpc-effd0e8a",
              "OwnerId": "056146032236",
              "GroupId": "sg-0f60196a"
            }
          ]
        },
        "output": [
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          },
          {
            "CidrIp": "0.0.0.0/0"
          }
        ]
      }
    ],
    "identifier": 46588456
  },
  {
    "context": [
      "I just want to get unique values.",
      "I just need 3 results, unique",
      "jq processor itself has `unique` function:",
      "jq 'unique' input.json",
      "[ \"a-b-c-v001\", \"a-b-c-v002\", \"a-b-c-v001\", \"a-b-c-v003\", \"a-b-c-v002\" ]",
      "[ \"a-b-c-v001\", \"a-b-c-v002\", \"a-b-c-v003\" ]",
      "Make sure your jq expression produces an array. For example, if your jq expression (the one producing a stream of strings) is E, then you could modify it to: [E] | unique | .[]",
      "or just: [E] | unique[]",
      "INDEX(E;.)[]"
    ],
    "utterance": "Extract the unique strings from an array containing repeated values like [\"a-b-c-v001\", \"a-b-c-v002\", \"a-b-c-v001\", \"a-b-c-v003\", \"a-b-c-v002\"]",
    "expressions": [
      "unique",
      "[E] | unique | .[]",
      "[E] | unique[]",
      "INDEX(E;.)[]"
    ],
    "data": [
      {
        "input": [
          "a-b-c-v001",
          "a-b-c-v002",
          "a-b-c-v001",
          "a-b-c-v003",
          "a-b-c-v002"
        ],
        "output": [
          "a-b-c-v001",
          "a-b-c-v002",
          "a-b-c-v003"
        ]
      }
    ],
    "identifier": 46814476
  },
  {
    "context": [
      "I want to get count of number of occurrences of \"1.2.3.46:8983_emo\" in this json string using jq.",
      "\"1.2.3.46:8983_emo\" is present under myApp & myApp_shadow. So the count will be 2",
      "If you just want to look in .myApp and .myApp_shadow, then consider:\n\n    .cluster.collections\n    | [(.myApp, .myApp_shadow) | .. | strings | select(.==\"1.2.3.46:8983_emo\")]\n    | length\n\n\nThis yields the answer you said you expect (i.e. 2).",
      ".cluster.collections\n| \"1.2.3.46:8983_emo\" as $s\n| count((.myApp, .myApp_shadow) | .. | strings | select(.==$s))"
    ],
    "utterance": "Count the number of times the string \"1.2.3.46:8983_emo\" appears under both 'myApp' and 'myApp_shadow' keys in the 'cluster.collections' object.",
    "expressions": [
      ".cluster.collections | [(.myApp, .myApp_shadow) | .. | strings | select(.==\"1.2.3.46:8983_emo\")] | length",
      ".cluster.collections | \"1.2.3.46:8983_emo\" as $s | count((.myApp, .myApp_shadow) | .. | strings | select(.==$s))"
    ],
    "identifier": 46839374
  },
  {
    "context": [
      "but is there a function to sort key so that the first one is always the same and not by alphabetical order?",
      "Would like {shouldbeFirstKey:value2, key1:value, ...}",
      "Here is a filter ... which will reorder the keys of subobjects using a function: ... def reorder(order): ... the order function is expected to return the set of keys in whatever order is desired.  e.g. the following function moves \"shouldbeFirstKey\" to the first position ... def neworder: \"shouldbeFirstKey\" as $s | index($s) as $i | if $i==null then . else [$s] + .[:$i] + .[$i+1:] end ; ... {key1:\"value\", shouldbeFirstKey:\"value2\", other:{key3:\"value3\", shouldbeFirstKey:\"value4\"}} | reorder(neworder)",
      "$ jq -n '{a:2,b:3,first:0,second:1} | . as $in | {first,second} + $in'",
      "def rekey(obj): . as $in | reduce (obj|keys_unsorted)[] as $k ({}; if $in|has($k) then . + {($k): $in[$k]} else . end) | . + $in ;",
      "If one wants to reorder keys recursively, one can use walk/1 (defined as at https://github.com/stedolan/jq/blob/master/src/builtin.jq), as illustrated here using the above definition of rekey: walk(if type == \"object\" then rekey($template) else . end)",
      "jq '[.[]  | reorder(\"id\"; 0)| reorder(\"size\"; 3) | reorder(\"name\"; 1)]' data.json"
    ],
    "utterance": "Move a specific key, such as 'shouldbeFirstKey', to the first position in each object, while keeping the order of other keys unchanged.",
    "expressions": [
      "def reorder(order):\n  . as $in\n  | if type == \"object\" then\n      reduce (keys_unsorted|order)[] as $key (\n        {}; . + { ($key): ($in[$key] | reorder(order)) }\n      )\n    elif type == \"array\" then map( reorder(order) )\n    else .\n    end;\ndef neworder:\n  \"shouldbeFirstKey\" as $s\n  | index($s) as $i\n  | if $i==null then . else [$s] + .[:$i] + .[$i+1:] end;\n{key1:\"value\", shouldbeFirstKey:\"value2\", other:{key3:\"value3\", shouldbeFirstKey:\"value4\"}} | reorder(neworder)",
      ". as $in | {shouldbeFirstKey} + $in",
      "def rekey(obj):\n  . as $in\n  | reduce (obj|keys_unsorted)[] as $k ({};\n      if $in|has($k) then . + {($k): $in[$k]} else . end)\n  | . + $in ;\n{a:2,b:3,shouldbeFirstKey:0} | rekey({shouldbeFirstKey})"
    ],
    "data": [
      {
        "input": {
          "key1": "value",
          "shouldbeFirstKey": "value2",
          "other": {
            "key3": "value3",
            "shouldbeFirstKey": "value4"
          }
        },
        "output": {
          "shouldbeFirstKey": "value2",
          "key1": "value",
          "other": {
            "shouldbeFirstKey": "value4",
            "key3": "value3"
          }
        }
      },
      {
        "input": {
          "a": 2,
          "b": 3,
          "shouldbeFirstKey": 0
        },
        "output": {
          "shouldbeFirstKey": 0,
          "a": 2,
          "b": 3
        }
      }
    ],
    "identifier": 46796701
  },
  {
    "context": [
      "cat /tmp/file.json | jq",
      "cat /tmp/gen_json | jq",
      "jq - commandline JSON processor [version 1.5-1-a5b5cbe]\nUsage: jq [options] <jq filter> [file...]",
      "When invoked from `node`, however, with `stdin` and **`stdout` redirected**, `jq` **requires the filter** argument. That\u2019s why you have to specify it explicitly:",
      "var command = \"cat /tmp/gen_json | jq .\";",
      "var command = \"jq . /tmp/gen_json\";"
    ],
    "utterance": "Pretty-print the contents of /tmp/gen_json by applying the identity filter.",
    "expressions": [
      "jq . /tmp/gen_json",
      "cat /tmp/gen_json | jq ."
    ],
    "data": [
      {
        "input": {
          "foo": 1,
          "bar": [
            2,
            3
          ]
        },
        "output": "{\n  \"foo\": 1,\n  \"bar\": [\n    2,\n    3\n  ]\n}"
      }
    ],
    "identifier": 46852418
  },
  {
    "context": [
      "not sure if it's important but the uniqueness of an object is based on `foo` and `bar`, not `baz`.",
      "An example of desired output would then be:\n\n    [\n        {\n            \"foo\": 1,\n            \"bar\": \"a\",\n            \"baz\": \"whatever\",\n            \"count\": 2\n        },\n        {\n            \"foo\": 1,\n            \"bar\": \"b\",\n            \"baz\": \"world\",\n            \"count\": 1\n        }\n    ]",
      "You can use the following command based on `group_by`:\n\n    group_by(.foo,.bar)\n    | map(.[]+{\"count\":length})\n    | unique_by(.foo,.bar)",
      "The other output you mentioned can be achieved with this command:\n\n    group_by(.foo,.bar)\n    | map({\"count\":length,\"data\":(unique_by(.foo,.bar)[])})",
      "Here is a solution which uses peak's GROUPS_BY instead of group_by/1 to avoid sorting:\n\ndef GROUPS_BY(stream; f): reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ;\n \n  GROUPS_BY(.[]; {foo,bar}|tostring)\n| .[0].count = length\n| .[0]"
    ],
    "utterance": "Remove duplicates from an array of objects based on the fields 'foo' and 'bar', and for each unique combination, include a count of occurrences.",
    "expressions": [
      "group_by(.foo,.bar) | map(.[]+{\"count\":length}) | unique_by(.foo,.bar)",
      "group_by(.foo,.bar) | map({\"count\":length,\"data\":(unique_by(.foo,.bar)[])})",
      "def GROUPS_BY(stream; f): reduce stream as $x ({}; .[$x|f] += [$x] ) | .[] ; GROUPS_BY(.[]; {foo,bar}|tostring) | .[0].count = length | .[0]"
    ],
    "data": [
      {
        "input": [
          {
            "foo": 1,
            "bar": "a",
            "baz": "whatever"
          },
          {
            "foo": 1,
            "bar": "a",
            "baz": "hello"
          },
          {
            "foo": 1,
            "bar": "b",
            "baz": "world"
          }
        ],
        "output": [
          {
            "foo": 1,
            "bar": "a",
            "baz": "whatever",
            "count": 2
          },
          {
            "foo": 1,
            "bar": "b",
            "baz": "world",
            "count": 1
          }
        ]
      },
      {
        "input": [
          {
            "foo": 1,
            "bar": "a",
            "baz": "whatever"
          },
          {
            "foo": 1,
            "bar": "a",
            "baz": "hello"
          },
          {
            "foo": 1,
            "bar": "b",
            "baz": "world"
          }
        ],
        "output": [
          {
            "count": 2,
            "data": {
              "foo": 1,
              "bar": "a",
              "baz": "whatever"
            }
          },
          {
            "count": 1,
            "data": {
              "foo": 1,
              "bar": "b",
              "baz": "world"
            }
          }
        ]
      }
    ],
    "identifier": 46829008
  },
  {
    "context": [
      "From this I would like to only show;\r\n\r\n    audience-view-dev-api\r\n    audience-view-dev-groups\r\n    audience-view-dev-groups\r\n    audience-view-dev-mock-api\r\n    audience-view-dev-mock-responder",
      "With **jq** **`match`** function:\r\n\r\n    aws ecs list-task-definitions --region eu-west-1 \\\r\n    | jq -r '.taskDefinitionArns[] | match(\".*/([^:]+):[0-9]+$\").captures[0].string'",
      "Try this:\r\n\r\n    $ aws ecs list-task-definitions --region eu-west-1 \\\r\n      | jq -Mr '.taskDefinitionArns[] | split(\":\")[5] | split(\"/\")[1]'"
    ],
    "utterance": "Extract the task definition names (such as audience-view-dev-api, audience-view-dev-groups, etc.) from the list of ARNs under the taskDefinitionArns array.",
    "expressions": [
      ".taskDefinitionArns[] | match(\".*/([^:]+):[0-9]+$\").captures[0].string",
      ".taskDefinitionArns[] | split(\":\")[5] | split(\"/\")[1]"
    ],
    "data": [
      {
        "input": {
          "taskDefinitionArns": [
            "arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-api:4",
            "arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-groups:4",
            "arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-groups:5",
            "arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-mock-api:1",
            "arn:aws:ecs:eu-west-1:543573289192:task-definition/audience-view-dev-mock-responder:1"
          ]
        },
        "output": [
          "audience-view-dev-api",
          "audience-view-dev-groups",
          "audience-view-dev-groups",
          "audience-view-dev-mock-api",
          "audience-view-dev-mock-responder"
        ]
      }
    ],
    "identifier": 46832763
  },
  {
    "context": [
      "Input:\r\n\r\n    {\"success\": true, \"results\": {\"a\": \u2026, \"b\": \u2026, \"c\": \u2026}}",
      "Desired output, given I want to keep `b`:\r\n\r\n    {\"success\": true, \"results\": {\"b\": \u2026}}",
      "Here is one solution:\r\n\r\n    .results |= {b}",
      "$ jq -M '.results |= {b}' <<< '{\"success\":true, \"results\":{\"a\": \"\u2026\", \"b\": \"\u2026\", \"c\": \"\u2026\"}}'\r\n    {\r\n      \"success\": true,\r\n      \"results\": {\r\n        \"b\": \"\u2026\"\r\n      }\r\n    }"
    ],
    "utterance": "Keep only the key 'b' inside the nested 'results' object, preserving all other top-level keys.",
    "expressions": [
      ".results |= {b}"
    ],
    "data": [
      {
        "input": {
          "success": true,
          "results": {
            "a": "\u2026",
            "b": "\u2026",
            "c": "\u2026"
          }
        },
        "output": {
          "success": true,
          "results": {
            "b": "\u2026"
          }
        }
      }
    ],
    "identifier": 46876940
  },
  {
    "context": [
      "curl GET \"https://jsonplaceholder.typicode.com/posts/2\" | jq '.body'",
      "result=\"$(curl GET https://jsonplaceholder.typicode.com/posts/2)\" | jq '.body'",
      "You should process the results in jq inside the subshell.",
      "result=$(curl GET https://jsonplaceholder.typicode.com/posts/2 | jq '.body')",
      "echo \"$result\""
    ],
    "utterance": "Extract the value of the 'body' field from the response to an HTTP GET request to https://jsonplaceholder.typicode.com/posts/2.",
    "expressions": [
      ".body"
    ],
    "data": [
      {
        "input": {
          "userId": 1,
          "id": 2,
          "title": "qui est esse",
          "body": "est rerum tempore vitae\nsequi sint nihil reprehenderit dolor beatae ea dolores neque\nfugiat blanditiis voluptate porro vel nihil molestiae ut reiciendis\nqui aperiam non debitis possimus qui neque nisi nulla"
        },
        "output": "est rerum tempore vitae\nsequi sint nihil reprehenderit dolor beatae ea dolores neque\nfugiat blanditiis voluptate porro vel nihil molestiae ut reiciendis\nqui aperiam non debitis possimus qui neque nisi nulla"
      }
    ],
    "identifier": 46889790
  },
  {
    "context": [
      "\"I'd like to print the value of members and id from below jq output:\"",
      "\"with +\" \"+ I get error: jq: error: number and string cannot be added\"",
      "\"Convert number to string with `tostring` function:\njq -r '.[] | select(.name==\"AAA\") | (.members|tostring) +\" \"+ .id test'\"",
      "\"I recommend to use [*string interpolation*][1]. It will automatically cast input to a string if necessary:\njq -r '.[]|select(.name==\"AAA\")|\"\\(.members) \\(.id)\"' file.json\""
    ],
    "utterance": "Retrieve the members and id fields from all objects where name is \"AAA\", displaying them together separated by a space.",
    "expressions": [
      ".[] | select(.name==\"AAA\") | (.members|tostring) + \" \" + .id",
      ".[] | select(.name==\"AAA\") | \"\u007f(.members) \u007f(.id)\""
    ],
    "data": [
      {
        "input": [
          {
            "name": "AAA",
            "members": 10,
            "profiles": 0,
            "templates": 0,
            "ldapGroups": 0,
            "ldapMembers": 0,
            "id": "20"
          }
        ],
        "output": "10 20"
      }
    ],
    "identifier": 46911763
  },
  {
    "context": [
      "I only want to display the id and state of the failed object, this is what I tried",
      "jq '.rows[] | .id, select(.state | contains(\"!STARTED\"))' test.json",
      "I'd like my output to be something like",
      "{\n \"id\": \"169\",\n \"state\": \"FAILED\"\n}",
      "If you simply want to print out the objects for which .state is NOT \"STARTED\", just use negation:",
      ".rows[] | select(.state != \"STARTED\")"
    ],
    "utterance": "Output all objects from rows where state is not equal to STARTED, showing their id and state.",
    "expressions": [
      ".rows[] | select(.state != \"STARTED\")"
    ],
    "data": [
      {
        "input": {
          "page": 0,
          "page_size": 100,
          "total_pages": 10,
          "total_rows": 929,
          "headers": [
            "*"
          ],
          "rows": [
            {
              "id": "168",
              "state": "STARTED"
            },
            {
              "id": "169",
              "state": "FAILED"
            },
            {
              "id": "170",
              "state": "STARTED"
            }
          ]
        },
        "output": {
          "id": "169",
          "state": "FAILED"
        }
      }
    ],
    "identifier": 46838417
  },
  {
    "context": [
      "The output of this is (if `DGRAPHIP = 1.2.3.4`): ... This is not the desired outcome, I would like the outcome to be encapsulated like:\r\n\r\n    {\r\n        \"environments\": [{\r\n            RESULTS\r\n        }]\r\n    }",
      "Simple adjustment:\r\n\r\n    jq --arg dgraphip \"1.2.3.4\" '{\"environments\" : .environments \r\n     | map(select(.name | contains(\"docker\")) \r\n     | .database.database_config.host = $dgraphip)}' weaviate.conf.json",
      "Here is another approach ...\r\n    .environments |= map(      \r\n         select(.name | contains(\"docker\"))\r\n       | .database.database_config.host = \"1.2.3.4\"\r\n    )"
    ],
    "utterance": "Update the host field to 1.2.3.4 for all environments with a name containing 'docker', and output the full environments array in an enclosing object.",
    "expressions": [
      "jq --arg dgraphip \"1.2.3.4\" '{\"environments\" : .environments | map(select(.name | contains(\"docker\")) | .database.database_config.host = $dgraphip)}' weaviate.conf.json",
      ".environments |= map(select(.name | contains(\"docker\")) | .database.database_config.host = \"1.2.3.4\")"
    ],
    "data": [
      {
        "input": {
          "environments": [
            {
              "name": "docker",
              "database": {
                "name": "dgraph",
                "database_config": {
                  "host": "localhost",
                  "port": 9080
                }
              },
              "schemas": {
                "Thing": "https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Thing-ontology-schema_org.min.json",
                "Action": "https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Action-ontology-schema_org.min.json"
              },
              "mqttEnabled": false
            },
            {
              "name": "other",
              "database": {
                "name": "mysql",
                "database_config": {
                  "host": "mysqlhost",
                  "port": 3306
                }
              },
              "schemas": {},
              "mqttEnabled": true
            }
          ]
        },
        "output": {
          "environments": [
            {
              "name": "docker",
              "database": {
                "name": "dgraph",
                "database_config": {
                  "host": "1.2.3.4",
                  "port": 9080
                }
              },
              "schemas": {
                "Thing": "https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Thing-ontology-schema_org.min.json",
                "Action": "https://raw.githubusercontent.com/weaviate/weaviate-semantic-schemas/master/weaviate-Action-ontology-schema_org.min.json"
              },
              "mqttEnabled": false
            }
          ]
        }
      }
    ],
    "identifier": 46910840
  },
  {
    "context": [
      "How can I find, say \"career\" and change it's value before it is placed in the $OUTPUT_FILE? Example below:\n\n    name=james\n    age=22\n    city=belfast\n    career=consultation",
      "echo $my_json | jq -r --arg career \"consultation\" '.Parameters[] \n     | [.ParameterKey, if (.ParameterKey == \"career\") then $career else .ParameterValue end] \n     | join(\"=\")' > outputfile",
      "$ jq -Mr --argjson replace '{\"career\":\"consultation\"}' -f filter.jq data.json",
      "def from_entries(k;v): map({(k):v})|add;\ndef format_output:     keys[] as $k | if .[$k]!=\"\" then \"\\($k)=\\(.[$k])\" else \"#\\($k)=\" end;\n\n  .Parameters\n| from_entries(.ParameterKey;.ParameterValue)\n| . * $replace\n| format_output",
      "Sample output:\n\n    age=22\n    career=consultation\n    city=belfast\n    name=james"
    ],
    "utterance": "Update the value of 'career' to 'consultation' in the Parameters array before outputting key-value pairs on separate lines.",
    "expressions": [
      ".Parameters | map(if .ParameterKey == \"career\" then (.ParameterValue = \"consultation\") else . end)[] | .ParameterKey + \"=\" + .ParameterValue",
      ".Parameters[] | [.ParameterKey, if (.ParameterKey == \"career\") then \"consultation\" else .ParameterValue end] | join(\"=\")",
      "def from_entries(k;v): map({(k):v})|add;\ndef format_output: keys[] as $k | if .[$k]!=\"\" then \"\\($k)=\\(.[$k])\" else \"#\\($k)=\" end;\n.Parameters | from_entries(.ParameterKey;.ParameterValue) | . * {\"career\":\"consultation\"} | format_output"
    ],
    "data": [
      {
        "input": {
          "userid": 334,
          "Parameters": [
            {
              "ParameterValue": "james",
              "ParameterKey": "name"
            },
            {
              "ParameterValue": "22",
              "ParameterKey": "age"
            },
            {
              "ParameterValue": "belfast",
              "ParameterKey": "city"
            },
            {
              "ParameterValue": "software",
              "ParameterKey": "career"
            }
          ]
        },
        "output": [
          "name=james",
          "age=22",
          "city=belfast",
          "career=consultation"
        ]
      }
    ],
    "identifier": 46827655
  },
  {
    "context": [
      "i need a csv which give me the following result:",
      "2017-09-01T00:00:00.000+02:00,value3,10367.xxx,1",
      "jq -r '.[] | .key_as_string as $ks | .agg1.buckets[] | .key as $key \n           | .agg2.buckets[] | [$ks,$key,.key,.doc_count] | @csv' jsonfile"
    ],
    "utterance": "Produce a CSV where each row contains the date from key_as_string, the agg1 bucket key, the agg2 bucket key, and the agg2 doc_count for every combination in the nested aggregation result.",
    "expressions": [
      ".[] | .key_as_string as $ks | .agg1.buckets[] | .key as $key | .agg2.buckets[] | [$ks, $key, .key, .doc_count] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "key_as_string": "2017-09-01T00:00:00.000+02:00",
            "key": 1506808800000,
            "doc_count": 5628,
            "agg1": {
              "doc_count_error_upper_bound": 5,
              "sum_other_doc_count": 1193,
              "buckets": [
                {
                  "key": "value3",
                  "doc_count": 3469,
                  "agg2": {
                    "doc_count_error_upper_bound": 1,
                    "sum_other_doc_count": 3459,
                    "buckets": [
                      {
                        "key": "10367.xxx",
                        "doc_count": 1
                      },
                      {
                        "key": "10997.xxx",
                        "doc_count": 1
                      },
                      {
                        "key": "12055.xxx",
                        "doc_count": 1
                      },
                      {
                        "key": "12157.xxx",
                        "doc_count": 1
                      },
                      {
                        "key": "12435.xxx",
                        "doc_count": 1
                      },
                      {
                        "key": "12volt.xxx",
                        "doc_count": 1
                      },
                      {
                        "key": "13158.xxx",
                        "doc_count": 1
                      },
                      {
                        "key": "13507.xxx",
                        "doc_count": 1
                      },
                      {
                        "key": "13597.xxx",
                        "doc_count": 1
                      },
                      {
                        "key": "137.xxx",
                        "doc_count": 1
                      }
                    ]
                  }
                },
                {
                  "key": "value2",
                  "doc_count": 608,
                  "agg2": {
                    "doc_count_error_upper_bound": 0,
                    "sum_other_doc_count": 577,
                    "buckets": [
                      {
                        "key": "saasf.xxx",
                        "doc_count": 7
                      },
                      {
                        "key": "asfasf.xxx",
                        "doc_count": 5
                      },
                      {
                        "key": "sasfsd.xxx",
                        "doc_count": 3
                      },
                      {
                        "key": "werwer.xxx",
                        "doc_count": 3
                      },
                      {
                        "key": "werwre.xxx",
                        "doc_count": 3
                      },
                      {
                        "key": "a-werwr.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "aef.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "sadhdhh.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "dhsdfsdg.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "ertetrt.xxx",
                        "doc_count": 2
                      }
                    ]
                  }
                },
                {
                  "key": "value1",
                  "doc_count": 358,
                  "agg2": {
                    "doc_count_error_upper_bound": 0,
                    "sum_other_doc_count": 336,
                    "buckets": [
                      {
                        "key": "fhshfg.xxx",
                        "doc_count": 3
                      },
                      {
                        "key": "sgh.xxx",
                        "doc_count": 3
                      },
                      {
                        "key": "12.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "sbgs.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "dp-eca.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "ztuhfb.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "javascript.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "koi-fdhfh.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "sdfh.xxx",
                        "doc_count": 2
                      },
                      {
                        "key": "etz5.xxx",
                        "doc_count": 2
                      }
                    ]
                  }
                }
              ]
            }
          }
        ],
        "output": [
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"10367.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"10997.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"12055.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"12157.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"12435.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"12volt.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"13158.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"13507.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"13597.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value3\",\"137.xxx\",1",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"saasf.xxx\",7",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"asfasf.xxx\",5",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"sasfsd.xxx\",3",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"werwer.xxx\",3",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"werwre.xxx\",3",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"a-werwr.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"aef.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"sadhdhh.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"dhsdfsdg.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value2\",\"ertetrt.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"fhshfg.xxx\",3",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"sgh.xxx\",3",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"12.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"sbgs.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"dp-eca.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"ztuhfb.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"javascript.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"koi-fdhfh.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"sdfh.xxx\",2",
          "\"2017-09-01T00:00:00.000+02:00\",\"value1\",\"etz5.xxx\",2"
        ]
      }
    ],
    "identifier": 46727645
  },
  {
    "context": [
      "but how to search for a specific stop, for example basing on stopDescr - exact name or containing a string?",
      ".[].node.stops[] | select(.stopDesc == \"Big Wall\")"
    ],
    "utterance": "Find stops with stopDesc exactly equal to \"Big Wall\".",
    "expressions": [
      ".[].node.stops[] | select(.stopDesc == \"Big Wall\")"
    ],
    "data": [
      {
        "input": {
          "2017-09-15": {
            "key": "stops",
            "node": {
              "lastUpdate": "2017-09-15 05:15:26",
              "stops": [
                {
                  "stopId": 11000,
                  "stopCode": null,
                  "stopName": null,
                  "stopShortName": "1000",
                  "stopDesc": "Tom Tail",
                  "subName": "1000",
                  "zoneId": null,
                  "zoneName": null,
                  "stopUrl": "",
                  "locationType": null,
                  "parentStation": null,
                  "stopTimezone": "",
                  "wheelchairBoarding": null,
                  "virtual": null,
                  "nonpassenger": null,
                  "depot": null,
                  "ticketZoneBorder": null,
                  "onDemand": null,
                  "activationDate": "2017-09-14"
                },
                {
                  "stopId": 1100,
                  "stopCode": "04",
                  "stopName": "One Three",
                  "stopShortName": "1100",
                  "stopDesc": "Big Wall",
                  "subName": "04",
                  "zoneId": 1,
                  "zoneName": "Demo2",
                  "stopUrl": "",
                  "locationType": null,
                  "parentStation": null,
                  "stopTimezone": "",
                  "wheelchairBoarding": null,
                  "virtual": 0,
                  "nonpassenger": 0,
                  "depot": 0,
                  "ticketZoneBorder": 0,
                  "onDemand": 0,
                  "activationDate": "2017-09-24"
                }
              ]
            }
          }
        },
        "output": {
          "stopId": 1100,
          "stopCode": "04",
          "stopName": "One Three",
          "stopShortName": "1100",
          "stopDesc": "Big Wall",
          "subName": "04",
          "zoneId": 1,
          "zoneName": "Demo2",
          "stopUrl": "",
          "locationType": null,
          "parentStation": null,
          "stopTimezone": "",
          "wheelchairBoarding": null,
          "virtual": 0,
          "nonpassenger": 0,
          "depot": 0,
          "ticketZoneBorder": 0,
          "onDemand": 0,
          "activationDate": "2017-09-24"
        }
      }
    ],
    "identifier": 46940636
  },
  {
    "context": [
      "Imagine I have a categories tree like this JSON file:",
      "How can I convert it to this flat table?",
      "The key here is to define a recursive function, like so:",
      "With your data, the filter:\n\n    .[]\n    | children(\"NULL\")\n    | @tsv\n\nproduces the tab-separated values shown below.",
      "Here is a solution which uses a recursive function:\n\ndef details($parent):\n   [.id, $parent, .text],\n   (.id as $p | .children[] | details($p))\n;\n\n[\"id\",\"parent_id\",\"text\"]\n, (.[] | details(null))\n| @tsv",
      "Here is another solution which uses jq's [recurse](https://stedolan.github.io/jq/manual/#recurse\\(f\\),recurse,recurse\\(f;condition\\),recurse_down) builtin:\n\n      [\"id\",\"parent_id\",\"text\"]\n    , (\n          .[]\n        | recurse(.id as $p| .children[] | .parent=$p )\n        | [.id, .parent, .text]\n      )\n    | @tsv "
    ],
    "utterance": "Convert a nested category tree into a flat table with columns: id, parent_id, and text, where root categories have parent_id as NULL or empty.",
    "expressions": [
      "def children($parent_id): .id as $id | [$id, $parent_id, .text], (.children[] | children($id)) ; .[] | children(\"NULL\") | @tsv",
      "def details($parent): [.id, $parent, .text], (.id as $p | .children[] | details($p)); [\"id\",\"parent_id\",\"text\"], (.[] | details(null)) | @tsv",
      "[\"id\",\"parent_id\",\"text\"], (.[] | recurse(.id as $p| .children[] | .parent=$p ) | [.id, .parent, .text]) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "text": "engine",
            "children": [
              {
                "id": "2",
                "text": "exhaust",
                "children": []
              },
              {
                "id": "3",
                "text": "cooling",
                "children": [
                  {
                    "id": "4",
                    "text": "cooling fan",
                    "children": []
                  },
                  {
                    "id": "5",
                    "text": "water pump",
                    "children": []
                  }
                ]
              }
            ]
          },
          {
            "id": "6",
            "text": "frame",
            "children": [
              {
                "id": "7",
                "text": "wheels",
                "children": []
              },
              {
                "id": "8",
                "text": "brakes",
                "children": [
                  {
                    "id": "9",
                    "text": "brake calipers",
                    "children": []
                  }
                ]
              },
              {
                "id": "10",
                "text": "cables",
                "children": []
              }
            ]
          }
        ],
        "output": "1\tNULL\tengine\n2\t1\texhaust\n3\t1\tcooling\n4\t3\tcooling fan\n5\t3\twater pump\n6\tNULL\tframe\n7\t6\twheels\n8\t6\tbrakes\n9\t8\tbrake calipers\n10\t6\tcables"
      }
    ],
    "identifier": 46896564
  },
  {
    "context": [
      "I want to find the \"time\" key and replace the string by dropping off the last 3 chars. The resulting document would be:\n\n    {\n        \"records\" : [\n                {\n                    \"time\": \"123456789\"\n    \n                },\n                {\n                    \"time\": \"123456789\"\n                }\n    \n        ]\n    }",
      "With **jq** **`sub()`** function:\n\n    jq '.records[].time |= sub(\"[0-9]{3}$\";\"\")' file",
      "Or even simpler: via dividing the `time` value by `1000`:\n\n    jq '.records[].time |= (tonumber / 1000 | tostring)' file",
      "Here is a solution using `|=` and [string slicing](https://stedolan.github.io/jq/manual/#Array/StringSlice:.[10:15])\n\n    .records[].time |= .[:-3]",
      "The following works with jq version 1.4 or later:\n\n    jq '.records[].time |= .[:-3]' file.json"
    ],
    "utterance": "Replace the value of every \"time\" key in all records by removing the last three characters, returning the entire updated document.",
    "expressions": [
      ".records[].time |= sub(\"[0-9]{3}$\";\"\")",
      ".records[].time |= .[:-3]",
      ".records[].time |= (tonumber / 1000 | tostring)"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "time": "123456789000"
            },
            {
              "time": "123456789000"
            }
          ]
        },
        "output": {
          "records": [
            {
              "time": "123456789"
            },
            {
              "time": "123456789"
            }
          ]
        }
      }
    ],
    "identifier": 46915043
  },
  {
    "context": [
      "I was wondering if there is a way with `jq` to simply check if the provided string is a valid JSON. ... I get a `true/false` or `1/0` from jq.",
      "if jq -e . &gt;/dev/null 2&gt;&amp;1 &lt;&lt;&lt;&quot;$json_string&quot;; then\n    echo \"Parsed JSON successfully and got something other than false/null\"\nelse\n    echo \"Failed to parse JSON, or got false/null\"\nfi",
      "echo $json_string | jq -e . &gt;/dev/null 2&gt;&amp;1  | echo ${PIPESTATUS[1]}",
      "jq -reM '\"\"' &lt;&lt;&lt;'<MAYBE_INVALID_JSON>' 1&gt;/dev/null",
      "echo \"$my_potential_json\"|jq empty > /dev/null 2>&1\nif [ $? -eq 0 ]; then\n    echo \"found valid json:$my_potential_json\"\n    do_whatever...."
    ],
    "utterance": "Determine whether a string contains valid JSON data and return a true/false or 1/0 status.",
    "expressions": [
      "jq -e . >/dev/null 2>&1 <<< \"$json_string\"",
      "echo \"$json_string\" | jq -e . >/dev/null 2>&1",
      "jq -reM '\"\"' <<< \"$json_string\" 1>/dev/null",
      "echo \"$my_potential_json\" | jq empty > /dev/null 2>&1"
    ],
    "data": [
      {
        "input": "error services-migration/foobar: Not found: services-migration/foobar",
        "output": false
      },
      {
        "input": "{ \"foo\": 42 }",
        "output": true
      },
      {
        "input": "null",
        "output": true
      }
    ],
    "identifier": 46954692
  },
  {
    "context": [
      "I need to keep the full structure but filter out the \"non-configurable\" child json blocks.",
      "Bonus marks to also filter out some of the fields in the sub-blocks, ie remove the credential and type lines.",
      "So desired output is:\n\n    {\n      \"properties\": {\n        \".properties.backup_options\": {\n          \"configurable\": true,\n          \"value\": \"disable\",\n          \"optional\": false\n        },\n        \".properties.backup_options.enable.cron_schedule\": {\n          \"configurable\": true,\n          \"value\": null,\n          \"optional\": false\n        },\n        \".properties.backup_options.enable.backup_all_masters\": {\n          \"configurable\": true,\n          \"value\": true,\n          \"optional\": false\n        }       \n    }\n",
      "$ jq '.properties |=\nwith_entries(select(.value.configurable)\n  | .value |= {configurable,value,optional}\n)' input.json",
      ".properties |= reduce keys[] as $k (. ;\n    if   .[$k].configurable \n    then .[$k] |= {configurable,value,optional} \n    else delpaths([[$k]]) end\n)"
    ],
    "utterance": "Keep only properties where configurable is true and include only the configurable, value, and optional fields in their objects.",
    "expressions": [
      ".properties |= with_entries(select(.value.configurable) | .value |= {configurable,value,optional})",
      ".properties |= reduce keys[] as $k (. ; if .[$k].configurable then .[$k] |= {configurable,value,optional} else delpaths([[$k]]) end )",
      "def objmap(cond;update): reduce keys[] as $k (.; if .[$k]|cond then .[$k]|=update else delpaths([[$k]]) end );\n.properties |= objmap(.configurable; {configurable,value,optional})"
    ],
    "data": [
      {
        "input": {
          "properties": {
            ".properties.backup_options": {
              "type": "selector",
              "configurable": true,
              "credential": false,
              "value": "disable",
              "optional": false
            },
            ".properties.backup_options.enable.cron_schedule": {
              "type": "string",
              "configurable": true,
              "credential": false,
              "value": null,
              "optional": false
            },
            ".properties.backup_options.enable.backup_all_masters": {
              "type": "boolean",
              "configurable": true,
              "credential": false,
              "value": true,
              "optional": false
            },
            ".properties.backups": {
              "type": "selector",
              "configurable": false,
              "credential": false,
              "value": "disable",
              "optional": false
            },
            ".properties.backups.enable.endpoint_url": {
              "type": "string",
              "configurable": false,
              "credential": false,
              "value": null,
              "optional": true
            }
          }
        },
        "output": {
          "properties": {
            ".properties.backup_options": {
              "configurable": true,
              "value": "disable",
              "optional": false
            },
            ".properties.backup_options.enable.cron_schedule": {
              "configurable": true,
              "value": null,
              "optional": false
            },
            ".properties.backup_options.enable.backup_all_masters": {
              "configurable": true,
              "value": true,
              "optional": false
            }
          }
        }
      }
    ],
    "identifier": 46947523
  },
  {
    "context": [
      "Use `jq` itself:",
      "my_formatted_json=$(jq -n '{\n  \"api_key\": \"XXXXXXXXXX-7AC9-D655F83B4825\",\n  \"app_guid\": \"XXXXXXXXXXXXXX\",\n  \"time_start\": 1508677200,\n  \"time_end\": 1508763600,\n  \"traffic\": [\"event\"],\n  \"traffic_including\": [\"unattributed_traffic\"],\n  \"time_zone\": \"Australia/NSW\",\n  \"delivery_format\": \"csv\",\n  \"columns_order\": [\n    \"attribution_attribution_action\",\n    \"attribution_campaign\",\n    ...,\n    \"timestamp_utc\"\n  ]\n}')",
      "# now use jq filter to read raw text and construct legal json object\njson_construct=$(jq -MRn '[inputs]|map(split(\" \")|{(.[0]):.[1]})|add' <<EOF\napi_key $key\napp_guid $guid\nEOF)\n\necho $json_construct",
      "$ ./script.sh\n{ \"api_key\": \"XXXXXXXXXX-7AC9-D655F83B4825\", \"app_guid\": \"XXXXXXXXXXXXXX\" }"
    ],
    "utterance": "Create a structured object with specified string, number, and array values directly in the command line.",
    "expressions": [
      "jq -n '{\n  \"api_key\": \"XXXXXXXXXX-7AC9-D655F83B4825\",\n  \"app_guid\": \"XXXXXXXXXXXXXX\",\n  \"time_start\": 1508677200,\n  \"time_end\": 1508763600,\n  \"traffic\": [\"event\"],\n  \"traffic_including\": [\"unattributed_traffic\"],\n  \"time_zone\": \"Australia/NSW\",\n  \"delivery_format\": \"csv\",\n  \"columns_order\": [\n    \"attribution_attribution_action\",\n    \"attribution_campaign\",\n    \"attribution_campaign_id\",\n    \"attribution_creative\",\n    \"attribution_date_adjusted\",\n    \"attribution_date_utc\",\n    \"attribution_matched_by\",\n    \"attribution_matched_to\",\n    \"attribution_network\",\n    \"attribution_network_id\",\n    \"attribution_seconds_since\",\n    \"attribution_site_id\",\n    \"attribution_site_id\",\n    \"attribution_tier\",\n    \"attribution_timestamp\",\n    \"attribution_timestamp_adjusted\",\n    \"attribution_tracker\",\n    \"attribution_tracker_id\",\n    \"attribution_tracker_name\",\n    \"count\",\n    \"custom_dimensions\",\n    \"device_id_adid\",\n    \"device_id_android_id\",\n    \"device_id_custom\",\n    \"device_id_idfa\",\n    \"device_id_idfv\",\n    \"device_id_kochava\",\n    \"device_os\",\n    \"device_type\",\n    \"device_version\",\n    \"dimension_count\",\n    \"dimension_data\",\n    \"dimension_sum\",\n    \"event_name\",\n    \"event_time_registered\",\n    \"geo_city\",\n    \"geo_country\",\n    \"geo_lat\",\n    \"geo_lon\",\n    \"geo_region\",\n    \"identity_link\",\n    \"install_date_adjusted\",\n    \"install_date_utc\",\n    \"install_device_version\",\n    \"install_devices_adid\",\n    \"install_devices_android_id\",\n    \"install_devices_custom\",\n    \"install_devices_email_0\",\n    \"install_devices_email_1\",\n    \"install_devices_idfa\",\n    \"install_devices_ids\",\n    \"install_devices_ip\",\n    \"install_devices_waid\",\n    \"install_matched_by\",\n    \"install_matched_on\",\n    \"install_receipt_status\",\n    \"install_san_original\",\n    \"install_status\",\n    \"request_ip\",\n    \"request_ua\",\n    \"timestamp_adjusted\",\n    \"timestamp_utc\"\n  ]\n}'",
      "jq -MRn '[inputs]|map(split(\" \")|{(.[0]):.[1]})|add'"
    ],
    "identifier": 46903037
  },
  {
    "context": [
      "I am trying to fetch the Group Id using the Group Name.",
      "the filter:\n\n    .SecurityGroups[] | select(.GroupName==\"MY1SG-PUBLIC-80\") | .GroupId\n\nproduces:\n \n    \"sg-ee0c979c\"",
      "It might be worthwhile considering this alternative filter:\n\n    .[][]|select(.GroupName==\"MY1SG-PUBLIC-80\")|.GroupId"
    ],
    "utterance": "Fetch the GroupId where GroupName is \"MY1SG-PUBLIC-80\".",
    "expressions": [
      ".SecurityGroups[] | select(.GroupName==\"MY1SG-PUBLIC-80\") | .GroupId",
      ".[][]|select(.GroupName==\"MY1SG-PUBLIC-80\")|.GroupId"
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "IpPermissionsEgress": [
                {
                  "IpProtocol": "-1"
                }
              ],
              "Description": "launch-wizard-2 created 2017-10-21T09:19:40.007-04:00",
              "GroupName": "MY1SG-PUBLIC-80",
              "VpcId": "vpc-ceed12b7",
              "OwnerId": "712503525534",
              "GroupId": "sg-ee0c979c"
            }
          ]
        },
        "output": "sg-ee0c979c"
      }
    ],
    "identifier": 46965781
  },
  {
    "context": [
      "From the class images=>classifiers=>classes:\"class\" & \"score\" are the values that I want to save in a csv file.",
      "cat foo.json | jq \".images[].classifiers[].classes[] | [.class, .score] | @csv \"",
      "jq -r '.images[0].classifiers[0].classes[0] | [.class, .score] | @csv' input.json",
      ".. | objects | select(has(\"class\")) | [.class,.score] | @csv",
      "getpath( paths(has(\"class\")?) ) | [.class,.score] | @csv"
    ],
    "utterance": "Extract the values of \"class\" and \"score\" from all objects within images \u2192 classifiers \u2192 classes, formatted as CSV rows.",
    "expressions": [
      ".images[].classifiers[].classes[] | [.class, .score] | @csv",
      ".images[0].classifiers[0].classes[0] | [.class, .score] | @csv",
      ".. | objects | select(has(\"class\")) | [.class,.score] | @csv",
      "getpath( paths(has(\"class\")?) ) | [.class,.score] | @csv"
    ],
    "data": [
      {
        "input": {
          "custom_classes": 2,
          "images": [
            {
              "classifiers": [
                {
                  "classes": [
                    {
                      "class": "football",
                      "score": 0.867376
                    }
                  ],
                  "classifier_id": "players_367677167",
                  "name": "players"
                }
              ],
              "image": "1496A400EDC351FD.jpg"
            }
          ],
          "images_processed": 1
        },
        "output": [
          "\"football\",0.867376"
        ]
      }
    ],
    "identifier": 46956201
  },
  {
    "context": [
      "echo '{\"x\" : 1}' | jq '. , .'",
      "Multiple filters in `jq` are separated by a comma. `. , .` duplicates the output because it means two times *the current context*.",
      "If two filters are separated by a comma, then the input  will  be  fed into both and there will be multiple outputs: first, all of the outputs produced by the left expression, and then all of the outputs produced by the right. For instance, filter .foo, .bar, produces both the \"foo\" fields and \"bar\" fields as separate outputs."
    ],
    "utterance": "Output the input object twice in succession.",
    "expressions": [
      ". , ."
    ],
    "data": [
      {
        "input": {
          "x": 1
        },
        "output": [
          {
            "x": 1
          },
          {
            "x": 1
          }
        ]
      }
    ],
    "identifier": 47016326
  },
  {
    "context": [
      "Goal: Find all SGs with ingress rules on port 22 with cidr 0.0.0.0/0",
      "Here is a jq filter which will return only SecurityGroups with an IpPermission with FromPort=22 and an IpRange CidrIp of \"0.0.0.0/0\":\n\n      .SecurityGroups[]\n    | select(.IpPermissions[] | .FromPort == 22 and .IpRanges[].CidrIp == \"0.0.0.0/0\")",
      "aws ec2 describe-security-groups --output json --query 'SecurityGroups[*].[GroupName,GroupId,IpPermissions[?ToPort==`22`]\n.[IpRanges[?CidrIp==`0.0.0.0/0`]]]' | jq 'map(select(.[2] | flatten | length > 0))'"
    ],
    "utterance": "Find all security groups that have an ingress rule allowing port 22 from 0.0.0.0/0.",
    "expressions": [
      ".SecurityGroups[] | select(.IpPermissions[] | .FromPort == 22 and .IpRanges[].CidrIp == \"0.0.0.0/0\")",
      "map(select(.[2] | flatten | length > 0))"
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "Description": "SG 1",
              "IpPermissions": [
                {
                  "PrefixListIds": [],
                  "FromPort": 22,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 22,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                }
              ],
              "GroupName": "SG 1",
              "VpcId": "vpc-12345678",
              "OwnerId": "1234567890",
              "GroupId": "sg-11111111"
            },
            {
              "Description": "SG 2",
              "IpPermissions": [
                {
                  "PrefixListIds": [],
                  "FromPort": 22,
                  "IpRanges": [],
                  "ToPort": 22,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [
                    {
                      "UserId": "1234567890",
                      "GroupId": "sg-abcdefab"
                    }
                  ],
                  "Ipv6Ranges": []
                },
                {
                  "PrefixListIds": [],
                  "FromPort": 443,
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "ToPort": 443,
                  "IpProtocol": "tcp",
                  "UserIdGroupPairs": [],
                  "Ipv6Ranges": []
                }
              ],
              "GroupName": "SG 2",
              "VpcId": "vpc-12345678",
              "OwnerId": "1234567890",
              "GroupId": "sg-22222222"
            }
          ]
        },
        "output": {
          "Description": "SG 1",
          "IpPermissions": [
            {
              "PrefixListIds": [],
              "FromPort": 22,
              "IpRanges": [
                {
                  "CidrIp": "0.0.0.0/0"
                }
              ],
              "ToPort": 22,
              "IpProtocol": "tcp",
              "UserIdGroupPairs": [],
              "Ipv6Ranges": []
            }
          ],
          "GroupName": "SG 1",
          "VpcId": "vpc-12345678",
          "OwnerId": "1234567890",
          "GroupId": "sg-11111111"
        }
      }
    ],
    "identifier": 46938368
  },
  {
    "context": [
      "input file is:",
      "{ \"env\": \"DC\", \"hosts\" : [ { \"apt_update_last_success\": \"1495991703\", \"architecture\": \"amd64\", \"hostname\": \"h1\" }, { \"apt_update_last_success\": \"1495991703\", \"architecture\": \"amd64\", \"hostname\": \"h2\" }, { \"apt_update_last_success\": \"1496045706\", \"architecture\": \"amd64\", \"hostname\": \"h3\" }, { \"apt_update_last_success\": \"1496045705\", \"architecture\": \"amd64\", \"hostname\": \"h4\" }, { \"apt_update_last_success\": \"1496049305\", \"architecture\": \"amd64\", \"hostname\": \"h5\" }, { \"apt_update_last_success\": \"1496049307\", \"architecture\": \"amd64\", \"hostname\": \"h6\" } ] }",
      "The right way is:",
      "jq '.hosts[] | select(.hostname==\"h6\")' ddd.json",
      "{ \"apt_update_last_success\": \"1496049307\", \"architecture\": \"amd64\", \"hostname\": \"h6\" }"
    ],
    "utterance": "Select the object in the hosts array where hostname equals \"h6\".",
    "expressions": [
      ".hosts[] | select(.hostname==\"h6\")"
    ],
    "data": [
      {
        "input": {
          "env": "DC",
          "hosts": [
            {
              "apt_update_last_success": "1495991703",
              "architecture": "amd64",
              "hostname": "h1"
            },
            {
              "apt_update_last_success": "1495991703",
              "architecture": "amd64",
              "hostname": "h2"
            },
            {
              "apt_update_last_success": "1496045706",
              "architecture": "amd64",
              "hostname": "h3"
            },
            {
              "apt_update_last_success": "1496045705",
              "architecture": "amd64",
              "hostname": "h4"
            },
            {
              "apt_update_last_success": "1496049305",
              "architecture": "amd64",
              "hostname": "h5"
            },
            {
              "apt_update_last_success": "1496049307",
              "architecture": "amd64",
              "hostname": "h6"
            }
          ]
        },
        "output": {
          "apt_update_last_success": "1496049307",
          "architecture": "amd64",
          "hostname": "h6"
        }
      }
    ],
    "identifier": 47012967
  },
  {
    "context": [
      "Say we have the following JSON:\r\n\r\n    [\r\n      {\r\n        \"dir-1\": [\r\n          \"file-1.1\",\r\n          \"file-1.2\"\r\n        ]\r\n      },\r\n      \"dir-1\",\r\n      {\r\n        \"dir-2\": [\r\n          \"file-2.1\"\r\n        ]\r\n      }\r\n    ]",
      "And we want to get the next output:\r\n\r\n      \"dir-1/file-1.1\"\r\n      \"dir-1/file-1.2\"\r\n      \"dir-1\"\r\n      \"dir-2/file-2.1\"\r\n\r\ni.e. to get the paths to all leafs, joining items with `/`.",
      "$ jq --stream '\r\nselect(length == 2) | [(.[0][] | select(strings)), .[1]] | join(\"/\")\r\n' source-file",
      "tostream | select(length==2) | .[0] |= map(strings) | flatten | join(\"/\")",
      "def slashpaths($p):\r\n  def concat($p;$k): if $p==\"\" then $k else \"\\($p)/\\($k)\" end;\r\n  if   type==\"array\"  then .[] | slashpaths($p)\r\n  elif type==\"object\" then\r\n       keys_unsorted[] as $k\r\n     | .[$k] | slashpaths(concat($p;$k))\r\n  else concat($p;.) end;\r\nslashpaths(\"\")",
      "paths(scalars) as $p\r\n| getpath($p) as $v\r\n| ($p | map(strings) + [$v])\r\n| join(\"/\")"
    ],
    "utterance": "List all leaf paths in the structure, using '/' as a separator, including both keys and string values.",
    "expressions": [
      "--stream 'select(length == 2) | [(.[0][] | select(strings)), .[1]] | join(\"/\")'",
      "tostream | select(length==2) | .[0] |= map(strings) | flatten | join(\"/\")",
      "def slashpaths($p):\n  def concat($p;$k): if $p==\"\" then $k else \"\\($p)/\\($k)\" end;\n  if   type==\"array\"  then .[] | slashpaths($p)\n  elif type==\"object\" then\n       keys_unsorted[] as $k\n     | .[$k] | slashpaths(concat($p;$k))\n  else concat($p;.) end;\nslashpaths(\"\")",
      "paths(scalars) as $p\n| getpath($p) as $v\n| ($p | map(strings) + [$v])\n| join(\"/\")"
    ],
    "data": [
      {
        "input": [
          {
            "dir-1": [
              "file-1.1",
              "file-1.2"
            ]
          },
          "dir-1",
          {
            "dir-2": [
              "file-2.1"
            ]
          }
        ],
        "output": [
          "dir-1/file-1.1",
          "dir-1/file-1.2",
          "dir-1",
          "dir-2/file-2.1"
        ]
      }
    ],
    "identifier": 47004904
  },
  {
    "context": [
      "However, in the next `cURL` statement, I need to use the integer from `AssetID` in order to execute it. In short, how can I take the `AssetID` value and store it to a variable to be used in the next statement?",
      "curl '...' | jq --raw-output '.AssetID'",
      "asset_ID=$( curl '...' | jq --raw-output '.AssetID' )"
    ],
    "utterance": "Extract the value of the AssetID key from the output and print it.",
    "expressions": [
      ".AssetID",
      ".AssetID // empty",
      ".[\"AssetID\"]"
    ],
    "data": [
      {
        "input": {
          "WorkgroupID": 1,
          "AssetID": 57,
          "AssetName": "apiTest",
          "AssetType": "apiTest",
          "DnsName": "apiTest",
          "DomainName": "domainNameString",
          "IPAddress": "ipAddressHere",
          "MacAddress": null,
          "OperatingSystem": null,
          "LastUpdateDate": "2017-10-30T15:18:05.67-07:00"
        },
        "output": 57
      }
    ],
    "identifier": 47018863
  },
  {
    "context": [
      "I want to know which id was passed in `a.json` and which is failed now in `b.json`.",
      "How to produce `expected.json` from `a.json` and `b.json` ?",
      "A simpler way is just:\r\n\r\n       $a[]\r\n     | select(.status == \"passed\") as $passed\r\n     | $b[]\r\n     | select( $passed.id == .id and .status == \"failed\")",
      "Program:\r\n\r\n    ([$a[] | select(.status==\"passed\") | {(.id): true}] | add) as $passed\r\n    | .[] | select(.status == \"failed\" and $passed[.id])"
    ],
    "utterance": "Find all entries where the id has status \"passed\" in a.json and status \"failed\" in b.json.",
    "expressions": [
      "$a[] | select(.status == \"passed\") as $passed | $b[] | select($passed.id == .id and .status == \"failed\")",
      "([$a[] | select(.status==\"passed\") | {(.id): true}] | add) as $passed | .[] | select(.status == \"failed\" and $passed[.id])"
    ],
    "data": [
      {
        "input": [
          {
            "status": "passed",
            "id": "id1"
          },
          {
            "status": "passed",
            "id": "id2"
          }
        ],
        "output": null
      },
      {
        "input": [
          {
            "status": "passed",
            "id": "id1"
          },
          {
            "status": "failed",
            "id": "id2"
          }
        ],
        "output": [
          {
            "status": "failed",
            "id": "id2"
          }
        ]
      }
    ],
    "identifier": 47018589
  },
  {
    "context": [
      "I want to delete the 1st level `pages` entire object and key, but retain the lower level `pages` intact.",
      "Using the builtin function `del`:\n\n$ jq 'del(.pages)' myfile.json",
      "To remove all pages everywhere, instead of just the outer level, you would use something like\n\n$ jq 'del(.. | .pages?)' myfile.json",
      "Since your input file is quite large, it might be worthwhile using jq 1.5's streaming parser:\n\n    jq -n --stream '\n      fromstream(inputs|select((length == 2 and .[0][0] == \"pages\")|not))\n    ' input.json"
    ],
    "utterance": "Remove the top-level 'pages' key and its entire object, but keep 'pages' keys at lower levels unchanged.",
    "expressions": [
      "del(.pages)"
    ],
    "data": [
      {
        "input": {
          "pages": {
            "elems": {
              "some": "stuff"
            }
          },
          "actions": {
            "pages": {
              "other": "stuff"
            }
          }
        },
        "output": {
          "actions": {
            "pages": {
              "other": "stuff"
            }
          }
        }
      }
    ],
    "identifier": 47023795
  },
  {
    "context": [
      "Using jq, I'd like to cherry-pick key/value pairs from the following json:",
      "For the sake of an example, I'd like to parse the following keys and their values: \"Project\", \"name\", \"net_tier\", \"vcpu\", \"mem\", \"disk001\", \"disk002\".",
      "I'm able to parse individual elements without much issue, but due to the hierarchical nature of the full parse, I've not had much luck parsing down different branches (i.e. both networks and hardware > disks).",
      "For clarity, the output I'm going for is a comma-separated CSV.",
      "Here\u2019s one way you could achieve the desired output.",
      "[\"project\",\"name\",\"net_tier\",\"vcpu\",\"mem\",\"disk001\",\"disk002\"],\n  [.project]\n+ (.nodes[] | .networks[] as $n |\n    [\n      .name,\n      $n.net_tier,\n      (.hardware |\n        .vcpu,\n        .mem,\n        (.disks | add[\"disk001\",\"disk002\"])\n      )\n    ]\n  )\n| @csv",
      "def s(f): first(.. | f? // empty) // null;\n[s(.project), s(.name), s(.net_tier), s(.vcpu), s(.mem), s(.disk001), s(.disk002)]| @csv",
      ". as $d\n| [\"project\", \"name\", \"net_tier\", \"vcpu\", \"mem\", \"disk001\",\"disk002\"]\n| (., map( . as $v | $d | s(.[$v])))\n| @csv",
      ".project as $p\n| [\"project\", \"name\", \"net_tier\", \"vcpu\", \"mem\", \"disk001\",\"disk002\"] as $h\n| ($h,\n   (.nodes[] as $d\n   | $h\n   | map( . as $v | $d | s(.[$v]) )\n   | .[0] = $p)\n   ) | @csv",
      "{\n  tiers: [ .nodes[].networks[].net_tier ] | unique\n, disks: [ .nodes[].hardware.disks[] | keys[] | select(startswith(\"disk\")) ] | unique\n} as $n\n\ndef column_names($n): [ \"project\", \"name\" ] + $n.tiers + [\"vcpu\", \"mem\"] + $n.disks ;\ndef tiers($n):        [ $n.tiers[] as $t | .networks[] | if .net_tier==$t then $t else null end ] ;\ndef disks($n):        [ $n.disks[] as $d | map(select(.[$d]!=null)|.[$d])[0] ] ;\ndef rows($n):\n    .project as $project\n  | .nodes[]\n  | .name as $name\n  | tiers($n) as $tier_values\n  | .hardware\n  | .vcpu as $vcpu\n  | .mem as $mem\n  | .disks\n  | disks($n) as $disk_values\n  | [$project, $name] + $tier_values + [$vcpu, $mem] + $disk_values\n;\ncolumn_names($n), rows($n)\n| @csv"
    ],
    "utterance": "Extract the values of the keys: project, name, net_tier, vcpu, mem, disk001, and disk002 from nested structures and output them as comma-separated CSV rows.",
    "expressions": [
      "[\"project\",\"name\",\"net_tier\",\"vcpu\",\"mem\",\"disk001\",\"disk002\"],\n  [.project]\n+ (.nodes[] | .networks[] as $n |\n    [\n      .name,\n      $n.net_tier,\n      (.hardware |\n        .vcpu,\n        .mem,\n        (.disks | add[\"disk001\",\"disk002\"])\n      )\n    ]\n  )\n| @csv",
      "def s(f): first(.. | f? // empty) // null;\n[s(.project), s(.name), s(.net_tier), s(.vcpu), s(.mem), s(.disk001), s(.disk002)] | @csv",
      ". as $d\n| [\"project\", \"name\", \"net_tier\", \"vcpu\", \"mem\", \"disk001\",\"disk002\"]\n| (., map( . as $v | $d | s(.[$v])))\n| @csv",
      ".project as $p\n| [\"project\", \"name\", \"net_tier\", \"vcpu\", \"mem\", \"disk001\",\"disk002\"] as $h\n| ($h,\n   (.nodes[] as $d\n   | $h\n   | map( . as $v | $d | s(.[$v]) )\n   | .[0] = $p)\n   ) | @csv",
      "{\n  tiers: [ .nodes[].networks[].net_tier ] | unique\n, disks: [ .nodes[].hardware.disks[] | keys[] | select(startswith(\"disk\")) ] | unique\n} as $n\n\ndef column_names($n): [ \"project\", \"name\" ] + $n.tiers + [\"vcpu\", \"mem\"] + $n.disks ;\ndef tiers($n):        [ $n.tiers[] as $t | .networks[] | if .net_tier==$t then $t else null end ] ;\ndef disks($n):        [ $n.disks[] as $d | map(select(.[$d]!=null)|.[$d])[0] ] ;\ndef rows($n):\n    .project as $project\n  | .nodes[]\n  | .name as $name\n  | tiers($n) as $tier_values\n  | .hardware\n  | .vcpu as $vcpu\n  | .mem as $mem\n  | .disks\n  | disks($n) as $disk_values\n  | [$project, $name] + $tier_values + [$vcpu, $mem] + $disk_values\n;\ncolumn_names($n), rows($n)\n| @csv"
    ],
    "data": [
      {
        "input": {
          "project": "Project X",
          "description": "This is a description of Project X",
          "nodes": [
            {
              "name": "server001",
              "detail001": "foo",
              "detail002": "bar",
              "networks": [
                {
                  "net_tier": "network_tier_001",
                  "ip_address": "10.1.1.10",
                  "gateway": "10.1.1.1",
                  "subnet_mask": "255.255.255.0",
                  "mac_address": "00:11:22:aa:bb:cc"
                }
              ],
              "hardware": {
                "vcpu": 1,
                "mem": 1024,
                "disks": [
                  {
                    "disk001": 40,
                    "detail001": "foo"
                  },
                  {
                    "disk002": 20,
                    "detail001": "bar"
                  }
                ]
              },
              "os": "debian8",
              "geo": {
                "region": "001",
                "country": "Sweden",
                "datacentre": "Malmo"
              },
              "detail003": "baz"
            }
          ],
          "detail001": "foo"
        },
        "output": "\"project\",\"name\",\"net_tier\",\"vcpu\",\"mem\",\"disk001\",\"disk002\"\n\"Project X\",\"server001\",\"network_tier_001\",1,1024,40,20"
      }
    ],
    "identifier": 46864773
  },
  {
    "context": [
      "I am just trying with this basic line, but I am not getting, here is the command.",
      "echo {\u201cx\u201d:1} | jq '[ . ]'",
      "It is showing the error as follows.",
      "parse error: Invalid numeric literal at line 1, column 9",
      "The expected output is :",
      "[{\"x\":1}]",
      "echo '{\"x\":1}{\"y\":1}' | jq -s '.'",
      "[",
      "  {",
      "    \"x\": 1",
      "  },",
      "  {",
      "    \"y\": 1",
      "  }",
      "]"
    ],
    "utterance": "Combine multiple adjacent JSON objects in input into an array of objects.",
    "expressions": [
      "jq -s '.'"
    ],
    "data": [
      {
        "input": "{\"x\":1}{\"y\":1}",
        "output": [
          {
            "x": 1
          },
          {
            "y": 1
          }
        ]
      }
    ],
    "identifier": 47032224
  },
  {
    "context": [
      "I would like to append the subject and template_id so that the output.json looks like below.",
      "jq '.template_id=\"someID\" | .personalizations[0].subject=\"Some subject\"' input.json"
    ],
    "utterance": "Add a field 'template_id' with value 'someID' at the root and a field 'subject' with value 'Some subject' inside the first element of 'personalizations'.",
    "expressions": [
      ".template_id=\"someID\" | .personalizations[0].subject=\"Some subject\""
    ],
    "data": [
      {
        "input": {
          "content": [],
          "from": {
            "email": "someemail@gmail.com",
            "name": "Some Name"
          },
          "reply_to": {
            "email": "someemail@gmail.com",
            "name": "Some Name"
          },
          "personalizations": [
            {
              "to": [
                {
                  "email": "someemail@gmail.com"
                },
                {
                  "email": "someotheremail@gmail.com"
                }
              ]
            }
          ]
        },
        "output": {
          "content": [],
          "from": {
            "email": "someemail@gmail.com",
            "name": "Some Name"
          },
          "reply_to": {
            "email": "someemail@gmail.com",
            "name": "Some Name"
          },
          "personalizations": [
            {
              "to": [
                {
                  "email": "someemail@gmail.com"
                },
                {
                  "email": "someotheremail@gmail.com"
                }
              ],
              "subject": "Some subject"
            }
          ],
          "template_id": "someID"
        }
      }
    ],
    "identifier": 47053855
  },
  {
    "context": [
      "What I want to do now is calculate the day's total values and also do some math. (in this case either add or multiply by 3). The results shall be added to the 'consolidated.json' file, which should contain one object for each day.",
      "I know I can get the totals of INPUT.json with [.[]|.VALUE_ONE]|add and [.[]|.VALUE_TWO*3]|add. But I am not sure how to get this into the desired structure and use last day's totals.",
      "def aggregate:\n  {DATE: (.[0]|.DATE|split(\" \")[0]),\n   VALUE_ONE_TODAY: (map(.VALUE_ONE) | add),\n   VALUE_TWO_TODAY: (map(.VALUE_TWO) | add)}\n  ;\n\n.[-1] as $previous\n| ($i | aggregate\n   | {DATE,\n      VALUE_ONE_TODAY,\n      VALUE_ONE_TOTAL : ($previous.VALUE_ONE_TOTAL + .VALUE_ONE_TODAY),\n      VALUE_THREE_TODAY : ($previous.VALUE_TWO_TOTAL + .VALUE_TWO_TODAY) }\n   |  .VALUE_THREE_TOTAL = ($previous.VALUE_THREE_TOTAL + 3 * .VALUE_THREE_TODAY) ) as $today\n| . + [$today]",
      "jq -f consolidate.jq --argfile i input.json consolidated.json",
      "The added entry is as requested, namely:\n{\n  \"DATE\": \"04.10.2017\",\n  \"VALUE_ONE_TODAY\": 70,\n  \"VALUE_ONE_TOTAL\": 960,\n  \"VALUE_THREE_TODAY\": 10,\n  \"VALUE_THREE_TOTAL\": 164\n}"
    ],
    "utterance": "Aggregate daily totals for VALUE_ONE and VALUE_TWO from new entries, calculate VALUE_THREE_TODAY as the total of VALUE_TWO for the day, and update consolidated data by incrementing VALUE_ONE_TOTAL by VALUE_ONE_TODAY and VALUE_THREE_TOTAL by 3 times VALUE_THREE_TODAY, appending the new day's results.",
    "expressions": [
      "def aggregate:\n  {DATE: (.[0]|.DATE|split(\" \")[0]),\n   VALUE_ONE_TODAY: (map(.VALUE_ONE) | add),\n   VALUE_TWO_TODAY: (map(.VALUE_TWO) | add)}\n  ;\n\n.[-1] as $previous\n| ($i | aggregate\n   | {DATE,\n      VALUE_ONE_TODAY,\n      VALUE_ONE_TOTAL : ($previous.VALUE_ONE_TOTAL + .VALUE_ONE_TODAY),\n      VALUE_THREE_TODAY : ($previous.VALUE_TWO_TOTAL + .VALUE_TWO_TODAY) }\n   |  .VALUE_THREE_TOTAL = ($previous.VALUE_THREE_TOTAL + 3 * .VALUE_THREE_TODAY) ) as $today\n| . + [$today]"
    ],
    "data": [
      {
        "input": [
          {
            "DATE": "04.10.2017 10:20",
            "ID": "x",
            "VALUE_ONE": 20,
            "VALUE_TWO": 3
          },
          {
            "DATE": "04.10.2017 12:50",
            "ID": "x",
            "VALUE_ONE": 40,
            "VALUE_TWO": 5
          },
          {
            "DATE": "04.10.2017 14:20",
            "ID": "x",
            "VALUE_ONE": 10,
            "VALUE_TWO": 2
          }
        ],
        "output": {
          "DATE": "04.10.2017",
          "VALUE_ONE_TODAY": 70,
          "VALUE_ONE_TOTAL": 960,
          "VALUE_THREE_TODAY": 10,
          "VALUE_THREE_TOTAL": 164
        }
      }
    ],
    "identifier": 47002191
  },
  {
    "context": [
      "I was looking for something output like this: \n\n    id:104909913,QBOL-QUERY-SCHEMA:/tmp/2017-10-31/5031/104909913.dir/000",
      "The output:\n\n    id:104909913,QBOL-QUERY-SCHEMA:/tmp/2017-10-31/5031/104909913.dir/000",
      "jq -r '\"id:\\(.id),QBOL-QUERY-SCHEMA:\\(.qlog | fromjson | .[\"QBOL-QUERY-SCHEMA\"] | keys[0])\"' input.json",
      "\"id:\\(.id),\" + \n  (.qlog | fromjson | to_entries[0] | .key + \":\" +\n            (.value | to_entries[0] | .key) )"
    ],
    "utterance": "Print id and the first QBOL-QUERY-SCHEMA key from the qlog property in the format id:ID,QBOL-QUERY-SCHEMA:KEY_PATH",
    "expressions": [
      "\"id:\\(.id),QBOL-QUERY-SCHEMA:\\(.qlog | fromjson | .[\\\"QBOL-QUERY-SCHEMA\\\"] | keys[0])\"",
      "\"id:\\(.id),\" + (.qlog | fromjson | to_entries[0] | .key + \":\" + (.value | to_entries[0] | .key) )"
    ],
    "data": [
      {
        "input": {
          "id": 104909913,
          "path": "/tmp/2017-10-31/5031/104909913",
          "status": "done",
          "created_at": "2017-10-31T05:03:19Z",
          "updated_at": "2017-10-31T05:10:24Z",
          "command_type": "HiveCommand",
          "progress": 100,
          "qbol_session_id": 6527670,
          "qlog": "{\"QBOL-QUERY-SCHEMA\":{\"/tmp/2017-10-31/5031/104909913.dir/000\":[{\"ColumnType\":\"string\",\"ColumnName\":\"ts_date\"},{\"ColumnType\":\"bigint\",\"ColumnName\":\"testing_requests\"},{\"ColumnType\":\"bigint\",\"ColumnName\":\"testings_placed\"}]},\"EXECUTION_ENGINE\":\"mr\",\"QBOL-S3N-BYTES-READ\":1258754351,\"QBOL-S3N-BYTES-WRITTEN\":224,\"HIVE_VERSION\":\"0.13\"}",
          "resolved_macros": null,
          "pid": 27212,
          "template": "generic",
          "submit_time": 1509426199,
          "start_time": 1509426202,
          "end_time": 1509426624,
          "can_notify": false,
          "num_result_dir": 1,
          "pool": null,
          "timeout": null,
          "name": null,
          "command_source": "API",
          "account_id": 5031,
          "saved_query_mutable_id": null,
          "user_id": 12146,
          "label": "default",
          "meta_data": {
            "results_resource": "commands/104909913/results",
            "logs_resource": "commands/104909913/logs"
          },
          "uid": 5164,
          "perms": null,
          "command": {
            "query": "select * from abc ",
            "sample": false,
            "approx_mode": false,
            "approx_aggregations": false,
            "loader_table_name": null,
            "loader_stable": null,
            "md_cmd": false,
            "script_location": null
          },
          "instance": null
        },
        "output": "id:104909913,QBOL-QUERY-SCHEMA:/tmp/2017-10-31/5031/104909913.dir/000"
      }
    ],
    "identifier": 47049316
  },
  {
    "context": [
      "How would I get a count of the ones where `sapm_score > 40`?",
      "map(select(.sapm_score > 40)) | length",
      "count(.[] | select(.sapm_score > 40))",
      "reduce .[] as $s(0; if $s.spam_score > 40 then .+1 else . end)",
      "reduce inputs as $s(0; if $s.spam_score > 40 then .+1 else . end)",
      "cat input.json | jq -c '. | select(.sapm_score > 40)' | wc -l"
    ],
    "utterance": "Count the number of objects where sapm_score is greater than 40.",
    "expressions": [
      "map(select(.sapm_score > 40)) | length",
      "count(.[] | select(.sapm_score > 40))",
      "reduce .[] as $s(0; if $s.sapm_score > 40 then .+1 else . end)",
      "reduce inputs as $s(0; if $s.sapm_score > 40 then .+1 else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "sapm_score": 40.776
          },
          {
            "sapm_score": 17.376
          },
          {
            "sapm_score": 41.2
          }
        ],
        "output": 2
      }
    ],
    "identifier": 47063311
  },
  {
    "context": [
      "What I want to do is to overwrite file A `elements` array with file B's just adding the elements that repeat in both.",
      "I'd like to have a command that sees both files compared them and autodetects repeated objects from A and B and overwrite those in A with those in B",
      "here is a filter which updates objects of `A.json` with corresponding objects of `B.json` having the same `.id`:",
      "def INDEX(stream; idx_expr):\n  reduce stream as $row ({};\n    .[$row|idx_expr| if type != \"string\" then tojson else . end] |= $row);\n\ndef merge_by_id(a;b):\n  if b then INDEX(a[];.id) * INDEX(b[];.id) | map(.) else a end;\n\n  INDEX($b[];.id) as $i\n| map( .elements = merge_by_id(.elements; $i[.id].elements) )",
      "Note that the above solution assumes the `.id` of the elements in `A.json` are unique otherwise `merge_by_id` won't produce the desired output.  In that case the following filter should suffice:\n\ndef INDEX(stream; idx_expr):\n  reduce stream as $row ({};\n    .[$row|idx_expr| if type != \"string\" then tojson else . end] |= $row);\n\n  (INDEX($b[];.id) | map_values(INDEX(.elements[];.id))) as $i\n| map( $i[.id] as $o | if $o then .elements |= map($o[.id]//.) else . end )"
    ],
    "utterance": "For each object with the same .id in two files, overwrite matching elements in file A with those from file B by matching on their .id values.",
    "expressions": [
      "def INDEX(stream; idx_expr):\n  reduce stream as $row ({};\n    .[$row|idx_expr| if type != \"string\" then tojson else . end] |= $row);\n\ndef merge_by_id(a;b):\n  if b then INDEX(a[];.id) * INDEX(b[];.id) | map(.) else a end;\n\n  INDEX($b[];.id) as $i\n| map( .elements = merge_by_id(.elements; $i[.id].elements) )",
      "def INDEX(stream; idx_expr):\n  reduce stream as $row ({};\n    .[$row|idx_expr| if type != \"string\" then tojson else . end] |= $row);\n\n  (INDEX($b[];.id) | map_values(INDEX(.elements[];.id))) as $i\n| map( $i[.id] as $o | if $o then .elements |= map($o[.id]//.) else . end )"
    ],
    "identifier": 47022870
  },
  {
    "context": [
      "I want to convert JSON string into an array in bash.\r\nThe JSON string is passed to the bash script as an argument (it doesn&#39;t exist in a file).",
      "Is there a way of achieving it without using some temp files?",
      "Use the bash: `echo &quot;$json_data&quot; | jq &#39;.key&#39;`",
      "jq '.key' <<< \"$json_data\"",
      "jq -n --argjson data \"$json_data\" '$data.key'",
      "Just do\r\n\r\n```\r\n$ jq '.key' <<< $'{\"key\":\"value\"}'\r\n\"value\"\r\n```"
    ],
    "utterance": "Extract the value of the key 'key' from a string variable containing {\"key\":\"value\"} passed to a shell script.",
    "expressions": [
      "echo \"$json_data\" | jq '.key'",
      "jq '.key' <<< \"$json_data\"",
      "jq -n --argjson data \"$json_data\" '$data.key'"
    ],
    "data": [
      {
        "input": {
          "json_data": "{\"key\":\"value\"}"
        },
        "output": "value"
      }
    ],
    "identifier": 47105490
  },
  {
    "context": [
      "In a scenario when file.json doesn't exist 404 page is returned and jq is throwing a parsing error. In such case I want to return string \"Installing\".",
      "Write the response into a variable:",
      "# -f makes curl return an error in case of HTTP error.",
      "response=\"$(curl -f ... )\"",
      "if [ $? -ne 0 ] ; then",
      "    echo \"Installing\"",
      "else",
      "    jq FILTER <<< \"${response}\"",
      "fi"
    ],
    "utterance": "Return 'Installing' if the HTTP request for a file fails with 404 and process with jq otherwise.",
    "expressions": [
      "response=\"$(curl -fsS http://site/file.json)\"; if [ $? -ne 0 ]; then echo \"Installing\"; else echo \"$response\" | jq -e -r '.data[]? | select(.state == \"Active\") | if . == null then \"Installing\" elif . == \"Active\" then \"Active\" else \"Installing\" end'; fi"
    ],
    "identifier": 47139605
  },
  {
    "context": [
      "jq -r --arg NEWGROUP \"$NEWGROUP\" '.[] | select(.name | contains(\"$NEWGROUP\") ) | .id'",
      "when I specify the group name explicitly in the contains() it works.",
      "Yes, within the jq program, you have quoted what you intended to be the jq variable, thus turning it into a JSON string. Simply remove the quotation marks to let the $-string be the $-variable."
    ],
    "utterance": "Select all elements where the name contains the value of a shell variable NEWGROUP and return their id fields.",
    "expressions": [
      ".[] | select(.name | contains($NEWGROUP)) | .id"
    ],
    "identifier": 47174988
  },
  {
    "context": [
      "And I am lost about how to get every nested keys out of the stream using jq. The following is a simplified representative json stream.",
      "And I am expecting the following output. I would be more than happy to have a better approach helping me with the table design.\n\n    startAt\n    total\n    issues: []\n    issues:id\n    issues:name\n    issues:key\n    issues:fields\n    issues:fields:fixVersions: []\n    issues:fields:fixVersions:id\n    issues:fields:fixVersions:releaseDate\n    issues:fields:status\n    issues:fields:status:id\n    issues:fields:status:statusCategory\n    issues:fields:status:statusCategory:id\n    issues:fields:status:statusCategory:name\n    issues:fields:assignee\n    issues:fields:assignee:id\n    issues:fields:assignee:name",
      "[paths(scalars) | map(if type == \"number\" then \"[]\" else . end)]\n| unique\n| .[]\n| join(\":\")",
      "If you want paths to empty arrays to be reported as well, you could (for example) simply change \"paths(scalars)\" to \"(paths(scalars), paths(arrays))\".",
      "def normalize:    # convert paths to requested structure\n    if .[-1]|type==\"number\" then .[-1]=\"[]\" else . end\n  | map(select(type!=\"number\"));\n\ndef collect:      # collect unique normalized paths into an object\n  reduce (paths|normalize) as $p (\n     {}\n   ; if getpath($p)==null then setpath($p;null) else . end\n  );\n\ndef colonize($p): # convert object back into : separated paths\n    keys_unsorted[] as $k\n  | (if $p==\"\" then $k else \"\\($p):\\($k)\" end) as $n\n  | $n, (.[$k] | if type==\"object\" then colonize($n) else empty end);\n\ndef summary:      # final output without redundant foo: if foo:[] is present \n    [ collect | colonize(\"\") ]\n  | map(select(endswith(\":[]\"))|.[:-3]) as $remove\n  | map(select($remove[[.]]==[]));\n\nsummary[]",
      "[paths as $p\n  | if (getpath($p)|type) == \"array\" then $p + [\" []\"]\n    elif ($p[-1]|type) == \"number\" then empty\n    else $p\n    end\n    | map(select(type != \"number\"))]\n| unique\n| .[]\n| join(\":\")"
    ],
    "utterance": "List all nested keys in the data, representing arrays as \":[]\", with paths separated by colons.",
    "expressions": [
      "[paths(scalars) | map(if type == \"number\" then \"[]\" else . end)] | unique | .[] | join(\":\")",
      "(paths(scalars), paths(arrays)) | map(if type == \"number\" then \"[]\" else . end) | unique | .[] | join(\":\")",
      "[paths as $p\n  | if (getpath($p)|type) == \"array\" then $p + [\" []\"]\n    elif ($p[-1]|type) == \"number\" then empty\n    else $p\n    end\n    | map(select(type != \"number\"))]\n| unique\n| .[]\n| join(\":\")"
    ],
    "data": [
      {
        "input": {
          "startAt": 0,
          "total": 5315,
          "issues": [
            {
              "id": "44269",
              "name": "someName",
              "fields": {
                "fixVersions": [
                  {
                    "id": "11401",
                    "releaseDate": "2016-09-30"
                  }
                ],
                "status": {
                  "id": "10110",
                  "statusCategory": {
                    "id": 3,
                    "name": "Done"
                  }
                }
              }
            },
            {
              "id": "44270",
              "key": "LEAD-XXXX",
              "fields": {
                "assignee": {
                  "id": "10111",
                  "name": "Don"
                },
                "status": {
                  "id": "10110",
                  "statusCategory": {
                    "id": 2,
                    "name": "inProgress"
                  }
                }
              }
            }
          ]
        },
        "output": [
          "startAt",
          "total",
          "issues:[]",
          "issues:id",
          "issues:name",
          "issues:key",
          "issues:fields",
          "issues:fields:fixVersions:[]",
          "issues:fields:fixVersions:id",
          "issues:fields:fixVersions:releaseDate",
          "issues:fields:status",
          "issues:fields:status:id",
          "issues:fields:status:statusCategory",
          "issues:fields:status:statusCategory:id",
          "issues:fields:status:statusCategory:name",
          "issues:fields:assignee",
          "issues:fields:assignee:id",
          "issues:fields:assignee:name"
        ]
      }
    ],
    "identifier": 46973467
  },
  {
    "context": [
      "I\u2019m having an issue with setting the fields.",
      "I have 8 total I need to set.",
      "I need to do 7 more modifications to the `template.json` file.",
      "Here is a solution which uses jq to build a legal json array from bash variables and then uses that array with a second jq invocation to substitute the variables into the template at corresponding positions:",
      "jq -M --argjson uuids \"$uuids\" '\n  reduce ($uuids|keys[]) as $k (.; .sections[$k].title = $uuids[$k])\n' <<< \"$template\"",
      "Here is a solution to a portion of the revised problem which works by replacing leaf values in the template with corresponding values from an object constructed from bash variables and passed to jq via `--argjson`.",
      "jq -M --argjson vars \"$vars\" '\nreduce (tostream|select(length==2)) as [$p,$v] (\n    {}\n  ; setpath($p;if $v|type!=\"string\" then . else $vars[$v]//$v end)\n)\n' <<< \"$template\"",
      "The following approach to the problem is similar ... but only one invocation of jq is required ...",
      "def fillin(vars):\n  reduce paths as $p (.;\n    getpath($p) as $v\n    | if $v|type == \"string\" and vars[$v] \n      then setpath($p; vars[$v])\n      else . \n      end);",
      "reduce inputs as $line ({i:0, value:$template};\n  (.value.sections[.i].title |= $line)\n  | .i +=1)\n| .value\n| fillin($vars)"
    ],
    "utterance": "Replace all placeholder string values and section titles in a template, setting titles based on input variables and substituting other placeholders with provided values.",
    "expressions": [
      "jq -M --argjson uuids \"$uuids\" 'reduce ($uuids|keys[]) as $k (.; .sections[$k].title = $uuids[$k])' <<< \"$template\"",
      "jq -M --argjson vars \"$vars\" 'reduce (tostream|select(length==2)) as [$p,$v] ({}; setpath($p;if $v|type!=\"string\" then . else $vars[$v]//$v end))' <<< \"$template\"",
      "def fillin(vars):\n  reduce paths as $p (.;\n    getpath($p) as $v\n    | if $v|type == \"string\" and vars[$v] \n      then setpath($p; vars[$v])\n      else . \n      end);\n\nreduce inputs as $line ({i:0, value:$template};\n  (.value.sections[.i].title |= $line)\n  | .i +=1)\n| .value\n| fillin($vars)"
    ],
    "data": [
      {
        "input": {
          "fields": [],
          "sections": [
            {
              "fields": [
                {
                  "k": "concealed",
                  "n": "[CHANGE_ME]",
                  "t": "ROOT_USER_PASS",
                  "v": "[CHANGE_ME]"
                },
                {
                  "k": "concealed",
                  "n": "[CHANGE_ME]",
                  "t": "DEV_USER_PASS",
                  "v": "[CHANGE_ME]"
                }
              ],
              "name": "Section_[CHANGE_ME]",
              "title": "Container SSH"
            },
            {
              "fields": [
                {
                  "k": "string",
                  "n": "[CHANGE_ME]",
                  "t": "placeholdertext",
                  "v": "[CHANGE_ME_LETTERS]"
                },
                {
                  "k": "string",
                  "n": "[CHANGE_ME]",
                  "t": "placeholdertext",
                  "v": "[CHANGE_ME_LETTERS]"
                },
                {
                  "k": "concealed",
                  "n": "[CHANGE_ME]",
                  "t": "placeholdertext",
                  "v": "[CHANGE_ME]"
                }
              ],
              "name": "Section_[CHANGE_ME]",
              "title": "MySQL"
            }
          ]
        },
        "output": {
          "fields": [],
          "sections": [
            {
              "fields": [
                {
                  "k": "concealed",
                  "n": "[CHANGE_ME]",
                  "t": "RUP",
                  "v": "[CHANGE_ME]"
                },
                {
                  "k": "concealed",
                  "n": "[CHANGE_ME]",
                  "t": "DUP",
                  "v": "[CHANGE_ME]"
                }
              ],
              "name": "Section_[CHANGE_ME]",
              "title": "Section_0"
            },
            {
              "fields": [
                {
                  "k": "string",
                  "n": "[CHANGE_ME]",
                  "t": "placeholdertext",
                  "v": "[CHANGE_ME_LETTERS]"
                },
                {
                  "k": "string",
                  "n": "[CHANGE_ME]",
                  "t": "placeholdertext",
                  "v": "[CHANGE_ME_LETTERS]"
                },
                {
                  "k": "concealed",
                  "n": "[CHANGE_ME]",
                  "t": "placeholdertext",
                  "v": "[CHANGE_ME]"
                }
              ],
              "name": "Section_[CHANGE_ME]",
              "title": "Section_1"
            }
          ]
        }
      }
    ],
    "identifier": 46981141
  },
  {
    "context": [
      "Looking to convert the following json example into csv using jq. The work is being performed on a centos 6.9, i am able to add tools to the box if need. The purpose of normalizing the json into csv is for a SIEM feed.",
      "Output expecting:",
      "\"key1\":\"Value1\",\"key2\":\"Value2\",\"key3\":\"Value3\",\"key4\":4,\"key5\":5,\"key6\":\"Value6\"",
      "But if that's what you want as output, you can definitely generate it, just know that it's not real csv.",
      "$ jq -r 'to_entries | map(\"\\(.key|tojson):\\(.value|tojson)\") | join(\",\")' input.json",
      "Here is a filter which generates the expected output (assuming data in `data.json`):",
      "$ jq -Mr '[keys[] as $k | {($k):.[$k]} | tojson[1:-1]] | join(\",\")' data.json"
    ],
    "utterance": "Produce lines for each object where each key-value pair is emitted in the format \"key\":value, quoted as shown, joined by commas, matching the example output.",
    "expressions": [
      "to_entries | map(\"\\(.key|tojson):\\(.value|tojson)\") | join(\",\")",
      "[keys[] as $k | {($k):.[$k]} | tojson[1:-1]] | join(\",\")"
    ],
    "data": [
      {
        "input": [
          {
            "Key1": "Value1",
            "Key2": "Value2",
            "Key3": "Value3",
            "key4": 4,
            "key5": 5,
            "key6": "value6"
          },
          {
            "Key1": "Value1",
            "Key2": "Value2",
            "Key3": "Value3",
            "key4": 4,
            "key5": 5,
            "key6": "value6"
          },
          {
            "Key1": "Value1",
            "Key2": "Value2",
            "Key3": "Value3",
            "key4": 4,
            "key5": 5,
            "key6": "value6"
          }
        ],
        "output": [
          "\"Key1\":\"Value1\",\"Key2\":\"Value2\",\"Key3\":\"Value3\",\"key4\":4,\"key5\":5,\"key6\":\"value6\"",
          "\"Key1\":\"Value1\",\"Key2\":\"Value2\",\"Key3\":\"Value3\",\"key4\":4,\"key5\":5,\"key6\":\"value6\"",
          "\"Key1\":\"Value1\",\"Key2\":\"Value2\",\"Key3\":\"Value3\",\"key4\":4,\"key5\":5,\"key6\":\"value6\""
        ]
      }
    ],
    "identifier": 47167963
  },
  {
    "context": [
      "I\u0019m trying to remove agent4 from anywhere inside an array underneath the field labelled agents.",
      "Here is a solution which uses [path](https://stedolan.github.io/jq/manual/#path\\(path_expression\\)) to find \"agent4\" and verify it appears within \"agents\" before removing it with [delpaths](https://stedolan.github.io/jq/manual/#delpaths\\(PATHS\\))",
      "delpaths([ path(..|select(.==\"agent4\")) | select(.[-2]==\"agents\") ])",
      "Here is another way using [reduce](https://stedolan.github.io/jq/manual/#Reduce), [leaf_paths](https://stedolan.github.io/jq/manual/#paths,paths\\(node_filter\\),leaf_paths), [getpath](https://stedolan.github.io/jq/manual/#getpath\\(PATHS\\)) and [delpaths](https://stedolan.github.io/jq/manual/#delpaths\\(PATHS\\)):",
      "reduce leaf_paths as $p (. ; if $p[-2]==\"agents\" and getpath($p)==\"agent4\" then delpaths([$p]) else . end )",
      "Here's a solution using `walk`:",
      "walk( if type == \"object\" and has(\"agents\") then .agents |= map(select(. != \"agent4\")) else . end )"
    ],
    "utterance": "Remove all occurrences of the value \"agent4\" from arrays located in properties named \"agents\" anywhere in the structure.",
    "expressions": [
      "delpaths([ path(..|select(.==\"agent4\")) | select(.[-2]==\"agents\") ])",
      "reduce leaf_paths as $p (. ; if $p[-2]==\"agents\" and getpath($p)==\"agent4\" then delpaths([$p]) else . end )",
      "walk( if type == \"object\" and has(\"agents\") then .agents |= map(select(. != \"agent4\")) else . end )"
    ],
    "data": [
      {
        "input": {
          "environments": {
            "default": {
              "machines": {
                "dev-machine": {
                  "agents": [
                    "agent1",
                    "agent2",
                    "agent3",
                    "agent4"
                  ]
                }
              }
            }
          },
          "environments2": {
            "agents": [
              "agent1",
              "agent2",
              "agent3",
              "agent4"
            ]
          }
        },
        "output": {
          "environments": {
            "default": {
              "machines": {
                "dev-machine": {
                  "agents": [
                    "agent1",
                    "agent2",
                    "agent3"
                  ]
                }
              }
            }
          },
          "environments2": {
            "agents": [
              "agent1",
              "agent2",
              "agent3"
            ]
          }
        }
      }
    ],
    "identifier": 47204952
  },
  {
    "context": [
      "I have two arrays of identical length with objects in them:",
      "input: [[{foo: 1}, {foo: 23}], [{bar: 12, baz: 543}, {bar: -1}]]",
      "How do I tell [jq](https://stedolan.github.io/jq/manual/) to merge them into one array like below?",
      "output: [{foo: 1, bar: 12, baz: 543}, {foo: 23, bar: -1}]",
      "Here is a solution which uses [transpose](https://stedolan.github.io/jq/manual/#transpose) and [add](https://stedolan.github.io/jq/manual/#add).",
      "jq -M 'transpose|map(add)' data.json",
      "a stream-oriented solution using `zips/2`",
      ". as $in | $in[0] | [zips( $in[1][]; add )]"
    ],
    "utterance": "Merge two arrays of equal length containing objects element-wise, so each output object is the result of merging the corresponding objects from each array.",
    "expressions": [
      "transpose | map(add)",
      ". as $in | $in[0] | [zips($in[1][]; add)]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "foo": 1
            },
            {
              "foo": 23
            }
          ],
          [
            {
              "bar": 12,
              "baz": 543
            },
            {
              "bar": -1
            }
          ]
        ],
        "output": [
          {
            "foo": 1,
            "bar": 12,
            "baz": 543
          },
          {
            "foo": 23,
            "bar": -1
          }
        ]
      }
    ],
    "identifier": 47221672
  },
  {
    "context": [
      "I need to combine these two using jq so that I end up with one object that contains all of the keys from both objects. If there are common keys, I need the values of from second object being used.",
      "$ jq -s 'add' file1 file2",
      "$ jq -n 'reduce inputs as $i ({}; . + $i)' file1 file2",
      "$ jq -n 'reduce inputs as $i ({}; . * $i)' file1 file2",
      "jq --slurpfile f2 file2 '. + $f2[0]' file1",
      "$ jq -Mn --argfile file1 file1.json --argfile file2 file2.json '$file1 + $file2'"
    ],
    "utterance": "Combine two files containing objects so that all keys from both are present, with values from the second file overwriting any matching keys.",
    "expressions": [
      "jq -s 'add' file1 file2",
      "jq -n 'reduce inputs as $i ({}; . + $i)' file1 file2",
      "jq -n 'reduce inputs as $i ({}; . * $i)' file1 file2",
      "jq --slurpfile f2 file2 '. + $f2[0]' file1",
      "jq -Mn --argfile file1 file1.json --argfile file2 file2.json '$file1 + $file2'"
    ],
    "data": [
      {
        "input": {
          "file1": {
            "key1": "value1",
            "key2": "value2"
          },
          "file2": {
            "key1": "valueA",
            "key3": "valueB"
          }
        },
        "output": {
          "key1": "valueA",
          "key2": "value2",
          "key3": "valueB"
        }
      }
    ],
    "identifier": 47190554
  },
  {
    "context": [
      "I am trying to parse hundreds of records and filter out all of the records that are in a specific channel number or have a specific geofenceProfileId.",
      "jq 'select(.channels | index(\"58b8a25cf9f6e19cf671872f\"))'",
      "select(.channels | index(\"58b8a25cf9f6e19cf671872f\")) | del(.channels)",
      "So most likely you'll end up with: curl ... | jq ..."
    ],
    "utterance": "Filter records where the channels array contains the value \"58b8a25cf9f6e19cf671872f\".",
    "expressions": [
      "jq 'select(.channels | index(\"58b8a25cf9f6e19cf671872f\"))'",
      "jq 'select(.channels | index(\"58b8a25cf9f6e19cf671872f\")) | del(.channels)'"
    ],
    "data": [
      {
        "input": [
          {
            "id": "593f468c81aaa30001960e16",
            "name": "Name 1",
            "channels": [
              "593f38398481bc00019632e5"
            ],
            "geofenceProfileId": null
          },
          {
            "id": "58e464585180ac000a748b57",
            "name": "Name 2",
            "channels": [
              "58b480097f04f20007f3cdca",
              "580ea26616de060006000001"
            ],
            "geofenceProfileId": null
          },
          {
            "id": "58b4d6db7f04f20007f3cdd2",
            "name": "Name 3",
            "channels": [
              "58b8a25cf9f6e19cf671872f"
            ],
            "geofenceProfileId": "57f53018271c810006000001"
          }
        ],
        "output": {
          "id": "58b4d6db7f04f20007f3cdd2",
          "name": "Name 3",
          "channels": [
            "58b8a25cf9f6e19cf671872f"
          ],
          "geofenceProfileId": "57f53018271c810006000001"
        }
      }
    ],
    "identifier": 47234312
  },
  {
    "context": [
      "I want to multiply each fn by 2 and output it like this -",
      "you could modify the object in a filter:",
      "echo \"$res\" | jq '[].fn *= 2'",
      "This filter multiplies the `.fn` member of each object within an array (or another object) by 2, leaving other members unchanged.",
      ".[].fn *= 2"
    ],
    "utterance": "Multiply the value of the fn key by 2 in each object of an array.",
    "expressions": [
      ".[].fn *= 2"
    ],
    "data": [
      {
        "input": [
          {
            "fn": 22222,
            "name": "raimonds"
          },
          {
            "fn": 22222,
            "name": "john"
          }
        ],
        "output": [
          {
            "fn": 44444,
            "name": "raimonds"
          },
          {
            "fn": 44444,
            "name": "john"
          }
        ]
      }
    ],
    "identifier": 47270454
  },
  {
    "context": [
      "JSON File:\r\n\r\n    {\r\n        \"script\": {\r\n        \"install\": \"${HOME}/lib/install.sh $HOST $PEMFILE\",\r\n        \"Setup\": \"${HOME}/lib/setup.sh $HOST $PEMFILE $VAR1 $VAR2\"\r\n        }\r\n    \r\n    }\r\n",
      "Is there a way I can interpret these variables on the fly without modifying the JSON?",
      "Here is a solution using [env](https://stedolan.github.io/jq/manual/#$ENV,env)  and [gsub](https://stedolan.github.io/jq/manual/#gsub\\(regex;string\\),gsub\\(regex;string;flags\\)) to perform the replacement.\r\n\r\nNote that `env` requires the variables to be passed as environment variables as opposed to shell variables.\r\n\r\n\r\n    #!/bin/bash\r\n    \r\n    examplefile=\"../lib/example.json\"\r\n    HOST=ec2-..-...-...-...us-west-2.compute.amazonaws.com\r\n    PEMFILE=${HOME}/test.pem\r\n    \r\n    export HOST\r\n    export PEMFILE\r\n    installScript=$(jq -Mr '\r\n       .script.install | gsub(\"(?<x>[$][{]?\\w+[}]?)\"; env[.x|gsub(\"[${}]+\";\"\")])\r\n    ' $examplefile)\r\n    \r\n    echo $installScript\r\n\r\nSample Output\r\n\r\n    /home/runner/lib/install.sh ec2-..-...-...-...us-west-2.compute.amazonaws.com /home/runner/test.pem\r\n",
      "### General solution\r\n\r\n    walk(if type == \"string\"\r\n         then gsub(\"\\$(?<x>[A-Za-z_][A-Za-z0-9_]+)\"; \"\\(env[.x])\") \r\n              | gsub(\"\\${(?<x>[A-Za-z_][A-Za-z0-9_]+)}\"; \"\\(env[.x])\") \r\n         else . end)\r\n"
    ],
    "utterance": "Replace variable references like $HOME, $HOST, $PEMFILE in the 'install' key's value with their corresponding environment variable values at query time",
    "expressions": [
      ".script.install | gsub(\"(?<x>[$][{]?\\w+[}]?)\"; env[.x|gsub(\"[${}]+\"; \"\")])",
      "walk(if type == \"string\" then gsub(\"\\$(?<x>[A-Za-z_][A-Za-z0-9_]+)\"; \"\\(env[.x])\") | gsub(\"\\${(?<x>[A-Za-z_][A-Za-z0-9_]+)}\"; \"\\(env[.x])\") else . end)"
    ],
    "data": [
      {
        "input": {
          "script": {
            "install": "${HOME}/lib/install.sh $HOST $PEMFILE",
            "Setup": "${HOME}/lib/setup.sh $HOST $PEMFILE $VAR1 $VAR2"
          }
        },
        "output": "/home/runner/lib/install.sh ec2-..-...-...-...us-west-2.compute.amazonaws.com /home/runner/test.pem"
      }
    ],
    "identifier": 47061923
  },
  {
    "context": [
      "I found myself in the world of JSON and I'm trying to convert out of it using `jq`. I'm trying to convert following structure to CSV:",
      "Expected output would be (quoted or unquoted, comma separated or not, I used pipe separators for clarity):",
      "Action|Group|Unit1|Unit2|Unit3|Unit4|Unit5",
      "A1|10|1|0|0|0|0",
      "A2|11|0|1|0|0|0",
      "A2|20|0|0|0|0|0",
      "A1|26|1|0|1|0|0",
      "A3|0|0|0|0|0",
      "To handle the case where `Group` may be `null` the easiest way is to use a variation of [peak](https://stackoverflow.com/users/997358/peak)'s suggestion.  E.g",
      "[\"\\(1+range(5))\"] as $units",
      "| [\"Action\", \"Group\", \"Unit\\($units[])\"]",
      ", ( inputs ",
      "| .Action as $a ",
      "| ( .Group // [{Id:\"0\", Units:[]}] )[]   # <-- supply default group if null",
      "| [$a, .Id, (.Units[$units[]|[.]] | if .!=[] then \"1\" else \"0\" end) ]",
      ") | join(\"|\")"
    ],
    "utterance": "Produce a table with columns Action, Group, Unit1 through Unit5, where each row contains values from the input structure; for each Unit column, output 1 if the unit number is present in the Units array, or 0 otherwise, and if Group is null, treat it as Id 0 and all Units 0.",
    "expressions": [
      "[\"\\(1+range(5))\"] as $units\n| [\"Action\", \"Group\", \"Unit\\($units[])\"]\n, ( inputs \n  | .Action as $a \n  | ( .Group // [{Id:\"0\", Units:[]}] )[]\n  | [$a, .Id, (.Units[$units[]|[.]] | if .!=[] then \"1\" else \"0\" end) ]\n) | join(\"|\")"
    ],
    "data": [
      {
        "input": [
          {
            "Action": "A1",
            "Group": [
              {
                "Id": "10",
                "Units": [
                  "1"
                ]
              }
            ]
          },
          {
            "Action": "A2",
            "Group": [
              {
                "Id": "11",
                "Units": [
                  "2"
                ]
              },
              {
                "Id": "20",
                "Units": []
              }
            ]
          },
          {
            "Action": "A1",
            "Group": [
              {
                "Id": "26",
                "Units": [
                  "1",
                  "3"
                ]
              }
            ]
          },
          {
            "Action": "A3",
            "Group": null
          }
        ],
        "output": [
          "Action|Group|Unit1|Unit2|Unit3|Unit4|Unit5",
          "A1|10|1|0|0|0|0",
          "A2|11|0|1|0|0|0",
          "A2|20|0|0|0|0|0",
          "A1|26|1|0|1|0|0",
          "A3|0|0|0|0|0|0"
        ]
      }
    ],
    "identifier": 47094953
  },
  {
    "context": [
      "And I would like to extract the .name. When name is an array, I would like to take always the first element.",
      "As output I would like to have \"aaa\" \"bbb\" \"fff\"",
      "To extract all `name`s, but only the *first name* in case the `name` is an array:",
      "jq '[].name | if type==\"array\" then first else . end' <file",
      "For your sample input, the [output](https://jqplay.org/s/S6jNSL0dN9) is:\n\n    \"aaa\"\n    \"bbb\"\n    \"fff\""
    ],
    "utterance": "Extract the name field from each object, but if name is an array, return only its first element.",
    "expressions": [
      ".[].name | if type==\"array\" then first else . end"
    ],
    "data": [
      {
        "input": [
          {
            "id": "109",
            "name": "aaa"
          },
          {
            "id": "1098",
            "name": [
              "bbb",
              "ccc"
            ]
          },
          {
            "id": "2000",
            "name": [
              "fff",
              "ddd"
            ]
          }
        ],
        "output": [
          "aaa",
          "bbb",
          "fff"
        ]
      }
    ],
    "identifier": 47350099
  },
  {
    "context": [
      "With the help of jq, i'd need to find out all the sku based on a particular keyword search like `.productFamily == \"Compute Instance\"`.",
      "Change the rather weird-looking `.\u201d\u201d` to `[]`",
      "jq1.3 '.products[] | select(.productFamily==\"Compute Instance\") | .sku' sku.json",
      "jq --raw-output '.products | map(select(.productFamily==\"Compute Instance\")) | .[].sku'"
    ],
    "utterance": "Find all sku values where productFamily equals \"Compute Instance\".",
    "expressions": [
      ".products[] | select(.productFamily==\"Compute Instance\") | .sku",
      ".products | map(select(.productFamily==\"Compute Instance\")) | .[].sku"
    ],
    "data": [
      {
        "input": {
          "formatVersion": "v1.0",
          "publicationDate": "2017-11-17T19:00:39Z",
          "products": {
            "HYZTQKMNAKH6FG9C": {
              "sku": "HYZTQKMNAKH6FG9C",
              "productFamily": "Compute Instance"
            },
            "2BEAK4F883TCCQMS": {
              "sku": "2BEAK4F883TCCQMS",
              "productFamily": "Compute2 Instance"
            },
            "7QJJXQX9QWC5GEPD": {
              "sku": "7QJJXQX9QWC5GEPD",
              "productFamily": "Compute3 Instance"
            }
          }
        },
        "output": "HYZTQKMNAKH6FG9C"
      }
    ],
    "identifier": 47366958
  },
  {
    "context": [
      "I\u2019m trying to change multiple json values with this line\n\n     jq '.two=\"newval\", .three=\"newval\"' my.json \n\nwith this is the input\n\n    {\n      \"one\": {\n        \"val\": 1\n      },\n      \"two\": \"val\",\n      \"three\": \"val\",\n      \"four\": \"val\"\n    }\n\nbut the output is 2 jsons:\n\n    {\n      \"one\": {\n        \"val\": 1\n      },\n      \"two\": \"newval\",\n      \"three\": \"val\",\n      \"four\": \"val\"\n    }\n    {\n      \"one\": {\n        \"val\": 1\n      },\n      \"two\": \"val\",\n      \"three\": \"newval\",\n      \"four\": \"val\"\n    }\n\nHow can I change multiple values and output in one item?",
      "Simply change the comma to a pipe character and you\u2019re done:\n\n    .two=\"newval\" | .three=\"newval\"",
      "Here is a method which uses [+ object addition](https://stedolan.github.io/jq/manual/#Addition:+) to update multiple members.\n\n    . + {two:\"newtwo\", three:\"newthree\"}",
      "Keep the comma operator and pass the combined stream to the assignment:\n$ jq '(.two, .three) = \"newval\"' data.json\n{\n  \"one\": {\n    \"val\": 1\n  },\n  \"two\": \"newval\",\n  \"three\": \"newval\",\n  \"four\": \"val\"\n}"
    ],
    "utterance": "Update both the 'two' and 'three' fields to 'newval' in an object that contains those keys.",
    "expressions": [
      ".two = \"newval\" | .three = \"newval\"",
      ". + {two:\"newval\", three:\"newval\"}",
      "(.two, .three) = \"newval\""
    ],
    "data": [
      {
        "input": {
          "one": {
            "val": 1
          },
          "two": "val",
          "three": "val",
          "four": "val"
        },
        "output": {
          "one": {
            "val": 1
          },
          "two": "newval",
          "three": "newval",
          "four": "val"
        }
      }
    ],
    "identifier": 47355901
  },
  {
    "context": [
      "map(if ParameterKey == \"Project\"           then . + {\"ParameterValue\" = \"jess-project\"}             else .             end           )",
      "Object construction in `jq` uses syntax similar to JavaScript Object Notation (JSON).\n\n`{\"ParameterValue\" = \"jess-project\"}` is not valid in JSON. Did you mean `{\"ParameterValue\": \"jess-project\"}`?",
      "if all ParameterKey/ParameterValues are in a list called `Parameters` and it looks something like this:\n\n    $ cat test.json\n    {\n      \"Parameters\": [\n        {\n          \"ParameterKey\": \"Project\",\n          \"ParameterValue\": \"jess-project\"\n        },\n        {\n          \"ParameterKey\": \"NumberOfInstances\",\n          \"ParameterValue\": \"2\"\n        }\n      ]\n    }\n\nThen you have to take into account the `Parameters` list by doing:\n\n    $ jq '.Parameters | map(if .ParameterKey == \"Project\" then . + {\"ParameterValue\":\"my-project\"} else . end) | {\"Parameters\":.}' test.json",
      "here's another way to update a key's value:\n\n    $ jq '.Parameters | map((select(.ParameterKey == \"Project\") | .ParameterValue) |= \"my-project\") | {\"Parameters\":.}' test.json",
      "And if you want to specify a shell variable, you can even do this:\n\n    PRJ=my-project\n    jq --arg prj \"$PRJ\" '.Parameters | map((select(.ParameterKey == \"Project\") | .ParameterValue) |= $prj) | {\"Parameters\":.}' test.json > test-updated.json"
    ],
    "utterance": "Update the value of ParameterValue to \"my-project\" for any object in the Parameters array where ParameterKey is \"Project\".",
    "expressions": [
      ".Parameters | map(if .ParameterKey == \"Project\" then . + {\"ParameterValue\":\"my-project\"} else . end) | {\"Parameters\":.}",
      ".Parameters | map((select(.ParameterKey == \"Project\") | .ParameterValue) |= \"my-project\") | {\"Parameters\":.}",
      "jq --arg prj \"$PRJ\" '.Parameters | map((select(.ParameterKey == \"Project\") | .ParameterValue) |= $prj) | {\"Parameters\":.}'"
    ],
    "data": [
      {
        "input": {
          "Parameters": [
            {
              "ParameterKey": "Project",
              "ParameterValue": "jess-project"
            },
            {
              "ParameterKey": "NumberOfInstances",
              "ParameterValue": "2"
            }
          ]
        },
        "output": {
          "Parameters": [
            {
              "ParameterKey": "Project",
              "ParameterValue": "my-project"
            },
            {
              "ParameterKey": "NumberOfInstances",
              "ParameterValue": "2"
            }
          ]
        }
      }
    ],
    "identifier": 47342084
  },
  {
    "context": [
      "And I want to delete all keys (recursively) which match `publicAccess` or `userGroupAccesses`, so that my JSON looks like this:",
      "Your problem is when `type == \"array\"` is true `.` will be an array so `.userGroupAccesses` won't work.  What you want to do is focus on the case when `.` is an object.  In your call to `walk` you only need to check for `type == \"object\"` and then remove the members you don't want.  e.g.",
      "walk(if type == \"object\" then del(.publicAccess, .userGroupAccesses) else . end)",
      "You can also solve this without `walk` by using [Recursive Descent `..`](https://stedolan.github.io/jq/manual/#RecursiveDescent:..)  e.g.",
      "del(.. | .publicAccess?, .userGroupAccesses?)"
    ],
    "utterance": "Recursively remove all keys named publicAccess or userGroupAccesses from the data, no matter where they appear.",
    "expressions": [
      "walk(if type == \"object\" then del(.publicAccess, .userGroupAccesses) else . end)",
      "del(.. | .publicAccess?, .userGroupAccesses?)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "name": "Test",
              "program": {
                "publicAccess": "--------",
                "externalAccess": false,
                "userGroupAccesses": [
                  {
                    "access": "r-------"
                  },
                  {
                    "access": "rw------"
                  }
                ],
                "id": "MmBqeMLIC2r"
              },
              "publicAccess": "rw------"
            }
          ]
        },
        "output": {
          "data": [
            {
              "name": "Test",
              "program": {
                "externalAccess": false,
                "id": "MmBqeMLIC2r"
              }
            }
          ]
        }
      }
    ],
    "identifier": 47371280
  },
  {
    "context": [
      "I need to get the values in Exon of the following Json input and split it by \";\" and convert to a nested JSON as show below in the Expected ouput section",
      "The low-level requirement (about converting the strings) can be implemented as follows:",
      "def gene2object:\n  split(\";\")\n  | [.[0], { chromosome: .[1], \n             start: (.[2]|tonumber),\n             end:   (.[3]|tonumber)} ];",
      "A solution can now be written quite simply as follows:\n\n    walk( if type == \"object\" and .metric == \"Exons\" \n          then .value |= (map(gene2object)|add) \n          else .\n          end )"
    ],
    "utterance": "For each object where metric is Exons, split each value by semicolons and transform into a list alternating between the first element as a string and an object with chromosome, start, and end keys using the subsequent elements.",
    "expressions": [
      "def gene2object: split(\";\") | [.[0], { chromosome: .[1], start: (.[2]|tonumber), end: (.[3]|tonumber) } ];\nwalk(if type == \"object\" and .metric == \"Exons\" then .value |= (map(gene2object)|add) else . end)"
    ],
    "data": [
      {
        "input": {
          "regions": [
            {
              "metric": "GENE1",
              "value": [
                {
                  "metric": "Exons",
                  "value": [
                    "GENE1;chr1;45656;5656667"
                  ],
                  "type": "set"
                },
                {
                  "metric": "Precent_no_call",
                  "value": 4.22623,
                  "type": "simple"
                },
                {
                  "metric": "Total_NoCall_bases",
                  "value": 112533,
                  "type": "simple"
                }
              ],
              "type": "metrics-set"
            },
            {
              "metric": "GENE2",
              "value": [
                {
                  "metric": "Exons",
                  "value": [
                    "GENE2_Exon5;chr1;45656;5656667",
                    "GENE2_Exon10;chr1;45656;5656667"
                  ],
                  "type": "set"
                },
                {
                  "metric": "Precent_no_call",
                  "value": 0.746464,
                  "type": "simple"
                },
                {
                  "metric": "Total_NoCall_bases",
                  "value": 16842,
                  "type": "simple"
                }
              ],
              "type": "metrics-set"
            }
          ]
        },
        "output": {
          "regions": [
            {
              "metric": "GENE1",
              "value": [
                {
                  "metric": "Exons",
                  "value": [
                    "GENE1",
                    {
                      "chromosome": "chr1",
                      "start": 45656,
                      "end": 5656667
                    }
                  ],
                  "type": "set"
                },
                {
                  "metric": "Precent_no_call",
                  "value": 4.22623,
                  "type": "simple"
                },
                {
                  "metric": "Total_NoCall_bases",
                  "value": 112533,
                  "type": "simple"
                }
              ],
              "type": "metrics-set"
            },
            {
              "metric": "GENE2",
              "value": [
                {
                  "metric": "Exons",
                  "value": [
                    "GENE2_Exon5",
                    {
                      "chromosome": "chr1",
                      "start": 45656,
                      "end": 5656667
                    },
                    "GENE2_Exon10",
                    {
                      "chromosome": "chr1",
                      "start": 45656,
                      "end": 5656667
                    }
                  ],
                  "type": "set"
                },
                {
                  "metric": "Precent_no_call",
                  "value": 0.746464,
                  "type": "simple"
                },
                {
                  "metric": "Total_NoCall_bases",
                  "value": 16842,
                  "type": "simple"
                }
              ],
              "type": "metrics-set"
            }
          ]
        }
      }
    ],
    "identifier": 47027372
  },
  {
    "context": [
      "If it is an array, I would like to get the 2nd element in the array and if it is not, just return the element available.",
      "{\n   numbers: (.numbers | if type==\"array\" then .[2] else . end)\n}",
      ".numbers | if type == \"array\" then .[1] else . end",
      ".numbers |= if type == \"array\" then .[1] else . end"
    ],
    "utterance": "Extract the second element if the field is an array; otherwise return its value.",
    "expressions": [
      ".numbers | if type == \"array\" then .[1] else . end",
      ".numbers |= if type == \"array\" then .[1] else . end",
      "{ numbers: (.numbers | if type==\"array\" then .[1] else . end) }"
    ],
    "data": [
      {
        "input": {
          "numbers": [
            "0",
            "1",
            "2"
          ]
        },
        "output": "1"
      },
      {
        "input": {
          "numbers": [
            "0"
          ]
        },
        "output": "0"
      }
    ],
    "identifier": 47382724
  },
  {
    "context": [
      "test.sh is not replacing test.json parameter values ($input1 and $input2). result.json has same ParameterValue \"$input1/solution/$input2.result\"",
      "shell variables in *jq* scripts should be interpolated or passed as arguments via `--arg name value`:",
      "jq --arg inp1 \"$input1\" --arg inp2 \"$input2\" \\",
      "'map(if .ParameterKey == \"Project\" \n    then . + {\"ParameterValue\" : ($inp1 + \"/solution/\" + $inp2 + \".result\") } \nelse . end)' test.json",
      "In your jq program, you have quoted \"$input1/solution/$input2.result\", and therefore it is a JSON string literal, whereas you evidently want string interpolation; you also need to distinguish between the shell variables ($input1 and $input2) on the one hand, and the corresponding jq dollar-variables (which may or may not have the same name) on the other.",
      "Since your shell variables are strings, you could pass them in using the `--arg` command-line option (e.g. `--arg input1 \"$input1\"` if you chose to name the variables in the same way).",
      "There are other ways to achieve the desired results too, but using string interpolation with same-named variables, you'd write: \n\n    \"\\($input1)/solution/\\($input2).result\""
    ],
    "utterance": "Replace the value of the 'ParameterValue' field to 'test1/solution/test2.result' only for entries where 'ParameterKey' is 'Project', using shell variables.",
    "expressions": [
      "jq --arg inp1 \"$input1\" --arg inp2 \"$input2\" 'map(if .ParameterKey == \"Project\" then . + {\"ParameterValue\" : ($inp1 + \"/solution/\" + $inp2 + \".result\") } else . end)'"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "Project",
            "ParameterValue": [
              "$input1/solution/$input2.result"
            ]
          }
        ],
        "output": [
          {
            "ParameterKey": "Project",
            "ParameterValue": "test1/solution/test2.result"
          }
        ]
      }
    ],
    "identifier": 47374719
  },
  {
    "context": [
      "The reason you're seeing that message is that the [`map()`](https://stedolan.github.io/jq/manual/#map\\(x\\),map_values\\(x\\)) expression is enumerating the values of your object (\"`Project`\" and \"`<check>`\") invoking the `if .ParameterKey ...` expression on each of them. Unfortunately those are strings and the `.ParameterKey` part of your `if` condition won't work with string values so jq gives you the error `Cannot index string with string \u201cParameterKey\u201d`.",
      "You probably only want the `map()` if your `test.json` contains an array of objects. If your `test.json` contains an object at the top level such as `{\"ParameterKey\": \"Project\", \"ParameterValue\": \"<check>\"}` then you should remove the `map()`.  e.g.",
      "$ cat test.json | \\\n  jq 'if .ParameterKey == \"Project\" then . + {\"ParameterValue\" : \"val\" }  else . end'\n{\n  \"ParameterKey\": \"Project\",\n  \"ParameterValue\": \"val\"\n}"
    ],
    "utterance": "Replace the value of ParameterValue with \"val\" if ParameterKey equals \"Project\".",
    "expressions": [
      "if .ParameterKey == \"Project\" then . + {\"ParameterValue\": \"val\"} else . end"
    ],
    "data": [
      {
        "input": {
          "ParameterKey": "Project",
          "ParameterValue": "<check>"
        },
        "output": {
          "ParameterKey": "Project",
          "ParameterValue": "val"
        }
      }
    ],
    "identifier": 47396243
  },
  {
    "context": [
      "{ \"key\":633447818234478180 } returns this (\"Result\" in jqplay.org): { \"key\": 633447818234478200 }",
      "Why is it changing 180 into 200? How can I overcome this?",
      "If you need to work with larger numbers as strings in jq you may want to try this library: jq-bigint"
    ],
    "utterance": "Preserve precise representation of large numbers without loss of digits.",
    "expressions": [
      ".",
      "jq -M --argjson key \"633447818234478180\" '{key: $key}'"
    ],
    "data": [
      {
        "input": {
          "key": "633447818234478180"
        },
        "output": {
          "key": "633447818234478180"
        }
      },
      {
        "input": {
          "key": 633447818234478180
        },
        "output": {
          "key": "633447818234478180"
        }
      }
    ],
    "identifier": 47397088
  },
  {
    "context": [
      "My script is\n\n    cat test.json | \\\n    jq 'map(if .ParameterKey == \"<ans1>\" then . + {\"ParameterKey\" : \"input1\" } else . end )' \\\n       'map(if .ParameterValue == \"<ans2>\" then . + {\"ParameterValue\" : \"input2\" } else . end)' \\ \n    > result.json",
      "To correct this you can combine the two filter strings into one string with | and pass test.json as the input file, e.g.\n\n    jq '\n       map(if .ParameterKey == \"<ans1>\" then . + {\"ParameterKey\": \"input1\"} else . end)\n     | map(if .ParameterValue == \"<ans2>\" then . + {\"ParameterValue\": \"input2\"} else . end)\n    ' test.json > result.json",
      "Here are two solutions - one that is both simple and brief, and one that scales well. Notice that in both cases, map is only needed once.",
      "### Simple and brief\n    map( if .ParameterKey   == \"<ans1>\" then . + {\"ParameterKey\":   \"input1\"} else . end\n       | if .ParameterValue == \"<ans2>\" then . + {\"ParameterValue\": \"input2\"} else . end)"
    ],
    "utterance": "Replace ParameterKey with \"input1\" when it equals \"<ans1>\", and ParameterValue with \"input2\" when it equals \"<ans2>\" across all objects in the array.",
    "expressions": [
      "map(if .ParameterKey == \"<ans1>\" then . + {\"ParameterKey\": \"input1\"} else . end | if .ParameterValue == \"<ans2>\" then . + {\"ParameterValue\": \"input2\"} else . end)",
      "map(if .ParameterKey == \"<ans1>\" then . + {\"ParameterKey\": \"input1\"} else . end) | map(if .ParameterValue == \"<ans2>\" then . + {\"ParameterValue\": \"input2\"} else . end)",
      "def maybe_update($key; $old; $new): if .[$key] == $old then .[$key] = $new else . end; map( maybe_update(\"ParameterKey\";   \"<ans1>\"; \"input1\") | maybe_update(\"ParameterValue\"; \"<ans2>\"; \"input2\") )"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "<ans1>",
            "ParameterValue": "<ans2>"
          }
        ],
        "output": [
          {
            "ParameterKey": "input1",
            "ParameterValue": "input2"
          }
        ]
      }
    ],
    "identifier": 47384026
  },
  {
    "context": [
      "Using `jq`, how would one count the number or records where the `charge` key is missing?",
      "Here is a solution using [`map`](https://stedolan.github.io/jq/manual/#map\\(x\\),map_values\\(x\\)) and [`length`](https://stedolan.github.io/jq/manual/#length):\r\n\r\n    .items | map(select(.charge == null)) | length",
      "If some items could have a `null` charge then the test for `== null` won&#39;t distinguish between those items and items without the `charge` key.  If this is a concern the following forms of the above filters which use [`has`](https://stedolan.github.io/jq/manual/#has\\(key\\)) are better:\r\n\r\n    .items | map(select(has(\"charge\")|not)) | length",
      "reduce (.items[] | select(has(\"charge\")|not)) as $i (0;.+=1)",
      "sigma(.items[] | select(has(\"charge\") == false) | 1)"
    ],
    "utterance": "Count the number of elements in the 'items' array where the 'charge' key is missing.",
    "expressions": [
      ".items | map(select(has(\"charge\")|not)) | length",
      "reduce (.items[] | select(has(\"charge\")|not)) as $i (0;.+=1)",
      "sigma(.items[] | select(has(\"charge\") == false) | 1)"
    ],
    "data": [
      {
        "input": {
          "current_page": 1,
          "items": [
            {
              "id": 1,
              "name": "vehicleA",
              "state": "available",
              "charge": 100
            },
            {
              "id": 2,
              "name": "vehicleB",
              "state": "available"
            },
            {
              "id": 3,
              "name": "vehicleB",
              "state": "available",
              "charge": 50
            }
          ]
        },
        "output": 1
      }
    ],
    "identifier": 47420833
  },
  {
    "context": [
      "What command can I use in `jq` to immediately fetch both pages of data?",
      "`jq` doesn't fetch pages. You need to fetch pages with multiple `curl` calls, and then combine the JSON outputs.",
      "For example you could get a JSON array of the combined `.item` properties:",
      "jq -s '.[0].items + .[1].items' <(curl \"$url&page=1\" | jq .) <(curl \"$url&page=2\" | jq .)",
      "If you can download all of the pages and create an array of all of the entries (much like @janos answer above), then you need not computationally generate the `jq` command.  Instead you can use `flatten` as in",
      "jq '[.[].items] | flatten'"
    ],
    "utterance": "Merge the 'items' arrays from multiple API response pages into a single array.",
    "expressions": [
      "jq -s '.[0].items + .[1].items' file1.json file2.json",
      "jq '[.[].items] | flatten'"
    ],
    "data": [
      {
        "input": [
          {
            "current_page": 1,
            "per_page": 100,
            "total_entries": 112,
            "items": [
              {
                "id": 1,
                "name": "vehicleA",
                "state": "available",
                "charge": 100
              },
              {
                "id": 2,
                "name": "vehicleB",
                "state": "available",
                "charge": 75
              }
            ]
          },
          {
            "current_page": 2,
            "per_page": 100,
            "total_entries": 112,
            "items": [
              {
                "id": 101,
                "name": "vehicleC",
                "state": "available",
                "charge": 80
              },
              {
                "id": 102,
                "name": "vehicleD",
                "state": "available",
                "charge": 90
              }
            ]
          }
        ],
        "output": [
          {
            "id": 1,
            "name": "vehicleA",
            "state": "available",
            "charge": 100
          },
          {
            "id": 2,
            "name": "vehicleB",
            "state": "available",
            "charge": 75
          },
          {
            "id": 101,
            "name": "vehicleC",
            "state": "available",
            "charge": 80
          },
          {
            "id": 102,
            "name": "vehicleD",
            "state": "available",
            "charge": 90
          }
        ]
      }
    ],
    "identifier": 47419750
  },
  {
    "context": [
      "How would one only get `id` and the value associated with `id` of the filtered records so that adding this step to the above query would return `2`?",
      "you can extract the `.id` from the result of `map` like this:",
      "jq -M 'map(select(.charge == null)) | .[].id' file.json",
      "If you want the values enumerated instead of being collected into an array this is better:",
      ".items[] | select(.charge == null) | .id"
    ],
    "utterance": "Get the id value of all objects where charge is null.",
    "expressions": [
      "map(select(.charge == null)) | .[].id",
      ".[] | select(.charge == null) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "vehicleA",
            "state": "available",
            "charge": 100
          },
          {
            "id": 2,
            "name": "vehicleB",
            "state": "available"
          },
          {
            "id": 3,
            "name": "vehicleB",
            "state": "available",
            "charge": 50
          }
        ],
        "output": [
          2
        ]
      }
    ],
    "identifier": 47421993
  },
  {
    "context": [
      "Anyway, assuming the JSON contents of the pastebin are in pastebin.json, you could write:",
      "jq \\\n --arg key0        Host \\\n --argjson value0  '[\"http\",\"host\"]' \\\n --arg key1        Vulnerability \\\n --argjson value1  '[\"opts\", \"vulns\", 0]' \\\n --arg key2        ISP \\\n --argjson value2  '[\"isp\"]' \\\n '. as $in\n  | {}\n  | .[$key0] = ($in|getpath($value0))\n  | .[$key1] = ($in|getpath($value1))\n  | .[$key2] = ($in|getpath($value2))' \\\n pastebin.json",
      "This would have the result:\n{\n  \"Host\": \"196.196.216.13\",\n  \"Vulnerability\": \"!CVE-2014-0160\",\n  \"ISP\": \"Fiber Grid Inc\"\n}",
      "$ config='{ \"Host\": [\"http\", \"host\"], \"Vulnerability\": [\"opts\", \"vulns\", 0], \"ISP\": [\"isp\"] }'",
      "jq --argjson config \"$config\" '\n   . as $in\n   | $config\n   | map_values( . as $p | $in | getpath($p) )' pastebin.json",
      "Output:\n{\n  \"Host\": \"196.196.216.13\",\n  \"Vulnerability\": \"!CVE-2014-0160\",\n  \"ISP\": \"Fiber Grid Inc\"\n}"
    ],
    "utterance": "Extract the values of http.host, opts.vulns[0], and isp and assign them to keys Host, Vulnerability, and ISP in a new object.",
    "expressions": [
      ". as $in | {} | .[$key0] = ($in|getpath($value0)) | .[$key1] = ($in|getpath($value1)) | .[$key2] = ($in|getpath($value2))",
      ". as $in | $config | map_values( . as $p | $in | getpath($p) )"
    ],
    "data": [
      {
        "input": {
          "ip": 3301234701,
          "_shodan": {
            "options": {
              "referrer": "7ae15507-f5cc-4353-b72e-5cc0b1c34c5e"
            }
          },
          "hash": -1056085507,
          "os": null,
          "title": "WHM Login",
          "opts": {
            "vulns": [
              "!CVE-2014-0160"
            ],
            "heartbleed": "2017/08/29 09:57:30 196.196.216.13:2087 - SAFE"
          },
          "isp": "Fiber Grid Inc",
          "http": {
            "redirects": [],
            "title": "WHM Login",
            "robots": null,
            "favicon": null,
            "host": "196.196.216.13",
            "html": ""
          }
        },
        "output": {
          "Host": "196.196.216.13",
          "Vulnerability": "!CVE-2014-0160",
          "ISP": "Fiber Grid Inc"
        }
      }
    ],
    "identifier": 47276532
  },
  {
    "context": [
      "I'm trying to convert a JSON with nested objects and arrays to a CSV file. The structure is:",
      "I'm trying to convert it to csv:\n\ndate|value1|value2|group|unit1|unit2|unit3|unit4|unit5\n2017-11-17T00:00:00|2|3|11|1|0|0|0|1\n2017-11-17T00:00:00|1|9|12|0|1|0|0|0",
      "the objects I want have RequiredObject but there are top level objects that don't have it. I've been pruning objects with select(.ThisOne==true) because I don't understand how to reference from .Group ... RequiredObject ... Value1 with changing values in the path.",
      "Assuming you have the same condition on the unit columns [as in your earlier question](https://stackoverflow.com/questions/47094953/converting-json-with-arrays-to-csv-using-jq), the following filter should produce the desired output:",
      "[\"\\(1+range(5))\"] as $units\n| [\"date\", \"value1\", \"value2\", \"group\", \"unit\\($units[])\"]\n, (\n      inputs\n    | .Date.Value as $date\n    | .Groups[]?\n    | .Id as $group\n    | .RequiredObject // {}\n    | keys[] as $k\n    | .[$k]\n    | .Value1 as $value1\n    | .Value2 as $value2\n    | [ $date, $value1, $value2, $group, (.Units[$units[]|[.]] | if .!=[] then \"1\" else \"0\" end) ]\n  )\n| join(\"|\")",
      "$ jq -Mnr -f filter.jq data.json\ndate|value1|value2|group|unit1|unit2|unit3|unit4|unit5\n2017-11-17T00:00:00|2|3|11|1|0|0|0|1\n2017-11-17T00:00:00|1|9|12|0|1|0|0|0"
    ],
    "utterance": "Produce a table with columns date, value1, value2, group, unit1 through unit5, where each row represents a group with a RequiredObject, and for each unit column outputs 1 if the unit number is present in the object's Units array and 0 otherwise.",
    "expressions": [
      "[\"\\(1+range(5))\"] as $units\n| [\"date\", \"value1\", \"value2\", \"group\", \"unit\\($units[])\"]\n, (\n      inputs\n    | .Date.Value as $date\n    | .Groups[]?\n    | .Id as $group\n    | .RequiredObject // {}\n    | keys[] as $k\n    | .[$k]\n    | .Value1 as $value1\n    | .Value2 as $value2\n    | [ $date, $value1, $value2, $group, (.Units[$units[]|[.]] | if .!=[] then \"1\" else \"0\" end) ]\n  )\n| join(\"|\")"
    ],
    "data": [
      {
        "input": [
          {
            "Date": {
              "Value": "2017-11-17T00:00:00"
            },
            "ThisOne": false
          },
          {
            "Date": {
              "Value": "2017-11-17T00:00:00"
            },
            "ThisOne": true,
            "Groups": {
              "10": {
                "Id": "10",
                "SomeUnnecessaryObject": true
              },
              "11": {
                "Id": "11",
                "RequiredObject": {
                  "SEeminGlyRANdOMStRiNG": {
                    "Value1": "2",
                    "Value2": "3",
                    "Units": [
                      "1",
                      "5"
                    ]
                  }
                }
              },
              "12": {
                "Id": "12",
                "RequiredObject": {
                  "AnOthEr321": {
                    "Value1": "1",
                    "Value2": "9",
                    "Units": [
                      "2"
                    ]
                  }
                }
              }
            }
          }
        ],
        "output": [
          "date|value1|value2|group|unit1|unit2|unit3|unit4|unit5",
          "2017-11-17T00:00:00|2|3|11|1|0|0|0|1",
          "2017-11-17T00:00:00|1|9|12|0|1|0|0|0"
        ]
      }
    ],
    "identifier": 47412818
  },
  {
    "context": [
      "Now, the task is to append the above file with the following element in json.",
      "If the first file is array.json and the second object.json, then ignoring the various ssh/rsync/sponge options, the basic jq invocation would be along the lines:\r\n\r\n    jq \u2014-argfile object object.json \u2018. + [$object]\u2019 array.json",
      "jq \u2014-argjson object \"$object\" \u2018. + [$object]\u2019 array.json",
      "on the shell terminal:\r\n\r\n    object=`cat file2.json`\r\n\r\n    jq --argjson object \"$object\" \". + [$object]\" file1.json > beta.json"
    ],
    "utterance": "Append a given object to an array in a file, producing a new file with the object added as the last element.",
    "expressions": [
      "jq --argjson object \"$object\" '. + [$object]' file1.json > beta.json",
      "jq --argfile object object.json '. + [$object]' array.json"
    ],
    "data": [
      {
        "input": [
          {
            "kind": "SpecialService",
            "type": "attribute",
            "spec": {
              "addresses": [
                "172.21.3.196:6379"
              ]
            },
            "apiVersion": "rbac.newDevops.com/v1",
            "metadata": {
              "name": "redis",
              "description": "autogenerated by superagent.py script"
            }
          }
        ],
        "output": [
          {
            "kind": "SpecialService",
            "type": "attribute",
            "spec": {
              "addresses": [
                "172.21.3.196:6379"
              ]
            },
            "apiVersion": "rbac.newDevops.com/v1",
            "metadata": {
              "name": "redis",
              "description": "autogenerated by superagent.py script"
            }
          },
          {
            "kind": "PilotService",
            "apiVersion": "rbac.newDevops.com/v1",
            "type": "attribute-based",
            "metadata": {
              "name": "apache",
              "description": "apache service as a process"
            },
            "spec": {
              "addresses": [
                "172.22.0.7/24:80"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 47413270
  },
  {
    "context": [
      "I have a json file with city names in it and I would like to replace them with particular city codes from another file.",
      "I've been trying to read the file in with `jq --argfile codes codes.json` but I've had a hard time of referring to the $codes in the jq:  .Customer.City=$codes.?",
      "The key to a good answer here is:\n\n    .Customer.City |= $codes[.]"
    ],
    "utterance": "Replace each Customer.City value with the corresponding code from an external mapping file.",
    "expressions": [
      ".Customer.City |= $codes[.]",
      ".Customer.City |= $codes[.Customer.City]"
    ],
    "data": [
      {
        "input": [
          {
            "Customer": {
              "CustomerName": "Customer1",
              "City": "Cityname1"
            }
          },
          {
            "RelevantObject": false
          },
          {
            "Customer": {
              "CustomerName": "Customer2",
              "City": "Cityname2"
            }
          }
        ],
        "output": [
          {
            "Customer": {
              "CustomerName": "Customer1",
              "City": "Code1"
            }
          },
          {
            "RelevantObject": false
          },
          {
            "Customer": {
              "CustomerName": "Customer2",
              "City": "Code2"
            }
          }
        ]
      },
      {
        "input": {
          "Cityname1": "Code1",
          "Cityname2": "Code2"
        }
      }
    ],
    "identifier": 47437773
  },
  {
    "context": [
      "I would like to convert the \"VALUE_ONE\",\"VALUE_TWO\" and \"DATE\" values to arrays for each \"ID\" just like this:",
      "Here it is important that you need to be able find the values that are linked to a certain time (date). As the input values for \"DATE\" are consecutive, you most probably do not need the DATE value anymore to find the requested \"VALUE..\" value.",
      "Is it possible to do it like that? This would keep the file size even smaller.",
      "[bucketize(.ID)[] | compact]",
      "jq 'reduce group_by(.ID)[] as $a ([]; . + [ reduce $a[] as $o \n   ({\"DATE\":[],\"VALUE_ONE\":[],\"VALUE_TWO\":[]}; \n    .DATE |= .+ [$o.DATE] | .ID = $o.ID |.VALUE_ONE |= .+ [$o.VALUE_ONE] \n    | .VALUE_TWO |= .+ [$o.VALUE_TWO]) ] )'",
      "reduce (.[] | [.ID, .DATE, del(.ID,.DATE)]) as [$id,$date,$v] ({};\n    (getpath([$id, \"DATE\"])|length) as $idx\n  | setpath([$id, \"ID\"]; $id)\n  | setpath([$id, \"DATE\", $idx]; $date)\n  | reduce ($v|keys[]) as $k (.; setpath([$id, $k, $idx]; $v[$k]))\n)\n| map(.)",
      "group_by(.ID) | map({\n    DATE: map(.DATE),\n    ID: .[0].ID,\n    VALUE_ONE: map(.VALUE_ONE),\n    VALUE_TWO: map(.VALUE_TWO)\n})"
    ],
    "utterance": "Group objects by ID and collect the DATE, VALUE_ONE, and VALUE_TWO fields for each group into arrays with corresponding values aligned by index.",
    "expressions": [
      "def bucketize(f): reduce .[] as $x ({}; .[$x|f] += [$x] );\ndef compact:\n  . as $in\n  | reduce (.[0]|keys_unsorted[]) as $key ({};\n      . + {($key): $in|map(.[$key])})\n    + {\"ID\": .[0].ID}\n    ;\n[bucketize(.ID)[] | compact]",
      "reduce group_by(.ID)[] as $a ([]; . + [ reduce $a[] as $o \n   ({\"DATE\":[],\"VALUE_ONE\":[],\"VALUE_TWO\":[]}; \n    .DATE |= .+ [$o.DATE] | .ID = $o.ID |.VALUE_ONE |= .+ [$o.VALUE_ONE] \n    | .VALUE_TWO |= .+ [$o.VALUE_TWO]) ] )",
      "reduce (.[] | [.ID, .DATE, del(.ID,.DATE)]) as [$id,$date,$v] ({};\n    (getpath([$id, \"DATE\"])|length) as $idx\n  | setpath([$id, \"ID\"]; $id)\n  | setpath([$id, \"DATE\", $idx]; $date)\n  | reduce ($v|keys[]) as $k (.; setpath([$id, $k, $idx]; $v[$k]))\n)\n| map(.)",
      "group_by(.ID) | map({\n    DATE: map(.DATE),\n    ID: .[0].ID,\n    VALUE_ONE: map(.VALUE_ONE),\n    VALUE_TWO: map(.VALUE_TWO)\n})"
    ],
    "data": [
      {
        "input": [
          {
            "DATE": "10.10.2017 01:00",
            "ID": "X",
            "VALUE_ONE": 20,
            "VALUE_TWO": 5
          },
          {
            "DATE": "10.10.2017 02:00",
            "ID": "X",
            "VALUE_ONE": 30,
            "VALUE_TWO": 7
          },
          {
            "DATE": "10.10.2017 03:00",
            "ID": "X",
            "VALUE_ONE": 25,
            "VALUE_TWO": 2
          },
          {
            "DATE": "10.10.2017 01:00",
            "ID": "Y",
            "VALUE_ONE": 10,
            "VALUE_TWO": 9
          },
          {
            "DATE": "10.10.2017 02:00",
            "ID": "Y",
            "VALUE_ONE": 20,
            "VALUE_TWO": 5
          },
          {
            "DATE": "10.10.2017 03:00",
            "ID": "Y",
            "VALUE_ONE": 50,
            "VALUE_TWO": 5
          },
          {
            "DATE": "10.10.2017 01:00",
            "ID": "Z",
            "VALUE_ONE": 55,
            "VALUE_TWO": 3
          },
          {
            "DATE": "10.10.2017 02:00",
            "ID": "Z",
            "VALUE_ONE": 60,
            "VALUE_TWO": 7
          },
          {
            "DATE": "10.10.2017 03:00",
            "ID": "Z",
            "VALUE_ONE": 15,
            "VALUE_TWO": 7
          }
        ],
        "output": [
          {
            "DATE": [
              "10.10.2017 01:00",
              "10.10.2017 02:00",
              "10.10.2017 03:00"
            ],
            "ID": "X",
            "VALUE_ONE": [
              20,
              30,
              25
            ],
            "VALUE_TWO": [
              5,
              7,
              2
            ]
          },
          {
            "DATE": [
              "10.10.2017 01:00",
              "10.10.2017 02:00",
              "10.10.2017 03:00"
            ],
            "ID": "Y",
            "VALUE_ONE": [
              10,
              20,
              50
            ],
            "VALUE_TWO": [
              9,
              5,
              5
            ]
          },
          {
            "DATE": [
              "10.10.2017 01:00",
              "10.10.2017 02:00",
              "10.10.2017 03:00"
            ],
            "ID": "Z",
            "VALUE_ONE": [
              55,
              60,
              15
            ],
            "VALUE_TWO": [
              3,
              7,
              7
            ]
          }
        ]
      }
    ],
    "identifier": 47273693
  },
  {
    "context": [
      "I need to transform this:\r\n\r\n    {\"input\":{\"text\":\"HI\"},\"output\":{\"text\":[\"OK1\",\"TWO\"]}}\r\n\r\nInto this:\r\n\r\n    {\r\n      \"localDB\": [\r\n        {\r\n          \"tableName\": \"Default\",\r\n          \"mode\": \"append\",\r\n          \"data\": [\r\n            {\r\n              \"time\": \"1511281401.991815\",\r\n              \"message\": \"HI\",\r\n              \"from\": \"me\"\r\n            },\r\n            {\r\n              \"time\": \"1511281401.991837\",\r\n              \"message\": \"OK1\"\r\n              \"from\": \"bot\"\r\n            }\r\n            {\r\n              \"time\": \"1511281401.991847\",\r\n              \"message\": \"TWO\"\r\n              \"from\": \"bot\"\r\n    }\r\n    ]}]}",
      "Key issue here is that number of \"records\" in the localDB <b>should vary depending on</b> the number of entries in .output.text node. There could be just one text, or three or more.",
      "You just need to use `.output.text[]` and take advantage of how [Object Construction](https://stedolan.github.io/jq/manual/#ObjectConstruction:{}) behaves when a member expression returns multiple results. Try this:\r\n\r\n    {\r\n     \"localDB\" : [{\r\n       \"tableName\": \"Default\",\r\n       \"mode\": \"append\",\r\n       \"data\": [\r\n         {\"time\" : now|tostring, \"message\" : .input.text,   \"from\" : \"me\"},\r\n         {\"time\" : now|tostring, \"message\" :.output.text[], \"from\" : \"bot\"}\r\n      ]\r\n     }]\r\n    }",
      "Here is a filter which uses a `settime` function to assign different times to the rows:\r\n\r\n    def settime: reduce range(length) as $i (.; .[$i].time = (now + $i|tostring));\r\n    {\r\n     \"localDB\" : [{\r\n       \"tableName\": \"Default\",\r\n       \"mode\": \"append\",\r\n       \"data\": [\r\n         {\"message\" : .input.text,   \"from\" : \"me\"},\r\n         {\"message\" :.output.text[], \"from\" : \"bot\"}\r\n       ] | settime\r\n     }]\r\n    }"
    ],
    "utterance": "Transform an object with a 'text' field and an array of response texts into an array of objects, each with 'message', 'from', and different timestamps, joining the input and each output as separate entries under a field named 'localDB[].data'.",
    "expressions": [
      "{ \"localDB\" : [{ \"tableName\": \"Default\", \"mode\": \"append\", \"data\": [ {\"time\" : now|tostring, \"message\" : .input.text, \"from\" : \"me\"}, {\"time\" : now|tostring, \"message\" :.output.text[], \"from\" : \"bot\"} ] }] }",
      "def settime: reduce range(length) as $i (.; .[$i].time = (now + $i|tostring)); { \"localDB\" : [{ \"tableName\": \"Default\", \"mode\": \"append\", \"data\": [ {\"message\" : .input.text, \"from\" : \"me\"}, {\"message\" :.output.text[], \"from\" : \"bot\"} ] | settime }] }"
    ],
    "data": [
      {
        "input": {
          "input": {
            "text": "HI"
          },
          "output": {
            "text": [
              "OK1",
              "TWO"
            ]
          }
        },
        "output": {
          "localDB": [
            {
              "tableName": "Default",
              "mode": "append",
              "data": [
                {
                  "message": "HI",
                  "from": "me",
                  "time": "1511285948.684203"
                },
                {
                  "message": "OK1",
                  "from": "bot",
                  "time": "1511285949.684243"
                },
                {
                  "message": "TWO",
                  "from": "bot",
                  "time": "1511285950.684261"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 47418378
  }
]